summaryrefslogtreecommitdiff
path: root/libavformat/libopenmpt.c
diff options
context:
space:
mode:
authorJosh de Kock <josh@itanimul.li>2016-07-18 13:58:04 +0100
committerJosh de Kock <josh@itanimul.li>2016-07-21 02:47:35 +0100
commit9134d2df5b17426b14dbc9c3411441c412af66b0 (patch)
treed87eea41e2c7101189264e84860f212c8214b963 /libavformat/libopenmpt.c
parent120f34b6ac062568a395ebc9490c7d213c264087 (diff)
downloadffmpeg-9134d2df5b17426b14dbc9c3411441c412af66b0.tar.gz
libopenmpt: add subsong support
Signed-off-by: Josh de Kock <josh@itanimul.li>
Diffstat (limited to 'libavformat/libopenmpt.c')
-rw-r--r--libavformat/libopenmpt.c30
1 files changed, 27 insertions, 3 deletions
diff --git a/libavformat/libopenmpt.c b/libavformat/libopenmpt.c
index 58a02be610..a87283b77b 100644
--- a/libavformat/libopenmpt.c
+++ b/libavformat/libopenmpt.c
@@ -36,15 +36,19 @@ typedef struct OpenMPTContext {
/* options */
int sample_rate;
int64_t layout;
+ int subsong;
} OpenMPTContext;
#define OFFSET(x) offsetof(OpenMPTContext, x)
#define A AV_OPT_FLAG_AUDIO_PARAM
#define D AV_OPT_FLAG_DECODING_PARAM
static const AVOption options[] = {
- {"sample_rate", "set sample rate", OFFSET(sample_rate), AV_OPT_TYPE_INT, {.i64 = 48000}, 1000, INT_MAX, A|D},
- {"layout", "set channel layout", OFFSET(layout), AV_OPT_TYPE_CHANNEL_LAYOUT, {.i64 = AV_CH_LAYOUT_STEREO}, 0, INT64_MAX, A|D},
- {NULL}
+ { "sample_rate", "set sample rate", OFFSET(sample_rate), AV_OPT_TYPE_INT, { .i64 = 48000 }, 1000, INT_MAX, A | D },
+ { "layout", "set channel layout", OFFSET(layout), AV_OPT_TYPE_CHANNEL_LAYOUT, { .i64 = AV_CH_LAYOUT_STEREO }, 0, INT64_MAX, A | D },
+ { "subsong", "set subsong", OFFSET(subsong), AV_OPT_TYPE_INT, { .i64 = -2 }, -2, INT_MAX, A | D, "subsong"},
+ { "all", "all", 0, AV_OPT_TYPE_CONST, { .i64 = -1}, 0, 0, A | D, "subsong" },
+ { "auto", "auto", 0, AV_OPT_TYPE_CONST, { .i64 = -2}, 0, 0, A | D, "subsong" },
+ { NULL }
};
static void openmpt_logfunc(const char *message, void *userdata)
@@ -70,6 +74,8 @@ static int read_header_openmpt(AVFormatContext *s)
OpenMPTContext *openmpt = s->priv_data;
int64_t size = avio_size(s->pb);
char *buf = av_malloc(size);
+ int ret;
+
if (!buf)
return AVERROR(ENOMEM);
@@ -88,6 +94,24 @@ static int read_header_openmpt(AVFormatContext *s)
add_meta(s, "encoder", openmpt_module_get_metadata(openmpt->module, "tracker"));
add_meta(s, "comment", openmpt_module_get_metadata(openmpt->module, "message"));
+ if (openmpt->subsong >= openmpt_module_get_num_subsongs(openmpt->module)) {
+ openmpt_module_destroy(openmpt->module);
+ av_log(s, AV_LOG_ERROR, "Invalid subsong index: %d\n", openmpt->subsong);
+ return AVERROR(EINVAL);
+ }
+
+ if (openmpt->subsong != -2) {
+ if (openmpt->subsong >= 0) {
+ av_dict_set_int(&s->metadata, "track", openmpt->subsong + 1, 0);
+ }
+ ret = openmpt_module_select_subsong(openmpt->module, openmpt->subsong);
+ if (!ret){
+ openmpt_module_destroy(openmpt->module);
+ av_log(s, AV_LOG_ERROR, "Could not select requested subsong: %d", openmpt->subsong);
+ return AVERROR(EINVAL);
+ }
+ }
+
st = avformat_new_stream(s, NULL);
if (!st) {
openmpt_module_destroy(openmpt->module);