transform.h 3.1 KB

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