/* libquvi * Copyright (C) 2012,2013 Toni Gundogdu * * This file is part of libquvi . * * This library 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 library 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 library. If not, see * . */ #include "config.h" #include #include #include #include "quvi.h" /* -- */ #include "_quvi_s.h" #include "_quvi_media_s.h" #include "_quvi_net_s.h" #include "_quvi_script_s.h" /* -- */ #include "misc/match_media_script.h" #include "misc/resolve.h" #include "misc/media.h" #include "net/handle.h" #include "lua/exec.h" static gboolean _chk_goto_url(_quvi_media_t qm) { if (qm->url.redirect_to->len >0) { g_string_assign(qm->url.input, qm->url.redirect_to->str); g_string_assign(qm->url.redirect_to, ""); return (TRUE); } return (FALSE); } extern QuviError l_match_url_to_media_script(_quvi_media_t, GSList**); extern const gchar *show_script; /* m_scan_scripts */ typedef QuviMatchMediaScriptMode _qm_mode; QuviError m_match_media_script(_quvi_t q, _quvi_media_t *qm, const gchar *url, const _qm_mode mode) { gboolean resolve_flag; QuviError rc; GSList *s; resolve_flag = (mode != QM_MATCH_MS_SUPPORTED_OFFLINE) ? TRUE : FALSE; if (*qm == NULL) *qm = m_media_new(q, url); if (resolve_flag == TRUE) /* Resolve URL redirection. */ { m_resolve(q, (*qm)->url.input); if (quvi_ok(q) == QUVI_FALSE) return (q->status.rc); } rc = l_match_url_to_media_script(*qm, &s); if (rc == QUVI_ERROR_NO_SUPPORT) { static const gchar *_E = N_("No support: %s: Could not find a media script for URL"); g_string_printf(q->status.errmsg, g_dgettext(GETTEXT_PACKAGE, _E), url); return (rc); } else if (rc != QUVI_OK) return (rc); if (show_script != NULL && strlen(show_script) >0) { const _quvi_script_t qs = (const _quvi_script_t) s->data; g_message("[%s] libquvi: %s: input URL accepted", __func__, qs->fpath->str); } switch (mode) { case QM_MATCH_MS_PARSE: rc = l_exec_media_script_parse(*qm, s); if (rc == QUVI_OK) { /* Check if goto_url was set. */ if (_chk_goto_url(*qm) == TRUE) return (m_match_media_script(q, qm, url, mode)); } break; case QM_MATCH_MS_SUPPORTED_OFFLINE: case QM_MATCH_MS_SUPPORTED_ONLINE: break; } return (rc); } /* vim: set ts=2 sw=2 tw=72 expandtab: */