| Index: third_party/woff2/src/woff2_dec.cc
|
| diff --git a/third_party/woff2/src/woff2_dec.cc b/third_party/woff2/src/woff2_dec.cc
|
| index ea1f1693bc5198507bfc5fa0ed89eb550d08f6b8..1e63caa3a3e41789cb6b838fc506ef9156df8aec 100644
|
| --- a/third_party/woff2/src/woff2_dec.cc
|
| +++ b/third_party/woff2/src/woff2_dec.cc
|
| @@ -634,35 +634,6 @@ Table* FindTable(std::vector<Table*>* tables, uint32_t tag) {
|
| return NULL;
|
| }
|
|
|
| -// This is linear search, but could be changed to binary because we
|
| -// do have a guarantee that the tables are sorted by tag. But the total
|
| -// cpu time is expected to be very small in any case.
|
| -const Table* FindTable(const std::vector<Table>& tables, uint32_t tag) {
|
| - size_t n_tables = tables.size();
|
| - for (size_t i = 0; i < n_tables; ++i) {
|
| - if (tables[i].tag == tag) {
|
| - return &tables[i];
|
| - }
|
| - }
|
| - return NULL;
|
| -}
|
| -
|
| -// https://www.microsoft.com/typography/otspec/maxp.htm
|
| -bool ReadNumGlyphs(const Table* maxp_table,
|
| - const uint8_t* dst, size_t dst_length,
|
| - uint16_t* num_glyphs) {
|
| - if (PREDICT_FALSE(static_cast<uint64_t>(maxp_table->dst_offset +
|
| - maxp_table->dst_length) > dst_length)) {
|
| - return FONT_COMPRESSION_FAILURE();
|
| - }
|
| - Buffer buffer(dst + maxp_table->dst_offset, maxp_table->dst_length);
|
| - // Skip 4 to reach 'maxp' numGlyphs
|
| - if (PREDICT_FALSE(!buffer.Skip(4) || !buffer.ReadU16(num_glyphs))) {
|
| - return FONT_COMPRESSION_FAILURE();
|
| - }
|
| - return true;
|
| -}
|
| -
|
| // Get numberOfHMetrics, https://www.microsoft.com/typography/otspec/hhea.htm
|
| bool ReadNumHMetrics(const uint8_t* data, size_t data_size,
|
| uint16_t* num_hmetrics) {
|
| @@ -674,37 +645,6 @@ bool ReadNumHMetrics(const uint8_t* data, size_t data_size,
|
| return true;
|
| }
|
|
|
| -// x_min for glyph; https://www.microsoft.com/typography/otspec/glyf.htm
|
| -bool ReadGlyphXMin(Buffer* glyf_buff, Buffer* loca_buff, int16_t loca_format,
|
| - uint16_t index, int16_t* x_min) {
|
| - uint32_t offset1, offset2;
|
| - loca_buff->set_offset((loca_format == 0 ? 2 : 4) * index);
|
| - if (loca_format == 0) {
|
| - uint16_t tmp1, tmp2;
|
| - if (PREDICT_FALSE(!loca_buff->ReadU16(&tmp1) ||
|
| - !loca_buff->ReadU16(&tmp2))) {
|
| - return FONT_COMPRESSION_FAILURE();
|
| - }
|
| - // https://www.microsoft.com/typography/otspec/loca.htm
|
| - // "The actual local offset divided by 2 is stored."
|
| - offset1 = tmp1 * 2;
|
| - offset2 = tmp2 * 2;
|
| - } else if (PREDICT_FALSE(!loca_buff->ReadU32(&offset1) ||
|
| - !loca_buff->ReadU32(&offset2))) {
|
| - return FONT_COMPRESSION_FAILURE();
|
| - }
|
| -
|
| - if (offset1 != offset2) {
|
| - glyf_buff->set_offset(offset1 + 2);
|
| - if (!glyf_buff->ReadS16(x_min)) {
|
| - return FONT_COMPRESSION_FAILURE();
|
| - }
|
| - } else {
|
| - *x_min = 0;
|
| - }
|
| - return true;
|
| -}
|
| -
|
| // http://dev.w3.org/webfonts/WOFF2/spec/Overview.html#hmtx_table_format
|
| bool ReconstructTransformedHmtx(const uint8_t* transformed_buf,
|
| size_t transformed_size,
|
| @@ -784,18 +724,6 @@ bool ReconstructTransformedHmtx(const uint8_t* transformed_buf,
|
| return true;
|
| }
|
|
|
| -uint32_t ComputeChecksum(const Table* table, const uint8_t* dst) {
|
| - return ComputeULongSum(dst + table->dst_offset, table->dst_length);
|
| -}
|
| -
|
| -const Table* FindTable(TtcFont ttc_font, const std::vector<Table>& tables,
|
| - uint32_t tag) {
|
| - for (const auto i : ttc_font.table_indices) {
|
| - if (tables[i].tag == tag) return &tables[i];
|
| - }
|
| - return NULL;
|
| -}
|
| -
|
| bool Woff2Uncompress(uint8_t* dst_buf, size_t dst_size,
|
| const uint8_t* src_buf, size_t src_size) {
|
| size_t uncompressed_size = dst_size;
|
|
|