diff options
author | wm4 <wm4@nowhere> | 2015-05-22 21:05:03 +0200 |
---|---|---|
committer | wm4 <wm4@nowhere> | 2015-05-22 21:05:03 +0200 |
commit | f7ca2c83e1da067f02dcd57da5cf72a34dc5c0fc (patch) | |
tree | 293af0ecfc946d788ee2bd41a11f0bb929674747 /player | |
parent | ae46833836453b7fc64f2cff9cb69d6cfd73f947 (diff) |
command: allow changing track properties while no file is loaded
Now it simply changes the options, i.e. what will be requested, instead
of returning M_PROPERTY_UNAVAILABLE.
This is another minor step towards unifying options and properties.
Still a bit weird: it will always return "no" if no file is loaded, and
disregards the option value.
Diffstat (limited to 'player')
-rw-r--r-- | player/command.c | 36 |
1 files changed, 20 insertions, 16 deletions
diff --git a/player/command.c b/player/command.c index e203dd93ab..9ae3880b31 100644 --- a/player/command.c +++ b/player/command.c @@ -1771,8 +1771,6 @@ static int property_switch_track(struct m_property *prop, int action, void *arg, MPContext *mpctx, int order, enum stream_type type) { - if (!mpctx->num_sources) - return M_PROPERTY_UNAVAILABLE; struct track *track = mpctx->current_track[order][type]; switch (action) { @@ -1804,9 +1802,13 @@ static int property_switch_track(struct m_property *prop, int action, void *arg, return M_PROPERTY_OK; } case M_PROPERTY_SET: - track = mp_track_by_tid(mpctx, type, *(int *)arg); - mp_switch_track_n(mpctx, order, type, track); - mp_mark_user_track_selection(mpctx, order, type); + if (mpctx->num_sources) { + track = mp_track_by_tid(mpctx, type, *(int *)arg); + mp_switch_track_n(mpctx, order, type, track); + mp_mark_user_track_selection(mpctx, order, type); + } else { + mpctx->opts->stream_id[order][type] = *(int *)arg; + } return M_PROPERTY_OK; } return mp_property_generic_option(mpctx, prop, action, arg); @@ -1818,8 +1820,6 @@ static int property_switch_track_ff(void *ctx, struct m_property *prop, { MPContext *mpctx = ctx; enum stream_type type = (intptr_t)prop->priv; - if (!mpctx->num_sources) - return M_PROPERTY_UNAVAILABLE; struct track *track = mpctx->current_track[0][type]; switch (action) { @@ -1828,17 +1828,21 @@ static int property_switch_track_ff(void *ctx, struct m_property *prop, return M_PROPERTY_OK; case M_PROPERTY_SET: { int id = *(int *)arg; - track = NULL; - for (int n = 0; n < mpctx->num_tracks; n++) { - struct track *cur = mpctx->tracks[n]; - if (cur->type == type && cur->ff_index == id) { - track = cur; - break; + if (mpctx->num_sources) { + track = NULL; + for (int n = 0; n < mpctx->num_tracks; n++) { + struct track *cur = mpctx->tracks[n]; + if (cur->type == type && cur->ff_index == id) { + track = cur; + break; + } } + if (!track && id >= 0) + return M_PROPERTY_ERROR; + mp_switch_track_n(mpctx, 0, type, track); + } else { + mpctx->opts->stream_id_ff[type] = *(int *)arg; } - if (!track && id >= 0) - return M_PROPERTY_ERROR; - mp_switch_track_n(mpctx, 0, type, track); return M_PROPERTY_OK; } } |