annotate libass/ass_utils.h @ 31733:7bbcba59cea6

Slightly simplify rle decoding.
author reimar
date Sun, 25 Jul 2010 09:41:30 +0000
parents 48d020c5ceca
children 88eebbbbd6a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
20008
fa122b7c71c6 Add copyright notice and vim/emacs comments to libass and vf_ass.c.
eugeni
parents: 18937
diff changeset
1 /*
26723
0f892cd714b2 Use standard license header.
diego
parents: 26138
diff changeset
2 * Copyright (C) 2006 Evgeniy Stepanov <eugeni.stepanov@gmail.com>
0f892cd714b2 Use standard license header.
diego
parents: 26138
diff changeset
3 *
26738
588ce97b44f2 Speak of libass instead of MPlayer in the libass license headers.
diego
parents: 26723
diff changeset
4 * This file is part of libass.
26723
0f892cd714b2 Use standard license header.
diego
parents: 26138
diff changeset
5 *
26738
588ce97b44f2 Speak of libass instead of MPlayer in the libass license headers.
diego
parents: 26723
diff changeset
6 * libass is free software; you can redistribute it and/or modify
26723
0f892cd714b2 Use standard license header.
diego
parents: 26138
diff changeset
7 * it under the terms of the GNU General Public License as published by
0f892cd714b2 Use standard license header.
diego
parents: 26138
diff changeset
8 * the Free Software Foundation; either version 2 of the License, or
0f892cd714b2 Use standard license header.
diego
parents: 26138
diff changeset
9 * (at your option) any later version.
0f892cd714b2 Use standard license header.
diego
parents: 26138
diff changeset
10 *
26738
588ce97b44f2 Speak of libass instead of MPlayer in the libass license headers.
diego
parents: 26723
diff changeset
11 * libass is distributed in the hope that it will be useful,
26723
0f892cd714b2 Use standard license header.
diego
parents: 26138
diff changeset
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
0f892cd714b2 Use standard license header.
diego
parents: 26138
diff changeset
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
0f892cd714b2 Use standard license header.
diego
parents: 26138
diff changeset
14 * GNU General Public License for more details.
0f892cd714b2 Use standard license header.
diego
parents: 26138
diff changeset
15 *
0f892cd714b2 Use standard license header.
diego
parents: 26138
diff changeset
16 * You should have received a copy of the GNU General Public License along
26738
588ce97b44f2 Speak of libass instead of MPlayer in the libass license headers.
diego
parents: 26723
diff changeset
17 * with libass; if not, write to the Free Software Foundation, Inc.,
26723
0f892cd714b2 Use standard license header.
diego
parents: 26138
diff changeset
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
0f892cd714b2 Use standard license header.
diego
parents: 26138
diff changeset
19 */
20008
fa122b7c71c6 Add copyright notice and vim/emacs comments to libass and vf_ass.c.
eugeni
parents: 18937
diff changeset
20
25897
aaebaf255b23 Consistently give all libass multiple inclusion guards a LIBASS_ prefix.
diego
parents: 25535
diff changeset
21 #ifndef LIBASS_UTILS_H
aaebaf255b23 Consistently give all libass multiple inclusion guards a LIBASS_ prefix.
diego
parents: 25535
diff changeset
22 #define LIBASS_UTILS_H
18937
9e95ac641e77 Initial libass release (without mencoder support).
eugeni
parents:
diff changeset
23
30200
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
24 #include <stdio.h>
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
25 #include <stdarg.h>
26138
74055622161d Add missing header #includes to fix 'make checkheaders'.
diego
parents: 26036
diff changeset
26 #include <stdint.h>
30200
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
27 #include <stdlib.h>
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
28 #include <string.h>
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
29 #include <assert.h>
26138
74055622161d Add missing header #includes to fix 'make checkheaders'.
diego
parents: 26036
diff changeset
30
30200
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
31 #ifdef CONFIG_ENCA
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
32 #include <enca.h>
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
33 #endif
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
34
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
35 #include "ass.h"
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
36
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
37 #define MSGL_FATAL 0
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
38 #define MSGL_ERR 1
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
39 #define MSGL_WARN 2
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
40 #define MSGL_INFO 4
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
41 #define MSGL_V 6
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
42 #define MSGL_DBG2 7
22213
66abe12ad374 Move conversions between 16.16, 26.6 fixed point and int, double to separate
eugeni
parents: 20503
diff changeset
43
30200
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
44 #define FFMAX(a,b) ((a) > (b) ? (a) : (b))
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
45 #define FFMIN(a,b) ((a) > (b) ? (b) : (a))
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
46 #define FFMINMAX(c,a,b) FFMIN(FFMAX(c, a), b)
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
47
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
48 int mystrtoi(char **p, int *res);
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
49 int mystrtoll(char **p, long long *res);
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
50 int mystrtou32(char **p, int base, uint32_t *res);
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
51 int mystrtod(char **p, double *res);
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
52 int strtocolor(ASS_Library *library, char **q, uint32_t *res, int hex);
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
53 char parse_bool(char *str);
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
54 unsigned ass_utf8_get_char(char **str);
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
55 void ass_msg(ASS_Library *priv, int lvl, char *fmt, ...);
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
56 #ifdef CONFIG_ENCA
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
57 void *ass_guess_buffer_cp(ASS_Library *library, unsigned char *buffer,
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
58 int buflen, char *preferred_language,
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
59 char *fallback);
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
60 #endif
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
61
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
62 /* defined in ass_strtod.c */
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
63 double ass_strtod(const char *string, char **endPtr);
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
64
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
65 static inline int d6_to_int(int x)
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
66 {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
67 return (x + 32) >> 6;
22213
66abe12ad374 Move conversions between 16.16, 26.6 fixed point and int, double to separate
eugeni
parents: 20503
diff changeset
68 }
30200
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
69 static inline int d16_to_int(int x)
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
70 {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
71 return (x + 32768) >> 16;
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
72 }
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
73 static inline int int_to_d6(int x)
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
74 {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
75 return x << 6;
22213
66abe12ad374 Move conversions between 16.16, 26.6 fixed point and int, double to separate
eugeni
parents: 20503
diff changeset
76 }
30200
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
77 static inline int int_to_d16(int x)
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
78 {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
79 return x << 16;
22213
66abe12ad374 Move conversions between 16.16, 26.6 fixed point and int, double to separate
eugeni
parents: 20503
diff changeset
80 }
30200
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
81 static inline int d16_to_d6(int x)
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
82 {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
83 return (x + 512) >> 10;
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
84 }
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
85 static inline int d6_to_d16(int x)
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
86 {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
87 return x << 10;
22213
66abe12ad374 Move conversions between 16.16, 26.6 fixed point and int, double to separate
eugeni
parents: 20503
diff changeset
88 }
30200
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
89 static inline double d6_to_double(int x)
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
90 {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
91 return x / 64.;
22213
66abe12ad374 Move conversions between 16.16, 26.6 fixed point and int, double to separate
eugeni
parents: 20503
diff changeset
92 }
30200
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
93 static inline int double_to_d6(double x)
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
94 {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
95 return (int) (x * 64);
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
96 }
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
97 static inline double d16_to_double(int x)
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
98 {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
99 return ((double) x) / 0x10000;
22213
66abe12ad374 Move conversions between 16.16, 26.6 fixed point and int, double to separate
eugeni
parents: 20503
diff changeset
100 }
30200
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
101 static inline int double_to_d16(double x)
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
102 {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
103 return (int) (x * 0x10000);
23299
0ee56ec36a40 Limit ass_font_set_transform to nonrotating transformations.
eugeni
parents: 22213
diff changeset
104 }
30200
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
105 static inline double d22_to_double(int x)
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
106 {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
107 return ((double) x) / 0x400000;
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
108 }
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
109 static inline int double_to_d22(double x)
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
110 {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
111 return (int) (x * 0x400000);
23299
0ee56ec36a40 Limit ass_font_set_transform to nonrotating transformations.
eugeni
parents: 22213
diff changeset
112 }
22213
66abe12ad374 Move conversions between 16.16, 26.6 fixed point and int, double to separate
eugeni
parents: 20503
diff changeset
113
30200
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
114 // Calculate cache key for a rotational angle in degrees
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
115 static inline int rot_key(double a)
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
116 {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
117 const int m = double_to_d22(360.0);
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
118 return double_to_d22(a) % m;
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
119 }
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
120
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
121 #define FNV1_32A_INIT (unsigned)0x811c9dc5
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
122
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
123 static inline unsigned fnv_32a_buf(void *buf, size_t len, unsigned hval)
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
124 {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
125 unsigned char *bp = buf;
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
126 unsigned char *be = bp + len;
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
127 while (bp < be) {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
128 hval ^= (unsigned) *bp++;
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
129 hval +=
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
130 (hval << 1) + (hval << 4) + (hval << 7) + (hval << 8) +
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
131 (hval << 24);
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
132 }
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
133 return hval;
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
134 }
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
135 static inline unsigned fnv_32a_str(char *str, unsigned hval)
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
136 {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
137 unsigned char *s = (unsigned char *) str;
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
138 while (*s) {
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
139 hval ^= (unsigned) *s++;
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
140 hval +=
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
141 (hval << 1) + (hval << 4) + (hval << 7) + (hval << 8) +
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
142 (hval << 24);
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
143 }
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
144 return hval;
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
145 }
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
146
48d020c5ceca Update internal libass copy to commit 8db4a5
greg
parents: 28785
diff changeset
147 #endif /* LIBASS_UTILS_H */