Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
F
ffmpeg.wasm-core
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Linshizhi
ffmpeg.wasm-core
Commits
d9b0d75c
Commit
d9b0d75c
authored
Jun 05, 2012
by
Nicolas George
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
opt: add AV_OPT_TYPE_PIXEL_FMT.
parent
9f7b014a
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
21 additions
and
0 deletions
+21
-0
opt.c
libavutil/opt.c
+20
-0
opt.h
libavutil/opt.h
+1
-0
No files found.
libavutil/opt.c
View file @
d9b0d75c
...
...
@@ -32,6 +32,7 @@
#include "dict.h"
#include "log.h"
#include "parseutils.h"
#include "pixdesc.h"
#if FF_API_FIND_OPT
//FIXME order them and do a bin search
...
...
@@ -249,6 +250,18 @@ int av_opt_set(void *obj, const char *name, const char *val, int search_flags)
if
(
ret
<
0
)
av_log
(
obj
,
AV_LOG_ERROR
,
"Unable to parse option value
\"
%s
\"
as image size
\n
"
,
val
);
return
ret
;
case
AV_OPT_TYPE_PIXEL_FMT
:
ret
=
av_get_pix_fmt
(
val
);
if
(
ret
==
PIX_FMT_NONE
)
{
char
*
tail
;
ret
=
strtol
(
val
,
&
tail
,
0
);
if
(
*
tail
||
(
unsigned
)
ret
>=
PIX_FMT_NB
)
{
av_log
(
obj
,
AV_LOG_ERROR
,
"Unable to parse option value
\"
%s
\"
as pixel format
\n
"
,
val
);
return
AVERROR
(
EINVAL
);
}
}
*
(
enum
PixelFormat
*
)
dst
=
ret
;
return
0
;
}
av_log
(
obj
,
AV_LOG_ERROR
,
"Invalid option type.
\n
"
);
...
...
@@ -434,6 +447,9 @@ int av_opt_get(void *obj, const char *name, int search_flags, uint8_t **out_val)
case
AV_OPT_TYPE_IMAGE_SIZE
:
ret
=
snprintf
(
buf
,
sizeof
(
buf
),
"%dx%d"
,
((
int
*
)
dst
)[
0
],
((
int
*
)
dst
)[
1
]);
break
;
case
AV_OPT_TYPE_PIXEL_FMT
:
ret
=
snprintf
(
buf
,
sizeof
(
buf
),
"%s"
,
(
char
*
)
av_x_if_null
(
av_get_pix_fmt_name
(
*
(
enum
PixelFormat
*
)
dst
),
"?"
));
break
;
default
:
return
AVERROR
(
EINVAL
);
}
...
...
@@ -606,6 +622,9 @@ static void opt_list(void *obj, void *av_log_obj, const char *unit,
case
AV_OPT_TYPE_IMAGE_SIZE
:
av_log
(
av_log_obj
,
AV_LOG_INFO
,
"%-7s "
,
"<image_size>"
);
break
;
case
AV_OPT_TYPE_PIXEL_FMT
:
av_log
(
av_log_obj
,
AV_LOG_INFO
,
"%-7s "
,
"<pix_fmt>"
);
break
;
case
AV_OPT_TYPE_CONST
:
default
:
av_log
(
av_log_obj
,
AV_LOG_INFO
,
"%-7s "
,
""
);
...
...
@@ -684,6 +703,7 @@ void av_opt_set_defaults2(void *s, int mask, int flags)
break
;
case
AV_OPT_TYPE_STRING
:
case
AV_OPT_TYPE_IMAGE_SIZE
:
case
AV_OPT_TYPE_PIXEL_FMT
:
av_opt_set
(
s
,
opt
->
name
,
opt
->
default_val
.
str
,
0
);
break
;
case
AV_OPT_TYPE_BINARY
:
...
...
libavutil/opt.h
View file @
d9b0d75c
...
...
@@ -226,6 +226,7 @@ enum AVOptionType{
AV_OPT_TYPE_BINARY
,
///< offset must point to a pointer immediately followed by an int for the length
AV_OPT_TYPE_CONST
=
128
,
AV_OPT_TYPE_IMAGE_SIZE
=
MKBETAG
(
'S'
,
'I'
,
'Z'
,
'E'
),
///< offset must point to two consecutive integers
AV_OPT_TYPE_PIXEL_FMT
=
MKBETAG
(
'P'
,
'F'
,
'M'
,
'T'
),
#if FF_API_OLD_AVOPTIONS
FF_OPT_TYPE_FLAGS
=
0
,
FF_OPT_TYPE_INT
,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment