| Index: third_party/brotli/enc/transform.h
|
| diff --git a/third_party/brotli/enc/transform.h b/third_party/brotli/enc/transform.h
|
| deleted file mode 100644
|
| index 1ec3849dd6f0a3402bffc03388eba1f449ef30fd..0000000000000000000000000000000000000000
|
| --- a/third_party/brotli/enc/transform.h
|
| +++ /dev/null
|
| @@ -1,248 +0,0 @@
|
| -/* Copyright 2010 Google Inc. All Rights Reserved.
|
| -
|
| - Distributed under MIT license.
|
| - See file LICENSE for detail or copy at https://opensource.org/licenses/MIT
|
| -*/
|
| -
|
| -// Transformations on dictionary words.
|
| -
|
| -#ifndef BROTLI_ENC_TRANSFORM_H_
|
| -#define BROTLI_ENC_TRANSFORM_H_
|
| -
|
| -#include <string>
|
| -
|
| -#include "./dictionary.h"
|
| -
|
| -namespace brotli {
|
| -
|
| -enum WordTransformType {
|
| - kIdentity = 0,
|
| - kOmitLast1 = 1,
|
| - kOmitLast2 = 2,
|
| - kOmitLast3 = 3,
|
| - kOmitLast4 = 4,
|
| - kOmitLast5 = 5,
|
| - kOmitLast6 = 6,
|
| - kOmitLast7 = 7,
|
| - kOmitLast8 = 8,
|
| - kOmitLast9 = 9,
|
| - kUppercaseFirst = 10,
|
| - kUppercaseAll = 11,
|
| - kOmitFirst1 = 12,
|
| - kOmitFirst2 = 13,
|
| - kOmitFirst3 = 14,
|
| - kOmitFirst4 = 15,
|
| - kOmitFirst5 = 16,
|
| - kOmitFirst6 = 17,
|
| - kOmitFirst7 = 18,
|
| - kOmitFirst8 = 19,
|
| - kOmitFirst9 = 20
|
| -};
|
| -
|
| -struct Transform {
|
| - const char* prefix;
|
| - WordTransformType word_transform;
|
| - const char* suffix;
|
| -};
|
| -
|
| -static const Transform kTransforms[] = {
|
| - { "", kIdentity, "" },
|
| - { "", kIdentity, " " },
|
| - { " ", kIdentity, " " },
|
| - { "", kOmitFirst1, "" },
|
| - { "", kUppercaseFirst, " " },
|
| - { "", kIdentity, " the " },
|
| - { " ", kIdentity, "" },
|
| - { "s ", kIdentity, " " },
|
| - { "", kIdentity, " of " },
|
| - { "", kUppercaseFirst, "" },
|
| - { "", kIdentity, " and " },
|
| - { "", kOmitFirst2, "" },
|
| - { "", kOmitLast1, "" },
|
| - { ", ", kIdentity, " " },
|
| - { "", kIdentity, ", " },
|
| - { " ", kUppercaseFirst, " " },
|
| - { "", kIdentity, " in " },
|
| - { "", kIdentity, " to " },
|
| - { "e ", kIdentity, " " },
|
| - { "", kIdentity, "\"" },
|
| - { "", kIdentity, "." },
|
| - { "", kIdentity, "\">" },
|
| - { "", kIdentity, "\n" },
|
| - { "", kOmitLast3, "" },
|
| - { "", kIdentity, "]" },
|
| - { "", kIdentity, " for " },
|
| - { "", kOmitFirst3, "" },
|
| - { "", kOmitLast2, "" },
|
| - { "", kIdentity, " a " },
|
| - { "", kIdentity, " that " },
|
| - { " ", kUppercaseFirst, "" },
|
| - { "", kIdentity, ". " },
|
| - { ".", kIdentity, "" },
|
| - { " ", kIdentity, ", " },
|
| - { "", kOmitFirst4, "" },
|
| - { "", kIdentity, " with " },
|
| - { "", kIdentity, "'" },
|
| - { "", kIdentity, " from " },
|
| - { "", kIdentity, " by " },
|
| - { "", kOmitFirst5, "" },
|
| - { "", kOmitFirst6, "" },
|
| - { " the ", kIdentity, "" },
|
| - { "", kOmitLast4, "" },
|
| - { "", kIdentity, ". The " },
|
| - { "", kUppercaseAll, "" },
|
| - { "", kIdentity, " on " },
|
| - { "", kIdentity, " as " },
|
| - { "", kIdentity, " is " },
|
| - { "", kOmitLast7, "" },
|
| - { "", kOmitLast1, "ing " },
|
| - { "", kIdentity, "\n\t" },
|
| - { "", kIdentity, ":" },
|
| - { " ", kIdentity, ". " },
|
| - { "", kIdentity, "ed " },
|
| - { "", kOmitFirst9, "" },
|
| - { "", kOmitFirst7, "" },
|
| - { "", kOmitLast6, "" },
|
| - { "", kIdentity, "(" },
|
| - { "", kUppercaseFirst, ", " },
|
| - { "", kOmitLast8, "" },
|
| - { "", kIdentity, " at " },
|
| - { "", kIdentity, "ly " },
|
| - { " the ", kIdentity, " of " },
|
| - { "", kOmitLast5, "" },
|
| - { "", kOmitLast9, "" },
|
| - { " ", kUppercaseFirst, ", " },
|
| - { "", kUppercaseFirst, "\"" },
|
| - { ".", kIdentity, "(" },
|
| - { "", kUppercaseAll, " " },
|
| - { "", kUppercaseFirst, "\">" },
|
| - { "", kIdentity, "=\"" },
|
| - { " ", kIdentity, "." },
|
| - { ".com/", kIdentity, "" },
|
| - { " the ", kIdentity, " of the " },
|
| - { "", kUppercaseFirst, "'" },
|
| - { "", kIdentity, ". This " },
|
| - { "", kIdentity, "," },
|
| - { ".", kIdentity, " " },
|
| - { "", kUppercaseFirst, "(" },
|
| - { "", kUppercaseFirst, "." },
|
| - { "", kIdentity, " not " },
|
| - { " ", kIdentity, "=\"" },
|
| - { "", kIdentity, "er " },
|
| - { " ", kUppercaseAll, " " },
|
| - { "", kIdentity, "al " },
|
| - { " ", kUppercaseAll, "" },
|
| - { "", kIdentity, "='" },
|
| - { "", kUppercaseAll, "\"" },
|
| - { "", kUppercaseFirst, ". " },
|
| - { " ", kIdentity, "(" },
|
| - { "", kIdentity, "ful " },
|
| - { " ", kUppercaseFirst, ". " },
|
| - { "", kIdentity, "ive " },
|
| - { "", kIdentity, "less " },
|
| - { "", kUppercaseAll, "'" },
|
| - { "", kIdentity, "est " },
|
| - { " ", kUppercaseFirst, "." },
|
| - { "", kUppercaseAll, "\">" },
|
| - { " ", kIdentity, "='" },
|
| - { "", kUppercaseFirst, "," },
|
| - { "", kIdentity, "ize " },
|
| - { "", kUppercaseAll, "." },
|
| - { "\xc2\xa0", kIdentity, "" },
|
| - { " ", kIdentity, "," },
|
| - { "", kUppercaseFirst, "=\"" },
|
| - { "", kUppercaseAll, "=\"" },
|
| - { "", kIdentity, "ous " },
|
| - { "", kUppercaseAll, ", " },
|
| - { "", kUppercaseFirst, "='" },
|
| - { " ", kUppercaseFirst, "," },
|
| - { " ", kUppercaseAll, "=\"" },
|
| - { " ", kUppercaseAll, ", " },
|
| - { "", kUppercaseAll, "," },
|
| - { "", kUppercaseAll, "(" },
|
| - { "", kUppercaseAll, ". " },
|
| - { " ", kUppercaseAll, "." },
|
| - { "", kUppercaseAll, "='" },
|
| - { " ", kUppercaseAll, ". " },
|
| - { " ", kUppercaseFirst, "=\"" },
|
| - { " ", kUppercaseAll, "='" },
|
| - { " ", kUppercaseFirst, "='" },
|
| -};
|
| -
|
| -static const size_t kNumTransforms =
|
| - sizeof(kTransforms) / sizeof(kTransforms[0]);
|
| -
|
| -static const size_t kOmitLastNTransforms[10] = {
|
| - 0, 12, 27, 23, 42, 63, 56, 48, 59, 64,
|
| -};
|
| -
|
| -static size_t ToUpperCase(uint8_t *p, size_t len) {
|
| - if (len == 1 || p[0] < 0xc0) {
|
| - if (p[0] >= 'a' && p[0] <= 'z') {
|
| - p[0] ^= 32;
|
| - }
|
| - return 1;
|
| - }
|
| - if (p[0] < 0xe0) {
|
| - p[1] ^= 32;
|
| - return 2;
|
| - }
|
| - if (len == 2) {
|
| - return 2;
|
| - }
|
| - p[2] ^= 5;
|
| - return 3;
|
| -}
|
| -
|
| -inline std::string TransformWord(
|
| - WordTransformType transform_type, const uint8_t* word, size_t len) {
|
| - if (transform_type <= kOmitLast9) {
|
| - if (len <= static_cast<size_t>(transform_type)) {
|
| - return std::string();
|
| - }
|
| - return std::string(word, word + len - transform_type);
|
| - }
|
| -
|
| - if (transform_type >= kOmitFirst1) {
|
| - const size_t skip = transform_type - (kOmitFirst1 - 1);
|
| - if (len <= skip) {
|
| - return std::string();
|
| - }
|
| - return std::string(word + skip, word + len);
|
| - }
|
| -
|
| - std::string ret = std::string(word, word + len);
|
| - uint8_t *uppercase = reinterpret_cast<uint8_t*>(&ret[0]);
|
| - if (transform_type == kUppercaseFirst) {
|
| - ToUpperCase(uppercase, len);
|
| - } else if (transform_type == kUppercaseAll) {
|
| - size_t position = 0;
|
| - while (position < len) {
|
| - size_t step = ToUpperCase(uppercase, len - position);
|
| - uppercase += step;
|
| - position += step;
|
| - }
|
| - }
|
| - return ret;
|
| -}
|
| -
|
| -inline std::string ApplyTransform(
|
| - const Transform& t, const uint8_t* word, size_t len) {
|
| - return std::string(t.prefix) +
|
| - TransformWord(t.word_transform, word, len) + std::string(t.suffix);
|
| -}
|
| -
|
| -inline std::string GetTransformedDictionaryWord(size_t len_code,
|
| - size_t word_id) {
|
| - size_t num_words = 1u << kBrotliDictionarySizeBitsByLength[len_code];
|
| - size_t offset = kBrotliDictionaryOffsetsByLength[len_code];
|
| - size_t t = word_id / num_words;
|
| - size_t word_idx = word_id % num_words;
|
| - offset += len_code * word_idx;
|
| - const uint8_t* word = &kBrotliDictionary[offset];
|
| - return ApplyTransform(kTransforms[t], word, len_code);
|
| -}
|
| -
|
| -} // namespace brotli
|
| -
|
| -#endif // BROTLI_ENC_TRANSFORM_H_
|
|
|