Add misc/url.* with m_url_(un)escaped_form
[libquvi.git] / src / api / playlist_new.c
blobbea17354a9fc08dfabb10f98341a2f647b954066
1 /* libquvi
2 * Copyright (C) 2012,2013 Toni Gundogdu <legatvs@gmail.com>
4 * This file is part of libquvi <http://quvi.sourceforge.net/>.
6 * This library is free software: you can redistribute it and/or
7 * modify it under the terms of the GNU Affero General Public
8 * License as published by the Free Software Foundation, either
9 * version 3 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU Affero General Public License for more details.
16 * You should have received a copy of the GNU Affero General
17 * Public License along with this library. If not, see
18 * <http://www.gnu.org/licenses/>.
21 /** @file playlist_new.c */
23 #include "config.h"
25 #include <glib.h>
27 #include "quvi.h"
28 /* -- */
29 #include "_quvi_s.h"
30 #include "_quvi_playlist_s.h"
31 /* -- */
32 #include "misc/match_playlist_script.h"
34 /** @brief Parse playlist properties for URL
35 @return New handle, @ref quvi_playlist_free it when done using it
36 @note
37 - Calling this function restores the current @ref sess_handle to its
38 initial state (cookies cleared, custom headers cleared, default
39 user-agent string restored, ...)
40 - Use @ref quvi_ok for checking if an error occurred
41 @sa @ref parse_playlist
42 @ingroup playlistprop
44 quvi_playlist_t quvi_playlist_new(quvi_t handle, const char *url)
46 _quvi_playlist_t qp;
47 _quvi_t q;
49 /* If G_DISABLE_CHECKS is defined then the check is not performed. */
50 g_return_val_if_fail(handle != NULL, NULL);
51 g_return_val_if_fail(url != NULL, NULL);
53 q = (_quvi_t) handle;
54 qp = NULL;
56 q->status.rc = m_match_playlist_script(q, &qp, url, QM_MATCH_PS_PARSE);
57 return (qp);
60 /* vim: set ts=2 sw=2 tw=72 expandtab: */