/* libquvi * Copyright (C) 2012,2013 Toni Gundogdu * * This file is part of libquvi . * * This program is free software: you can redistribute it and/or * modify it under the terms of the GNU Affero General Public * License as published by the Free Software Foundation, either * version 3 of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General * Public License along with this program. If not, see * . */ #include "config.h" #include #include #include #include #include #include "examples.h" struct _opts_s { gboolean autoproxy; gboolean cookies; gboolean verbose; gboolean best; gchar *stream; gchar **url; }; static struct _opts_s opts; static const GOptionEntry entries[] = { { "stream", 's', 0, G_OPTION_ARG_STRING, &opts.stream, "Select stream ID, or a comma-separated list of IDs", "ID" }, { "best", 'b', 0, G_OPTION_ARG_NONE, &opts.best, "Choose the best available stream, negates --stream", NULL }, { "autoproxy", 'a', 0, G_OPTION_ARG_NONE, &opts.autoproxy, "Enable the autoproxy feature", NULL }, { "verbose", 'v', 0, G_OPTION_ARG_NONE, &opts.verbose, "Verbose libcurl output", NULL }, { "cookies", 'c', 0, G_OPTION_ARG_NONE, &opts.cookies, "Parse and use HTTP cookies", NULL }, { G_OPTION_REMAINING, 0, 0, G_OPTION_ARG_STRING_ARRAY, &opts.url, "URL" }, {NULL, 0, 0, 0, NULL, NULL, NULL} }; static void dump_stream() { gchar *url, *id; quvi_media_get(qm, QUVI_MEDIA_STREAM_PROPERTY_URL, &url); quvi_media_get(qm, QUVI_MEDIA_STREAM_PROPERTY_ID, &id); g_print(" id='%s', url='%s'\n", id, url); } static void dump_streams() { while (quvi_media_stream_next(qm) == QUVI_TRUE) dump_stream(); } static gint opts_new(gint argc, gchar **argv) { GOptionContext *c; GError *e; gint r; c = g_option_context_new("URL"); r = EXIT_SUCCESS; e = NULL; g_option_context_set_help_enabled(c, TRUE); g_option_context_add_main_entries(c, entries, NULL); if (g_option_context_parse(c, &argc, &argv, &e) == FALSE) { g_printerr("error: %s\n", e->message); g_error_free(e); r = EXIT_FAILURE; e = NULL; } g_option_context_free(c); c = NULL; /* Check input. */ if (opts.url == NULL) { g_printerr("error: no input URL\n"); return (EXIT_FAILURE); } return (r); } static void opts_free() { g_free(opts.stream); opts.stream = NULL; g_strfreev(opts.url); opts.url = NULL; } typedef quvi_callback_status qcs; gint main(gint argc, gchar **argv) { gint i,r; gchar *s; g_assert(qm == NULL); g_assert(q == NULL); memset(&opts, 0, sizeof(struct _opts_s)); setlocale(LC_ALL, ""); r = opts_new(argc, argv); if (r != EXIT_SUCCESS) return (r); q = quvi_new(); examples_exit_if_error(); if (opts.autoproxy == TRUE) examples_enable_autoproxy(); if (opts.cookies == TRUE) examples_enable_cookies(); if (opts.verbose == TRUE) examples_enable_verbose(); quvi_set(q, QUVI_OPTION_CALLBACK_STATUS, (qcs) examples_status); for (i=0; opts.url[i] != NULL; ++i) { qm = quvi_media_new(q, opts.url[i]); examples_exit_if_error(); quvi_media_get(qm, QUVI_MEDIA_PROPERTY_TITLE, &s); g_print("[%s]\n title='%s'\n", __func__, s); if (opts.best == TRUE) { quvi_media_stream_choose_best(qm); dump_stream(); } else if (opts.stream != NULL) { quvi_media_stream_select(qm, opts.stream); examples_exit_if_error(); dump_stream(); } else dump_streams(); quvi_media_free(qm); qm = NULL; } opts_free(); examples_cleanup(); g_assert(qm == NULL); g_assert(q == NULL); return (r); } /* vim: set ts=2 sw=2 tw=72 expandtab: */