42 for (; o && o->
name; o++) {
43 if (!strcmp(o->
name, name) && (!unit || (o->
unit && !strcmp(o->
unit, unit))) && (o->
flags &
mask) == flags)
50 #if FF_API_OLD_AVOPTIONS
60 if (!last && class->option && class->option[0].
name)
62 if (last && last[1].
name)
84 if (o->
max*den < num*intnum || o->
min*den > num*intnum) {
120 if (c >=
'0' && c <=
'9')
return c -
'0';
121 if (c >=
'a' && c <=
'f')
return c -
'a' + 10;
122 if (c >=
'A' && c <=
'F')
return c -
'A' + 10;
128 int *lendst = (
int *)(dst + 1);
130 int len = strlen(val);
143 if (a < 0 || b < 0) {
147 *ptr++ = (a << 4) | b;
164 int ret = 0, notfirst = 0;
172 if (*val ==
'+' || *val ==
'-')
175 for (i = 0; i <
sizeof(buf) - 1 && val[i] && val[i] !=
'+' && val[i] !=
'-'; i++)
184 else if (!strcmp(buf,
"max" )) d = o->
max;
185 else if (!strcmp(buf,
"min" )) d = o->
min;
186 else if (!strcmp(buf,
"none" )) d = 0;
187 else if (!strcmp(buf,
"all" )) d = ~0;
189 int res =
av_expr_parse_and_eval(&d, buf,
const_names,
const_values,
NULL,
NULL,
NULL,
NULL,
NULL, 0, obj);
198 if (cmd ==
'+') d = intnum | (int64_t)d;
199 else if (cmd ==
'-') d = intnum &~(int64_t)d;
202 if (cmd ==
'+') d = notfirst*num*intnum/den + d;
203 else if (cmd ==
'-') d = notfirst*num*intnum/den - d;
217 #if FF_API_OLD_AVOPTIONS
229 void *dst, *target_obj;
231 if (!o || !target_obj)
236 dst = ((uint8_t*)target_obj) + o->
offset;
252 #define OPT_EVAL_NUMBER(name, opttype, vartype)\
253 int av_opt_eval_ ## name(void *obj, const AVOption *o, const char *val, vartype *name ## _out)\
255 if (!o || o->type != opttype)\
256 return AVERROR(EINVAL);\
257 return set_string_number(obj, o, val, name ## _out);\
267 static
int set_number(
void *obj, const
char *
name,
double num,
int den, int64_t intnum,
270 void *dst, *target_obj;
273 if (!o || !target_obj)
276 dst = ((uint8_t*)target_obj) + o->
offset;
280 #if FF_API_OLD_AVOPTIONS
308 return set_number(obj, name, 1, 1, val, search_flags);
313 return set_number(obj, name, val, 1, 1, search_flags);
321 #if FF_API_OLD_AVOPTIONS
338 dst= ((uint8_t*)obj) + o->
offset;
339 if (o_out) *o_out= o;
343 case AV_OPT_TYPE_INT: snprintf(buf, buf_len,
"%d" , *(
int *)dst);
break;
350 len = *(
int*)(((uint8_t *)dst) +
sizeof(uint8_t *));
351 if (len >= (buf_len + 1)/2)
return NULL;
352 bin = *(uint8_t**)dst;
353 for (i = 0; i <
len; i++) snprintf(buf + i*2, 3,
"%02X", bin[i]);
355 default:
return NULL;
363 void *dst, *target_obj;
365 uint8_t *bin, buf[128];
368 if (!o || !target_obj)
371 dst = (uint8_t*)target_obj + o->
offset;
375 case AV_OPT_TYPE_FLAGS: ret = snprintf(buf,
sizeof(buf),
"0x%08X", *(
int *)dst);
break;
376 case AV_OPT_TYPE_INT: ret = snprintf(buf,
sizeof(buf),
"%d" , *(
int *)dst);
break;
377 case AV_OPT_TYPE_INT64: ret = snprintf(buf,
sizeof(buf),
"%"PRId64, *(int64_t*)dst);
break;
378 case AV_OPT_TYPE_FLOAT: ret = snprintf(buf,
sizeof(buf),
"%f" , *(
float *)dst);
break;
379 case AV_OPT_TYPE_DOUBLE: ret = snprintf(buf,
sizeof(buf),
"%f" , *(
double *)dst);
break;
388 len = *(
int*)(((uint8_t *)dst) +
sizeof(uint8_t *));
389 if ((uint64_t)len*2 + 1 > INT_MAX)
393 bin = *(uint8_t**)dst;
394 for (i = 0; i <
len; i++)
395 snprintf(*out_val + i*2, 3,
"%02X", bin[i]);
401 if (ret >=
sizeof(buf))
410 void *dst, *target_obj;
412 if (!o || !target_obj)
415 dst = ((uint8_t*)target_obj) + o->
offset;
417 if (o_out) *o_out= o;
426 #if FF_API_OLD_AVOPTIONS
433 if (
get_number(obj, name, o_out, &num, &den, &intnum, 0) < 0)
435 return num*intnum/den;
444 if (
get_number(obj, name, o_out, &num, &den, &intnum, 0) < 0)
446 if (num == 1.0 && (
int)intnum == intnum)
449 return av_d2q(num*intnum/den, 1<<24);
458 if (
get_number(obj, name, o_out, &num, &den, &intnum, 0) < 0)
460 return num*intnum/den;
470 if ((ret =
get_number(obj, name,
NULL, &num, &den, &intnum, search_flags)) < 0)
472 *out_val = num*intnum/den;
482 if ((ret =
get_number(obj, name,
NULL, &num, &den, &intnum, search_flags)) < 0)
484 *out_val = num*intnum/den;
494 if ((ret =
get_number(obj, name,
NULL, &num, &den, &intnum, search_flags)) < 0)
497 if (num == 1.0 && (
int)intnum == intnum)
500 *out_val =
av_d2q(num*intnum/den, 1<<24);
517 static void opt_list(
void *obj,
void *av_log_obj,
const char *unit,
518 int req_flags,
int rej_flags)
523 if (!(opt->
flags & req_flags) || (opt->
flags & rej_flags))
581 opt_list(obj, av_log_obj, opt->
unit, req_flags, rej_flags);
586 int av_opt_show2(
void *obj,
void *av_log_obj,
int req_flags,
int rej_flags)
600 #if FF_API_OLD_AVOPTIONS
609 #if FF_API_OLD_AVOPTIONS
610 if ((opt->
flags & mask) != flags)
672 const char *key_val_sep,
const char *pairs_sep)
678 if (*key && strspn(*buf, key_val_sep)) {
682 av_log(ctx,
AV_LOG_ERROR,
"Missing key or no key/value separator found after key '%s'\n", key);
699 const char *key_val_sep,
const char *pairs_sep)
748 int opt_flags,
int search_flags)
754 int opt_flags,
int search_flags,
void **target_obj)
768 if (o =
av_opt_find2(child, name, unit, opt_flags, search_flags, target_obj))
774 if (!strcmp(o->
name, name) && (o->
flags & opt_flags) == opt_flags &&
776 (unit && o->
unit && !strcmp(o->
unit, unit)))) {
808 typedef struct TestContext
818 #define OFFSET(x) offsetof(TestContext, x)
820 #define TEST_FLAG_COOL 01
821 #define TEST_FLAG_LAME 02
822 #define TEST_FLAG_MU 04
824 static const AVOption test_options[]= {
830 {
"cool",
"set cool flag ", 0,
AV_OPT_TYPE_CONST, {TEST_FLAG_COOL}, INT_MIN, INT_MAX, 0,
"flags" },
831 {
"lame",
"set lame flag ", 0,
AV_OPT_TYPE_CONST, {TEST_FLAG_LAME}, INT_MIN, INT_MAX, 0,
"flags" },
832 {
"mu",
"set mu flag ", 0,
AV_OPT_TYPE_CONST, {TEST_FLAG_MU}, INT_MIN, INT_MAX, 0,
"flags" },
836 static const char *test_get_name(
void *ctx)
841 static const AVClass test_class = {
851 printf(
"\nTesting av_set_options_string()\n");
853 TestContext test_ctx;
870 "flags=+mu-lame : num=42: toggle=0",
871 "num=42 : string=blahblah",
872 "rational=0 : rational=1/2 : rational=1/-1",
876 test_ctx.class = &test_class;