summaryrefslogtreecommitdiffstats
path: root/stream/stream_dvb.c
diff options
context:
space:
mode:
authorOliver Freyermuth <o.freyermuth@googlemail.com>2016-01-08 20:19:57 +0100
committerwm4 <wm4@nowhere>2016-01-14 00:36:53 +0100
commit62acd315ade4c95db5f88c9bda668677e9c6f438 (patch)
tree79628972e6797155158bd004ca242f8c63a2f2a8 /stream/stream_dvb.c
parentc55b242b4ee89e91b4f9896e214c3bbe0ed46ea1 (diff)
downloadmpv-62acd315ade4c95db5f88c9bda668677e9c6f438.tar.bz2
mpv-62acd315ade4c95db5f88c9bda668677e9c6f438.tar.xz
player, stream_dvb: implement dvb-channel-name property.
On read, it returns the name of the current DVB program, on write, it triggers a channel-switch to the program if it is found in the channel list of the currently active card. Compared to the dvb-channel property which already exists and is a pair of integers (card + channel number) this has the limitation of not switching the card, but is probably of much more common use.
Diffstat (limited to 'stream/stream_dvb.c')
-rw-r--r--stream/stream_dvb.c35
1 files changed, 34 insertions, 1 deletions
diff --git a/stream/stream_dvb.c b/stream/stream_dvb.c
index 450f8500d0..8bc6c4e200 100644
--- a/stream/stream_dvb.c
+++ b/stream/stream_dvb.c
@@ -792,6 +792,31 @@ static int dvbin_stream_control(struct stream *s, int cmd, void *arg)
}
return STREAM_ERROR;
}
+ case STREAM_CTRL_DVB_SET_CHANNEL_NAME: {
+ char *progname = *((char**)arg);
+ dvb_priv_t *priv = (dvb_priv_t *) s->priv;
+ dvb_state_t* state = priv->state;
+ int new_channel = -1;
+ for (int i=0; i < state->list->NUM_CHANNELS; ++i) {
+ if (!strcmp(state->list->channels[i].name, progname)) {
+ new_channel = i;
+ break;
+ }
+ }
+ if (new_channel == -1) {
+ MP_ERR(s, "Program '%s' not found for card %d!\n",
+ progname, state->card);
+ return STREAM_ERROR;
+ }
+ r = dvb_set_channel(s, state->card, new_channel);
+ if (r) {
+ // Stream will be pulled down after channel switch,
+ // persist state.
+ state->switching_channel = true;
+ return STREAM_OK;
+ }
+ return STREAM_ERROR;
+ }
case STREAM_CTRL_DVB_STEP_CHANNEL: {
r = dvb_step_channel(s, *(int *)arg);
if (r) {
@@ -804,6 +829,14 @@ static int dvbin_stream_control(struct stream *s, int cmd, void *arg)
}
return STREAM_ERROR;
}
+ case STREAM_CTRL_DVB_GET_CHANNEL_NAME: {
+ dvb_priv_t *priv = (dvb_priv_t *) s->priv;
+ dvb_state_t* state = priv->state;
+ int current_channel = state->list->current;
+ char* progname = state->list->channels[current_channel].name;
+ *(char **)arg = talloc_strdup(NULL, progname);
+ return STREAM_OK;
+ }
case STREAM_CTRL_GET_METADATA: {
struct mp_tags* metadata = talloc_zero(NULL, struct mp_tags);
dvb_priv_t *priv = (dvb_priv_t *) s->priv;
@@ -812,7 +845,7 @@ static int dvbin_stream_control(struct stream *s, int cmd, void *arg)
char* progname = state->list->channels[current_channel].name;
mp_tags_set_str(metadata, "title", progname);
*(struct mp_tags **)arg = metadata;
- return 1;
+ return STREAM_OK;
}
}
return STREAM_UNSUPPORTED;