summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorvoroshil <voroshil@b3059339-0415-0410-9bf9-f77b7e298cf2>2006-09-11 18:41:14 +0000
committervoroshil <voroshil@b3059339-0415-0410-9bf9-f77b7e298cf2>2006-09-11 18:41:14 +0000
commite409a93e36359f5634a129cb299415022f829c49 (patch)
tree8d2bd2325b48512f9f6f9c759d0c86c06bd430ec
parent9eea286729fb8c80bececeeca85c537390807902 (diff)
downloadmpv-e409a93e36359f5634a129cb299415022f829c49.tar.bz2
mpv-e409a93e36359f5634a129cb299415022f829c49.tar.xz
ability to pass channel name (not only number) to radio_set_channel
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@19799 b3059339-0415-0410-9bf9-f77b7e298cf2
-rw-r--r--help/help_mp-en.h1
-rw-r--r--help/help_mp-ru.h1
-rw-r--r--stream/stream_radio.c17
3 files changed, 18 insertions, 1 deletions
diff --git a/help/help_mp-en.h b/help/help_mp-en.h
index c502351da8..0756c3d173 100644
--- a/help/help_mp-en.h
+++ b/help/help_mp-en.h
@@ -1821,6 +1821,7 @@ static char help_text[]=
#define MSGTR_RADIO_WrongFreqForChannel "[radio] Wrong frequency for channel %s\n"
#define MSGTR_RADIO_WrongChannelNumberFloat "[radio] Wrong channel number: %.2f\n"
#define MSGTR_RADIO_WrongChannelNumberInt "[radio] Wrong channel number: %d\n"
+#define MSGTR_RADIO_WrongChannelName "[radio] Wrong channel name: %s\n"
#define MSGTR_RADIO_FreqParameterDetected "[radio] Radio frequency parameter detected.\n"
#define MSGTR_RADIO_DoneParsingChannels "[radio] Done parsing channels.\n"
#define MSGTR_RADIO_GetTunerFailed "[radio] Warning: ioctl get tuner failed: %s. Setting frac to %d.\n"
diff --git a/help/help_mp-ru.h b/help/help_mp-ru.h
index 3b07c7ce68..79d2a7679c 100644
--- a/help/help_mp-ru.h
+++ b/help/help_mp-ru.h
@@ -1180,6 +1180,7 @@ static char help_text[]=
#define MSGTR_RADIO_WrongFreqForChannel "[radio] Неверная частота для станции %s\n"
#define MSGTR_RADIO_WrongChannelNumberFloat "[radio] Неверный номер станции: %.2f\n"
#define MSGTR_RADIO_WrongChannelNumberInt "[radio] Неверный номер станции: %d\n"
+#define MSGTR_RADIO_WrongChannelName "[radio] Неверное название станции: %s\n"
#define MSGTR_RADIO_FreqParameterDetected "[radio] В параметрах обнаружена частота.\n"
#define MSGTR_RADIO_DoneParsingChannels "[radio] Разбор имен радиостанций завершен.\n"
#define MSGTR_RADIO_GetTunerFailed "[radio] Предупреждение: сбой вызова ioctl get tuner : %s. frac установлен в %d.\n"
diff --git a/stream/stream_radio.c b/stream/stream_radio.c
index 85a4d9ce15..7daed44cd8 100644
--- a/stream/stream_radio.c
+++ b/stream/stream_radio.c
@@ -862,10 +862,24 @@ int radio_set_channel(struct stream_st *stream, char *channel) {
radio_priv_t* priv=(radio_priv_t*)stream->priv;
int i, channel_int;
radio_channels_t* tmp;
+ char* endptr;
+ if (*channel=='\0')
+ mp_msg(MSGT_RADIO,MSGL_ERR,MSGTR_RADIO_WrongChannelName,channel);
+
if (priv->radio_channel_list) {
- channel_int = atoi(channel);
+ channel_int = strtol(channel,&endptr,10);
tmp = priv->radio_channel_list;
+ if (*endptr!='\0'){
+ //channel is not a number, so it contains channel name
+ for ( ; tmp; tmp=tmp->next)
+ if (!strncmp(channel,tmp->name,sizeof(tmp->name)-1))
+ break;
+ if (!tmp){
+ mp_msg(MSGT_RADIO,MSGL_ERR,MSGTR_RADIO_WrongChannelName,channel);
+ return 0;
+ }
+ }else{
for (i = 1; i < channel_int; i++)
if (tmp->next)
tmp = tmp->next;
@@ -875,6 +889,7 @@ int radio_set_channel(struct stream_st *stream, char *channel) {
mp_msg(MSGT_RADIO,MSGL_ERR,MSGTR_RADIO_WrongChannelNumberInt,channel_int);
return 0;
}
+ }
priv->radio_channel_current=tmp;
mp_msg(MSGT_RADIO, MSGL_V, MSGTR_RADIO_SelectedChannel, priv->radio_channel_current->index,
priv->radio_channel_current->name, priv->radio_channel_current->freq);