54 #include "libavutil/ffversion.h"
59 #if HAVE_SYS_RESOURCE_H
61 #include <sys/resource.h>
97 vfprintf(stdout, fmt, vl);
104 static int print_prefix = 1;
132 double min,
double max)
138 error =
"Expected number for %s but found: %s\n";
139 else if (d < min || d > max)
140 error =
"The value for %s was %s which is not within %f - %f\n";
141 else if (type ==
OPT_INT64 && (int64_t)d != d)
142 error =
"Expected int64 for %s but found %s\n";
143 else if (type ==
OPT_INT && (
int)d != d)
144 error =
"Expected int for %s but found %s\n";
158 is_duration ?
"duration" :
"date", context, timestr);
165 int rej_flags,
int alt_flags)
171 for (po = options; po->
name; po++) {
174 if (((po->
flags & req_flags) != req_flags) ||
175 (alt_flags && !(po->
flags & alt_flags)) ||
176 (po->
flags & rej_flags))
188 printf(
"-%-17s %s\n", buf, po->
help);
207 const char *p = strchr(name,
':');
208 int len = p ? p - name : strlen(name);
211 if (!strncmp(name, po->
name, len) && strlen(po->
name) == len)
221 #if HAVE_COMMANDLINETOARGVW && defined(_WIN32)
223 #include <shellapi.h>
225 static char** win32_argv_utf8 =
NULL;
226 static int win32_argc = 0;
239 int i, buffsize = 0,
offset = 0;
241 if (win32_argv_utf8) {
242 *argc_ptr = win32_argc;
243 *argv_ptr = win32_argv_utf8;
248 argv_w = CommandLineToArgvW(GetCommandLineW(), &win32_argc);
249 if (win32_argc <= 0 || !argv_w)
253 for (i = 0; i < win32_argc; i++)
254 buffsize += WideCharToMultiByte(CP_UTF8, 0, argv_w[i], -1,
257 win32_argv_utf8 =
av_mallocz(
sizeof(
char *) * (win32_argc + 1) + buffsize);
258 argstr_flat = (
char *)win32_argv_utf8 +
sizeof(
char *) * (win32_argc + 1);
259 if (!win32_argv_utf8) {
264 for (i = 0; i < win32_argc; i++) {
265 win32_argv_utf8[i] = &argstr_flat[
offset];
266 offset += WideCharToMultiByte(CP_UTF8, 0, argv_w[i], -1,
270 win32_argv_utf8[i] =
NULL;
273 *argc_ptr = win32_argc;
274 *argv_ptr = win32_argv_utf8;
294 char *p = strchr(opt,
':');
297 dstcount = (
int *)(so + 1);
298 *so =
grow_array(*so,
sizeof(**so), dstcount, *dstcount + 1);
302 (*so)[*dstcount - 1].specifier = str;
303 dst = &(*so)[*dstcount - 1].u;
327 "Failed to set value '%s' for option '%s': %s\n",
345 if (!po->
name && opt[0] ==
'n' && opt[1] ==
'o') {
372 void (*parse_arg_function)(
void *,
const char*))
375 int optindex, handleoptions = 1,
ret;
382 while (optindex < argc) {
383 opt = argv[optindex++];
385 if (handleoptions && opt[0] ==
'-' && opt[1] !=
'\0') {
386 if (opt[1] ==
'-' && opt[2] ==
'\0') {
396 if (parse_arg_function)
397 parse_arg_function(optctx, opt);
409 for (i = 0; i < g->
nb_opts; i++) {
415 "%s %s -- you are trying to apply an input option to an "
416 "output file or vice versa. Move this option before the "
417 "file it belongs to.\n", o->
key, o->
opt->
help,
441 for (i = 1; i < argc; i++) {
442 const char *cur_opt = argv[i];
444 if (*cur_opt++ !=
'-')
448 if (!po->
name && cur_opt[0] ==
'n' && cur_opt[1] ==
'o')
451 if ((!po->
name && !strcmp(cur_opt, optname)) ||
452 (po->
name && !strcmp(optname, po->
name)))
463 const unsigned char *p;
466 if (!((*p >=
'+' && *p <=
':') || (*p >=
'@' && *p <=
'Z') ||
467 *p ==
'_' || (*p >=
'a' && *p <=
'z')))
474 for (p = a; *p; p++) {
475 if (*p ==
'\\' || *p ==
'"' || *p ==
'$' || *p ==
'`')
477 else if (*p < ' ' || *p >
'~')
503 if (idx && argv[idx + 1])
506 if ((env = getenv(
"FFREPORT")) || idx) {
511 for (i = 0; i < argc; i++) {
524 int opt_flags,
int search_flags)
532 #define FLAGS (o->type == AV_OPT_TYPE_FLAGS) ? AV_DICT_APPEND : 0
537 char opt_stripped[128];
540 #if CONFIG_AVRESAMPLE
545 if (!strcmp(opt,
"debug") || !strcmp(opt,
"fdebug"))
548 if (!(p = strchr(opt,
':')))
549 p = opt + strlen(opt);
550 av_strlcpy(opt_stripped, opt,
FFMIN(
sizeof(opt_stripped), p - opt + 1));
554 ((opt[0] ==
'v' || opt[0] ==
'a' || opt[0] ==
's') &&
579 if (!consumed && !strcmp(opt,
"sws_flags")) {
584 #if CONFIG_SWRESAMPLE
599 #if CONFIG_AVRESAMPLE
622 for (i = 0; i < nb_groups; i++) {
624 if (p->
sep && !strcmp(p->
sep, opt))
659 resample_opts =
NULL;
673 const char *key,
const char *
val)
690 memset(octx, 0,
sizeof(*octx));
746 while (optindex < argc) {
747 const char *opt = argv[optindex++], *
arg;
753 if (opt[0] ==
'-' && opt[1] ==
'-' && !opt[2]) {
758 if (opt[0] !=
'-' || !opt[1] || dashdash+1 == optindex) {
765 #define GET_ARG(arg) \
767 arg = argv[optindex++]; \
769 av_log(NULL, AV_LOG_ERROR, "Missing argument for option '%s'.\n", opt);\
770 return AVERROR(EINVAL); \
779 groups[ret].
name, arg);
788 arg = argv[optindex++];
797 "argument '%s'.\n", po->
name, po->
help, arg);
802 if (argv[optindex]) {
806 "argument '%s'.\n", opt, argv[optindex]);
811 "with argument '%s'.\n", opt, argv[optindex]);
817 if (opt[0] ==
'n' && opt[1] ==
'o' &&
822 "argument 0.\n", po->
name, po->
help);
853 const struct {
const char *
name;
int level; } log_levels[] = {
870 tail = strstr(arg,
"repeat");
878 arg += 6 + (arg[6]==
'+');
883 if (!strcmp(log_levels[i].
name, arg)) {
889 level = strtol(arg, &tail, 10);
892 "Possible levels are numbers or:\n", arg);
906 while ((c = *(
template++))) {
908 if (!(c = *(
template++)))
916 tm->tm_year + 1900, tm->tm_mon + 1, tm->tm_mday,
917 tm->tm_hour, tm->tm_min, tm->tm_sec);
931 char *filename_template =
NULL;
941 tm = localtime(&now);
943 while (env && *env) {
947 "Failed to parse FFREPORT environment variable: %s\n",
954 if (!strcmp(key,
"file")) {
956 filename_template =
val;
958 }
else if (!strcmp(key,
"level")) {
985 filename.str, strerror(errno));
990 "%s started on %04d-%02d-%02d at %02d:%02d:%02d\n"
991 "Report written to \"%s\"\n",
993 tm->tm_year + 1900, tm->tm_mon + 1, tm->tm_mday,
994 tm->tm_hour, tm->tm_min, tm->tm_sec,
1010 max = strtol(arg, &tail, 10);
1023 struct rlimit rl = { lim, lim + 1 };
1024 if (setrlimit(RLIMIT_CPU, &rl))
1025 perror(
"setrlimit");
1035 const char *errbuf_ptr = errbuf;
1045 #define SHOW_VERSION 2
1046 #define SHOW_CONFIG 4
1047 #define SHOW_COPYRIGHT 8
1049 #define PRINT_LIB_INFO(libname, LIBNAME, flags, level) \
1050 if (CONFIG_##LIBNAME) { \
1051 const char *indent = flags & INDENT? " " : ""; \
1052 if (flags & SHOW_VERSION) { \
1053 unsigned int version = libname##_version(); \
1054 av_log(NULL, level, \
1055 "%slib%-11s %2d.%3d.%3d / %2d.%3d.%3d\n", \
1057 LIB##LIBNAME##_VERSION_MAJOR, \
1058 LIB##LIBNAME##_VERSION_MINOR, \
1059 LIB##LIBNAME##_VERSION_MICRO, \
1060 version >> 16, version >> 8 & 0xff, version & 0xff); \
1062 if (flags & SHOW_CONFIG) { \
1063 const char *cfg = libname##_configuration(); \
1064 if (strcmp(FFMPEG_CONFIGURATION, cfg)) { \
1065 if (!warned_cfg) { \
1066 av_log(NULL, level, \
1067 "%sWARNING: library configuration mismatch\n", \
1071 av_log(NULL, level, "%s%-11s configuration: %s\n", \
1072 indent, #libname, cfg); \
1092 const char *indent = flags &
INDENT?
" " :
"";
1096 av_log(
NULL, level,
" Copyright (c) %d-%d the FFmpeg developers",
1099 av_log(
NULL, level,
"%sbuilt with %s\n", indent, CC_IDENT);
1101 av_log(
NULL, level,
"%sconfiguration: " FFMPEG_CONFIGURATION
"\n", indent);
1106 const char *indent = flags &
INDENT ?
" " :
"";
1107 char str[] = { FFMPEG_CONFIGURATION };
1108 char *conflist, *remove_tilde, *splitconf;
1112 while ((conflist = strstr(str,
" --")) !=
NULL) {
1113 strncpy(conflist,
"~--", 3);
1118 while ((remove_tilde = strstr(str,
"pkg-config~")) !=
NULL) {
1119 strncpy(remove_tilde,
"pkg-config ", 11);
1122 splitconf = strtok(str,
"~");
1123 av_log(
NULL, level,
"\n%sconfiguration:\n", indent);
1124 while (splitconf !=
NULL) {
1125 av_log(
NULL, level,
"%s%s%s\n", indent, indent, splitconf);
1126 splitconf = strtok(
NULL,
"~");
1162 "This version of %s has nonfree parts compiled in.\n"
1163 "Therefore it is not legally redistributable.\n",
1167 "%s is free software; you can redistribute it and/or modify\n"
1168 "it under the terms of the GNU General Public License as published by\n"
1169 "the Free Software Foundation; either version 3 of the License, or\n"
1170 "(at your option) any later version.\n"
1172 "%s is distributed in the hope that it will be useful,\n"
1173 "but WITHOUT ANY WARRANTY; without even the implied warranty of\n"
1174 "MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n"
1175 "GNU General Public License for more details.\n"
1177 "You should have received a copy of the GNU General Public License\n"
1178 "along with %s. If not, see <http://www.gnu.org/licenses/>.\n",
1182 "%s is free software; you can redistribute it and/or modify\n"
1183 "it under the terms of the GNU General Public License as published by\n"
1184 "the Free Software Foundation; either version 2 of the License, or\n"
1185 "(at your option) any later version.\n"
1187 "%s is distributed in the hope that it will be useful,\n"
1188 "but WITHOUT ANY WARRANTY; without even the implied warranty of\n"
1189 "MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n"
1190 "GNU General Public License for more details.\n"
1192 "You should have received a copy of the GNU General Public License\n"
1193 "along with %s; if not, write to the Free Software\n"
1194 "Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA\n",
1198 "%s is free software; you can redistribute it and/or modify\n"
1199 "it under the terms of the GNU Lesser General Public License as published by\n"
1200 "the Free Software Foundation; either version 3 of the License, or\n"
1201 "(at your option) any later version.\n"
1203 "%s is distributed in the hope that it will be useful,\n"
1204 "but WITHOUT ANY WARRANTY; without even the implied warranty of\n"
1205 "MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n"
1206 "GNU Lesser General Public License for more details.\n"
1208 "You should have received a copy of the GNU Lesser General Public License\n"
1209 "along with %s. If not, see <http://www.gnu.org/licenses/>.\n",
1213 "%s is free software; you can redistribute it and/or\n"
1214 "modify it under the terms of the GNU Lesser General Public\n"
1215 "License as published by the Free Software Foundation; either\n"
1216 "version 2.1 of the License, or (at your option) any later version.\n"
1218 "%s is distributed in the hope that it will be useful,\n"
1219 "but WITHOUT ANY WARRANTY; without even the implied warranty of\n"
1220 "MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU\n"
1221 "Lesser General Public License for more details.\n"
1223 "You should have received a copy of the GNU Lesser General Public\n"
1224 "License along with %s; if not, write to the Free Software\n"
1225 "Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA\n",
1243 const char *last_name;
1247 " D. = Demuxing supported\n"
1248 " .E = Muxing supported\n"
1249 " --\n", device_only ?
"Devices:" :
"File formats:");
1255 const char *long_name =
NULL;
1259 if (!is_dev && device_only)
1261 if ((!name || strcmp(ofmt->
name, name) < 0) &&
1262 strcmp(ofmt->
name, last_name) > 0) {
1270 if (!is_dev && device_only)
1272 if ((!name || strcmp(ifmt->
name, name) < 0) &&
1273 strcmp(ifmt->
name, last_name) > 0) {
1278 if (name && strcmp(ifmt->
name, name) == 0)
1285 printf(
" %s%s %-15s %s\n",
1289 long_name ? long_name:
" ");
1304 #define PRINT_CODEC_SUPPORTED(codec, field, type, list_name, term, get_name) \
1305 if (codec->field) { \
1306 const type *p = codec->field; \
1308 printf(" Supported " list_name ":"); \
1309 while (*p != term) { \
1311 printf(" %s", name); \
1321 printf(
"%s %s [%s]:\n", encoder ?
"Encoder" :
"Decoder", c->
name,
1326 printf(
" Threading capabilities: ");
1333 default: printf(
"no");
break;
1341 printf(
" Supported framerates:");
1343 printf(
" %d/%d", fps->
num, fps->
den);
1372 default:
return '?';
1380 if (prev->
id ==
id &&
1392 return (*da)->type != (*db)->type ? (*da)->type - (*db)->type :
1393 strcmp((*da)->name, (*db)->name);
1400 unsigned nb_codecs = 0, i = 0;
1404 if (!(codecs =
av_calloc(nb_codecs,
sizeof(*codecs)))) {
1421 printf(
" (%s: ", encoder ?
"encoders" :
"decoders");
1424 printf(
"%s ", codec->
name);
1435 " D..... = Decoding supported\n"
1436 " .E.... = Encoding supported\n"
1437 " ..V... = Video codec\n"
1438 " ..A... = Audio codec\n"
1439 " ..S... = Subtitle codec\n"
1440 " ...I.. = Intra frame-only codec\n"
1441 " ....L. = Lossy compression\n"
1442 " .....S = Lossless compression\n"
1444 for (i = 0; i < nb_codecs; i++) {
1448 if (strstr(desc->
name,
"_deprecated"))
1465 if (strcmp(codec->
name, desc->
name)) {
1472 if (strcmp(codec->
name, desc->
name)) {
1492 " S..... = Subtitle\n"
1493 " .F.... = Frame-level multithreading\n"
1494 " ..S... = Slice-level multithreading\n"
1495 " ...X.. = Codec is experimental\n"
1496 " ....B. = Supports draw_horiz_band\n"
1497 " .....D = Supports direct rendering method 1\n"
1499 encoder ?
"Encoders" :
"Decoders");
1500 for (i = 0; i < nb_codecs; i++) {
1513 if (strcmp(codec->
name, desc->
name))
1514 printf(
" (codec %s)", desc->
name);
1538 printf(
"Bitstream filters:\n");
1540 printf(
"%s\n", bsf->
name);
1547 void *opaque =
NULL;
1550 printf(
"Supported file protocols:\n"
1553 printf(
" %s\n", name);
1554 printf(
"Output:\n");
1556 printf(
" %s\n", name);
1564 char descr[64], *descr_cur;
1569 " T.. = Timeline support\n"
1570 " .S. = Slice threading\n"
1571 " ..C = Command support\n"
1572 " A = Audio input/output\n"
1573 " V = Video input/output\n"
1574 " N = Dynamic number and/or type of input/output\n"
1575 " | = Source or sink filter\n");
1578 for (i = 0; i < 2; i++) {
1580 *(descr_cur++) =
'-';
1581 *(descr_cur++) =
'>';
1584 for (j = 0; pad && pad[j].
name; j++) {
1585 if (descr_cur >= descr +
sizeof(descr) - 4)
1594 printf(
" %c%c%c %-16s %-10s %s\n",
1601 printf(
"No filters available: libavfilter disabled\n");
1612 printf(
"%-32s #RRGGBB\n",
"name");
1615 printf(
"%-32s #%02x%02x%02x\n", name, rgb[0], rgb[1], rgb[2]);
1624 printf(
"Pixel formats:\n"
1625 "I.... = Supported Input format for conversion\n"
1626 ".O... = Supported Output format for conversion\n"
1627 "..H.. = Hardware accelerated format\n"
1628 "...P. = Paletted format\n"
1629 "....B = Bitstream format\n"
1630 "FLAGS NAME NB_COMPONENTS BITS_PER_PIXEL\n"
1634 # define sws_isSupportedInput(x) 0
1635 # define sws_isSupportedOutput(x) 0
1640 printf(
"%c%c%c%c%c %-16s %d %2d\n",
1657 const char *
name, *descr;
1659 printf(
"Individual channels:\n"
1660 "NAME DESCRIPTION\n");
1661 for (i = 0; i < 63; i++) {
1666 printf(
"%-14s %s\n", name, descr);
1668 printf(
"\nStandard channel layouts:\n"
1669 "NAME DECOMPOSITION\n");
1672 printf(
"%-14s ", name);
1673 for (j = 1; j; j <<= 1)
1716 "but no %s for it are available. FFmpeg might need to be "
1717 "recompiled with additional external libraries.\n",
1718 name, encoder ?
"encoders" :
"decoders");
1738 printf(
" Common extensions: %s.\n", fmt->
extensions);
1757 printf(
" Common extensions: %s.\n", fmt->
extensions);
1759 printf(
" Mime type: %s.\n", fmt->
mime_type);
1762 printf(
" Default video codec: %s.\n", desc->
name);
1766 printf(
" Default audio codec: %s.\n", desc->
name);
1770 printf(
" Default subtitle codec: %s.\n", desc->
name);
1778 static void show_help_filter(
const char *
name)
1792 printf(
"Filter %s\n", f->
name);
1797 printf(
" slice threading supported\n");
1799 printf(
" Inputs:\n");
1801 for (i = 0; i <
count; i++) {
1806 printf(
" dynamic (depending on the options)\n");
1808 printf(
" none (source filter)\n");
1810 printf(
" Outputs:\n");
1812 for (i = 0; i <
count; i++) {
1817 printf(
" dynamic (depending on the options)\n");
1819 printf(
" none (sink filter)\n");
1825 printf(
"This filter has support for timeline through the 'enable' option.\n");
1828 "can not to satisfy request\n");
1841 par = strchr(topic,
'=');
1847 }
else if (!strcmp(topic,
"decoder")) {
1849 }
else if (!strcmp(topic,
"encoder")) {
1851 }
else if (!strcmp(topic,
"demuxer")) {
1853 }
else if (!strcmp(topic,
"muxer")) {
1856 }
else if (!strcmp(topic,
"filter")) {
1857 show_help_filter(par);
1872 while (c !=
'\n' && c != EOF)
1890 ret = fseek(f, 0, SEEK_END);
1903 ret = fseek(f, 0, SEEK_SET);
1915 ret = fread(*bufptr, 1, *size, f);
1921 filename, strerror(errno));
1926 (*bufptr)[(*size)++] =
'\0';
1937 const char *preset_name,
int is_path,
1938 const char *codec_name)
1942 const char *base[3] = { getenv(
"FFMPEG_DATADIR"),
1947 av_strlcpy(filename, preset_name, filename_size);
1948 f = fopen(filename,
"r");
1951 char datadir[MAX_PATH], *ls;
1954 if (GetModuleFileNameA(GetModuleHandleA(
NULL), datadir,
sizeof(datadir) - 1))
1956 for (ls = datadir; ls < datadir + strlen(datadir); ls++)
1957 if (*ls ==
'\\') *ls =
'/';
1959 if (ls = strrchr(datadir,
'/'))
1962 strncat(datadir,
"/ffpresets",
sizeof(datadir) - 1 - strlen(datadir));
1967 for (i = 0; i < 3 && !f; i++) {
1970 snprintf(filename, filename_size,
"%s%s/%s.ffpreset", base[i],
1971 i != 1 ?
"" :
"/.ffmpeg", preset_name);
1972 f = fopen(filename,
"r");
1973 if (!f && codec_name) {
1975 "%s%s/%s-%s.ffpreset",
1976 base[i], i != 1 ?
"" :
"/.ffmpeg", codec_name,
1978 f = fopen(filename,
"r");
2024 char *p = strchr(t->
key,
':');
2029 case 1: *p = 0;
break;
2040 else if (t->
key[0] == prefix &&
2062 "Could not alloc memory for stream options.\n");
2073 if (new_size >= INT_MAX / elem_size) {
2077 if (*size < new_size) {
2083 memset(tmp + *size*elem_size, 0, (new_size-*size) * elem_size);
2097 if (rotate_tag && *rotate_tag->
value && strcmp(rotate_tag->
value,
"0")) {
2103 if (displaymatrix && !theta)
2106 theta -= 360*floor(theta/360 + 0.9/360);
2108 if (fabs(theta - 90*
round(theta/90)) > 2)
2123 printf(
"Audo-detected sources for %s:\n", fmt->
name);
2126 printf(
"Cannot list sources. Not implemented.\n");
2131 printf(
"Cannot list sources.\n");
2135 for (i = 0; i < device_list->
nb_devices; i++) {
2136 printf(
"%s %s [%s]\n", device_list->
default_device == i ?
"*" :
" ",
2153 printf(
"Audo-detected sinks for %s:\n", fmt->
name);
2156 printf(
"Cannot list sinks. Not implemented.\n");
2161 printf(
"Cannot list sinks.\n");
2165 for (i = 0; i < device_list->
nb_devices; i++) {
2166 printf(
"%s %s [%s]\n", device_list->
default_device == i ?
"*" :
" ",
2175 static int show_sinks_sources_parse_arg(
const char *
arg,
char **dev,
AVDictionary **opts)
2179 char *opts_str =
NULL;
2184 if ((opts_str = strchr(*dev,
','))) {
2185 *(opts_str++) =
'\0';
2192 printf(
"\nDevice name is not provided.\n"
2193 "You can pass devicename[,opt1=val1[,opt2=val2...]] as an argument.\n\n");
2197 int show_sources(
void *optctx,
const char *opt,
const char *arg)
2207 if ((ret = show_sinks_sources_parse_arg(arg, &dev, &opts)) < 0)
2213 if (!strcmp(fmt->
name,
"lavfi"))
2217 print_device_sources(fmt, opts);
2225 print_device_sources(fmt, opts);
2235 int show_sinks(
void *optctx,
const char *opt,
const char *arg)
2245 if ((ret = show_sinks_sources_parse_arg(arg, &dev, &opts)) < 0)
2253 print_device_sinks(fmt, opts);
2261 print_device_sinks(fmt, opts);
AVOutputFormat * av_output_audio_device_next(AVOutputFormat *d)
Audio output devices iterator.
#define AV_PIX_FMT_FLAG_PAL
Pixel format has a palette in data[1], values are indexes in this palette.
int parse_optgroup(void *optctx, OptionGroup *g)
Parse an options group and write results into optctx.
#define AV_CODEC_PROP_INTRA_ONLY
Codec uses only intra compression.
const char const char void * val
AVDictionary * resample_opts
Number of sample formats. DO NOT USE if linking dynamically.
static enum AVPixelFormat pix_fmt
void av_bprintf(AVBPrint *buf, const char *fmt,...)
int show_decoders(void *optctx, const char *opt, const char *arg)
Print a listing containing all the decoders supported by the program.
AVCodec * avcodec_find_encoder(enum AVCodecID id)
Find a registered encoder with a matching codec ID.
const char * name
< group name
static void finish_group(OptionParseContext *octx, int group_idx, const char *arg)
int show_license(void *optctx, const char *opt, const char *arg)
Print the license of the program to stdout.
#define AV_CODEC_PROP_LOSSY
Codec supports lossy compression.
#define AV_OPT_FLAG_SUBTITLE_PARAM
double get_rotation(AVStream *st)
char * device_description
human friendly name
int(* func_arg)(void *, const char *, const char *)
#define AV_LOG_WARNING
Something somehow does not look correct.
char * av_get_sample_fmt_string(char *buf, int buf_size, enum AVSampleFormat sample_fmt)
Generate a string corresponding to the sample format with sample_fmt, or a header if sample_fmt is ne...
Main libavfilter public API header.
int av_parse_time(int64_t *timeval, const char *timestr, int duration)
Parse timestr and return in *time a corresponding number of microseconds.
void av_log_set_level(int level)
Set the log level.
int split_commandline(OptionParseContext *octx, int argc, char *argv[], const OptionDef *options, const OptionGroupDef *groups, int nb_groups)
Split the commandline into an intermediate form convenient for further processing.
int av_get_bits_per_pixel(const AVPixFmtDescriptor *pixdesc)
Return the number of bits per pixel used by the pixel format described by pixdesc.
const AVClass * av_opt_child_class_next(const AVClass *parent, const AVClass *prev)
Iterate over potential AVOptions-enabled children of parent.
int opt_loglevel(void *optctx, const char *opt, const char *arg)
Set the libav* libraries log level.
int check_stream_specifier(AVFormatContext *s, AVStream *st, const char *spec)
Check if the given stream matches a stream specifier.
FILE * av_fopen_utf8(const char *path, const char *mode)
Open a file using a UTF-8 filename.
#define AVFILTER_FLAG_DYNAMIC_INPUTS
The number of the filter inputs is not determined just by AVFilter.inputs.
enum AVMediaType avfilter_pad_get_type(const AVFilterPad *pads, int pad_idx)
Get the type of an AVFilterPad.
char * device_name
device name, format depends on device
#define AV_OPT_FLAG_AUDIO_PARAM
void show_banner(int argc, char **argv, const OptionDef *options)
Print the program banner to stderr.
static int is_device(const AVClass *avclass)
int show_protocols(void *optctx, const char *opt, const char *arg)
Print a listing containing all the protocols supported by the program.
uint8_t * av_stream_get_side_data(AVStream *stream, enum AVPacketSideDataType type, int *size)
Get side information from stream.
const char * sep
Option to be used as group separator.
#define GET_CH_LAYOUT_DESC(ch_layout)
static const AVOption * opt_find(void *obj, const char *name, const char *unit, int opt_flags, int search_flags)
#define FF_ARRAY_ELEMS(a)
int show_devices(void *optctx, const char *opt, const char *arg)
Print a listing containing all the devices supported by the program.
int show_formats(void *optctx, const char *opt, const char *arg)
Print a listing containing all the formats supported by the program (including devices).
const AVClass * sws_get_class(void)
Get the AVClass for swsContext.
static void check_options(const OptionDef *po)
void av_max_alloc(size_t max)
Set the maximum size that may me allocated in one block.
int show_pix_fmts(void *optctx, const char *opt, const char *arg)
Print a listing containing all the pixel formats supported by the program.
AVDictionary * filter_codec_opts(AVDictionary *opts, enum AVCodecID codec_id, AVFormatContext *s, AVStream *st, AVCodec *codec)
Filter out options for given codec.
int av_bprint_finalize(AVBPrint *buf, char **ret_str)
Finalize a print buffer.
void uninit_parse_context(OptionParseContext *octx)
Free all allocated memory in an OptionParseContext.
int av_codec_is_decoder(const AVCodec *codec)
int av_get_standard_channel_layout(unsigned index, uint64_t *layout, const char **name)
Get the value and name of a standard channel layout.
const AVCodecDescriptor * avcodec_descriptor_next(const AVCodecDescriptor *prev)
Iterate over all codec descriptors known to libavcodec.
const AVClass * avresample_get_class(void)
Get the AVClass for AVAudioResampleContext.
const AVClass * avcodec_get_class(void)
Get the AVClass for AVCodecContext.
int av_codec_is_encoder(const AVCodec *codec)
const char * name
Pad name.
#define AV_LOG_QUIET
Print no output.
#define av_assert0(cond)
assert() equivalent, that is always enabled.
int show_codecs(void *optctx, const char *opt, const char *arg)
Print a listing containing all the codecs supported by the program.
static double cb(void *priv, double x, double y)
static void dump_argument(const char *a)
void register_exit(void(*cb)(int ret))
Register a program-specific cleanup routine.
void log_callback_help(void *ptr, int level, const char *fmt, va_list vl)
Trivial log callback.
av_cold struct SwrContext * swr_alloc(void)
Allocate SwrContext.
Opaque data information usually continuous.
int opt_default(void *optctx, const char *opt, const char *arg)
Fallback for options that are not explicitly handled, these will be parsed through AVOptions...
#define AV_LOG_PANIC
Something went really wrong and we will crash now.
#define va_copy(dst, src)
#define AV_LOG_TRACE
Extremely verbose debugging, useful for libav* development.
static const OptionGroupDef groups[]
static unsigned get_codecs_sorted(const AVCodecDescriptor ***rcodecs)
AVS_FilterInfo AVS_Value child
#define AV_CODEC_PROP_LOSSLESS
Codec supports lossless compression.
int opt_max_alloc(void *optctx, const char *opt, const char *arg)
#define media_type_string
This side data contains a 3x3 transformation matrix describing an affine transformation that needs to...
int avformat_match_stream_specifier(AVFormatContext *s, AVStream *st, const char *spec)
Check if the stream st contained in s is matched by the stream specifier spec.
static void init_parse_context(OptionParseContext *octx, const OptionGroupDef *groups, int nb_groups)
#define AV_IS_INPUT_DEVICE(category)
int show_buildconf(void *optctx, const char *opt, const char *arg)
Print the build configuration of the program to stdout.
void init_opts(void)
Initialize the cmdutils option system, in particular allocate the *_opts contexts.
AVStream ** streams
A list of all streams in the file.
int flags
A combination of AVFILTER_FLAG_*.
#define CODEC_CAP_DR1
Codec uses get_buffer() for allocating buffers and supports custom allocators.
AVDictionaryEntry * av_dict_get(const AVDictionary *m, const char *key, const AVDictionaryEntry *prev, int flags)
Get a dictionary entry with matching key.
void parse_options(void *optctx, int argc, char **argv, const OptionDef *options, void(*parse_arg_function)(void *, const char *))
struct SwsContext * sws_getContext(int srcW, int srcH, enum AVPixelFormat srcFormat, int dstW, int dstH, enum AVPixelFormat dstFormat, int flags, SwsFilter *srcFilter, SwsFilter *dstFilter, const double *param)
Allocate and return an SwsContext.
const AVFilter * avfilter_next(const AVFilter *prev)
Iterate over all registered filters.
static void print_all_libs_info(int flags, int level)
#define AVERROR_EOF
End of file.
AVInputFormat * av_input_video_device_next(AVInputFormat *d)
Video input devices iterator.
#define AV_LOG_VERBOSE
Detailed information.
const AVClass * avformat_get_class(void)
Get the AVClass for AVFormatContext.
void parse_loglevel(int argc, char **argv, const OptionDef *options)
Find the '-loglevel' option in the command line args and apply it.
#define AVFILTER_FLAG_DYNAMIC_OUTPUTS
The number of the filter outputs is not determined just by AVFilter.outputs.
void show_help_options(const OptionDef *options, const char *msg, int req_flags, int rej_flags, int alt_flags)
Print help for all options matching specified flags.
int(* process_command)(AVFilterContext *, const char *cmd, const char *arg, char *res, int res_len, int flags)
Make the filter instance process a command.
const OptionDef options[]
static void print_codecs(int encoder)
int locate_option(int argc, char **argv, const OptionDef *options, const char *optname)
Return index of option opt in argv or 0 if not found.
#define AV_OPT_FLAG_ENCODING_PARAM
a generic parameter which can be set by the user for muxing or encoding
struct AVOutputFormat * oformat
The output container format.
AVDictionary ** setup_find_stream_info_opts(AVFormatContext *s, AVDictionary *codec_opts)
Setup AVCodecContext options for avformat_find_stream_info().
AVCodec * avcodec_find_encoder_by_name(const char *name)
Find a registered encoder with the specified name.
AVDictionary * format_opts
int show_help(void *optctx, const char *opt, const char *arg)
Generic -h handler common to all fftools.
A filter pad used for either input or output.
static void * av_x_if_null(const void *p, const void *x)
Return x default pointer in case p is NULL.
Main libavdevice API header.
int flags
Option flags that must be set on each option that is applied to this group.
void avdevice_free_list_devices(AVDeviceInfoList **device_list)
Convenient function to free result of avdevice_list_devices().
libswresample public header
AVCodecID
Identify the syntax and semantics of the bitstream.
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
void av_log_format_line(void *ptr, int level, const char *fmt, va_list vl, char *line, int line_size, int *print_prefix)
Format a line of log the same way as the default callback.
#define AV_OPT_FLAG_FILTERING_PARAM
a generic parameter which can be set by the user for filtering
int show_sample_fmts(void *optctx, const char *opt, const char *arg)
Print a listing containing all the sample formats supported by the program.
#define sws_isSupportedOutput(x)
AVCodec * av_codec_next(const AVCodec *c)
If c is NULL, returns the first registered codec, if c is non-NULL, returns the next registered codec...
The libswresample context.
void av_bprint_init(AVBPrint *buf, unsigned size_init, unsigned size_max)
int capabilities
Codec capabilities.
#define AVFILTER_FLAG_SLICE_THREADS
The filter supports multithreading by splitting frames into multiple parts and processing them concur...
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
void av_dict_free(AVDictionary **pm)
Free all the memory allocated for an AVDictionary struct and all keys and values. ...
static int show_formats_devices(void *optctx, const char *opt, const char *arg, int device_only)
static void show_help_muxer(const char *name)
int parse_option(void *optctx, const char *opt, const char *arg, const OptionDef *options)
Parse one given option.
#define AV_LOG_SKIP_REPEATED
Skip repeated messages, this requires the user app to use av_log() instead of (f)printf as the 2 woul...
#define AV_PIX_FMT_FLAG_HWACCEL
Pixel format is an HW accelerated format.
simple assert() macros that are a bit more flexible than ISO C assert().
#define PRINT_CODEC_SUPPORTED(codec, field, type, list_name, term, get_name)
int av_log_get_level(void)
Get the current log level.
const char * name
Name of the codec implementation.
int av_match_name(const char *name, const char *names)
Match instances of a name in a comma-separated list of names.
static av_always_inline av_const double round(double x)
AVClassCategory category
Category used for visualization (like color) This is only set if the category is equal for all object...
int avdevice_list_input_sources(AVInputFormat *device, const char *device_name, AVDictionary *device_options, AVDeviceInfoList **device_list)
List devices.
const char * long_name
A more descriptive name for this codec.
AVDeviceInfo ** devices
list of autodetected devices
static const uint8_t offset[127][2]
int show_filters(void *optctx, const char *opt, const char *arg)
Print a listing containing all the filters supported by the program.
size_t av_strlcpy(char *dst, const char *src, size_t size)
Copy the string src to dst, but no more than size - 1 bytes, and null-terminate dst.
void av_log_default_callback(void *ptr, int level, const char *fmt, va_list vl)
Default logging callback.
int av_parse_cpu_caps(unsigned *flags, const char *s)
Parse CPU caps from a string and update the given AV_CPU_* flags based on that.
const AVCodecDescriptor * avcodec_descriptor_get(enum AVCodecID id)
static const OptionDef * find_option(const OptionDef *po, const char *name)
AVCodecContext * codec
Codec context associated with this stream.
const char * av_get_known_color_name(int color_idx, const uint8_t **rgbp)
Get the name of a color from the internal table of hard-coded named colors.
int opt_report(const char *opt)
int props
Codec properties, a combination of AV_CODEC_PROP_* flags.
const AVFilter * avfilter_get_by_name(const char *name)
Get a filter definition matching the given name.
const int program_birth_year
program birth year, defined by the program for show_banner()
const AVOption * av_opt_find(void *obj, const char *name, const char *unit, int opt_flags, int search_flags)
Look for an option in an object.
#define AV_IS_OUTPUT_DEVICE(category)
AVBitStreamFilter * av_bitstream_filter_next(const AVBitStreamFilter *f)
If f is NULL, return the first registered bitstream filter, if f is non-NULL, return the next registe...
unsigned int nb_streams
Number of elements in AVFormatContext.streams.
enum AVPixelFormat av_pix_fmt_desc_get_id(const AVPixFmtDescriptor *desc)
AVInputFormat * av_find_input_format(const char *short_name)
Find AVInputFormat based on the short name of the input format.
static const uint16_t fc[]
uint8_t nb_components
The number of components each pixel has, (1-4)
int show_colors(void *optctx, const char *opt, const char *arg)
Print a listing containing all the color names and values recognized by the program.
static void log_callback_report(void *ptr, int level, const char *fmt, va_list vl)
#define CODEC_CAP_DRAW_HORIZ_BAND
Decoder can use draw_horiz_band callback.
void av_log_set_callback(void(*callback)(void *, int, const char *, va_list))
Set the logging callback.
#define AV_OPT_SEARCH_CHILDREN
Search in possible children of the given object first.
int show_bsfs(void *optctx, const char *opt, const char *arg)
Print a listing containing all the bit stream filters supported by the program.
typedef void(APIENTRY *FF_PFNGLACTIVETEXTUREPROC)(GLenum texture)
int avdevice_list_output_sinks(AVOutputFormat *device, const char *device_name, AVDictionary *device_options, AVDeviceInfoList **device_list)
static void print_codecs_for_id(enum AVCodecID id, int encoder)
static int init_report(const char *env)
const char * avio_enum_protocols(void **opaque, int output)
Iterate through names of available protocols.
#define GET_PIX_FMT_NAME(pix_fmt)
#define av_err2str(errnum)
Convenience macro, the return value should be used only directly in function arguments but never stan...
const OptionGroupDef * group_def
A list of option groups that all have the same group type (e.g.
void sws_freeContext(struct SwsContext *swsContext)
Free the swscaler context swsContext.
void show_help_default(const char *opt, const char *arg)
Per-fftool specific help handler.
AVDictionary * resample_opts
static int av_bprint_is_complete(const AVBPrint *buf)
Test if the print buffer is complete (not truncated).
AVOutputFormat * av_guess_format(const char *short_name, const char *filename, const char *mime_type)
Return the output format in the list of registered output formats which best matches the provided par...
#define sws_isSupportedInput(x)
Opaque data information usually sparse.
const AVClass * swr_get_class(void)
Get the AVClass for SwrContext.
int opt_timelimit(void *optctx, const char *opt, const char *arg)
Limit the execution time.
AVOutputFormat * av_output_video_device_next(AVOutputFormat *d)
Video output devices iterator.
AVOutputFormat * av_oformat_next(const AVOutputFormat *f)
If f is NULL, returns the first registered output format, if f is non-NULL, returns the next register...
const AVCodecDescriptor * avcodec_descriptor_get_by_name(const char *name)
#define GET_SAMPLE_FMT_NAME(sample_fmt)
void exit_program(int ret)
Wraps exit with a program-specific cleanup routine.
const AVFilterPad * inputs
List of inputs, terminated by a zeroed element.
static char get_media_type_char(enum AVMediaType type)
double av_strtod(const char *numstr, char **tail)
Parse the string in numstr and return its value as a double.
int av_dict_parse_string(AVDictionary **pm, const char *str, const char *key_val_sep, const char *pairs_sep, int flags)
Parse the key/value pairs list and add the parsed entries to a dictionary.
#define GET_SAMPLE_RATE_NAME(rate)
const char * long_name
Descriptive name for the codec, meant to be more human readable than name.
const AVClass * priv_class
A class for the private data, used to declare filter private AVOptions.
#define AV_LOG_INFO
Standard information.
static const AVCodec * next_codec_for_id(enum AVCodecID id, const AVCodec *prev, int encoder)
attribute_deprecated void av_log_ask_for_sample(void *avc, const char *msg,...) av_printf_format(2
Log a generic warning message asking for a sample.
enum AVMediaType codec_type
const AVRational * supported_framerates
array of supported framerates, or NULL if any, array is terminated by {0,0}
AVSampleFormat
Audio sample formats.
char * av_strdup(const char *s)
Duplicate the string s.
int av_opt_show2(void *obj, void *av_log_obj, int req_flags, int rej_flags)
Show the obj options.
Descriptor that unambiguously describes how the bits of a pixel are stored in the up to 4 data planes...
#define AV_OPT_FLAG_VIDEO_PARAM
AVCodec * avcodec_find_decoder(enum AVCodecID id)
Find a registered decoder with a matching codec ID.
int av_log_get_flags(void)
av_cold void swr_free(SwrContext **ss)
Free the given SwrContext and set the pointer to NULL.
int av_dict_set(AVDictionary **pm, const char *key, const char *value, int flags)
Set the given entry in *pm, overwriting an existing entry.
Replacements for frequently missing libm functions.
FILE * get_preset_file(char *filename, size_t filename_size, const char *preset_name, int is_path, const char *codec_name)
Get a file corresponding to a preset file.
const OptionGroupDef * group_def
#define PRINT_LIB_INFO(libname, LIBNAME, flags, level)
Describe the class of an AVClass context structure.
static av_const int av_toupper(int c)
Locale-independent conversion of ASCII characters to uppercase.
rational number numerator/denominator
static void expand_filename_template(AVBPrint *bp, const char *template, struct tm *tm)
#define AV_OPT_FLAG_DECODING_PARAM
a generic parameter which can be set by the user for demuxing or decoding
int64_t parse_time_or_die(const char *context, const char *timestr, int is_duration)
Parse a string specifying a time and return its corresponding value as a number of microseconds...
void * grow_array(void *array, int elem_size, int *size, int new_size)
Realloc array to hold new_size elements of elem_size.
struct SwsContext * sws_opts
const char * name
Filter name.
const char * name
Name of the codec described by this descriptor.
const char * avfilter_pad_get_name(const AVFilterPad *pads, int pad_idx)
Get the name of an AVFilterPad.
int av_get_cpu_flags(void)
Return the flags which specify extensions supported by the CPU.
static void print_codec(const AVCodec *c)
int default_device
index of default device or -1 if no default
#define AV_PIX_FMT_FLAG_BITSTREAM
All values of a component are bit-wise packed end to end.
size_t av_strlcat(char *dst, const char *src, size_t size)
Append the string src to the string dst, but to a total length of no more than size - 1 bytes...
This struct describes the properties of a single codec described by an AVCodecID. ...
double parse_number_or_die(const char *context, const char *numstr, int type, double min, double max)
Parse a string and return its corresponding value as a double.
void * av_calloc(size_t nmemb, size_t size)
Allocate a block of nmemb * size bytes with alignment suitable for all memory accesses (including vec...
int cmdutils_read_file(const char *filename, char **bufptr, size_t *size)
Read the file with name filename, and put its content in a newly allocated 0-terminated buffer...
AVCodec * avcodec_find_decoder_by_name(const char *name)
Find a registered decoder with the specified name.
const AVClass * priv_class
AVClass for the private context.
static int match_group_separator(const OptionGroupDef *groups, int nb_groups, const char *opt)
static int swscale(SwsContext *c, const uint8_t *src[], int srcStride[], int srcSliceY, int srcSliceH, uint8_t *dst[], int dstStride[])
int av_strerror(int errnum, char *errbuf, size_t errbuf_size)
Put a description of the AVERROR code errnum in errbuf.
static int decode(AVCodecContext *avctx, void *data, int *got_sub, AVPacket *avpkt)
An option extracted from the commandline.
static FILE * report_file
void print_error(const char *filename, int err)
Print an error message to stderr, indicating filename and a human readable description of the error c...
static void filter(MpegAudioContext *s, int ch, const short *samples, int incr)
AVDictionary * codec_opts
#define CODEC_CAP_SLICE_THREADS
Codec supports slice-based (or partition-based) multithreading.
AVDictionary * format_opts
#define CODEC_CAP_FRAME_THREADS
Codec supports frame-level multithreading.
#define AVFILTER_FLAG_SUPPORT_TIMELINE
Handy mask to test whether the filter supports or no the timeline feature (internally or generically)...
static void(* program_exit)(int ret)
#define CODEC_CAP_EXPERIMENTAL
Codec is experimental and is thus avoided in favor of non experimental encoders.
static void print_buildconf(int flags, int level)
AVInputFormat * av_input_audio_device_next(AVInputFormat *d)
Audio input devices iterator.
#define AV_OPT_SEARCH_FAKE_OBJ
The obj passed to av_opt_find() is fake – only a double pointer to AVClass instead of a required poin...
void * av_realloc_array(void *ptr, size_t nmemb, size_t size)
void uninit_opts(void)
Uninitialize the cmdutils option system, in particular free the *_opts contexts and their contents...
double av_display_rotation_get(const int32_t matrix[9])
The display transformation matrix specifies an affine transformation that should be applied to video ...
#define GROW_ARRAY(array, nb_elems)
const char * description
A description of the filter.
const char * av_get_channel_name(uint64_t channel)
Get the name of a given channel.
#define AVERROR_OPTION_NOT_FOUND
Option not found.
static int report_file_level
int av_opt_get_key_value(const char **ropts, const char *key_val_sep, const char *pairs_sep, unsigned flags, char **rkey, char **rval)
Extract a key-value pair from the beginning of a string.
static void prepare_app_arguments(int *argc_ptr, char ***argv_ptr)
static int write_option(void *optctx, const OptionDef *po, const char *opt, const char *arg)
void av_log_set_flags(int arg)
void show_help_children(const AVClass *class, int flags)
Show help for all options with given flags in class and all its children.
int show_layouts(void *optctx, const char *opt, const char *arg)
Print a listing containing all the standard channel layouts supported by the program.
uint8_t pi<< 24) CONV_FUNC_GROUP(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_U8, uint8_t,(*(constuint8_t *) pi-0x80)*(1.0f/(1<< 7))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_U8, uint8_t,(*(constuint8_t *) pi-0x80)*(1.0/(1<< 7))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_S16, int16_t,(*(constint16_t *) pi >>8)+0x80) CONV_FUNC_GROUP(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_S16, int16_t,*(constint16_t *) pi *(1.0f/(1<< 15))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_S16, int16_t,*(constint16_t *) pi *(1.0/(1<< 15))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_S32, int32_t,(*(constint32_t *) pi >>24)+0x80) CONV_FUNC_GROUP(AV_SAMPLE_FMT_FLT, float, AV_SAMPLE_FMT_S32, int32_t,*(constint32_t *) pi *(1.0f/(1U<< 31))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_DBL, double, AV_SAMPLE_FMT_S32, int32_t,*(constint32_t *) pi *(1.0/(1U<< 31))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_FLT, float, av_clip_uint8(lrintf(*(constfloat *) pi *(1<< 7))+0x80)) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S16, int16_t, AV_SAMPLE_FMT_FLT, float, av_clip_int16(lrintf(*(constfloat *) pi *(1<< 15)))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S32, int32_t, AV_SAMPLE_FMT_FLT, float, av_clipl_int32(llrintf(*(constfloat *) pi *(1U<< 31)))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_U8, uint8_t, AV_SAMPLE_FMT_DBL, double, av_clip_uint8(lrint(*(constdouble *) pi *(1<< 7))+0x80)) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S16, int16_t, AV_SAMPLE_FMT_DBL, double, av_clip_int16(lrint(*(constdouble *) pi *(1<< 15)))) CONV_FUNC_GROUP(AV_SAMPLE_FMT_S32, int32_t, AV_SAMPLE_FMT_DBL, double, av_clipl_int32(llrint(*(constdouble *) pi *(1U<< 31))))#defineSET_CONV_FUNC_GROUP(ofmt, ifmt) staticvoidset_generic_function(AudioConvert *ac){}voidff_audio_convert_free(AudioConvert **ac){if(!*ac) return;ff_dither_free(&(*ac) ->dc);av_freep(ac);}AudioConvert *ff_audio_convert_alloc(AVAudioResampleContext *avr, enumAVSampleFormatout_fmt, enumAVSampleFormatin_fmt, intchannels, intsample_rate, intapply_map){AudioConvert *ac;intin_planar, out_planar;ac=av_mallocz(sizeof(*ac));if(!ac) returnNULL;ac->avr=avr;ac->out_fmt=out_fmt;ac->in_fmt=in_fmt;ac->channels=channels;ac->apply_map=apply_map;if(avr->dither_method!=AV_RESAMPLE_DITHER_NONE &&av_get_packed_sample_fmt(out_fmt)==AV_SAMPLE_FMT_S16 &&av_get_bytes_per_sample(in_fmt)>2){ac->dc=ff_dither_alloc(avr, out_fmt, in_fmt, channels, sample_rate, apply_map);if(!ac->dc){av_free(ac);returnNULL;}returnac;}in_planar=ff_sample_fmt_is_planar(in_fmt, channels);out_planar=ff_sample_fmt_is_planar(out_fmt, channels);if(in_planar==out_planar){ac->func_type=CONV_FUNC_TYPE_FLAT;ac->planes=in_planar?ac->channels:1;}elseif(in_planar) ac->func_type=CONV_FUNC_TYPE_INTERLEAVE;elseac->func_type=CONV_FUNC_TYPE_DEINTERLEAVE;set_generic_function(ac);if(ARCH_AARCH64) ff_audio_convert_init_aarch64(ac);if(ARCH_ARM) ff_audio_convert_init_arm(ac);if(ARCH_X86) ff_audio_convert_init_x86(ac);returnac;}intff_audio_convert(AudioConvert *ac, AudioData *out, AudioData *in){intuse_generic=1;intlen=in->nb_samples;intp;if(ac->dc){av_log(ac->avr, AV_LOG_TRACE,"%dsamples-audio_convert:%sto%s(dithered)\n", len, av_get_sample_fmt_name(ac->in_fmt), av_get_sample_fmt_name(ac->out_fmt));returnff_convert_dither(ac-> out
int avfilter_pad_count(const AVFilterPad *pads)
Get the number of elements in a NULL-terminated array of AVFilterPads (e.g.
int opt_cpuflags(void *optctx, const char *opt, const char *arg)
Override the cpuflags.
static void * av_mallocz_array(size_t nmemb, size_t size)
static enum AVSampleFormat sample_fmts[]
AVDictionary * codec_opts
int read_yesno(void)
Return a positive value if a line read from standard input starts with [yY], otherwise return 0...
const AVFilterPad * outputs
List of outputs, terminated by a zeroed element.
#define AV_DICT_IGNORE_SUFFIX
Return first entry in a dictionary whose first part corresponds to the search key, ignoring the suffix of the found key string.
static void show_help_demuxer(const char *name)
const char * av_get_channel_description(uint64_t channel)
Get the description of a given channel.
#define AV_LOG_FATAL
Something went wrong and recovery is not possible.
int show_version(void *optctx, const char *opt, const char *arg)
Print the version of the program to stdout.
void av_force_cpu_flags(int arg)
Disables cpu detection and forces the specified flags.
int nb_devices
number of autodetected devices
struct SwsContext * sws_opts
static void print_program_info(int flags, int level)
AVPixelFormat
Pixel format.
int av_opt_set(void *obj, const char *name, const char *val, int search_flags)
void * av_mallocz(size_t size)
Allocate a block of size bytes with alignment suitable for all memory accesses (including vectors if ...
const char program_name[]
program name, defined by the program for show_version().
AVInputFormat * av_iformat_next(const AVInputFormat *f)
If f is NULL, returns the first registered input format, if f is non-NULL, returns the next registere...
static void show_help_codec(const char *name, int encoder)
static int compare_codec_desc(const void *a, const void *b)
int show_encoders(void *optctx, const char *opt, const char *arg)
Print a listing containing all the encoders supported by the program.
simple arithmetic expression evaluator
const AVPixFmtDescriptor * av_pix_fmt_desc_next(const AVPixFmtDescriptor *prev)
Iterate over all pixel format descriptors known to libavutil.
static void add_opt(OptionParseContext *octx, const OptionDef *opt, const char *key, const char *val)
void av_bprint_chars(AVBPrint *buf, char c, unsigned n)
Append char c n times to a print buffer.