38 #define av_get_random_seed av_get_random_seed_deterministic
39 static uint32_t av_get_random_seed_deterministic(
void);
41 #define av_gettime() 1331972053200000
46 int log_offset,
void *log_ctx)
51 if (sscanf(str,
"%d:%d%c", &q->
num, &q->
den, &c) != 2) {
55 NULL, log_offset, log_ctx);
79 {
"qntsc", 352, 240 },
81 {
"sntsc", 640, 480 },
84 {
"ntsc-film", 352, 240 },
89 {
"16cif", 1408,1152 },
90 {
"qqvga", 160, 120 },
95 {
"uxga", 1600,1200 },
96 {
"qxga", 2048,1536 },
97 {
"sxga", 1280,1024 },
98 {
"qsxga", 2560,2048 },
99 {
"hsxga", 5120,4096 },
100 {
"wvga", 852, 480 },
101 {
"wxga", 1366, 768 },
102 {
"wsxga", 1600,1024 },
103 {
"wuxga", 1920,1200 },
104 {
"woxga", 2560,1600 },
105 {
"wqsxga", 3200,2048 },
106 {
"wquxga", 3840,2400 },
107 {
"whsxga", 6400,4096 },
108 {
"whuxga", 7680,4800 },
111 {
"hd480", 852, 480 },
112 {
"hd720", 1280, 720 },
113 {
"hd1080", 1920,1080 },
115 {
"2kdci", 2048,1080 },
116 {
"2kflat", 1998,1080 },
117 {
"2kscope", 2048, 858 },
119 {
"4kdci", 4096,2160 },
120 {
"4kflat", 3996,2160 },
121 {
"4kscope", 4096,1716 },
123 {
"hqvga", 240,160 },
124 {
"wqvga", 400,240 },
125 {
"fwqvga", 432,240 },
128 {
"uhd2160", 3840,2160 },
129 {
"uhd4320", 7680,4320 },
133 {
"ntsc", { 30000, 1001 } },
134 {
"pal", { 25, 1 } },
135 {
"qntsc", { 30000, 1001 } },
136 {
"qpal", { 25, 1 } },
137 {
"sntsc", { 30000, 1001 } },
138 {
"spal", { 25, 1 } },
139 {
"film", { 24, 1 } },
140 {
"ntsc-film", { 24000, 1001 } },
150 for (i = 0; i <
n; i++) {
151 if (!strcmp(video_size_abbrs[i].abbr, str)) {
152 width = video_size_abbrs[i].
width;
158 width = strtol(str, (
void*)&p, 10);
161 height = strtol(p, (
void*)&p, 10);
167 if (width <= 0 ||
height <= 0)
180 for (i = 0; i <
n; ++i)
181 if (!strcmp(video_rate_abbrs[i].abbr, arg)) {
182 *rate = video_rate_abbrs[i].
rate;
189 if (rate->
num <= 0 || rate->
den <= 0)
200 {
"AliceBlue", { 0xF0, 0xF8, 0xFF } },
201 {
"AntiqueWhite", { 0xFA, 0xEB, 0xD7 } },
202 {
"Aqua", { 0x00, 0xFF, 0xFF } },
203 {
"Aquamarine", { 0x7F, 0xFF, 0xD4 } },
204 {
"Azure", { 0xF0, 0xFF, 0xFF } },
205 {
"Beige", { 0xF5, 0xF5, 0xDC } },
206 {
"Bisque", { 0xFF, 0xE4, 0xC4 } },
207 {
"Black", { 0x00, 0x00, 0x00 } },
208 {
"BlanchedAlmond", { 0xFF, 0xEB, 0xCD } },
209 {
"Blue", { 0x00, 0x00, 0xFF } },
210 {
"BlueViolet", { 0x8A, 0x2B, 0xE2 } },
211 {
"Brown", { 0xA5, 0x2A, 0x2A } },
212 {
"BurlyWood", { 0xDE, 0xB8, 0x87 } },
213 {
"CadetBlue", { 0x5F, 0x9E, 0xA0 } },
214 {
"Chartreuse", { 0x7F, 0xFF, 0x00 } },
215 {
"Chocolate", { 0xD2, 0x69, 0x1E } },
216 {
"Coral", { 0xFF, 0x7F, 0x50 } },
217 {
"CornflowerBlue", { 0x64, 0x95, 0xED } },
218 {
"Cornsilk", { 0xFF, 0xF8, 0xDC } },
219 {
"Crimson", { 0xDC, 0x14, 0x3C } },
220 {
"Cyan", { 0x00, 0xFF, 0xFF } },
221 {
"DarkBlue", { 0x00, 0x00, 0x8B } },
222 {
"DarkCyan", { 0x00, 0x8B, 0x8B } },
223 {
"DarkGoldenRod", { 0xB8, 0x86, 0x0B } },
224 {
"DarkGray", { 0xA9, 0xA9, 0xA9 } },
225 {
"DarkGreen", { 0x00, 0x64, 0x00 } },
226 {
"DarkKhaki", { 0xBD, 0xB7, 0x6B } },
227 {
"DarkMagenta", { 0x8B, 0x00, 0x8B } },
228 {
"DarkOliveGreen", { 0x55, 0x6B, 0x2F } },
229 {
"Darkorange", { 0xFF, 0x8C, 0x00 } },
230 {
"DarkOrchid", { 0x99, 0x32, 0xCC } },
231 {
"DarkRed", { 0x8B, 0x00, 0x00 } },
232 {
"DarkSalmon", { 0xE9, 0x96, 0x7A } },
233 {
"DarkSeaGreen", { 0x8F, 0xBC, 0x8F } },
234 {
"DarkSlateBlue", { 0x48, 0x3D, 0x8B } },
235 {
"DarkSlateGray", { 0x2F, 0x4F, 0x4F } },
236 {
"DarkTurquoise", { 0x00, 0xCE, 0xD1 } },
237 {
"DarkViolet", { 0x94, 0x00, 0xD3 } },
238 {
"DeepPink", { 0xFF, 0x14, 0x93 } },
239 {
"DeepSkyBlue", { 0x00, 0xBF, 0xFF } },
240 {
"DimGray", { 0x69, 0x69, 0x69 } },
241 {
"DodgerBlue", { 0x1E, 0x90, 0xFF } },
242 {
"FireBrick", { 0xB2, 0x22, 0x22 } },
243 {
"FloralWhite", { 0xFF, 0xFA, 0xF0 } },
244 {
"ForestGreen", { 0x22, 0x8B, 0x22 } },
245 {
"Fuchsia", { 0xFF, 0x00, 0xFF } },
246 {
"Gainsboro", { 0xDC, 0xDC, 0xDC } },
247 {
"GhostWhite", { 0xF8, 0xF8, 0xFF } },
248 {
"Gold", { 0xFF, 0xD7, 0x00 } },
249 {
"GoldenRod", { 0xDA, 0xA5, 0x20 } },
250 {
"Gray", { 0x80, 0x80, 0x80 } },
251 {
"Green", { 0x00, 0x80, 0x00 } },
252 {
"GreenYellow", { 0xAD, 0xFF, 0x2F } },
253 {
"HoneyDew", { 0xF0, 0xFF, 0xF0 } },
254 {
"HotPink", { 0xFF, 0x69, 0xB4 } },
255 {
"IndianRed", { 0xCD, 0x5C, 0x5C } },
256 {
"Indigo", { 0x4B, 0x00, 0x82 } },
257 {
"Ivory", { 0xFF, 0xFF, 0xF0 } },
258 {
"Khaki", { 0xF0, 0xE6, 0x8C } },
259 {
"Lavender", { 0xE6, 0xE6, 0xFA } },
260 {
"LavenderBlush", { 0xFF, 0xF0, 0xF5 } },
261 {
"LawnGreen", { 0x7C, 0xFC, 0x00 } },
262 {
"LemonChiffon", { 0xFF, 0xFA, 0xCD } },
263 {
"LightBlue", { 0xAD, 0xD8, 0xE6 } },
264 {
"LightCoral", { 0xF0, 0x80, 0x80 } },
265 {
"LightCyan", { 0xE0, 0xFF, 0xFF } },
266 {
"LightGoldenRodYellow", { 0xFA, 0xFA, 0xD2 } },
267 {
"LightGreen", { 0x90, 0xEE, 0x90 } },
268 {
"LightGrey", { 0xD3, 0xD3, 0xD3 } },
269 {
"LightPink", { 0xFF, 0xB6, 0xC1 } },
270 {
"LightSalmon", { 0xFF, 0xA0, 0x7A } },
271 {
"LightSeaGreen", { 0x20, 0xB2, 0xAA } },
272 {
"LightSkyBlue", { 0x87, 0xCE, 0xFA } },
273 {
"LightSlateGray", { 0x77, 0x88, 0x99 } },
274 {
"LightSteelBlue", { 0xB0, 0xC4, 0xDE } },
275 {
"LightYellow", { 0xFF, 0xFF, 0xE0 } },
276 {
"Lime", { 0x00, 0xFF, 0x00 } },
277 {
"LimeGreen", { 0x32, 0xCD, 0x32 } },
278 {
"Linen", { 0xFA, 0xF0, 0xE6 } },
279 {
"Magenta", { 0xFF, 0x00, 0xFF } },
280 {
"Maroon", { 0x80, 0x00, 0x00 } },
281 {
"MediumAquaMarine", { 0x66, 0xCD, 0xAA } },
282 {
"MediumBlue", { 0x00, 0x00, 0xCD } },
283 {
"MediumOrchid", { 0xBA, 0x55, 0xD3 } },
284 {
"MediumPurple", { 0x93, 0x70, 0xD8 } },
285 {
"MediumSeaGreen", { 0x3C, 0xB3, 0x71 } },
286 {
"MediumSlateBlue", { 0x7B, 0x68, 0xEE } },
287 {
"MediumSpringGreen", { 0x00, 0xFA, 0x9A } },
288 {
"MediumTurquoise", { 0x48, 0xD1, 0xCC } },
289 {
"MediumVioletRed", { 0xC7, 0x15, 0x85 } },
290 {
"MidnightBlue", { 0x19, 0x19, 0x70 } },
291 {
"MintCream", { 0xF5, 0xFF, 0xFA } },
292 {
"MistyRose", { 0xFF, 0xE4, 0xE1 } },
293 {
"Moccasin", { 0xFF, 0xE4, 0xB5 } },
294 {
"NavajoWhite", { 0xFF, 0xDE, 0xAD } },
295 {
"Navy", { 0x00, 0x00, 0x80 } },
296 {
"OldLace", { 0xFD, 0xF5, 0xE6 } },
297 {
"Olive", { 0x80, 0x80, 0x00 } },
298 {
"OliveDrab", { 0x6B, 0x8E, 0x23 } },
299 {
"Orange", { 0xFF, 0xA5, 0x00 } },
300 {
"OrangeRed", { 0xFF, 0x45, 0x00 } },
301 {
"Orchid", { 0xDA, 0x70, 0xD6 } },
302 {
"PaleGoldenRod", { 0xEE, 0xE8, 0xAA } },
303 {
"PaleGreen", { 0x98, 0xFB, 0x98 } },
304 {
"PaleTurquoise", { 0xAF, 0xEE, 0xEE } },
305 {
"PaleVioletRed", { 0xD8, 0x70, 0x93 } },
306 {
"PapayaWhip", { 0xFF, 0xEF, 0xD5 } },
307 {
"PeachPuff", { 0xFF, 0xDA, 0xB9 } },
308 {
"Peru", { 0xCD, 0x85, 0x3F } },
309 {
"Pink", { 0xFF, 0xC0, 0xCB } },
310 {
"Plum", { 0xDD, 0xA0, 0xDD } },
311 {
"PowderBlue", { 0xB0, 0xE0, 0xE6 } },
312 {
"Purple", { 0x80, 0x00, 0x80 } },
313 {
"Red", { 0xFF, 0x00, 0x00 } },
314 {
"RosyBrown", { 0xBC, 0x8F, 0x8F } },
315 {
"RoyalBlue", { 0x41, 0x69, 0xE1 } },
316 {
"SaddleBrown", { 0x8B, 0x45, 0x13 } },
317 {
"Salmon", { 0xFA, 0x80, 0x72 } },
318 {
"SandyBrown", { 0xF4, 0xA4, 0x60 } },
319 {
"SeaGreen", { 0x2E, 0x8B, 0x57 } },
320 {
"SeaShell", { 0xFF, 0xF5, 0xEE } },
321 {
"Sienna", { 0xA0, 0x52, 0x2D } },
322 {
"Silver", { 0xC0, 0xC0, 0xC0 } },
323 {
"SkyBlue", { 0x87, 0xCE, 0xEB } },
324 {
"SlateBlue", { 0x6A, 0x5A, 0xCD } },
325 {
"SlateGray", { 0x70, 0x80, 0x90 } },
326 {
"Snow", { 0xFF, 0xFA, 0xFA } },
327 {
"SpringGreen", { 0x00, 0xFF, 0x7F } },
328 {
"SteelBlue", { 0x46, 0x82, 0xB4 } },
329 {
"Tan", { 0xD2, 0xB4, 0x8C } },
330 {
"Teal", { 0x00, 0x80, 0x80 } },
331 {
"Thistle", { 0xD8, 0xBF, 0xD8 } },
332 {
"Tomato", { 0xFF, 0x63, 0x47 } },
333 {
"Turquoise", { 0x40, 0xE0, 0xD0 } },
334 {
"Violet", { 0xEE, 0x82, 0xEE } },
335 {
"Wheat", { 0xF5, 0xDE, 0xB3 } },
336 {
"White", { 0xFF, 0xFF, 0xFF } },
337 {
"WhiteSmoke", { 0xF5, 0xF5, 0xF5 } },
338 {
"Yellow", { 0xFF, 0xFF, 0x00 } },
339 {
"YellowGreen", { 0x9A, 0xCD, 0x32 } },
347 #define ALPHA_SEP '@'
352 char *tail, color_string2[128];
354 int len, hex_offset = 0;
356 if (color_string[0] ==
'#') {
358 }
else if (!strncmp(color_string,
"0x", 2))
362 slen = strlen(color_string);
363 av_strlcpy(color_string2, color_string + hex_offset,
364 FFMIN(slen-hex_offset+1,
sizeof(color_string2)));
365 if ((tail = strchr(color_string2,
ALPHA_SEP)))
367 len = strlen(color_string2);
372 rgba_color[0] = rgba >> 24;
373 rgba_color[1] = rgba >> 16;
374 rgba_color[2] = rgba >> 8;
375 rgba_color[3] = rgba;
376 }
else if (hex_offset ||
377 strspn(color_string2,
"0123456789ABCDEFabcdef") == len) {
379 unsigned int rgba = strtoul(color_string2, &tail, 16);
381 if (*tail || (len != 6 && len != 8)) {
382 av_log(log_ctx,
AV_LOG_ERROR,
"Invalid 0xRRGGBB[AA] color string: '%s'\n", color_string2);
386 rgba_color[3] = rgba;
389 rgba_color[0] = rgba >> 16;
390 rgba_color[1] = rgba >> 8;
391 rgba_color[2] = rgba;
393 entry = bsearch(color_string2,
407 const char *alpha_string = tail;
408 if (!strncmp(alpha_string,
"0x", 2)) {
409 alpha = strtoul(alpha_string, &tail, 16);
411 double norm_alpha =
strtod(alpha_string, &tail);
412 if (norm_alpha < 0.0 || norm_alpha > 1.0)
415 alpha = 255 * norm_alpha;
418 if (tail == alpha_string || *tail || alpha > 255 || alpha < 0) {
420 alpha_string, color_string);
423 rgba_color[3] =
alpha;
436 color = &color_table[color_idx];
446 int n_min,
int n_max,
int len_max)
453 for(i = 0; i < len_max; i++) {
457 val = (val * 10) + c -
'0';
463 if (val < n_min || val > n_max)
473 while((c = *fmt++)) {
509 dt->tm_year = val - 1900;
515 dt->tm_mon = val - 1;
544 int y = tm->tm_year + 1900,
m = tm->tm_mon + 1, d = tm->tm_mday;
552 (d + (153 *
m - 457) / 5 + 365 * y + y / 4 - y / 100 + y / 400 - 719469);
554 t += 3600 * tm->tm_hour + 60 * tm->tm_min + tm->tm_sec;
564 struct tm dt = { 0 }, tmbuf;
565 int today = 0, negative = 0, microseconds = 0;
567 static const char *
const date_fmt[] = {
571 static const char *
const time_fmt[] = {
575 static const char *
const tz_fmt[] = {
583 *timeval = INT64_MIN;
586 now = now64 / 1000000;
608 if (*p ==
'T' || *p ==
't')
636 dt.tm_sec = strtol(p, &o, 10);
653 for (n = 100000; n >= 1; n /= 10, q++) {
656 microseconds += n * (*q -
'0');
663 t = dt.tm_hour * 3600 + dt.tm_min * 60 + dt.tm_sec;
665 int is_utc = *q ==
'Z' || *q ==
'z';
668 if (!today && !is_utc && (*q ==
'+' || *q ==
'-')) {
669 struct tm tz = { 0 };
670 int sign = (*q ==
'+' ? -1 : 1);
680 tzoffset = sign * (tz.tm_hour * 60 + tz.tm_min) * 60;
685 dt2.tm_hour = dt.tm_hour;
686 dt2.tm_min = dt.tm_min;
687 dt2.tm_sec = dt.tm_sec;
690 t = is_utc ?
av_timegm(&dt) : mktime(&dt);
700 *timeval = negative ? -t : t;
714 while (*p !=
'\0' && *p !=
'=' && *p !=
'&') {
715 if ((q - tag) <
sizeof(tag) - 1)
723 while (*p !=
'&' && *p !=
'\0') {
724 if ((q - arg) < arg_size - 1) {
734 if (!strcmp(tag, tag1))
745 static uint32_t randomv =
MKTAG(
'L',
'A',
'V',
'U');
747 static uint32_t av_get_random_seed_deterministic(
void)
749 return randomv = randomv * 1664525 + 1013904223;
754 printf(
"Testing av_parse_video_rate()\n");
757 static const char *
const rates[] = {
789 printf(
"'%s' -> %d/%d %s\n",
790 rates[i], q.
num, q.
den, ret ?
"ERROR" :
"OK");
794 printf(
"\nTesting av_parse_color()\n");
841 printf(
"%s -> R(%d) G(%d) B(%d) A(%d)\n",
842 color_names[i], rgba[0], rgba[1], rgba[2], rgba[3]);
844 printf(
"%s -> error\n", color_names[i]);
848 printf(
"\nTesting av_small_strptime()\n");
851 struct tm tm = { 0 };
852 struct fmt_timespec_entry {
853 const char *
fmt, *timespec;
854 } fmt_timespec_entries[] = {
855 {
"%Y-%m-%d",
"2012-12-21" },
856 {
"%Y - %m - %d",
"2012-12-21" },
857 {
"%Y-%m-%d %H:%M:%S",
"2012-12-21 20:12:21" },
858 {
" %Y - %m - %d %H : %M : %S",
" 2012 - 12 - 21 20 : 12 : 21" },
864 struct fmt_timespec_entry *e = &fmt_timespec_entries[i];
865 printf(
"fmt:'%s' spec:'%s' -> ", e->fmt, e->timespec);
868 printf(
"%04d-%02d-%2d %02d:%02d:%02d\n",
869 1900+tm.tm_year, tm.tm_mon+1, tm.tm_mday,
870 tm.tm_hour, tm.tm_min, tm.tm_sec);
877 printf(
"\nTesting av_parse_time()\n");
883 static char tzstr[] =
"TZ=CET-1";
884 static const char *
const time_string[] = {
887 "2000-12-20 0:02:47.5z",
888 "2012 - 02-22 17:44:07",
889 "2000-12-20T010247.6",
890 "2000-12-12 1:35:46+05:30",
891 "2002-12-12 22:30:40-02",
893 static const char *
const duration_string[] = {
903 printf(
"(now is 2012-03-17 09:14:13.2 +0100, local time is UTC+1)\n");
905 printf(
"%-24s -> ", time_string[i]);
911 printf(
"%14"PRIi64
".%06d = %04d-%02d-%02dT%02d:%02d:%02dZ\n",
912 tv / 1000000, (
int)(tv % 1000000),
913 tm->tm_year + 1900, tm->tm_mon + 1, tm->tm_mday,
914 tm->tm_hour, tm->tm_min, tm->tm_sec);
918 printf(
"%-24s -> ", duration_string[i]);
922 printf(
"%+21"PRIi64
"\n", tv);
time_t av_timegm(struct tm *tm)
Convert the decomposed UTC time in tm to a time_t value.
int av_parse_ratio(AVRational *q, const char *str, int max, int log_offset, void *log_ctx)
Parse str and store the parsed ratio in q.
const char * name
a string representing the name of the color
const char const char void * val
static av_const int av_isdigit(int c)
Locale-independent conversion of ASCII isdigit.
int av_parse_video_rate(AVRational *rate, const char *arg)
Parse str and store the detected values in *rate.
int av_parse_video_size(int *width_ptr, int *height_ptr, const char *str)
Parse str and put in width_ptr and height_ptr the detected values.
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.
static av_const int av_isspace(int c)
Locale-independent conversion of ASCII isspace.
static const uint32_t color[16+AV_CLASS_CATEGORY_NB]
char * av_small_strptime(const char *p, const char *fmt, struct tm *dt)
Simplified version of strptime.
double strtod(const char *, char **)
int av_find_info_tag(char *arg, int arg_size, const char *tag1, const char *info)
Attempt to find a specific tag in a URL.
uint8_t rgb_color[3]
RGB values for the color.
int av_parse_color(uint8_t *rgba_color, const char *color_string, int slen, void *log_ctx)
Put the RGBA values that correspond to color_string in rgba_color.
int av_expr_parse_and_eval(double *d, const char *s, const char *const *const_names, const double *const_values, const char *const *func1_names, double(*const *funcs1)(void *, double), const char *const *func2_names, double(*const *funcs2)(void *, double, double), void *opaque, int log_offset, void *log_ctx)
Parse and evaluate an expression.
static double alpha(void *priv, double x, double y)
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
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.
static struct tm * gmtime_r(const time_t *clock, struct tm *result)
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 av_reduce(int *dst_num, int *dst_den, int64_t num, int64_t den, int64_t max)
Reduce a fraction.
AVRational av_d2q(double d, int max)
Convert a double precision floating point number to a rational.
int av_strcasecmp(const char *a, const char *b)
Locale-independent case-insensitive compare.
static struct tm * localtime_r(const time_t *clock, struct tm *result)
#define FF_ARRAY_ELEMS(a)
static int color_table_compare(const void *lhs, const void *rhs)
int64_t av_gettime(void)
Get the current time in microseconds.
static const ColorEntry color_table[]
static const VideoRateAbbr video_rate_abbrs[]
static int date_get_num(const char **pp, int n_min, int n_max, int len_max)
static const char * color_names[NB_RANGES]
BYTE int const BYTE int int int height
rational number numerator/denominator
static const VideoSizeAbbr video_size_abbrs[]
common internal and external API header
uint32_t av_get_random_seed(void)
Get a seed to use in conjunction with random functions.
int main(int argc, char **argv)
#define MKTAG(a, b, c, d)
#define av_parse_ratio_quiet(rate, str, max)
simple arithmetic expression evaluator