forked from FFmpeg/FFmpeg
AVOptions: add av_opt_find() as a replacement for av_find_opt.
This commit is contained in:
parent
7e83e1c511
commit
dc59ec5e79
6 changed files with 70 additions and 9 deletions
|
@ -299,7 +299,7 @@ int opt_default(const char *opt, const char *arg){
|
||||||
int opt_types[]={AV_OPT_FLAG_VIDEO_PARAM, AV_OPT_FLAG_AUDIO_PARAM, 0, AV_OPT_FLAG_SUBTITLE_PARAM, 0};
|
int opt_types[]={AV_OPT_FLAG_VIDEO_PARAM, AV_OPT_FLAG_AUDIO_PARAM, 0, AV_OPT_FLAG_SUBTITLE_PARAM, 0};
|
||||||
|
|
||||||
for(type=0; *avcodec_opts && type<AVMEDIA_TYPE_NB && ret>= 0; type++){
|
for(type=0; *avcodec_opts && type<AVMEDIA_TYPE_NB && ret>= 0; type++){
|
||||||
const AVOption *o2 = av_find_opt(avcodec_opts[0], opt, NULL, opt_types[type], opt_types[type]);
|
const AVOption *o2 = av_opt_find(avcodec_opts[0], opt, NULL, opt_types[type], 0);
|
||||||
if(o2)
|
if(o2)
|
||||||
ret = av_set_string3(avcodec_opts[type], opt, arg, 1, &o);
|
ret = av_set_string3(avcodec_opts[type], opt, arg, 1, &o);
|
||||||
}
|
}
|
||||||
|
@ -324,13 +324,13 @@ int opt_default(const char *opt, const char *arg){
|
||||||
AVOutputFormat *oformat = NULL;
|
AVOutputFormat *oformat = NULL;
|
||||||
while ((p=av_codec_next(p))){
|
while ((p=av_codec_next(p))){
|
||||||
const AVClass *c = p->priv_class;
|
const AVClass *c = p->priv_class;
|
||||||
if(c && av_find_opt(&c, opt, NULL, 0, 0))
|
if(c && av_opt_find(&c, opt, NULL, 0, 0))
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (!p) {
|
if (!p) {
|
||||||
while ((oformat = av_oformat_next(oformat))) {
|
while ((oformat = av_oformat_next(oformat))) {
|
||||||
const AVClass *c = oformat->priv_class;
|
const AVClass *c = oformat->priv_class;
|
||||||
if (c && av_find_opt(&c, opt, NULL, 0, 0))
|
if (c && av_opt_find(&c, opt, NULL, 0, 0))
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3944,7 +3944,7 @@ static int ffserver_opt_default(const char *opt, const char *arg,
|
||||||
AVCodecContext *avctx, int type)
|
AVCodecContext *avctx, int type)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
const AVOption *o = av_find_opt(avctx, opt, NULL, type, type);
|
const AVOption *o = av_opt_find(avctx, opt, NULL, type, 0);
|
||||||
if(o)
|
if(o)
|
||||||
ret = av_set_string3(avctx, opt, arg, 1, NULL);
|
ret = av_set_string3(avctx, opt, arg, 1, NULL);
|
||||||
return ret;
|
return ret;
|
||||||
|
|
|
@ -60,6 +60,9 @@
|
||||||
#ifndef FF_API_GET_BITS_PER_SAMPLE_FMT
|
#ifndef FF_API_GET_BITS_PER_SAMPLE_FMT
|
||||||
#define FF_API_GET_BITS_PER_SAMPLE_FMT (LIBAVUTIL_VERSION_MAJOR < 52)
|
#define FF_API_GET_BITS_PER_SAMPLE_FMT (LIBAVUTIL_VERSION_MAJOR < 52)
|
||||||
#endif
|
#endif
|
||||||
|
#ifndef FF_API_FIND_OPT
|
||||||
|
#define FF_API_FIND_OPT (LIBAVUTIL_VERSION_MAJOR < 52)
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the LIBAVUTIL_VERSION_INT constant.
|
* Return the LIBAVUTIL_VERSION_INT constant.
|
||||||
|
|
|
@ -70,6 +70,13 @@ typedef struct {
|
||||||
* can be NULL of course
|
* can be NULL of course
|
||||||
*/
|
*/
|
||||||
int parent_log_context_offset;
|
int parent_log_context_offset;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A function for extended searching, e.g. in possible
|
||||||
|
* children objects.
|
||||||
|
*/
|
||||||
|
const struct AVOption* (*opt_find)(void *obj, const char *name, const char *unit,
|
||||||
|
int opt_flags, int search_flags);
|
||||||
} AVClass;
|
} AVClass;
|
||||||
|
|
||||||
/* av_log API */
|
/* av_log API */
|
||||||
|
|
|
@ -31,6 +31,7 @@
|
||||||
#include "eval.h"
|
#include "eval.h"
|
||||||
#include "dict.h"
|
#include "dict.h"
|
||||||
|
|
||||||
|
#if FF_API_FIND_OPT
|
||||||
//FIXME order them and do a bin search
|
//FIXME order them and do a bin search
|
||||||
const AVOption *av_find_opt(void *v, const char *name, const char *unit, int mask, int flags)
|
const AVOption *av_find_opt(void *v, const char *name, const char *unit, int mask, int flags)
|
||||||
{
|
{
|
||||||
|
@ -43,6 +44,7 @@ const AVOption *av_find_opt(void *v, const char *name, const char *unit, int mas
|
||||||
}
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
const AVOption *av_next_option(void *obj, const AVOption *last)
|
const AVOption *av_next_option(void *obj, const AVOption *last)
|
||||||
{
|
{
|
||||||
|
@ -53,7 +55,7 @@ const AVOption *av_next_option(void *obj, const AVOption *last)
|
||||||
|
|
||||||
static int av_set_number2(void *obj, const char *name, double num, int den, int64_t intnum, const AVOption **o_out)
|
static int av_set_number2(void *obj, const char *name, double num, int den, int64_t intnum, const AVOption **o_out)
|
||||||
{
|
{
|
||||||
const AVOption *o= av_find_opt(obj, name, NULL, 0, 0);
|
const AVOption *o = av_opt_find(obj, name, NULL, 0, 0);
|
||||||
void *dst;
|
void *dst;
|
||||||
if (o_out)
|
if (o_out)
|
||||||
*o_out= o;
|
*o_out= o;
|
||||||
|
@ -116,7 +118,7 @@ static int hexchar2int(char c) {
|
||||||
int av_set_string3(void *obj, const char *name, const char *val, int alloc, const AVOption **o_out)
|
int av_set_string3(void *obj, const char *name, const char *val, int alloc, const AVOption **o_out)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
const AVOption *o= av_find_opt(obj, name, NULL, 0, 0);
|
const AVOption *o = av_opt_find(obj, name, NULL, 0, 0);
|
||||||
if (o_out)
|
if (o_out)
|
||||||
*o_out = o;
|
*o_out = o;
|
||||||
if (!o)
|
if (!o)
|
||||||
|
@ -163,7 +165,7 @@ int av_set_string3(void *obj, const char *name, const char *val, int alloc, cons
|
||||||
buf[i]=0;
|
buf[i]=0;
|
||||||
|
|
||||||
{
|
{
|
||||||
const AVOption *o_named= av_find_opt(obj, buf, o->unit, 0, 0);
|
const AVOption *o_named = av_opt_find(obj, buf, o->unit, 0, 0);
|
||||||
if (o_named && o_named->type == FF_OPT_TYPE_CONST)
|
if (o_named && o_named->type == FF_OPT_TYPE_CONST)
|
||||||
d= o_named->default_val.dbl;
|
d= o_named->default_val.dbl;
|
||||||
else if (!strcmp(buf, "default")) d= o->default_val.dbl;
|
else if (!strcmp(buf, "default")) d= o->default_val.dbl;
|
||||||
|
@ -228,7 +230,7 @@ const AVOption *av_set_int(void *obj, const char *name, int64_t n)
|
||||||
*/
|
*/
|
||||||
const char *av_get_string(void *obj, const char *name, const AVOption **o_out, char *buf, int buf_len)
|
const char *av_get_string(void *obj, const char *name, const AVOption **o_out, char *buf, int buf_len)
|
||||||
{
|
{
|
||||||
const AVOption *o= av_find_opt(obj, name, NULL, 0, 0);
|
const AVOption *o = av_opt_find(obj, name, NULL, 0, 0);
|
||||||
void *dst;
|
void *dst;
|
||||||
uint8_t *bin;
|
uint8_t *bin;
|
||||||
int len, i;
|
int len, i;
|
||||||
|
@ -261,7 +263,7 @@ const char *av_get_string(void *obj, const char *name, const AVOption **o_out, c
|
||||||
|
|
||||||
static int av_get_number(void *obj, const char *name, const AVOption **o_out, double *num, int *den, int64_t *intnum)
|
static int av_get_number(void *obj, const char *name, const AVOption **o_out, double *num, int *den, int64_t *intnum)
|
||||||
{
|
{
|
||||||
const AVOption *o= av_find_opt(obj, name, NULL, 0, 0);
|
const AVOption *o = av_opt_find(obj, name, NULL, 0, 0);
|
||||||
void *dst;
|
void *dst;
|
||||||
if (!o || o->offset<=0)
|
if (!o || o->offset<=0)
|
||||||
goto error;
|
goto error;
|
||||||
|
@ -560,6 +562,24 @@ int av_opt_set_dict(void *obj, AVDictionary **options)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const AVOption *av_opt_find(void *obj, const char *name, const char *unit,
|
||||||
|
int opt_flags, int search_flags)
|
||||||
|
{
|
||||||
|
AVClass *c = *(AVClass**)obj;
|
||||||
|
const AVOption *o = NULL;
|
||||||
|
|
||||||
|
if (c->opt_find && search_flags & AV_OPT_SEARCH_CHILDREN &&
|
||||||
|
(o = c->opt_find(obj, name, unit, opt_flags, search_flags)))
|
||||||
|
return o;
|
||||||
|
|
||||||
|
while (o = av_next_option(obj, o)) {
|
||||||
|
if (!strcmp(o->name, name) && (!unit || (o->unit && !strcmp(o->unit, unit))) &&
|
||||||
|
(o->flags & opt_flags) == opt_flags)
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef TEST
|
#ifdef TEST
|
||||||
|
|
||||||
#undef printf
|
#undef printf
|
||||||
|
|
|
@ -92,6 +92,7 @@ typedef struct AVOption {
|
||||||
const char *unit;
|
const char *unit;
|
||||||
} AVOption;
|
} AVOption;
|
||||||
|
|
||||||
|
#if FF_API_FIND_OPT
|
||||||
/**
|
/**
|
||||||
* Look for an option in obj. Look only for the options which
|
* Look for an option in obj. Look only for the options which
|
||||||
* have the flags set as specified in mask and flags (that is,
|
* have the flags set as specified in mask and flags (that is,
|
||||||
|
@ -103,8 +104,12 @@ typedef struct AVOption {
|
||||||
* @param[in] unit the unit of the option to look for, or any if NULL
|
* @param[in] unit the unit of the option to look for, or any if NULL
|
||||||
* @return a pointer to the option found, or NULL if no option
|
* @return a pointer to the option found, or NULL if no option
|
||||||
* has been found
|
* has been found
|
||||||
|
*
|
||||||
|
* @deprecated use av_opt_find.
|
||||||
*/
|
*/
|
||||||
|
attribute_deprecated
|
||||||
const AVOption *av_find_opt(void *obj, const char *name, const char *unit, int mask, int flags);
|
const AVOption *av_find_opt(void *obj, const char *name, const char *unit, int mask, int flags);
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set the field of obj with the given name to value.
|
* Set the field of obj with the given name to value.
|
||||||
|
@ -208,4 +213,30 @@ int av_opt_flag_is_set(void *obj, const char *field_name, const char *flag_name)
|
||||||
*/
|
*/
|
||||||
int av_opt_set_dict(void *obj, struct AVDictionary **options);
|
int av_opt_set_dict(void *obj, struct AVDictionary **options);
|
||||||
|
|
||||||
|
#define AV_OPT_SEARCH_CHILDREN 0x0001 /**< Search in possible children of the
|
||||||
|
given object first. */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Look for an option in an object. Consider only options which
|
||||||
|
* have all the specified flags set.
|
||||||
|
*
|
||||||
|
* @param[in] obj A pointer to a struct whose first element is a
|
||||||
|
* pointer to an AVClass.
|
||||||
|
* @param[in] name The name of the option to look for.
|
||||||
|
* @param[in] unit When searching for named constants, name of the unit
|
||||||
|
* it belongs to.
|
||||||
|
* @param opt_flags Find only options with all the specified flags set (AV_OPT_FLAG).
|
||||||
|
* @param search_flags A combination of AV_OPT_SEARCH_*.
|
||||||
|
*
|
||||||
|
* @return A pointer to the option found, or NULL if no option
|
||||||
|
* was found.
|
||||||
|
*
|
||||||
|
* @note Options found with AV_OPT_SEARCH_CHILDREN flag may not be settable
|
||||||
|
* directly with av_set_string3(). Use special calls which take an options
|
||||||
|
* AVDictionary (e.g. avformat_open_input()) to set options found with this
|
||||||
|
* flag.
|
||||||
|
*/
|
||||||
|
const AVOption *av_opt_find(void *obj, const char *name, const char *unit,
|
||||||
|
int opt_flags, int search_flags);
|
||||||
|
|
||||||
#endif /* AVUTIL_OPT_H */
|
#endif /* AVUTIL_OPT_H */
|
||||||
|
|
Loading…
Add table
Reference in a new issue