Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(189)

Unified Diff: third_party/brotli/dec/transform.h

Issue 960873002: Update from https://crrev.com/318214 (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Created 5 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « third_party/brotli/dec/streams.c ('k') | third_party/brotli/dec/types.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: third_party/brotli/dec/transform.h
diff --git a/third_party/brotli/dec/transform.h b/third_party/brotli/dec/transform.h
new file mode 100644
index 0000000000000000000000000000000000000000..cd9e1b5b72a2c4aa89175439dc6f5e4f696787a7
--- /dev/null
+++ b/third_party/brotli/dec/transform.h
@@ -0,0 +1,239 @@
+/* Copyright 2013 Google Inc. All Rights Reserved.
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+
+ Transformations on dictionary words.
+*/
+
+#ifndef BROTLI_DEC_TRANSFORM_H_
+#define BROTLI_DEC_TRANSFORM_H_
+
+#include <stdio.h>
+#include <ctype.h>
+#include "./types.h"
+
+#if defined(__cplusplus) || defined(c_plusplus)
+extern "C" {
+#endif
+
+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
+};
+
+typedef struct {
+ const char* prefix;
+ enum WordTransformType transform;
+ const char* suffix;
+} Transform;
+
+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 int kNumTransforms = sizeof(kTransforms) / sizeof(kTransforms[0]);
+
+static int ToUpperCase(uint8_t *p) {
+ if (p[0] < 0xc0) {
+ if (p[0] >= 'a' && p[0] <= 'z') {
+ p[0] ^= 32;
+ }
+ return 1;
+ }
+ /* An overly simplified uppercasing model for utf-8. */
+ if (p[0] < 0xe0) {
+ p[1] ^= 32;
+ return 2;
+ }
+ /* An arbitrary transform for three byte characters. */
+ p[2] ^= 5;
+ return 3;
+}
+
+static BROTLI_INLINE int TransformDictionaryWord(
+ uint8_t* dst, const uint8_t* word, int len, int transform) {
+ const char* prefix = kTransforms[transform].prefix;
+ const char* suffix = kTransforms[transform].suffix;
+ const int t = kTransforms[transform].transform;
+ int skip = t < kOmitFirst1 ? 0 : t - (kOmitFirst1 - 1);
+ int idx = 0;
+ int i = 0;
+ uint8_t* uppercase;
+ if (skip > len) {
+ skip = len;
+ }
+ while (*prefix) { dst[idx++] = (uint8_t)*prefix++; }
+ word += skip;
+ len -= skip;
+ if (t <= kOmitLast9) {
+ len -= t;
+ }
+ while (i < len) { dst[idx++] = word[i++]; }
+ uppercase = &dst[idx - len];
+ if (t == kUppercaseFirst) {
+ ToUpperCase(uppercase);
+ } else if (t == kUppercaseAll) {
+ while (len > 0) {
+ int step = ToUpperCase(uppercase);
+ uppercase += step;
+ len -= step;
+ }
+ }
+ while (*suffix) { dst[idx++] = (uint8_t)*suffix++; }
+ return idx;
+}
+
+#if defined(__cplusplus) || defined(c_plusplus)
+} /* extern "C" */
+#endif
+
+#endif /* BROTLI_DEC_TRANSFORM_H_ */
« no previous file with comments | « third_party/brotli/dec/streams.c ('k') | third_party/brotli/dec/types.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698