summaryrefslogtreecommitdiffstats
path: root/mpvcore/command.c
diff options
context:
space:
mode:
authorwm4 <wm4@nowhere>2013-09-10 16:38:34 +0200
committerwm4 <wm4@nowhere>2013-09-10 16:38:34 +0200
commitcf0e852fcdd4f6e223d76f21ce27f89681bd6e74 (patch)
treea004e0bf29f48d3486d368947e58dab450da28e7 /mpvcore/command.c
parentc9a740fccd1128e43542beeec6f50bc59c2bddb9 (diff)
downloadmpv-cf0e852fcdd4f6e223d76f21ce27f89681bd6e74.tar.bz2
mpv-cf0e852fcdd4f6e223d76f21ce27f89681bd6e74.tar.xz
quvi: coerce libquvi 0.4 support into allowing format switching
libquvi 0.4 doesn't allow us listing the formats supported by a streaming site without doing additional network accesses, so switching formats was not supported with it. (It's different with libquvi 0.9.) But the most important case is switching between SD and HD. Usually, --quvi-format=default will get SD, while --quvi-format=best gives HD. Use this, and pretend that an URL supported by libquvi 0.4 supports both of these. "cycle quvi-format" will switch between these. If the user specifies something else via --quvi-format, this is included in the list of switchable formats additionally to "default" and "best".
Diffstat (limited to 'mpvcore/command.c')
-rw-r--r--mpvcore/command.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/mpvcore/command.c b/mpvcore/command.c
index a5f66aae2b..a99dd3dcab 100644
--- a/mpvcore/command.c
+++ b/mpvcore/command.c
@@ -496,17 +496,22 @@ static int mp_property_edition(m_option_t *prop, int action, void *arg,
}
static struct mp_resolve_src *find_source(struct mp_resolve_result *res,
- char *url)
+ char *encid, char *url)
{
if (res->num_srcs == 0)
return NULL;
int src = 0;
for (int n = 0; n < res->num_srcs; n++) {
- if (strcmp(res->srcs[n]->url, res->url) == 0) {
+ char *s_url = res->srcs[n]->url;
+ char *s_encid = res->srcs[n]->encid;
+ if (url && s_url && strcmp(url, s_url) == 0) {
src = n;
break;
}
+ // Prefer source URL if possible; so continue in case encid isn't unique
+ if (encid && s_encid && strcmp(encid, s_encid) == 0)
+ src = n;
}
return res->srcs[src];
}
@@ -514,11 +519,12 @@ static struct mp_resolve_src *find_source(struct mp_resolve_result *res,
static int mp_property_quvi_format(m_option_t *prop, int action, void *arg,
MPContext *mpctx)
{
+ struct MPOpts *opts = mpctx->opts;
struct mp_resolve_result *res = mpctx->resolve_result;
if (!res || !res->num_srcs)
return M_PROPERTY_UNAVAILABLE;
- struct mp_resolve_src *cur = find_source(res, res->url);
+ struct mp_resolve_src *cur = find_source(res, opts->quvi_format, res->url);
if (!cur)
return M_PROPERTY_UNAVAILABLE;