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

Unified Diff: src/math.cc

Issue 658573004: Updating to new OTS repo from https://github.com/khaledhosny/ots.git (Closed) Base URL: https://chromium.googlesource.com/external/ots@master
Patch Set: Adding Colored Emoji changes from external/git repo Created 6 years, 2 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
« .gitmodules ('K') | « src/ltsh.cc ('k') | src/maxp.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/math.cc
diff --git a/src/math.cc b/src/math.cc
old mode 100644
new mode 100755
index 06e1361c27a58706073c0ecdf0e329fbb71f87a8..97aa313651d0a43552742684cec80d12bb547431
--- a/src/math.cc
+++ b/src/math.cc
@@ -17,6 +17,8 @@
// Format" Color Font Technology and MATH layout support'. Meanwhile, you can
// contact Microsoft's engineer Murray Sargent to obtain a copy.
+#define TABLE_NAME "MATH"
+
namespace {
// The size of MATH header.
@@ -48,7 +50,8 @@ const unsigned kGlyphPartRecordSize = 5 * 2;
// Shared Table: MathValueRecord
-bool ParseMathValueRecord(ots::Buffer* subtable, const uint8_t *data,
+bool ParseMathValueRecord(const ots::OpenTypeFile *file,
+ ots::Buffer* subtable, const uint8_t *data,
const size_t length) {
// Check the Value field.
if (!subtable->Skip(2)) {
@@ -64,7 +67,7 @@ bool ParseMathValueRecord(ots::Buffer* subtable, const uint8_t *data,
if (offset >= length) {
return OTS_FAILURE();
}
- if (!ots::ParseDeviceTable(data + offset, length - offset)) {
+ if (!ots::ParseDeviceTable(file, data + offset, length - offset)) {
return OTS_FAILURE();
}
}
@@ -72,7 +75,8 @@ bool ParseMathValueRecord(ots::Buffer* subtable, const uint8_t *data,
return true;
}
-bool ParseMathConstantsTable(const uint8_t *data, size_t length) {
+bool ParseMathConstantsTable(const ots::OpenTypeFile *file,
+ const uint8_t *data, size_t length) {
ots::Buffer subtable(data, length);
// Part 1: int16 or uint16 constants.
@@ -142,7 +146,7 @@ bool ParseMathConstantsTable(const uint8_t *data, size_t length) {
//
// RadicalKernAfterDegree
for (unsigned i = 0; i < static_cast<unsigned>(51); ++i) {
- if (!ParseMathValueRecord(&subtable, data, length)) {
+ if (!ParseMathValueRecord(file, &subtable, data, length)) {
return OTS_FAILURE();
}
}
@@ -156,7 +160,8 @@ bool ParseMathConstantsTable(const uint8_t *data, size_t length) {
return true;
}
-bool ParseMathValueRecordSequenceForGlyphs(ots::Buffer* subtable,
+bool ParseMathValueRecordSequenceForGlyphs(const ots::OpenTypeFile *file,
+ ots::Buffer* subtable,
const uint8_t *data,
const size_t length,
const uint16_t num_glyphs) {
@@ -178,7 +183,7 @@ bool ParseMathValueRecordSequenceForGlyphs(ots::Buffer* subtable,
if (offset_coverage < sequence_end || offset_coverage >= length) {
return OTS_FAILURE();
}
- if (!ots::ParseCoverageTable(data + offset_coverage,
+ if (!ots::ParseCoverageTable(file, data + offset_coverage,
length - offset_coverage,
num_glyphs, sequence_count)) {
return OTS_FAILURE();
@@ -186,7 +191,7 @@ bool ParseMathValueRecordSequenceForGlyphs(ots::Buffer* subtable,
// Check sequence.
for (unsigned i = 0; i < sequence_count; ++i) {
- if (!ParseMathValueRecord(subtable, data, length)) {
+ if (!ParseMathValueRecord(file, subtable, data, length)) {
return OTS_FAILURE();
}
}
@@ -194,23 +199,26 @@ bool ParseMathValueRecordSequenceForGlyphs(ots::Buffer* subtable,
return true;
}
-bool ParseMathItalicsCorrectionInfoTable(const uint8_t *data,
+bool ParseMathItalicsCorrectionInfoTable(const ots::OpenTypeFile *file,
+ const uint8_t *data,
size_t length,
const uint16_t num_glyphs) {
ots::Buffer subtable(data, length);
- return ParseMathValueRecordSequenceForGlyphs(&subtable, data, length,
+ return ParseMathValueRecordSequenceForGlyphs(file, &subtable, data, length,
num_glyphs);
}
-bool ParseMathTopAccentAttachmentTable(const uint8_t *data,
+bool ParseMathTopAccentAttachmentTable(const ots::OpenTypeFile *file,
+ const uint8_t *data,
size_t length,
const uint16_t num_glyphs) {
ots::Buffer subtable(data, length);
- return ParseMathValueRecordSequenceForGlyphs(&subtable, data, length,
+ return ParseMathValueRecordSequenceForGlyphs(file, &subtable, data, length,
num_glyphs);
}
-bool ParseMathKernTable(const uint8_t *data, size_t length) {
+bool ParseMathKernTable(const ots::OpenTypeFile *file,
+ const uint8_t *data, size_t length) {
ots::Buffer subtable(data, length);
// Check the Height count.
@@ -221,14 +229,14 @@ bool ParseMathKernTable(const uint8_t *data, size_t length) {
// Check the Correction Heights.
for (unsigned i = 0; i < height_count; ++i) {
- if (!ParseMathValueRecord(&subtable, data, length)) {
+ if (!ParseMathValueRecord(file, &subtable, data, length)) {
return OTS_FAILURE();
}
}
// Check the Kern Values.
for (unsigned i = 0; i <= height_count; ++i) {
- if (!ParseMathValueRecord(&subtable, data, length)) {
+ if (!ParseMathValueRecord(file, &subtable, data, length)) {
return OTS_FAILURE();
}
}
@@ -236,7 +244,8 @@ bool ParseMathKernTable(const uint8_t *data, size_t length) {
return true;
}
-bool ParseMathKernInfoTable(const uint8_t *data, size_t length,
+bool ParseMathKernInfoTable(const ots::OpenTypeFile *file,
+ const uint8_t *data, size_t length,
const uint16_t num_glyphs) {
ots::Buffer subtable(data, length);
@@ -258,7 +267,7 @@ bool ParseMathKernInfoTable(const uint8_t *data, size_t length,
if (offset_coverage < sequence_end || offset_coverage >= length) {
return OTS_FAILURE();
}
- if (!ots::ParseCoverageTable(data + offset_coverage, length - offset_coverage,
+ if (!ots::ParseCoverageTable(file, data + offset_coverage, length - offset_coverage,
num_glyphs, sequence_count)) {
return OTS_FAILURE();
}
@@ -273,7 +282,7 @@ bool ParseMathKernInfoTable(const uint8_t *data, size_t length,
}
if (offset_math_kern) {
if (offset_math_kern < sequence_end || offset_math_kern >= length ||
- !ParseMathKernTable(data + offset_math_kern,
+ !ParseMathKernTable(file, data + offset_math_kern,
length - offset_math_kern)) {
return OTS_FAILURE();
}
@@ -284,7 +293,8 @@ bool ParseMathKernInfoTable(const uint8_t *data, size_t length,
return true;
}
-bool ParseMathGlyphInfoTable(const uint8_t *data, size_t length,
+bool ParseMathGlyphInfoTable(const ots::OpenTypeFile *file,
+ const uint8_t *data, size_t length,
const uint16_t num_glyphs) {
ots::Buffer subtable(data, length);
@@ -308,7 +318,7 @@ bool ParseMathGlyphInfoTable(const uint8_t *data, size_t length,
if (offset_math_italics_correction_info >= length ||
offset_math_italics_correction_info < kMathGlyphInfoHeaderSize ||
!ParseMathItalicsCorrectionInfoTable(
- data + offset_math_italics_correction_info,
+ file, data + offset_math_italics_correction_info,
length - offset_math_italics_correction_info,
num_glyphs)) {
return OTS_FAILURE();
@@ -317,7 +327,7 @@ bool ParseMathGlyphInfoTable(const uint8_t *data, size_t length,
if (offset_math_top_accent_attachment) {
if (offset_math_top_accent_attachment >= length ||
offset_math_top_accent_attachment < kMathGlyphInfoHeaderSize ||
- !ParseMathTopAccentAttachmentTable(data +
+ !ParseMathTopAccentAttachmentTable(file, data +
offset_math_top_accent_attachment,
length -
offset_math_top_accent_attachment,
@@ -328,7 +338,7 @@ bool ParseMathGlyphInfoTable(const uint8_t *data, size_t length,
if (offset_extended_shaped_coverage) {
if (offset_extended_shaped_coverage >= length ||
offset_extended_shaped_coverage < kMathGlyphInfoHeaderSize ||
- !ots::ParseCoverageTable(data + offset_extended_shaped_coverage,
+ !ots::ParseCoverageTable(file, data + offset_extended_shaped_coverage,
length - offset_extended_shaped_coverage,
num_glyphs)) {
return OTS_FAILURE();
@@ -337,7 +347,7 @@ bool ParseMathGlyphInfoTable(const uint8_t *data, size_t length,
if (offset_math_kern_info) {
if (offset_math_kern_info >= length ||
offset_math_kern_info < kMathGlyphInfoHeaderSize ||
- !ParseMathKernInfoTable(data + offset_math_kern_info,
+ !ParseMathKernInfoTable(file, data + offset_math_kern_info,
length - offset_math_kern_info, num_glyphs)) {
return OTS_FAILURE();
}
@@ -346,13 +356,14 @@ bool ParseMathGlyphInfoTable(const uint8_t *data, size_t length,
return true;
}
-bool ParseGlyphAssemblyTable(const uint8_t *data,
+bool ParseGlyphAssemblyTable(const ots::OpenTypeFile *file,
+ const uint8_t *data,
size_t length, const uint16_t num_glyphs) {
ots::Buffer subtable(data, length);
// Check the header.
uint16_t part_count = 0;
- if (!ParseMathValueRecord(&subtable, data, length) ||
+ if (!ParseMathValueRecord(file, &subtable, data, length) ||
!subtable.ReadU16(&part_count)) {
return OTS_FAILURE();
}
@@ -373,19 +384,18 @@ bool ParseGlyphAssemblyTable(const uint8_t *data,
return OTS_FAILURE();
}
if (glyph >= num_glyphs) {
- OTS_WARNING("bad glyph ID: %u", glyph);
- return OTS_FAILURE();
+ return OTS_FAILURE_MSG("bad glyph ID: %u", glyph);
}
if (part_flags & ~0x00000001) {
- OTS_WARNING("unknown part flag: %u", part_flags);
- return OTS_FAILURE();
+ return OTS_FAILURE_MSG("unknown part flag: %u", part_flags);
}
}
return true;
}
-bool ParseMathGlyphConstructionTable(const uint8_t *data,
+bool ParseMathGlyphConstructionTable(const ots::OpenTypeFile *file,
+ const uint8_t *data,
size_t length, const uint16_t num_glyphs) {
ots::Buffer subtable(data, length);
@@ -409,7 +419,7 @@ bool ParseMathGlyphConstructionTable(const uint8_t *data,
offset_glyph_assembly < sequence_end) {
return OTS_FAILURE();
}
- if (!ParseGlyphAssemblyTable(data + offset_glyph_assembly,
+ if (!ParseGlyphAssemblyTable(file, data + offset_glyph_assembly,
length - offset_glyph_assembly, num_glyphs)) {
return OTS_FAILURE();
}
@@ -423,15 +433,15 @@ bool ParseMathGlyphConstructionTable(const uint8_t *data,
return OTS_FAILURE();
}
if (glyph >= num_glyphs) {
- OTS_WARNING("bad glyph ID: %u", glyph);
- return OTS_FAILURE();
+ return OTS_FAILURE_MSG("bad glyph ID: %u", glyph);
}
}
return true;
}
-bool ParseMathGlyphConstructionSequence(ots::Buffer* subtable,
+bool ParseMathGlyphConstructionSequence(const ots::OpenTypeFile *file,
+ ots::Buffer* subtable,
const uint8_t *data,
size_t length,
const uint16_t num_glyphs,
@@ -442,7 +452,7 @@ bool ParseMathGlyphConstructionSequence(ots::Buffer* subtable,
if (offset_coverage < sequence_end || offset_coverage >= length) {
return OTS_FAILURE();
}
- if (!ots::ParseCoverageTable(data + offset_coverage,
+ if (!ots::ParseCoverageTable(file, data + offset_coverage,
length - offset_coverage,
num_glyphs, glyph_count)) {
return OTS_FAILURE();
@@ -456,7 +466,7 @@ bool ParseMathGlyphConstructionSequence(ots::Buffer* subtable,
}
if (offset_glyph_construction < sequence_end ||
offset_glyph_construction >= length ||
- !ParseMathGlyphConstructionTable(data + offset_glyph_construction,
+ !ParseMathGlyphConstructionTable(file, data + offset_glyph_construction,
length - offset_glyph_construction,
num_glyphs)) {
return OTS_FAILURE();
@@ -466,7 +476,8 @@ bool ParseMathGlyphConstructionSequence(ots::Buffer* subtable,
return true;
}
-bool ParseMathVariantsTable(const uint8_t *data,
+bool ParseMathVariantsTable(const ots::OpenTypeFile *file,
+ const uint8_t *data,
size_t length, const uint16_t num_glyphs) {
ots::Buffer subtable(data, length);
@@ -489,11 +500,11 @@ bool ParseMathVariantsTable(const uint8_t *data,
return OTS_FAILURE();
}
- if (!ParseMathGlyphConstructionSequence(&subtable, data, length, num_glyphs,
+ if (!ParseMathGlyphConstructionSequence(file, &subtable, data, length, num_glyphs,
offset_vert_glyph_coverage,
vert_glyph_count,
sequence_end) ||
- !ParseMathGlyphConstructionSequence(&subtable, data, length, num_glyphs,
+ !ParseMathGlyphConstructionSequence(file, &subtable, data, length, num_glyphs,
offset_horiz_glyph_coverage,
horiz_glyph_count,
sequence_end)) {
@@ -505,8 +516,12 @@ bool ParseMathVariantsTable(const uint8_t *data,
} // namespace
-#define DROP_THIS_TABLE \
- do { file->math->data = 0; file->math->length = 0; } while (0)
+#define DROP_THIS_TABLE(msg_) \
+ do { \
+ file->math->data = 0; \
+ file->math->length = 0; \
+ OTS_FAILURE_MSG(msg_ ", table discarded"); \
+ } while (0)
namespace ots {
@@ -528,8 +543,7 @@ bool ots_math_parse(OpenTypeFile *file, const uint8_t *data, size_t length) {
return OTS_FAILURE();
}
if (version != 0x00010000) {
- OTS_WARNING("bad MATH version");
- DROP_THIS_TABLE;
+ DROP_THIS_TABLE("bad MATH version");
return true;
}
@@ -548,24 +562,23 @@ bool ots_math_parse(OpenTypeFile *file, const uint8_t *data, size_t length) {
offset_math_glyph_info < kMathHeaderSize ||
offset_math_variants >= length ||
offset_math_variants < kMathHeaderSize) {
- OTS_WARNING("bad offset in MATH header");
- DROP_THIS_TABLE;
+ DROP_THIS_TABLE("bad offset in MATH header");
return true;
}
- if (!ParseMathConstantsTable(data + offset_math_constants,
+ if (!ParseMathConstantsTable(file, data + offset_math_constants,
length - offset_math_constants)) {
- DROP_THIS_TABLE;
+ DROP_THIS_TABLE("failed to parse MathConstants table");
return true;
}
- if (!ParseMathGlyphInfoTable(data + offset_math_glyph_info,
+ if (!ParseMathGlyphInfoTable(file, data + offset_math_glyph_info,
length - offset_math_glyph_info, num_glyphs)) {
- DROP_THIS_TABLE;
+ DROP_THIS_TABLE("failed to parse MathGlyphInfo table");
return true;
}
- if (!ParseMathVariantsTable(data + offset_math_variants,
+ if (!ParseMathVariantsTable(file, data + offset_math_variants,
length - offset_math_variants, num_glyphs)) {
- DROP_THIS_TABLE;
+ DROP_THIS_TABLE("failed to parse MathVariants table");
return true;
}
@@ -592,3 +605,5 @@ void ots_math_free(OpenTypeFile *file) {
} // namespace ots
+#undef TABLE_NAME
+#undef DROP_THIS_TABLE
« .gitmodules ('K') | « src/ltsh.cc ('k') | src/maxp.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698