Quoting Martin Storsjö (2016-03-18 13:01:39)
> From: Michael Niedermayer <[email protected]>
>
> This includes documentation and other modifications by
> Lukasz Marek.
> ---
> doc/APIchanges | 3 +++
> libavutil/opt.c | 58
> +++++++++++++++++++++++++++++++++++++++++++++++++++++
> libavutil/opt.h | 13 ++++++++++++
> libavutil/version.h | 2 +-
> 4 files changed, 75 insertions(+), 1 deletion(-)
>
> diff --git a/doc/APIchanges b/doc/APIchanges
> index 20fecb9..aa6f004 100644
> --- a/doc/APIchanges
> +++ b/doc/APIchanges
> @@ -13,6 +13,9 @@ libavutil: 2015-08-28
>
> API changes, most recent first:
>
> +2016-xx-xx - xxxxxxx - lavu 55.7.0 - opt.h
> + Add av_opt_copy().
> +
> 2016-02-23 - 9200514 - lavf 57.5.0 - avformat.h
> Add AVStream.codecpar, deprecate AVStream.codec.
>
> diff --git a/libavutil/opt.c b/libavutil/opt.c
> index 5825a72..75e8970 100644
> --- a/libavutil/opt.c
> +++ b/libavutil/opt.c
> @@ -757,6 +757,64 @@ const AVClass *av_opt_child_class_next(const AVClass
> *parent, const AVClass *pre
> return NULL;
> }
>
> +static int opt_size(enum AVOptionType type)
> +{
> + switch(type) {
> + case AV_OPT_TYPE_INT:
> + case AV_OPT_TYPE_FLAGS: return sizeof(int);
> + case AV_OPT_TYPE_INT64: return sizeof(int64_t);
> + case AV_OPT_TYPE_DOUBLE: return sizeof(double);
> + case AV_OPT_TYPE_FLOAT: return sizeof(float);
> + case AV_OPT_TYPE_STRING: return sizeof(uint8_t*);
> + case AV_OPT_TYPE_RATIONAL: return sizeof(AVRational);
> + case AV_OPT_TYPE_BINARY: return sizeof(uint8_t*) + sizeof(int);
> + }
> + return 0;
This should return an error that should be checked by the caller.
> +}
> +
> +int av_opt_copy(void *dst, const void *src)
> +{
> + const AVOption *o = NULL;
> + const AVClass *c;
> + int ret = 0;
> +
> + if (!src)
> + return 0;
I'm not sure about this, it looks invalid.
> +
> + c = *(AVClass**)src;
> + if (*(AVClass**)dst && c != *(AVClass**)dst)
Why the first check? dst is assumed to be non-NULL anyway, and if it is
NULL, the code lower down will explode.
> + return AVERROR(EINVAL);
> +
> + while ((o = av_opt_next(src, o))) {
> + void *field_dst = ((uint8_t*)dst) + o->offset;
> + void *field_src = ((uint8_t*)src) + o->offset;
> + uint8_t **field_dst8 = (uint8_t**)field_dst;
> + uint8_t **field_src8 = (uint8_t**)field_src;
> +
> + if (o->type == AV_OPT_TYPE_STRING) {
> + set_string(dst, o, *field_src8, field_dst8);
> + if (*field_src8 && !*field_dst8)
> + ret = AVERROR(ENOMEM);
> + } else if (o->type == AV_OPT_TYPE_BINARY) {
> + int len = *(int*)(field_src8 + 1);
> + if (*field_dst8 != *field_src8)
> + av_freep(field_dst8);
> + *field_dst8 = av_malloc(len);
Didn't we have some objections to zero-size mallocs?
--
Anton Khirnov
_______________________________________________
libav-devel mailing list
[email protected]
https://lists.libav.org/mailman/listinfo/libav-devel