summaryrefslogtreecommitdiffstats
path: root/libmpdemux
diff options
context:
space:
mode:
Diffstat (limited to 'libmpdemux')
-rw-r--r--libmpdemux/demuxer.c87
-rw-r--r--libmpdemux/demuxer.h23
2 files changed, 53 insertions, 57 deletions
diff --git a/libmpdemux/demuxer.c b/libmpdemux/demuxer.c
index 99f1be9fe8..32fc486e59 100644
--- a/libmpdemux/demuxer.c
+++ b/libmpdemux/demuxer.c
@@ -1618,61 +1618,54 @@ int demuxer_set_angle(demuxer_t *demuxer, int angle)
return angle;
}
-int demuxer_audio_track_by_lang(demuxer_t *d, char *lang)
+int demuxer_audio_track_by_lang_and_default(struct demuxer *d, char *lang)
{
- int i, len;
- lang += strspn(lang, ",");
- while ((len = strcspn(lang, ",")) > 0) {
- for (i = 0; i < MAX_A_STREAMS; ++i) {
- sh_audio_t *sh = d->a_streams[i];
- if (sh && sh->lang && strncmp(sh->lang, lang, len) == 0)
- return sh->aid;
+ if (!lang)
+ lang = "";
+ while (1) {
+ lang += strspn(lang, ",");
+ int len = strcspn(lang, ",");
+ int id = -1;
+ for (int i = 0; i < MAX_A_STREAMS; i++) {
+ struct sh_audio *sh = d->a_streams[i];
+ if (sh && (!len || sh->lang && strlen(sh->lang) == len &&
+ !memcmp(lang, sh->lang, len))) {
+ if (sh->default_track)
+ return sh->aid;
+ if (id < 0)
+ id = sh->aid;
+ }
}
+ if (id >= 0)
+ return id;
+ if (!len)
+ return -1;
lang += len;
- lang += strspn(lang, ",");
}
- return -1;
}
-int demuxer_sub_track_by_lang(demuxer_t *d, char *lang)
+int demuxer_sub_track_by_lang_and_default(struct demuxer *d, char *lang)
{
- int i, len;
- lang += strspn(lang, ",");
- while ((len = strcspn(lang, ",")) > 0) {
- for (i = 0; i < MAX_S_STREAMS; ++i) {
- sh_sub_t *sh = d->s_streams[i];
- if (sh && sh->lang && strncmp(sh->lang, lang, len) == 0)
- return sh->sid;
+ if (!lang)
+ lang = "";
+ while (1) {
+ lang += strspn(lang, ",");
+ int len = strcspn(lang, ",");
+ int id = -1;
+ for (int i = 0; i < MAX_A_STREAMS; i++) {
+ struct sh_audio *sh = d->a_streams[i];
+ if (sh && (!len || sh->lang && strlen(sh->lang) == len &&
+ !memcmp(lang, sh->lang, len))) {
+ if (sh->default_track)
+ return sh->aid;
+ if (id < 0)
+ id = sh->aid;
+ }
}
+ if (!len)
+ return -1;
+ if (id >= 0)
+ return id;
lang += len;
- lang += strspn(lang, ",");
- }
- return -1;
-}
-
-int demuxer_default_audio_track(demuxer_t *d)
-{
- int i;
- for (i = 0; i < MAX_A_STREAMS; ++i) {
- sh_audio_t *sh = d->a_streams[i];
- if (sh && sh->default_track)
- return sh->aid;
- }
- for (i = 0; i < MAX_A_STREAMS; ++i) {
- sh_audio_t *sh = d->a_streams[i];
- if (sh)
- return sh->aid;
}
- return -1;
-}
-
-int demuxer_default_sub_track(demuxer_t *d)
-{
- int i;
- for (i = 0; i < MAX_S_STREAMS; ++i) {
- sh_sub_t *sh = d->s_streams[i];
- if (sh && sh->default_track)
- return sh->sid;
- }
- return -1;
}
diff --git a/libmpdemux/demuxer.h b/libmpdemux/demuxer.h
index 2c200ead1e..63a34f30f6 100644
--- a/libmpdemux/demuxer.h
+++ b/libmpdemux/demuxer.h
@@ -466,15 +466,18 @@ int demuxer_set_angle(demuxer_t *demuxer, int angle);
/// Get number of angles.
int demuxer_angles_count(demuxer_t *demuxer);
-// get the index of a track
-// lang is a comma-separated list
-int demuxer_audio_track_by_lang(demuxer_t* demuxer, char* lang);
-int demuxer_sub_track_by_lang(demuxer_t* demuxer, char* lang);
-
-// find the default track
-// for subtitles, it is the first track with default attribute
-// for audio, additionally, the first track is selected if no track has default attribute set
-int demuxer_default_audio_track(demuxer_t* d);
-int demuxer_default_sub_track(demuxer_t* d);
+/* Get the index of a track.
+ * lang is a comma-separated list, NULL is same as empty list
+ * Sort tracks based on the following criteria:
+ * 1) earlier match in lang list, or last no match
+ * 2) track is marked default (default wins)
+ * 3) track number (lower wins)
+ * For audio, select best track according to these criteria; only return -1
+ * if there are no tracks at all.
+ * For subs, select best track according to the same criteria, but return -1
+ * if all tracks are no-lang-match, not-default.
+ */
+int demuxer_audio_track_by_lang_and_default(struct demuxer *d, char *lang);
+int demuxer_sub_track_by_lang_and_default(struct demuxer *d, char *lang);
#endif /* MPLAYER_DEMUXER_H */