xref: /aosp_15_r20/external/brotli/c/common/transform.h (revision f4ee7fba7774faf2a30f13154332c0a06550dbc4)
1*f4ee7fbaSAndroid Build Coastguard Worker /* transforms is a part of ABI, but not API.
2*f4ee7fbaSAndroid Build Coastguard Worker 
3*f4ee7fbaSAndroid Build Coastguard Worker    It means that there are some functions that are supposed to be in "common"
4*f4ee7fbaSAndroid Build Coastguard Worker    library, but header itself is not placed into include/brotli. This way,
5*f4ee7fbaSAndroid Build Coastguard Worker    aforementioned functions will be available only to brotli internals.
6*f4ee7fbaSAndroid Build Coastguard Worker  */
7*f4ee7fbaSAndroid Build Coastguard Worker 
8*f4ee7fbaSAndroid Build Coastguard Worker #ifndef BROTLI_COMMON_TRANSFORM_H_
9*f4ee7fbaSAndroid Build Coastguard Worker #define BROTLI_COMMON_TRANSFORM_H_
10*f4ee7fbaSAndroid Build Coastguard Worker 
11*f4ee7fbaSAndroid Build Coastguard Worker #include <brotli/port.h>
12*f4ee7fbaSAndroid Build Coastguard Worker #include <brotli/types.h>
13*f4ee7fbaSAndroid Build Coastguard Worker 
14*f4ee7fbaSAndroid Build Coastguard Worker #if defined(__cplusplus) || defined(c_plusplus)
15*f4ee7fbaSAndroid Build Coastguard Worker extern "C" {
16*f4ee7fbaSAndroid Build Coastguard Worker #endif
17*f4ee7fbaSAndroid Build Coastguard Worker 
18*f4ee7fbaSAndroid Build Coastguard Worker enum BrotliWordTransformType {
19*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_IDENTITY = 0,
20*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_LAST_1 = 1,
21*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_LAST_2 = 2,
22*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_LAST_3 = 3,
23*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_LAST_4 = 4,
24*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_LAST_5 = 5,
25*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_LAST_6 = 6,
26*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_LAST_7 = 7,
27*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_LAST_8 = 8,
28*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_LAST_9 = 9,
29*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_UPPERCASE_FIRST = 10,
30*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_UPPERCASE_ALL = 11,
31*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_FIRST_1 = 12,
32*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_FIRST_2 = 13,
33*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_FIRST_3 = 14,
34*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_FIRST_4 = 15,
35*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_FIRST_5 = 16,
36*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_FIRST_6 = 17,
37*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_FIRST_7 = 18,
38*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_FIRST_8 = 19,
39*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_OMIT_FIRST_9 = 20,
40*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_SHIFT_FIRST = 21,
41*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_TRANSFORM_SHIFT_ALL = 22,
42*f4ee7fbaSAndroid Build Coastguard Worker   BROTLI_NUM_TRANSFORM_TYPES  /* Counts transforms, not a transform itself. */
43*f4ee7fbaSAndroid Build Coastguard Worker };
44*f4ee7fbaSAndroid Build Coastguard Worker 
45*f4ee7fbaSAndroid Build Coastguard Worker #define BROTLI_TRANSFORMS_MAX_CUT_OFF BROTLI_TRANSFORM_OMIT_LAST_9
46*f4ee7fbaSAndroid Build Coastguard Worker 
47*f4ee7fbaSAndroid Build Coastguard Worker typedef struct BrotliTransforms {
48*f4ee7fbaSAndroid Build Coastguard Worker   uint16_t prefix_suffix_size;
49*f4ee7fbaSAndroid Build Coastguard Worker   /* Last character must be null, so prefix_suffix_size must be at least 1. */
50*f4ee7fbaSAndroid Build Coastguard Worker   const uint8_t* prefix_suffix;
51*f4ee7fbaSAndroid Build Coastguard Worker   const uint16_t* prefix_suffix_map;
52*f4ee7fbaSAndroid Build Coastguard Worker   uint32_t num_transforms;
53*f4ee7fbaSAndroid Build Coastguard Worker   /* Each entry is a [prefix_id, transform, suffix_id] triplet. */
54*f4ee7fbaSAndroid Build Coastguard Worker   const uint8_t* transforms;
55*f4ee7fbaSAndroid Build Coastguard Worker   /* Shift for BROTLI_TRANSFORM_SHIFT_FIRST and BROTLI_TRANSFORM_SHIFT_ALL,
56*f4ee7fbaSAndroid Build Coastguard Worker      must be NULL if and only if no such transforms are present. */
57*f4ee7fbaSAndroid Build Coastguard Worker   const uint8_t* params;
58*f4ee7fbaSAndroid Build Coastguard Worker   /* Indices of transforms like ["", BROTLI_TRANSFORM_OMIT_LAST_#, ""].
59*f4ee7fbaSAndroid Build Coastguard Worker      0-th element corresponds to ["", BROTLI_TRANSFORM_IDENTITY, ""].
60*f4ee7fbaSAndroid Build Coastguard Worker      -1, if cut-off transform does not exist. */
61*f4ee7fbaSAndroid Build Coastguard Worker   int16_t cutOffTransforms[BROTLI_TRANSFORMS_MAX_CUT_OFF + 1];
62*f4ee7fbaSAndroid Build Coastguard Worker } BrotliTransforms;
63*f4ee7fbaSAndroid Build Coastguard Worker 
64*f4ee7fbaSAndroid Build Coastguard Worker /* T is BrotliTransforms*; result is uint8_t. */
65*f4ee7fbaSAndroid Build Coastguard Worker #define BROTLI_TRANSFORM_PREFIX_ID(T, I) ((T)->transforms[((I) * 3) + 0])
66*f4ee7fbaSAndroid Build Coastguard Worker #define BROTLI_TRANSFORM_TYPE(T, I)      ((T)->transforms[((I) * 3) + 1])
67*f4ee7fbaSAndroid Build Coastguard Worker #define BROTLI_TRANSFORM_SUFFIX_ID(T, I) ((T)->transforms[((I) * 3) + 2])
68*f4ee7fbaSAndroid Build Coastguard Worker 
69*f4ee7fbaSAndroid Build Coastguard Worker /* T is BrotliTransforms*; result is const uint8_t*. */
70*f4ee7fbaSAndroid Build Coastguard Worker #define BROTLI_TRANSFORM_PREFIX(T, I) (&(T)->prefix_suffix[ \
71*f4ee7fbaSAndroid Build Coastguard Worker     (T)->prefix_suffix_map[BROTLI_TRANSFORM_PREFIX_ID(T, I)]])
72*f4ee7fbaSAndroid Build Coastguard Worker #define BROTLI_TRANSFORM_SUFFIX(T, I) (&(T)->prefix_suffix[ \
73*f4ee7fbaSAndroid Build Coastguard Worker     (T)->prefix_suffix_map[BROTLI_TRANSFORM_SUFFIX_ID(T, I)]])
74*f4ee7fbaSAndroid Build Coastguard Worker 
75*f4ee7fbaSAndroid Build Coastguard Worker BROTLI_COMMON_API const BrotliTransforms* BrotliGetTransforms(void);
76*f4ee7fbaSAndroid Build Coastguard Worker 
77*f4ee7fbaSAndroid Build Coastguard Worker BROTLI_COMMON_API int BrotliTransformDictionaryWord(
78*f4ee7fbaSAndroid Build Coastguard Worker     uint8_t* dst, const uint8_t* word, int len,
79*f4ee7fbaSAndroid Build Coastguard Worker     const BrotliTransforms* transforms, int transform_idx);
80*f4ee7fbaSAndroid Build Coastguard Worker 
81*f4ee7fbaSAndroid Build Coastguard Worker #if defined(__cplusplus) || defined(c_plusplus)
82*f4ee7fbaSAndroid Build Coastguard Worker }  /* extern "C" */
83*f4ee7fbaSAndroid Build Coastguard Worker #endif
84*f4ee7fbaSAndroid Build Coastguard Worker 
85*f4ee7fbaSAndroid Build Coastguard Worker #endif  /* BROTLI_COMMON_TRANSFORM_H_ */
86