From 8f60de98beef61c3631819a4e3a4be1ec56da00d Mon Sep 17 00:00:00 2001 From: wm4 Date: Wed, 11 Jun 2014 02:04:02 +0200 Subject: encode: make option struct local Similar to previous commits. --- common/encode.h | 27 ++++++++++++++++++++++++--- common/encode_lavc.c | 35 +++++++++++++++++++++++++++++++++-- common/encode_lavc.h | 2 +- 3 files changed, 58 insertions(+), 6 deletions(-) (limited to 'common') diff --git a/common/encode.h b/common/encode.h index 530805c76f..996fe66857 100644 --- a/common/encode.h +++ b/common/encode.h @@ -8,15 +8,36 @@ struct mpv_global; struct mp_log; struct encode_lavc_context; -struct encode_output_conf; + +struct encode_opts { + char *file; + char *format; + char **fopts; + float fps; + float maxfps; + char *vcodec; + char **vopts; + char *acodec; + char **aopts; + int harddup; + float voffset; + float aoffset; + int copyts; + int rawts; + int autofps; + int neverdrop; + int video_first; + int audio_first; + int metadata; +}; // interface for mplayer.c -struct encode_lavc_context *encode_lavc_init(struct encode_output_conf *options, +struct encode_lavc_context *encode_lavc_init(struct encode_opts *options, struct mpv_global *global); void encode_lavc_finish(struct encode_lavc_context *ctx); void encode_lavc_free(struct encode_lavc_context *ctx); void encode_lavc_discontinuity(struct encode_lavc_context *ctx); -bool encode_lavc_showhelp(struct mp_log *log, struct encode_output_conf *options); +bool encode_lavc_showhelp(struct mp_log *log, struct encode_opts *options); int encode_lavc_getstatus(struct encode_lavc_context *ctx, char *buf, int bufsize, float relative_position); void encode_lavc_expect_stream(struct encode_lavc_context *ctx, int mt); void encode_lavc_set_metadata(struct encode_lavc_context *ctx, diff --git a/common/encode_lavc.c b/common/encode_lavc.c index 0ec3e93b06..df5710e07a 100644 --- a/common/encode_lavc.c +++ b/common/encode_lavc.c @@ -27,12 +27,43 @@ #include "common/msg.h" #include "common/msg_control.h" #include "video/vfcap.h" +#include "options/m_option.h" #include "options/options.h" #include "osdep/timer.h" #include "video/out/vo.h" #include "talloc.h" #include "stream/stream.h" +#define OPT_BASE_STRUCT struct encode_opts +const struct m_sub_options encode_config = { + .opts = (const m_option_t[]) { + OPT_STRING("o", file, CONF_GLOBAL | CONF_NOCFG | CONF_PRE_PARSE), + OPT_STRING("of", format, CONF_GLOBAL), + OPT_STRINGLIST("ofopts*", fopts, CONF_GLOBAL), + OPT_FLOATRANGE("ofps", fps, CONF_GLOBAL, 0.0, 1000000.0), + OPT_FLOATRANGE("omaxfps", maxfps, CONF_GLOBAL, 0.0, 1000000.0), + OPT_STRING("ovc", vcodec, CONF_GLOBAL), + OPT_STRINGLIST("ovcopts*", vopts, CONF_GLOBAL), + OPT_STRING("oac", acodec, CONF_GLOBAL), + OPT_STRINGLIST("oacopts*", aopts, CONF_GLOBAL), + OPT_FLAG("oharddup", harddup, CONF_GLOBAL), + OPT_FLOATRANGE("ovoffset", voffset, CONF_GLOBAL, -1000000.0, 1000000.0), + OPT_FLOATRANGE("oaoffset", aoffset, CONF_GLOBAL, -1000000.0, 1000000.0), + OPT_FLAG("ocopyts", copyts, CONF_GLOBAL), + OPT_FLAG("orawts", rawts, CONF_GLOBAL), + OPT_FLAG("oautofps", autofps, CONF_GLOBAL), + OPT_FLAG("oneverdrop", neverdrop, CONF_GLOBAL), + OPT_FLAG("ovfirst", video_first, CONF_GLOBAL), + OPT_FLAG("oafirst", audio_first, CONF_GLOBAL), + OPT_FLAG("ometadata", metadata, CONF_GLOBAL), + {0} + }, + .size = sizeof(struct encode_opts), + .defaults = &(const struct encode_opts){ + .metadata = 1, + }, +}; + static int set_to_avdictionary(struct encode_lavc_context *ctx, AVDictionary **dictp, const char *key, @@ -124,7 +155,7 @@ int encode_lavc_oformat_flags(struct encode_lavc_context *ctx) return ctx->avc ? ctx->avc->oformat->flags : 0; } -struct encode_lavc_context *encode_lavc_init(struct encode_output_conf *options, +struct encode_lavc_context *encode_lavc_init(struct encode_opts *options, struct mpv_global *global) { struct encode_lavc_context *ctx; @@ -905,7 +936,7 @@ static void encode_lavc_printoptions(struct mp_log *log, void *obj, } } -bool encode_lavc_showhelp(struct mp_log *log, struct encode_output_conf *opts) +bool encode_lavc_showhelp(struct mp_log *log, struct encode_opts *opts) { bool help_output = false; if (av_codec_next(NULL) == NULL) diff --git a/common/encode_lavc.h b/common/encode_lavc.h index 7a7f86cde1..fc1e754f00 100644 --- a/common/encode_lavc.h +++ b/common/encode_lavc.h @@ -36,7 +36,7 @@ struct encode_lavc_context { struct mpv_global *global; - struct encode_output_conf *options; + struct encode_opts *options; struct mp_log *log; struct mp_tags *metadata; -- cgit v1.2.3