@geekybones/canvas-kit 1.1.0 → 1.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (96) hide show
  1. package/README.md +1 -2
  2. package/dist/canvas/Application.d.ts +6 -0
  3. package/dist/canvas/Application.d.ts.map +1 -1
  4. package/dist/canvas/CanvasKit.d.ts +11 -2
  5. package/dist/canvas/CanvasKit.d.ts.map +1 -1
  6. package/dist/canvas/CanvasKitActions.d.ts +3 -2
  7. package/dist/canvas/CanvasKitActions.d.ts.map +1 -1
  8. package/dist/canvas/CanvasKitOptions.d.ts +1 -0
  9. package/dist/canvas/CanvasKitOptions.d.ts.map +1 -1
  10. package/dist/canvas/ExtensionLoader.d.ts.map +1 -1
  11. package/dist/canvas-kit.js +11256 -11476
  12. package/dist/canvas-kit.js.map +1 -1
  13. package/dist/chunks/rolldown-runtime.js +13 -0
  14. package/dist/chunks/vendor-earcut.js +258 -0
  15. package/dist/chunks/vendor-earcut.js.map +1 -0
  16. package/dist/chunks/vendor-opentype.js +10440 -0
  17. package/dist/chunks/vendor-opentype.js.map +1 -0
  18. package/dist/core/BaseElement.d.ts.map +1 -1
  19. package/dist/core/Events.d.ts +4 -0
  20. package/dist/core/Events.d.ts.map +1 -1
  21. package/dist/elements/Image/ImageElement.d.ts.map +1 -1
  22. package/dist/elements/SVG/SVGElement.d.ts +1 -0
  23. package/dist/elements/SVG/SVGElement.d.ts.map +1 -1
  24. package/dist/elements/Shape/Circle/CircleOptions.d.ts +2 -2
  25. package/dist/elements/Shape/Circle/CircleOptions.d.ts.map +1 -1
  26. package/dist/elements/Shape/Circle/CircleShape.d.ts.map +1 -1
  27. package/dist/elements/Shape/Line/LineOptions.d.ts +1 -1
  28. package/dist/elements/Shape/Line/LineOptions.d.ts.map +1 -1
  29. package/dist/elements/Shape/Rectangle/RectangleOptions.d.ts +2 -2
  30. package/dist/elements/Shape/Rectangle/RectangleOptions.d.ts.map +1 -1
  31. package/dist/elements/Shape/Rectangle/RectangleShape.d.ts.map +1 -1
  32. package/dist/elements/Shape/Star/StarOptions.d.ts +2 -2
  33. package/dist/elements/Shape/Star/StarOptions.d.ts.map +1 -1
  34. package/dist/elements/Shape/Star/StarShape.d.ts.map +1 -1
  35. package/dist/elements/Shape/index.d.ts +8 -4
  36. package/dist/elements/Shape/index.d.ts.map +1 -1
  37. package/dist/elements/Text/BaseTextElement.d.ts +4 -0
  38. package/dist/elements/Text/BaseTextElement.d.ts.map +1 -1
  39. package/dist/elements/Text/Vector/shader.d.ts.map +1 -1
  40. package/dist/elements/Text/Vector/vectorLayers.d.ts.map +1 -1
  41. package/dist/extensions/fonts/FontManager.d.ts +2 -1
  42. package/dist/extensions/fonts/FontManager.d.ts.map +1 -1
  43. package/dist/extensions/fonts/index.d.ts +0 -1
  44. package/dist/extensions/fonts/index.d.ts.map +1 -1
  45. package/dist/extensions/grid/GridManager.d.ts +2 -0
  46. package/dist/extensions/grid/GridManager.d.ts.map +1 -1
  47. package/dist/extensions/interaction/BoundingBox.d.ts.map +1 -1
  48. package/dist/extensions/interaction/InteractionGestures.d.ts.map +1 -1
  49. package/dist/extensions/interaction/InteractionManager.d.ts +3 -0
  50. package/dist/extensions/interaction/InteractionManager.d.ts.map +1 -1
  51. package/dist/extensions/performance/PerformanceManager.d.ts +0 -3
  52. package/dist/extensions/performance/PerformanceManager.d.ts.map +1 -1
  53. package/dist/extensions/performance/accessor.d.ts.map +1 -1
  54. package/dist/extensions/performance/types.d.ts +0 -4
  55. package/dist/extensions/performance/types.d.ts.map +1 -1
  56. package/dist/index.d.ts +0 -1
  57. package/dist/index.d.ts.map +1 -1
  58. package/package.json +1 -2
  59. package/dist/__tests__/CanvasKit.test.d.ts +0 -2
  60. package/dist/__tests__/CanvasKit.test.d.ts.map +0 -1
  61. package/dist/__tests__/ResizeStrategy.test.d.ts +0 -2
  62. package/dist/__tests__/ResizeStrategy.test.d.ts.map +0 -1
  63. package/dist/__tests__/alignment.test.d.ts +0 -2
  64. package/dist/__tests__/alignment.test.d.ts.map +0 -1
  65. package/dist/__tests__/camera.test.d.ts +0 -2
  66. package/dist/__tests__/camera.test.d.ts.map +0 -1
  67. package/dist/__tests__/contextMenu.test.d.ts +0 -2
  68. package/dist/__tests__/contextMenu.test.d.ts.map +0 -1
  69. package/dist/__tests__/elements/image.test.d.ts +0 -2
  70. package/dist/__tests__/elements/image.test.d.ts.map +0 -1
  71. package/dist/__tests__/elements/shape.test.d.ts +0 -2
  72. package/dist/__tests__/elements/shape.test.d.ts.map +0 -1
  73. package/dist/__tests__/elements/text.test.d.ts +0 -2
  74. package/dist/__tests__/elements/text.test.d.ts.map +0 -1
  75. package/dist/__tests__/export.test.d.ts +0 -2
  76. package/dist/__tests__/export.test.d.ts.map +0 -1
  77. package/dist/__tests__/fonts.test.d.ts +0 -2
  78. package/dist/__tests__/fonts.test.d.ts.map +0 -1
  79. package/dist/__tests__/grid.test.d.ts +0 -2
  80. package/dist/__tests__/grid.test.d.ts.map +0 -1
  81. package/dist/__tests__/history.test.d.ts +0 -2
  82. package/dist/__tests__/history.test.d.ts.map +0 -1
  83. package/dist/__tests__/interaction.test.d.ts +0 -2
  84. package/dist/__tests__/interaction.test.d.ts.map +0 -1
  85. package/dist/__tests__/layering.test.d.ts +0 -2
  86. package/dist/__tests__/layering.test.d.ts.map +0 -1
  87. package/dist/__tests__/performance.test.d.ts +0 -2
  88. package/dist/__tests__/performance.test.d.ts.map +0 -1
  89. package/dist/__tests__/serialization.test.d.ts +0 -2
  90. package/dist/__tests__/serialization.test.d.ts.map +0 -1
  91. package/dist/__tests__/setup.d.ts +0 -2
  92. package/dist/__tests__/setup.d.ts.map +0 -1
  93. package/dist/__tests__/snap.test.d.ts +0 -2
  94. package/dist/__tests__/snap.test.d.ts.map +0 -1
  95. package/dist/extensions/performance/DirtyTracker.d.ts +0 -8
  96. package/dist/extensions/performance/DirtyTracker.d.ts.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vendor-opentype.js","names":[],"sources":["../../node_modules/.pnpm/opentype.js@2.0.0/node_modules/opentype.js/dist/opentype.js"],"sourcesContent":["var opentype = (() => {\n var __defProp = Object.defineProperty;\n var __getOwnPropDesc = Object.getOwnPropertyDescriptor;\n var __getOwnPropNames = Object.getOwnPropertyNames;\n var __hasOwnProp = Object.prototype.hasOwnProperty;\n var __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n };\n var __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n };\n var __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n // src/opentype.mjs\n var opentype_exports = {};\n __export(opentype_exports, {\n BoundingBox: () => bbox_default,\n Font: () => font_default,\n Glyph: () => glyph_default,\n Path: () => path_default,\n _parse: () => parse_default,\n load: () => load,\n loadSync: () => loadSync,\n parse: () => parseBuffer\n });\n\n // src/tiny-inflate@1.0.3.esm.mjs\n var TINF_OK = 0;\n var TINF_DATA_ERROR = -3;\n function Tree() {\n this.table = new Uint16Array(16);\n this.trans = new Uint16Array(288);\n }\n function Data(source, dest) {\n this.source = source;\n this.sourceIndex = 0;\n this.tag = 0;\n this.bitcount = 0;\n this.dest = dest;\n this.destLen = 0;\n this.ltree = new Tree();\n this.dtree = new Tree();\n }\n var sltree = new Tree();\n var sdtree = new Tree();\n var length_bits = new Uint8Array(30);\n var length_base = new Uint16Array(30);\n var dist_bits = new Uint8Array(30);\n var dist_base = new Uint16Array(30);\n var clcidx = new Uint8Array([\n 16,\n 17,\n 18,\n 0,\n 8,\n 7,\n 9,\n 6,\n 10,\n 5,\n 11,\n 4,\n 12,\n 3,\n 13,\n 2,\n 14,\n 1,\n 15\n ]);\n var code_tree = new Tree();\n var lengths = new Uint8Array(288 + 32);\n function tinf_build_bits_base(bits, base, delta, first) {\n var i, sum;\n for (i = 0; i < delta; ++i) bits[i] = 0;\n for (i = 0; i < 30 - delta; ++i) bits[i + delta] = i / delta | 0;\n for (sum = first, i = 0; i < 30; ++i) {\n base[i] = sum;\n sum += 1 << bits[i];\n }\n }\n function tinf_build_fixed_trees(lt, dt) {\n var i;\n for (i = 0; i < 7; ++i) lt.table[i] = 0;\n lt.table[7] = 24;\n lt.table[8] = 152;\n lt.table[9] = 112;\n for (i = 0; i < 24; ++i) lt.trans[i] = 256 + i;\n for (i = 0; i < 144; ++i) lt.trans[24 + i] = i;\n for (i = 0; i < 8; ++i) lt.trans[24 + 144 + i] = 280 + i;\n for (i = 0; i < 112; ++i) lt.trans[24 + 144 + 8 + i] = 144 + i;\n for (i = 0; i < 5; ++i) dt.table[i] = 0;\n dt.table[5] = 32;\n for (i = 0; i < 32; ++i) dt.trans[i] = i;\n }\n var offs = new Uint16Array(16);\n function tinf_build_tree(t, lengths2, off, num) {\n var i, sum;\n for (i = 0; i < 16; ++i) t.table[i] = 0;\n for (i = 0; i < num; ++i) t.table[lengths2[off + i]]++;\n t.table[0] = 0;\n for (sum = 0, i = 0; i < 16; ++i) {\n offs[i] = sum;\n sum += t.table[i];\n }\n for (i = 0; i < num; ++i) {\n if (lengths2[off + i]) t.trans[offs[lengths2[off + i]]++] = i;\n }\n }\n function tinf_getbit(d) {\n if (!d.bitcount--) {\n d.tag = d.source[d.sourceIndex++];\n d.bitcount = 7;\n }\n var bit = d.tag & 1;\n d.tag >>>= 1;\n return bit;\n }\n function tinf_read_bits(d, num, base) {\n if (!num)\n return base;\n while (d.bitcount < 24) {\n d.tag |= d.source[d.sourceIndex++] << d.bitcount;\n d.bitcount += 8;\n }\n var val = d.tag & 65535 >>> 16 - num;\n d.tag >>>= num;\n d.bitcount -= num;\n return val + base;\n }\n function tinf_decode_symbol(d, t) {\n while (d.bitcount < 24) {\n d.tag |= d.source[d.sourceIndex++] << d.bitcount;\n d.bitcount += 8;\n }\n var sum = 0, cur = 0, len = 0;\n var tag = d.tag;\n do {\n cur = 2 * cur + (tag & 1);\n tag >>>= 1;\n ++len;\n sum += t.table[len];\n cur -= t.table[len];\n } while (cur >= 0);\n d.tag = tag;\n d.bitcount -= len;\n return t.trans[sum + cur];\n }\n function tinf_decode_trees(d, lt, dt) {\n var hlit, hdist, hclen;\n var i, num, length;\n hlit = tinf_read_bits(d, 5, 257);\n hdist = tinf_read_bits(d, 5, 1);\n hclen = tinf_read_bits(d, 4, 4);\n for (i = 0; i < 19; ++i) lengths[i] = 0;\n for (i = 0; i < hclen; ++i) {\n var clen = tinf_read_bits(d, 3, 0);\n lengths[clcidx[i]] = clen;\n }\n tinf_build_tree(code_tree, lengths, 0, 19);\n for (num = 0; num < hlit + hdist; ) {\n var sym = tinf_decode_symbol(d, code_tree);\n switch (sym) {\n case 16:\n var prev = lengths[num - 1];\n for (length = tinf_read_bits(d, 2, 3); length; --length) {\n lengths[num++] = prev;\n }\n break;\n case 17:\n for (length = tinf_read_bits(d, 3, 3); length; --length) {\n lengths[num++] = 0;\n }\n break;\n case 18:\n for (length = tinf_read_bits(d, 7, 11); length; --length) {\n lengths[num++] = 0;\n }\n break;\n default:\n lengths[num++] = sym;\n break;\n }\n }\n tinf_build_tree(lt, lengths, 0, hlit);\n tinf_build_tree(dt, lengths, hlit, hdist);\n }\n function tinf_inflate_block_data(d, lt, dt) {\n for (; ; ) {\n var sym = tinf_decode_symbol(d, lt);\n if (sym === 256) {\n return TINF_OK;\n }\n if (sym < 256) {\n d.dest[d.destLen++] = sym;\n } else {\n var length, dist, offs2;\n var i;\n sym -= 257;\n length = tinf_read_bits(d, length_bits[sym], length_base[sym]);\n dist = tinf_decode_symbol(d, dt);\n offs2 = d.destLen - tinf_read_bits(d, dist_bits[dist], dist_base[dist]);\n for (i = offs2; i < offs2 + length; ++i) {\n d.dest[d.destLen++] = d.dest[i];\n }\n }\n }\n }\n function tinf_inflate_uncompressed_block(d) {\n var length, invlength;\n var i;\n while (d.bitcount > 8) {\n d.sourceIndex--;\n d.bitcount -= 8;\n }\n length = d.source[d.sourceIndex + 1];\n length = 256 * length + d.source[d.sourceIndex];\n invlength = d.source[d.sourceIndex + 3];\n invlength = 256 * invlength + d.source[d.sourceIndex + 2];\n if (length !== (~invlength & 65535))\n return TINF_DATA_ERROR;\n d.sourceIndex += 4;\n for (i = length; i; --i)\n d.dest[d.destLen++] = d.source[d.sourceIndex++];\n d.bitcount = 0;\n return TINF_OK;\n }\n function tinf_uncompress(source, dest) {\n var d = new Data(source, dest);\n var bfinal, btype, res;\n do {\n bfinal = tinf_getbit(d);\n btype = tinf_read_bits(d, 2, 0);\n switch (btype) {\n case 0:\n res = tinf_inflate_uncompressed_block(d);\n break;\n case 1:\n res = tinf_inflate_block_data(d, sltree, sdtree);\n break;\n case 2:\n tinf_decode_trees(d, d.ltree, d.dtree);\n res = tinf_inflate_block_data(d, d.ltree, d.dtree);\n break;\n default:\n res = TINF_DATA_ERROR;\n }\n if (res !== TINF_OK)\n throw new Error(\"Data error\");\n } while (!bfinal);\n if (d.destLen < d.dest.length) {\n if (typeof d.dest.slice === \"function\")\n return d.dest.slice(0, d.destLen);\n else\n return d.dest.subarray(0, d.destLen);\n }\n return d.dest;\n }\n tinf_build_fixed_trees(sltree, sdtree);\n tinf_build_bits_base(length_bits, length_base, 4, 3);\n tinf_build_bits_base(dist_bits, dist_base, 2, 1);\n length_bits[28] = 0;\n length_base[28] = 258;\n\n // src/bbox.mjs\n function derive(v0, v1, v2, v3, t) {\n return Math.pow(1 - t, 3) * v0 + 3 * Math.pow(1 - t, 2) * t * v1 + 3 * (1 - t) * Math.pow(t, 2) * v2 + Math.pow(t, 3) * v3;\n }\n function BoundingBox() {\n this.x1 = Number.NaN;\n this.y1 = Number.NaN;\n this.x2 = Number.NaN;\n this.y2 = Number.NaN;\n }\n BoundingBox.prototype.isEmpty = function() {\n return isNaN(this.x1) || isNaN(this.y1) || isNaN(this.x2) || isNaN(this.y2);\n };\n BoundingBox.prototype.addPoint = function(x, y) {\n if (typeof x === \"number\") {\n if (isNaN(this.x1) || isNaN(this.x2)) {\n this.x1 = x;\n this.x2 = x;\n }\n if (x < this.x1) {\n this.x1 = x;\n }\n if (x > this.x2) {\n this.x2 = x;\n }\n }\n if (typeof y === \"number\") {\n if (isNaN(this.y1) || isNaN(this.y2)) {\n this.y1 = y;\n this.y2 = y;\n }\n if (y < this.y1) {\n this.y1 = y;\n }\n if (y > this.y2) {\n this.y2 = y;\n }\n }\n };\n BoundingBox.prototype.addX = function(x) {\n this.addPoint(x, null);\n };\n BoundingBox.prototype.addY = function(y) {\n this.addPoint(null, y);\n };\n BoundingBox.prototype.addBezier = function(x0, y0, x1, y1, x2, y2, x, y) {\n const p0 = [x0, y0];\n const p1 = [x1, y1];\n const p2 = [x2, y2];\n const p3 = [x, y];\n this.addPoint(x0, y0);\n this.addPoint(x, y);\n for (let i = 0; i <= 1; i++) {\n const b = 6 * p0[i] - 12 * p1[i] + 6 * p2[i];\n const a = -3 * p0[i] + 9 * p1[i] - 9 * p2[i] + 3 * p3[i];\n const c = 3 * p1[i] - 3 * p0[i];\n if (a === 0) {\n if (b === 0) continue;\n const t = -c / b;\n if (0 < t && t < 1) {\n if (i === 0) this.addX(derive(p0[i], p1[i], p2[i], p3[i], t));\n if (i === 1) this.addY(derive(p0[i], p1[i], p2[i], p3[i], t));\n }\n continue;\n }\n const b2ac = Math.pow(b, 2) - 4 * c * a;\n if (b2ac < 0) continue;\n const t1 = (-b + Math.sqrt(b2ac)) / (2 * a);\n if (0 < t1 && t1 < 1) {\n if (i === 0) this.addX(derive(p0[i], p1[i], p2[i], p3[i], t1));\n if (i === 1) this.addY(derive(p0[i], p1[i], p2[i], p3[i], t1));\n }\n const t2 = (-b - Math.sqrt(b2ac)) / (2 * a);\n if (0 < t2 && t2 < 1) {\n if (i === 0) this.addX(derive(p0[i], p1[i], p2[i], p3[i], t2));\n if (i === 1) this.addY(derive(p0[i], p1[i], p2[i], p3[i], t2));\n }\n }\n };\n BoundingBox.prototype.addQuad = function(x0, y0, x1, y1, x, y) {\n const cp1x = x0 + 2 / 3 * (x1 - x0);\n const cp1y = y0 + 2 / 3 * (y1 - y0);\n const cp2x = cp1x + 1 / 3 * (x - x0);\n const cp2y = cp1y + 1 / 3 * (y - y0);\n this.addBezier(x0, y0, cp1x, cp1y, cp2x, cp2y, x, y);\n };\n var bbox_default = BoundingBox;\n\n // src/path.mjs\n function Path() {\n this.commands = [];\n this.fill = \"black\";\n this.stroke = null;\n this.strokeWidth = 1;\n }\n var decimalRoundingCache = {};\n function roundDecimal(float, places) {\n const integerPart = Math.floor(float);\n const decimalPart = float - integerPart;\n if (!decimalRoundingCache[places]) {\n decimalRoundingCache[places] = {};\n }\n if (decimalRoundingCache[places][decimalPart] !== void 0) {\n const roundedDecimalPart2 = decimalRoundingCache[places][decimalPart];\n return integerPart + roundedDecimalPart2;\n }\n const roundedDecimalPart = +(Math.round(decimalPart + \"e+\" + places) + \"e-\" + places);\n decimalRoundingCache[places][decimalPart] = roundedDecimalPart;\n return integerPart + roundedDecimalPart;\n }\n function optimizeCommands(commands) {\n let subpaths = [[]];\n let startX = 0, startY = 0;\n for (let i = 0; i < commands.length; i += 1) {\n const subpath = subpaths[subpaths.length - 1];\n const cmd = commands[i];\n const firstCommand = subpath[0];\n const secondCommand = subpath[1];\n const previousCommand = subpath[subpath.length - 1];\n const nextCommand = commands[i + 1];\n subpath.push(cmd);\n if (cmd.type === \"M\") {\n startX = cmd.x;\n startY = cmd.y;\n } else if (cmd.type === \"L\" && (!nextCommand || nextCommand.type === \"Z\")) {\n if (!(Math.abs(cmd.x - startX) > 1 || Math.abs(cmd.y - startY) > 1)) {\n subpath.pop();\n }\n } else if (cmd.type === \"L\" && previousCommand && previousCommand.x === cmd.x && previousCommand.y === cmd.y) {\n subpath.pop();\n } else if (cmd.type === \"Z\") {\n if (firstCommand && secondCommand && previousCommand && firstCommand.type === \"M\" && secondCommand.type === \"L\" && previousCommand.type === \"L\" && previousCommand.x === firstCommand.x && previousCommand.y === firstCommand.y) {\n subpath.shift();\n subpath[0].type = \"M\";\n }\n if (i + 1 < commands.length) {\n subpaths.push([]);\n }\n }\n }\n commands = [].concat.apply([], subpaths);\n return commands;\n }\n function createSVGParsingOptions(options) {\n const defaultOptions = {\n decimalPlaces: 2,\n optimize: true,\n flipY: true,\n flipYBase: void 0,\n scale: 1,\n x: 0,\n y: 0\n };\n const newOptions = Object.assign({}, defaultOptions, options);\n return newOptions;\n }\n function createSVGOutputOptions(options) {\n if (parseInt(options) === options) {\n options = { decimalPlaces: options, flipY: false };\n }\n const defaultOptions = {\n decimalPlaces: 2,\n optimize: true,\n flipY: true,\n flipYBase: void 0\n };\n const newOptions = Object.assign({}, defaultOptions, options);\n return newOptions;\n }\n Path.prototype.fromSVG = function(pathData, options = {}) {\n if (typeof SVGPathElement !== \"undefined\" && pathData instanceof SVGPathElement) {\n pathData = pathData.getAttribute(\"d\");\n }\n options = createSVGParsingOptions(options);\n this.commands = [];\n const number = \"0123456789\";\n const supportedCommands = \"MmLlQqCcZzHhVv\";\n const unsupportedCommands = \"SsTtAa\";\n const sign = \"-+\";\n let command = {};\n let buffer = [\"\"];\n let isUnexpected = false;\n function parseBuffer2(buffer2) {\n return buffer2.filter((b) => b.length).map((b) => {\n let float = parseFloat(b);\n if (options.decimalPlaces || options.decimalPlaces === 0) {\n float = roundDecimal(float, options.decimalPlaces);\n }\n return float;\n });\n }\n function makeRelative(buffer2) {\n if (!this.commands.length) {\n return buffer2;\n }\n const lastCommand = this.commands[this.commands.length - 1];\n for (let i = 0; i < buffer2.length; i++) {\n buffer2[i] += lastCommand[i & 1 ? \"y\" : \"x\"];\n }\n return buffer2;\n }\n function applyCommand() {\n if (command.type === void 0) {\n return;\n }\n const commandType = command.type.toUpperCase();\n const relative = commandType !== \"Z\" && command.type.toUpperCase() !== command.type;\n let parsedBuffer = parseBuffer2(buffer);\n buffer = [\"\"];\n if (!parsedBuffer.length && commandType !== \"Z\") {\n return;\n }\n if (relative && commandType !== \"H\" && commandType !== \"V\") {\n parsedBuffer = makeRelative.apply(this, [parsedBuffer]);\n }\n const currentX = this.commands.length ? this.commands[this.commands.length - 1].x || 0 : 0;\n const currentY = this.commands.length ? this.commands[this.commands.length - 1].y || 0 : 0;\n switch (commandType) {\n case \"M\":\n this.moveTo(...parsedBuffer);\n break;\n case \"L\":\n this.lineTo(...parsedBuffer);\n break;\n case \"V\":\n for (let i = 0; i < parsedBuffer.length; i++) {\n let offset = 0;\n if (relative) {\n offset = this.commands.length ? this.commands[this.commands.length - 1].y || 0 : 0;\n }\n this.lineTo(currentX, parsedBuffer[i] + offset);\n }\n break;\n case \"H\":\n for (let i = 0; i < parsedBuffer.length; i++) {\n let offset = 0;\n if (relative) {\n offset = this.commands.length ? this.commands[this.commands.length - 1].x || 0 : 0;\n }\n this.lineTo(parsedBuffer[i] + offset, currentY);\n }\n break;\n case \"C\":\n this.bezierCurveTo(...parsedBuffer);\n break;\n case \"Q\":\n this.quadraticCurveTo(...parsedBuffer);\n break;\n case \"Z\":\n if (this.commands.length < 1 || this.commands[this.commands.length - 1].type !== \"Z\") {\n this.close();\n }\n break;\n }\n if (this.commands.length) {\n for (const prop in this.commands[this.commands.length - 1]) {\n if (this.commands[this.commands.length - 1][prop] === void 0) {\n this.commands[this.commands.length - 1][prop] = 0;\n }\n }\n }\n }\n for (let i = 0; i < pathData.length; i++) {\n const token = pathData.charAt(i);\n const lastBuffer = buffer[buffer.length - 1];\n if (number.indexOf(token) > -1) {\n buffer[buffer.length - 1] += token;\n } else if (sign.indexOf(token) > -1) {\n if (!command.type && !this.commands.length) {\n command.type = \"L\";\n }\n if (token === \"-\") {\n if (!command.type || lastBuffer.indexOf(\"-\") > 0) {\n isUnexpected = true;\n } else if (lastBuffer.length) {\n buffer.push(\"-\");\n } else {\n buffer[buffer.length - 1] = token;\n }\n } else {\n if (!command.type || lastBuffer.length > 0) {\n isUnexpected = true;\n } else {\n continue;\n }\n }\n } else if (supportedCommands.indexOf(token) > -1) {\n if (command.type) {\n applyCommand.apply(this);\n command = { type: token };\n } else {\n command.type = token;\n }\n } else if (unsupportedCommands.indexOf(token) > -1) {\n throw new Error(\"Unsupported path command: \" + token + \". Currently supported commands are \" + supportedCommands.split(\"\").join(\", \") + \".\");\n } else if (\" ,\t\\n\\r\\f\\v\".indexOf(token) > -1) {\n buffer.push(\"\");\n } else if (token === \".\") {\n if (!command.type || lastBuffer.indexOf(token) > -1) {\n isUnexpected = true;\n } else {\n buffer[buffer.length - 1] += token;\n }\n } else {\n isUnexpected = true;\n }\n if (isUnexpected) {\n throw new Error(\"Unexpected character: \" + token + \" at offset \" + i);\n }\n }\n applyCommand.apply(this);\n if (options.optimize) {\n this.commands = optimizeCommands(this.commands);\n }\n const flipY = options.flipY;\n let flipYBase = options.flipYBase;\n if (flipY === true && options.flipYBase === void 0) {\n const boundingBox = this.getBoundingBox();\n flipYBase = boundingBox.y1 + boundingBox.y2;\n }\n for (const i in this.commands) {\n const cmd = this.commands[i];\n for (const prop in cmd) {\n if ([\"x\", \"x1\", \"x2\"].includes(prop)) {\n this.commands[i][prop] = options.x + cmd[prop] * options.scale;\n } else if ([\"y\", \"y1\", \"y2\"].includes(prop)) {\n this.commands[i][prop] = options.y + (flipY ? flipYBase - cmd[prop] : cmd[prop]) * options.scale;\n }\n }\n }\n return this;\n };\n Path.fromSVG = function(path, options) {\n const newPath = new Path();\n return newPath.fromSVG(path, options);\n };\n Path.prototype.moveTo = function(x, y) {\n this.commands.push({\n type: \"M\",\n x,\n y\n });\n };\n Path.prototype.lineTo = function(x, y) {\n this.commands.push({\n type: \"L\",\n x,\n y\n });\n };\n Path.prototype.curveTo = Path.prototype.bezierCurveTo = function(x1, y1, x2, y2, x, y) {\n this.commands.push({\n type: \"C\",\n x1,\n y1,\n x2,\n y2,\n x,\n y\n });\n };\n Path.prototype.quadTo = Path.prototype.quadraticCurveTo = function(x1, y1, x, y) {\n this.commands.push({\n type: \"Q\",\n x1,\n y1,\n x,\n y\n });\n };\n Path.prototype.close = Path.prototype.closePath = function() {\n this.commands.push({\n type: \"Z\"\n });\n };\n Path.prototype.extend = function(pathOrCommands) {\n if (pathOrCommands.commands) {\n pathOrCommands = pathOrCommands.commands;\n } else if (pathOrCommands instanceof bbox_default) {\n const box = pathOrCommands;\n this.moveTo(box.x1, box.y1);\n this.lineTo(box.x2, box.y1);\n this.lineTo(box.x2, box.y2);\n this.lineTo(box.x1, box.y2);\n this.close();\n return;\n }\n Array.prototype.push.apply(this.commands, pathOrCommands);\n };\n Path.prototype.getBoundingBox = function() {\n const box = new bbox_default();\n let startX = 0;\n let startY = 0;\n let prevX = 0;\n let prevY = 0;\n for (let i = 0; i < this.commands.length; i++) {\n const cmd = this.commands[i];\n switch (cmd.type) {\n case \"M\":\n box.addPoint(cmd.x, cmd.y);\n startX = prevX = cmd.x;\n startY = prevY = cmd.y;\n break;\n case \"L\":\n box.addPoint(cmd.x, cmd.y);\n prevX = cmd.x;\n prevY = cmd.y;\n break;\n case \"Q\":\n box.addQuad(prevX, prevY, cmd.x1, cmd.y1, cmd.x, cmd.y);\n prevX = cmd.x;\n prevY = cmd.y;\n break;\n case \"C\":\n box.addBezier(prevX, prevY, cmd.x1, cmd.y1, cmd.x2, cmd.y2, cmd.x, cmd.y);\n prevX = cmd.x;\n prevY = cmd.y;\n break;\n case \"Z\":\n prevX = startX;\n prevY = startY;\n break;\n default:\n throw new Error(\"Unexpected path command \" + cmd.type);\n }\n }\n if (box.isEmpty()) {\n box.addPoint(0, 0);\n }\n return box;\n };\n Path.prototype.draw = function(ctx) {\n const layers = this._layers;\n if (layers && layers.length) {\n for (let l = 0; l < layers.length; l++) {\n this.draw.call(layers[l], ctx);\n }\n return;\n }\n const image = this._image;\n if (image) {\n ctx.drawImage(image.image, image.x, image.y, image.width, image.height);\n return;\n }\n ctx.beginPath();\n for (let i = 0; i < this.commands.length; i += 1) {\n const cmd = this.commands[i];\n if (cmd.type === \"M\") {\n ctx.moveTo(cmd.x, cmd.y);\n } else if (cmd.type === \"L\") {\n ctx.lineTo(cmd.x, cmd.y);\n } else if (cmd.type === \"C\") {\n ctx.bezierCurveTo(cmd.x1, cmd.y1, cmd.x2, cmd.y2, cmd.x, cmd.y);\n } else if (cmd.type === \"Q\") {\n ctx.quadraticCurveTo(cmd.x1, cmd.y1, cmd.x, cmd.y);\n } else if (cmd.type === \"Z\" && this.stroke && this.strokeWidth) {\n ctx.closePath();\n }\n }\n if (this.fill) {\n ctx.fillStyle = this.fill;\n ctx.fill();\n }\n if (this.stroke) {\n ctx.strokeStyle = this.stroke;\n ctx.lineWidth = this.strokeWidth;\n ctx.stroke();\n }\n };\n Path.prototype.toPathData = function(options) {\n options = createSVGOutputOptions(options);\n function floatToString(v) {\n const rounded = roundDecimal(v, options.decimalPlaces);\n if (Math.round(v) === rounded) {\n return \"\" + rounded;\n } else {\n return rounded.toFixed(options.decimalPlaces);\n }\n }\n function packValues() {\n let s = \"\";\n for (let i = 0; i < arguments.length; i += 1) {\n const v = arguments[i];\n if (v >= 0 && i > 0) {\n s += \" \";\n }\n s += floatToString(v);\n }\n return s;\n }\n let commandsCopy = this.commands;\n if (options.optimize) {\n commandsCopy = JSON.parse(JSON.stringify(this.commands));\n commandsCopy = optimizeCommands(commandsCopy);\n }\n const flipY = options.flipY;\n let flipYBase = options.flipYBase;\n if (flipY === true && flipYBase === void 0) {\n const tempPath = new Path();\n tempPath.extend(commandsCopy);\n const boundingBox = tempPath.getBoundingBox();\n flipYBase = boundingBox.y1 + boundingBox.y2;\n }\n let d = \"\";\n for (let i = 0; i < commandsCopy.length; i += 1) {\n const cmd = commandsCopy[i];\n if (cmd.type === \"M\") {\n d += \"M\" + packValues(\n cmd.x,\n flipY ? flipYBase - cmd.y : cmd.y\n );\n } else if (cmd.type === \"L\") {\n d += \"L\" + packValues(\n cmd.x,\n flipY ? flipYBase - cmd.y : cmd.y\n );\n } else if (cmd.type === \"C\") {\n d += \"C\" + packValues(\n cmd.x1,\n flipY ? flipYBase - cmd.y1 : cmd.y1,\n cmd.x2,\n flipY ? flipYBase - cmd.y2 : cmd.y2,\n cmd.x,\n flipY ? flipYBase - cmd.y : cmd.y\n );\n } else if (cmd.type === \"Q\") {\n d += \"Q\" + packValues(\n cmd.x1,\n flipY ? flipYBase - cmd.y1 : cmd.y1,\n cmd.x,\n flipY ? flipYBase - cmd.y : cmd.y\n );\n } else if (cmd.type === \"Z\") {\n d += \"Z\";\n }\n }\n return d;\n };\n Path.prototype.toSVG = function(options, pathData) {\n if (this._layers && this._layers.length) {\n console.warn(\"toSVG() does not support colr font layers yet\");\n }\n if (this._image) {\n console.warn(\"toSVG() does not support SVG glyphs yet\");\n }\n if (!pathData) {\n pathData = this.toPathData(options);\n }\n let svg = '<path d=\"';\n svg += pathData;\n svg += '\"';\n if (this.fill !== void 0 && this.fill !== \"black\") {\n if (this.fill === null) {\n svg += ' fill=\"none\"';\n } else {\n svg += ' fill=\"' + this.fill + '\"';\n }\n }\n if (this.stroke) {\n svg += ' stroke=\"' + this.stroke + '\" stroke-width=\"' + this.strokeWidth + '\"';\n }\n svg += \"/>\";\n return svg;\n };\n Path.prototype.toDOMElement = function(options, pathData) {\n if (this._layers && this._layers.length) {\n console.warn(\"toDOMElement() does not support colr font layers yet\");\n }\n if (!pathData) {\n pathData = this.toPathData(options);\n }\n const newPath = document.createElementNS(\"http://www.w3.org/2000/svg\", \"path\");\n newPath.setAttribute(\"d\", pathData);\n if (this.fill !== void 0 && this.fill !== \"black\") {\n if (this.fill === null) {\n newPath.setAttribute(\"fill\", \"none\");\n } else {\n newPath.setAttribute(\"fill\", this.fill);\n }\n }\n if (this.stroke) {\n newPath.setAttribute(\"stroke\", this.stroke);\n newPath.setAttribute(\"stroke-width\", this.strokeWidth);\n }\n return newPath;\n };\n var path_default = Path;\n\n // src/check.mjs\n function fail(message) {\n throw new Error(message);\n }\n function argument(predicate, message) {\n if (!predicate) {\n fail(message);\n }\n }\n var check_default = { fail, argument, assert: argument };\n\n // src/types.mjs\n var LIMIT16 = 32768;\n var LIMIT32 = 2147483648;\n var MIN_16_16 = -(1 << 15);\n var MAX_16_16 = (1 << 15) - 1 + 1 / (1 << 16);\n var decode = {};\n var encode = {};\n var sizeOf = {};\n function constant(v) {\n return function() {\n return v;\n };\n }\n encode.BYTE = function(v) {\n check_default.argument(v >= 0 && v <= 255, \"Byte value should be between 0 and 255.\");\n return [v];\n };\n sizeOf.BYTE = constant(1);\n encode.CHAR = function(v) {\n return [v.charCodeAt(0)];\n };\n sizeOf.CHAR = constant(1);\n encode.CHARARRAY = function(v) {\n if (v === null || typeof v === \"undefined\") {\n v = \"\";\n console.warn(\"CHARARRAY with undefined or null value encountered and treated as an empty string. This is probably caused by a missing glyph name.\");\n }\n const b = [];\n for (let i = 0; i < v.length; i += 1) {\n b[i] = v.charCodeAt(i);\n }\n return b;\n };\n sizeOf.CHARARRAY = function(v) {\n if (typeof v === \"undefined\") {\n return 0;\n }\n return v.length;\n };\n encode.USHORT = function(v) {\n return [v >> 8 & 255, v & 255];\n };\n sizeOf.USHORT = constant(2);\n encode.SHORT = function(v) {\n if (v >= LIMIT16) {\n v = -(2 * LIMIT16 - v);\n }\n return [v >> 8 & 255, v & 255];\n };\n sizeOf.SHORT = constant(2);\n encode.UINT24 = function(v) {\n return [v >> 16 & 255, v >> 8 & 255, v & 255];\n };\n sizeOf.UINT24 = constant(3);\n encode.ULONG = function(v) {\n return [v >> 24 & 255, v >> 16 & 255, v >> 8 & 255, v & 255];\n };\n sizeOf.ULONG = constant(4);\n encode.LONG = function(v) {\n if (v >= LIMIT32) {\n v = -(2 * LIMIT32 - v);\n }\n return [v >> 24 & 255, v >> 16 & 255, v >> 8 & 255, v & 255];\n };\n sizeOf.LONG = constant(4);\n encode.FLOAT = function(v) {\n if (v > MAX_16_16 || v < MIN_16_16) {\n throw new Error(`Value ${v} is outside the range of representable values in 16.16 format`);\n }\n const fixedValue = Math.round(v * (1 << 16)) << 0;\n return encode.ULONG(fixedValue);\n };\n sizeOf.FLOAT = sizeOf.ULONG;\n encode.FIXED = encode.ULONG;\n sizeOf.FIXED = sizeOf.ULONG;\n encode.FWORD = encode.SHORT;\n sizeOf.FWORD = sizeOf.SHORT;\n encode.UFWORD = encode.USHORT;\n sizeOf.UFWORD = sizeOf.USHORT;\n encode.F2DOT14 = function(v) {\n return encode.USHORT(v * 16384);\n };\n sizeOf.F2DOT14 = sizeOf.USHORT;\n encode.LONGDATETIME = function(v) {\n return [0, 0, 0, 0, v >> 24 & 255, v >> 16 & 255, v >> 8 & 255, v & 255];\n };\n sizeOf.LONGDATETIME = constant(8);\n encode.TAG = function(v) {\n check_default.argument(v.length === 4, \"Tag should be exactly 4 ASCII characters.\");\n return [\n v.charCodeAt(0),\n v.charCodeAt(1),\n v.charCodeAt(2),\n v.charCodeAt(3)\n ];\n };\n sizeOf.TAG = constant(4);\n encode.Card8 = encode.BYTE;\n sizeOf.Card8 = sizeOf.BYTE;\n encode.Card16 = encode.USHORT;\n sizeOf.Card16 = sizeOf.USHORT;\n encode.OffSize = encode.BYTE;\n sizeOf.OffSize = sizeOf.BYTE;\n encode.SID = encode.USHORT;\n sizeOf.SID = sizeOf.USHORT;\n encode.NUMBER = function(v) {\n if (v >= -107 && v <= 107) {\n return [v + 139];\n } else if (v >= 108 && v <= 1131) {\n v = v - 108;\n return [(v >> 8) + 247, v & 255];\n } else if (v >= -1131 && v <= -108) {\n v = -v - 108;\n return [(v >> 8) + 251, v & 255];\n } else if (v >= -32768 && v <= 32767) {\n return encode.NUMBER16(v);\n } else {\n return encode.NUMBER32(v);\n }\n };\n sizeOf.NUMBER = function(v) {\n return encode.NUMBER(v).length;\n };\n encode.NUMBER16 = function(v) {\n return [28, v >> 8 & 255, v & 255];\n };\n sizeOf.NUMBER16 = constant(3);\n encode.NUMBER32 = function(v) {\n return [29, v >> 24 & 255, v >> 16 & 255, v >> 8 & 255, v & 255];\n };\n sizeOf.NUMBER32 = constant(5);\n encode.REAL = function(v) {\n let value = v.toString();\n const m = /\\.(\\d*?)(?:9{5,20}|0{5,20})\\d{0,2}(?:e(.+)|$)/.exec(value);\n if (m) {\n const epsilon = parseFloat(\"1e\" + ((m[2] ? +m[2] : 0) + m[1].length));\n value = (Math.round(v * epsilon) / epsilon).toString();\n }\n let nibbles = \"\";\n for (let i = 0, ii = value.length; i < ii; i += 1) {\n const c = value[i];\n if (c === \"e\") {\n nibbles += value[++i] === \"-\" ? \"c\" : \"b\";\n } else if (c === \".\") {\n nibbles += \"a\";\n } else if (c === \"-\") {\n nibbles += \"e\";\n } else {\n nibbles += c;\n }\n }\n nibbles += nibbles.length & 1 ? \"f\" : \"ff\";\n const out = [30];\n for (let i = 0, ii = nibbles.length; i < ii; i += 2) {\n out.push(parseInt(nibbles.substr(i, 2), 16));\n }\n return out;\n };\n sizeOf.REAL = function(v) {\n return encode.REAL(v).length;\n };\n encode.NAME = encode.CHARARRAY;\n sizeOf.NAME = sizeOf.CHARARRAY;\n encode.STRING = encode.CHARARRAY;\n sizeOf.STRING = sizeOf.CHARARRAY;\n decode.UTF8 = function(data, offset, numBytes) {\n const codePoints = [];\n const numChars = numBytes;\n for (let j = 0; j < numChars; j++, offset += 1) {\n codePoints[j] = data.getUint8(offset);\n }\n return String.fromCharCode.apply(null, codePoints);\n };\n decode.UTF16 = function(data, offset, numBytes) {\n const codePoints = [];\n const numChars = numBytes / 2;\n for (let j = 0; j < numChars; j++, offset += 2) {\n codePoints[j] = data.getUint16(offset);\n }\n return String.fromCharCode.apply(null, codePoints);\n };\n encode.UTF16 = function(v) {\n const b = [];\n for (let i = 0; i < v.length; i += 1) {\n const codepoint = v.charCodeAt(i);\n b[b.length] = codepoint >> 8 & 255;\n b[b.length] = codepoint & 255;\n }\n return b;\n };\n sizeOf.UTF16 = function(v) {\n return v.length * 2;\n };\n var eightBitMacEncodings = {\n \"x-mac-croatian\": (\n // Python: 'mac_croatian'\n \"\\xC4\\xC5\\xC7\\xC9\\xD1\\xD6\\xDC\\xE1\\xE0\\xE2\\xE4\\xE3\\xE5\\xE7\\xE9\\xE8\\xEA\\xEB\\xED\\xEC\\xEE\\xEF\\xF1\\xF3\\xF2\\xF4\\xF6\\xF5\\xFA\\xF9\\xFB\\xFC\\u2020\\xB0\\xA2\\xA3\\xA7\\u2022\\xB6\\xDF\\xAE\\u0160\\u2122\\xB4\\xA8\\u2260\\u017D\\xD8\\u221E\\xB1\\u2264\\u2265\\u2206\\xB5\\u2202\\u2211\\u220F\\u0161\\u222B\\xAA\\xBA\\u03A9\\u017E\\xF8\\xBF\\xA1\\xAC\\u221A\\u0192\\u2248\\u0106\\xAB\\u010C\\u2026\\xA0\\xC0\\xC3\\xD5\\u0152\\u0153\\u0110\\u2014\\u201C\\u201D\\u2018\\u2019\\xF7\\u25CA\\uF8FF\\xA9\\u2044\\u20AC\\u2039\\u203A\\xC6\\xBB\\u2013\\xB7\\u201A\\u201E\\u2030\\xC2\\u0107\\xC1\\u010D\\xC8\\xCD\\xCE\\xCF\\xCC\\xD3\\xD4\\u0111\\xD2\\xDA\\xDB\\xD9\\u0131\\u02C6\\u02DC\\xAF\\u03C0\\xCB\\u02DA\\xB8\\xCA\\xE6\\u02C7\"\n ),\n \"x-mac-cyrillic\": (\n // Python: 'mac_cyrillic'\n \"\\u0410\\u0411\\u0412\\u0413\\u0414\\u0415\\u0416\\u0417\\u0418\\u0419\\u041A\\u041B\\u041C\\u041D\\u041E\\u041F\\u0420\\u0421\\u0422\\u0423\\u0424\\u0425\\u0426\\u0427\\u0428\\u0429\\u042A\\u042B\\u042C\\u042D\\u042E\\u042F\\u2020\\xB0\\u0490\\xA3\\xA7\\u2022\\xB6\\u0406\\xAE\\xA9\\u2122\\u0402\\u0452\\u2260\\u0403\\u0453\\u221E\\xB1\\u2264\\u2265\\u0456\\xB5\\u0491\\u0408\\u0404\\u0454\\u0407\\u0457\\u0409\\u0459\\u040A\\u045A\\u0458\\u0405\\xAC\\u221A\\u0192\\u2248\\u2206\\xAB\\xBB\\u2026\\xA0\\u040B\\u045B\\u040C\\u045C\\u0455\\u2013\\u2014\\u201C\\u201D\\u2018\\u2019\\xF7\\u201E\\u040E\\u045E\\u040F\\u045F\\u2116\\u0401\\u0451\\u044F\\u0430\\u0431\\u0432\\u0433\\u0434\\u0435\\u0436\\u0437\\u0438\\u0439\\u043A\\u043B\\u043C\\u043D\\u043E\\u043F\\u0440\\u0441\\u0442\\u0443\\u0444\\u0445\\u0446\\u0447\\u0448\\u0449\\u044A\\u044B\\u044C\\u044D\\u044E\"\n ),\n \"x-mac-gaelic\": (\n // http://unicode.org/Public/MAPPINGS/VENDORS/APPLE/GAELIC.TXT\n \"\\xC4\\xC5\\xC7\\xC9\\xD1\\xD6\\xDC\\xE1\\xE0\\xE2\\xE4\\xE3\\xE5\\xE7\\xE9\\xE8\\xEA\\xEB\\xED\\xEC\\xEE\\xEF\\xF1\\xF3\\xF2\\xF4\\xF6\\xF5\\xFA\\xF9\\xFB\\xFC\\u2020\\xB0\\xA2\\xA3\\xA7\\u2022\\xB6\\xDF\\xAE\\xA9\\u2122\\xB4\\xA8\\u2260\\xC6\\xD8\\u1E02\\xB1\\u2264\\u2265\\u1E03\\u010A\\u010B\\u1E0A\\u1E0B\\u1E1E\\u1E1F\\u0120\\u0121\\u1E40\\xE6\\xF8\\u1E41\\u1E56\\u1E57\\u027C\\u0192\\u017F\\u1E60\\xAB\\xBB\\u2026\\xA0\\xC0\\xC3\\xD5\\u0152\\u0153\\u2013\\u2014\\u201C\\u201D\\u2018\\u2019\\u1E61\\u1E9B\\xFF\\u0178\\u1E6A\\u20AC\\u2039\\u203A\\u0176\\u0177\\u1E6B\\xB7\\u1EF2\\u1EF3\\u204A\\xC2\\xCA\\xC1\\xCB\\xC8\\xCD\\xCE\\xCF\\xCC\\xD3\\xD4\\u2663\\xD2\\xDA\\xDB\\xD9\\u0131\\xDD\\xFD\\u0174\\u0175\\u1E84\\u1E85\\u1E80\\u1E81\\u1E82\\u1E83\"\n ),\n \"x-mac-greek\": (\n // Python: 'mac_greek'\n \"\\xC4\\xB9\\xB2\\xC9\\xB3\\xD6\\xDC\\u0385\\xE0\\xE2\\xE4\\u0384\\xA8\\xE7\\xE9\\xE8\\xEA\\xEB\\xA3\\u2122\\xEE\\xEF\\u2022\\xBD\\u2030\\xF4\\xF6\\xA6\\u20AC\\xF9\\xFB\\xFC\\u2020\\u0393\\u0394\\u0398\\u039B\\u039E\\u03A0\\xDF\\xAE\\xA9\\u03A3\\u03AA\\xA7\\u2260\\xB0\\xB7\\u0391\\xB1\\u2264\\u2265\\xA5\\u0392\\u0395\\u0396\\u0397\\u0399\\u039A\\u039C\\u03A6\\u03AB\\u03A8\\u03A9\\u03AC\\u039D\\xAC\\u039F\\u03A1\\u2248\\u03A4\\xAB\\xBB\\u2026\\xA0\\u03A5\\u03A7\\u0386\\u0388\\u0153\\u2013\\u2015\\u201C\\u201D\\u2018\\u2019\\xF7\\u0389\\u038A\\u038C\\u038E\\u03AD\\u03AE\\u03AF\\u03CC\\u038F\\u03CD\\u03B1\\u03B2\\u03C8\\u03B4\\u03B5\\u03C6\\u03B3\\u03B7\\u03B9\\u03BE\\u03BA\\u03BB\\u03BC\\u03BD\\u03BF\\u03C0\\u03CE\\u03C1\\u03C3\\u03C4\\u03B8\\u03C9\\u03C2\\u03C7\\u03C5\\u03B6\\u03CA\\u03CB\\u0390\\u03B0\\xAD\"\n ),\n \"x-mac-icelandic\": (\n // Python: 'mac_iceland'\n \"\\xC4\\xC5\\xC7\\xC9\\xD1\\xD6\\xDC\\xE1\\xE0\\xE2\\xE4\\xE3\\xE5\\xE7\\xE9\\xE8\\xEA\\xEB\\xED\\xEC\\xEE\\xEF\\xF1\\xF3\\xF2\\xF4\\xF6\\xF5\\xFA\\xF9\\xFB\\xFC\\xDD\\xB0\\xA2\\xA3\\xA7\\u2022\\xB6\\xDF\\xAE\\xA9\\u2122\\xB4\\xA8\\u2260\\xC6\\xD8\\u221E\\xB1\\u2264\\u2265\\xA5\\xB5\\u2202\\u2211\\u220F\\u03C0\\u222B\\xAA\\xBA\\u03A9\\xE6\\xF8\\xBF\\xA1\\xAC\\u221A\\u0192\\u2248\\u2206\\xAB\\xBB\\u2026\\xA0\\xC0\\xC3\\xD5\\u0152\\u0153\\u2013\\u2014\\u201C\\u201D\\u2018\\u2019\\xF7\\u25CA\\xFF\\u0178\\u2044\\u20AC\\xD0\\xF0\\xDE\\xFE\\xFD\\xB7\\u201A\\u201E\\u2030\\xC2\\xCA\\xC1\\xCB\\xC8\\xCD\\xCE\\xCF\\xCC\\xD3\\xD4\\uF8FF\\xD2\\xDA\\xDB\\xD9\\u0131\\u02C6\\u02DC\\xAF\\u02D8\\u02D9\\u02DA\\xB8\\u02DD\\u02DB\\u02C7\"\n ),\n \"x-mac-inuit\": (\n // http://unicode.org/Public/MAPPINGS/VENDORS/APPLE/INUIT.TXT\n \"\\u1403\\u1404\\u1405\\u1406\\u140A\\u140B\\u1431\\u1432\\u1433\\u1434\\u1438\\u1439\\u1449\\u144E\\u144F\\u1450\\u1451\\u1455\\u1456\\u1466\\u146D\\u146E\\u146F\\u1470\\u1472\\u1473\\u1483\\u148B\\u148C\\u148D\\u148E\\u1490\\u1491\\xB0\\u14A1\\u14A5\\u14A6\\u2022\\xB6\\u14A7\\xAE\\xA9\\u2122\\u14A8\\u14AA\\u14AB\\u14BB\\u14C2\\u14C3\\u14C4\\u14C5\\u14C7\\u14C8\\u14D0\\u14EF\\u14F0\\u14F1\\u14F2\\u14F4\\u14F5\\u1505\\u14D5\\u14D6\\u14D7\\u14D8\\u14DA\\u14DB\\u14EA\\u1528\\u1529\\u152A\\u152B\\u152D\\u2026\\xA0\\u152E\\u153E\\u1555\\u1556\\u1557\\u2013\\u2014\\u201C\\u201D\\u2018\\u2019\\u1558\\u1559\\u155A\\u155D\\u1546\\u1547\\u1548\\u1549\\u154B\\u154C\\u1550\\u157F\\u1580\\u1581\\u1582\\u1583\\u1584\\u1585\\u158F\\u1590\\u1591\\u1592\\u1593\\u1594\\u1595\\u1671\\u1672\\u1673\\u1674\\u1675\\u1676\\u1596\\u15A0\\u15A1\\u15A2\\u15A3\\u15A4\\u15A5\\u15A6\\u157C\\u0141\\u0142\"\n ),\n \"x-mac-ce\": (\n // Python: 'mac_latin2'\n \"\\xC4\\u0100\\u0101\\xC9\\u0104\\xD6\\xDC\\xE1\\u0105\\u010C\\xE4\\u010D\\u0106\\u0107\\xE9\\u0179\\u017A\\u010E\\xED\\u010F\\u0112\\u0113\\u0116\\xF3\\u0117\\xF4\\xF6\\xF5\\xFA\\u011A\\u011B\\xFC\\u2020\\xB0\\u0118\\xA3\\xA7\\u2022\\xB6\\xDF\\xAE\\xA9\\u2122\\u0119\\xA8\\u2260\\u0123\\u012E\\u012F\\u012A\\u2264\\u2265\\u012B\\u0136\\u2202\\u2211\\u0142\\u013B\\u013C\\u013D\\u013E\\u0139\\u013A\\u0145\\u0146\\u0143\\xAC\\u221A\\u0144\\u0147\\u2206\\xAB\\xBB\\u2026\\xA0\\u0148\\u0150\\xD5\\u0151\\u014C\\u2013\\u2014\\u201C\\u201D\\u2018\\u2019\\xF7\\u25CA\\u014D\\u0154\\u0155\\u0158\\u2039\\u203A\\u0159\\u0156\\u0157\\u0160\\u201A\\u201E\\u0161\\u015A\\u015B\\xC1\\u0164\\u0165\\xCD\\u017D\\u017E\\u016A\\xD3\\xD4\\u016B\\u016E\\xDA\\u016F\\u0170\\u0171\\u0172\\u0173\\xDD\\xFD\\u0137\\u017B\\u0141\\u017C\\u0122\\u02C7\"\n ),\n macintosh: (\n // Python: 'mac_roman'\n \"\\xC4\\xC5\\xC7\\xC9\\xD1\\xD6\\xDC\\xE1\\xE0\\xE2\\xE4\\xE3\\xE5\\xE7\\xE9\\xE8\\xEA\\xEB\\xED\\xEC\\xEE\\xEF\\xF1\\xF3\\xF2\\xF4\\xF6\\xF5\\xFA\\xF9\\xFB\\xFC\\u2020\\xB0\\xA2\\xA3\\xA7\\u2022\\xB6\\xDF\\xAE\\xA9\\u2122\\xB4\\xA8\\u2260\\xC6\\xD8\\u221E\\xB1\\u2264\\u2265\\xA5\\xB5\\u2202\\u2211\\u220F\\u03C0\\u222B\\xAA\\xBA\\u03A9\\xE6\\xF8\\xBF\\xA1\\xAC\\u221A\\u0192\\u2248\\u2206\\xAB\\xBB\\u2026\\xA0\\xC0\\xC3\\xD5\\u0152\\u0153\\u2013\\u2014\\u201C\\u201D\\u2018\\u2019\\xF7\\u25CA\\xFF\\u0178\\u2044\\u20AC\\u2039\\u203A\\uFB01\\uFB02\\u2021\\xB7\\u201A\\u201E\\u2030\\xC2\\xCA\\xC1\\xCB\\xC8\\xCD\\xCE\\xCF\\xCC\\xD3\\xD4\\uF8FF\\xD2\\xDA\\xDB\\xD9\\u0131\\u02C6\\u02DC\\xAF\\u02D8\\u02D9\\u02DA\\xB8\\u02DD\\u02DB\\u02C7\"\n ),\n \"x-mac-romanian\": (\n // Python: 'mac_romanian'\n \"\\xC4\\xC5\\xC7\\xC9\\xD1\\xD6\\xDC\\xE1\\xE0\\xE2\\xE4\\xE3\\xE5\\xE7\\xE9\\xE8\\xEA\\xEB\\xED\\xEC\\xEE\\xEF\\xF1\\xF3\\xF2\\xF4\\xF6\\xF5\\xFA\\xF9\\xFB\\xFC\\u2020\\xB0\\xA2\\xA3\\xA7\\u2022\\xB6\\xDF\\xAE\\xA9\\u2122\\xB4\\xA8\\u2260\\u0102\\u0218\\u221E\\xB1\\u2264\\u2265\\xA5\\xB5\\u2202\\u2211\\u220F\\u03C0\\u222B\\xAA\\xBA\\u03A9\\u0103\\u0219\\xBF\\xA1\\xAC\\u221A\\u0192\\u2248\\u2206\\xAB\\xBB\\u2026\\xA0\\xC0\\xC3\\xD5\\u0152\\u0153\\u2013\\u2014\\u201C\\u201D\\u2018\\u2019\\xF7\\u25CA\\xFF\\u0178\\u2044\\u20AC\\u2039\\u203A\\u021A\\u021B\\u2021\\xB7\\u201A\\u201E\\u2030\\xC2\\xCA\\xC1\\xCB\\xC8\\xCD\\xCE\\xCF\\xCC\\xD3\\xD4\\uF8FF\\xD2\\xDA\\xDB\\xD9\\u0131\\u02C6\\u02DC\\xAF\\u02D8\\u02D9\\u02DA\\xB8\\u02DD\\u02DB\\u02C7\"\n ),\n \"x-mac-turkish\": (\n // Python: 'mac_turkish'\n \"\\xC4\\xC5\\xC7\\xC9\\xD1\\xD6\\xDC\\xE1\\xE0\\xE2\\xE4\\xE3\\xE5\\xE7\\xE9\\xE8\\xEA\\xEB\\xED\\xEC\\xEE\\xEF\\xF1\\xF3\\xF2\\xF4\\xF6\\xF5\\xFA\\xF9\\xFB\\xFC\\u2020\\xB0\\xA2\\xA3\\xA7\\u2022\\xB6\\xDF\\xAE\\xA9\\u2122\\xB4\\xA8\\u2260\\xC6\\xD8\\u221E\\xB1\\u2264\\u2265\\xA5\\xB5\\u2202\\u2211\\u220F\\u03C0\\u222B\\xAA\\xBA\\u03A9\\xE6\\xF8\\xBF\\xA1\\xAC\\u221A\\u0192\\u2248\\u2206\\xAB\\xBB\\u2026\\xA0\\xC0\\xC3\\xD5\\u0152\\u0153\\u2013\\u2014\\u201C\\u201D\\u2018\\u2019\\xF7\\u25CA\\xFF\\u0178\\u011E\\u011F\\u0130\\u0131\\u015E\\u015F\\u2021\\xB7\\u201A\\u201E\\u2030\\xC2\\xCA\\xC1\\xCB\\xC8\\xCD\\xCE\\xCF\\xCC\\xD3\\xD4\\uF8FF\\xD2\\xDA\\xDB\\xD9\\uF8A0\\u02C6\\u02DC\\xAF\\u02D8\\u02D9\\u02DA\\xB8\\u02DD\\u02DB\\u02C7\"\n )\n };\n decode.MACSTRING = function(dataView, offset, dataLength, encoding) {\n const table = eightBitMacEncodings[encoding];\n if (table === void 0) {\n return void 0;\n }\n let result = \"\";\n for (let i = 0; i < dataLength; i++) {\n const c = dataView.getUint8(offset + i);\n if (c <= 127) {\n result += String.fromCharCode(c);\n } else {\n result += table[c & 127];\n }\n }\n return result;\n };\n var macEncodingTableCache = typeof WeakMap === \"function\" && /* @__PURE__ */ new WeakMap();\n var macEncodingCacheKeys;\n var getMacEncodingTable = function(encoding) {\n if (!macEncodingCacheKeys) {\n macEncodingCacheKeys = {};\n for (let e in eightBitMacEncodings) {\n macEncodingCacheKeys[e] = new String(e);\n }\n }\n const cacheKey = macEncodingCacheKeys[encoding];\n if (cacheKey === void 0) {\n return void 0;\n }\n if (macEncodingTableCache) {\n const cachedTable = macEncodingTableCache.get(cacheKey);\n if (cachedTable !== void 0) {\n return cachedTable;\n }\n }\n const decodingTable = eightBitMacEncodings[encoding];\n if (decodingTable === void 0) {\n return void 0;\n }\n const encodingTable = {};\n for (let i = 0; i < decodingTable.length; i++) {\n encodingTable[decodingTable.charCodeAt(i)] = i + 128;\n }\n if (macEncodingTableCache) {\n macEncodingTableCache.set(cacheKey, encodingTable);\n }\n return encodingTable;\n };\n encode.MACSTRING = function(str, encoding) {\n const table = getMacEncodingTable(encoding);\n if (table === void 0) {\n return void 0;\n }\n const result = [];\n for (let i = 0; i < str.length; i++) {\n let c = str.charCodeAt(i);\n if (c >= 128) {\n c = table[c];\n if (c === void 0) {\n return void 0;\n }\n }\n result[i] = c;\n }\n return result;\n };\n sizeOf.MACSTRING = function(str, encoding) {\n const b = encode.MACSTRING(str, encoding);\n if (b !== void 0) {\n return b.length;\n } else {\n return 0;\n }\n };\n function isByteEncodable(value) {\n return value >= -128 && value <= 127;\n }\n function encodeVarDeltaRunAsZeroes(deltas, pos, result) {\n let runLength = 0;\n const numDeltas = deltas.length;\n while (pos < numDeltas && runLength < 64 && deltas[pos] === 0) {\n ++pos;\n ++runLength;\n }\n result.push(128 | runLength - 1);\n return pos;\n }\n function encodeVarDeltaRunAsBytes(deltas, offset, result) {\n let runLength = 0;\n const numDeltas = deltas.length;\n let pos = offset;\n while (pos < numDeltas && runLength < 64) {\n const value = deltas[pos];\n if (!isByteEncodable(value)) {\n break;\n }\n if (value === 0 && pos + 1 < numDeltas && deltas[pos + 1] === 0) {\n break;\n }\n ++pos;\n ++runLength;\n }\n result.push(runLength - 1);\n for (let i = offset; i < pos; ++i) {\n result.push(deltas[i] + 256 & 255);\n }\n return pos;\n }\n function encodeVarDeltaRunAsWords(deltas, offset, result) {\n let runLength = 0;\n const numDeltas = deltas.length;\n let pos = offset;\n while (pos < numDeltas && runLength < 64) {\n const value = deltas[pos];\n if (value === 0) {\n break;\n }\n if (isByteEncodable(value) && pos + 1 < numDeltas && isByteEncodable(deltas[pos + 1])) {\n break;\n }\n ++pos;\n ++runLength;\n }\n result.push(64 | runLength - 1);\n for (let i = offset; i < pos; ++i) {\n const val = deltas[i];\n result.push(val + 65536 >> 8 & 255, val + 256 & 255);\n }\n return pos;\n }\n encode.VARDELTAS = function(deltas) {\n let pos = 0;\n const result = [];\n while (pos < deltas.length) {\n const value = deltas[pos];\n if (value === 0) {\n pos = encodeVarDeltaRunAsZeroes(deltas, pos, result);\n } else if (value >= -128 && value <= 127) {\n pos = encodeVarDeltaRunAsBytes(deltas, pos, result);\n } else {\n pos = encodeVarDeltaRunAsWords(deltas, pos, result);\n }\n }\n return result;\n };\n encode.INDEX = function(l) {\n let offset = 1;\n const offsets = [offset];\n const data = [];\n for (let i = 0; i < l.length; i += 1) {\n const v = encode.OBJECT(l[i]);\n Array.prototype.push.apply(data, v);\n offset += v.length;\n offsets.push(offset);\n }\n if (data.length === 0) {\n return [0, 0];\n }\n const encodedOffsets = [];\n const offSize = 1 + Math.floor(Math.log(offset) / Math.log(2)) / 8 | 0;\n const offsetEncoder = [void 0, encode.BYTE, encode.USHORT, encode.UINT24, encode.ULONG][offSize];\n for (let i = 0; i < offsets.length; i += 1) {\n const encodedOffset = offsetEncoder(offsets[i]);\n Array.prototype.push.apply(encodedOffsets, encodedOffset);\n }\n return Array.prototype.concat(\n encode.Card16(l.length),\n encode.OffSize(offSize),\n encodedOffsets,\n data\n );\n };\n sizeOf.INDEX = function(v) {\n return encode.INDEX(v).length;\n };\n encode.DICT = function(m) {\n let d = [];\n const keys = Object.keys(m);\n const length = keys.length;\n for (let i = 0; i < length; i += 1) {\n const k = parseInt(keys[i], 0);\n const v = m[k];\n const enc1 = encode.OPERAND(v.value, v.type);\n const enc2 = encode.OPERATOR(k);\n for (let j = 0; j < enc1.length; j++) {\n d.push(enc1[j]);\n }\n for (let j = 0; j < enc2.length; j++) {\n d.push(enc2[j]);\n }\n }\n return d;\n };\n sizeOf.DICT = function(m) {\n return encode.DICT(m).length;\n };\n encode.OPERATOR = function(v) {\n if (v < 1200) {\n return [v];\n } else {\n return [12, v - 1200];\n }\n };\n encode.OPERAND = function(v, type) {\n let d = [];\n if (Array.isArray(type)) {\n for (let i = 0; i < type.length; i += 1) {\n check_default.argument(v.length === type.length, \"Not enough arguments given for type\" + type);\n const enc1 = encode.OPERAND(v[i], type[i]);\n for (let j = 0; j < enc1.length; j++) {\n d.push(enc1[j]);\n }\n }\n } else {\n if (type === \"SID\") {\n const enc1 = encode.NUMBER(v);\n for (let j = 0; j < enc1.length; j++) {\n d.push(enc1[j]);\n }\n } else if (type === \"offset\") {\n const enc1 = encode.NUMBER32(v);\n for (let j = 0; j < enc1.length; j++) {\n d.push(enc1[j]);\n }\n } else if (type === \"number\") {\n const enc1 = encode.NUMBER(v);\n for (let j = 0; j < enc1.length; j++) {\n d.push(enc1[j]);\n }\n } else if (type === \"real\") {\n const enc1 = encode.REAL(v);\n for (let j = 0; j < enc1.length; j++) {\n d.push(enc1[j]);\n }\n } else {\n throw new Error(\"Unknown operand type \" + type);\n }\n }\n return d;\n };\n encode.OP = encode.BYTE;\n sizeOf.OP = sizeOf.BYTE;\n var wmm = typeof WeakMap === \"function\" && /* @__PURE__ */ new WeakMap();\n encode.CHARSTRING = function(ops) {\n if (wmm) {\n const cachedValue = wmm.get(ops);\n if (cachedValue !== void 0) {\n return cachedValue;\n }\n }\n let d = [];\n const length = ops.length;\n for (let i = 0; i < length; i += 1) {\n const op = ops[i];\n const enc1 = encode[op.type](op.value);\n for (let j = 0; j < enc1.length; j++) {\n d.push(enc1[j]);\n }\n }\n if (wmm) {\n wmm.set(ops, d);\n }\n return d;\n };\n sizeOf.CHARSTRING = function(ops) {\n return encode.CHARSTRING(ops).length;\n };\n encode.OBJECT = function(v) {\n const encodingFunction = encode[v.type];\n check_default.argument(encodingFunction !== void 0, \"No encoding function for type \" + v.type);\n return encodingFunction(v.value);\n };\n sizeOf.OBJECT = function(v) {\n const sizeOfFunction = sizeOf[v.type];\n check_default.argument(sizeOfFunction !== void 0, \"No sizeOf function for type \" + v.type);\n return sizeOfFunction(v.value);\n };\n encode.TABLE = function(table) {\n let d = [];\n const length = (table.fields || []).length;\n const subtables = [];\n const subtableOffsets = [];\n for (let i = 0; i < length; i += 1) {\n const field = table.fields[i];\n const encodingFunction = encode[field.type];\n check_default.argument(encodingFunction !== void 0, \"No encoding function for field type \" + field.type + \" (\" + field.name + \")\");\n let value = table[field.name];\n if (value === void 0) {\n value = field.value;\n }\n const bytes = encodingFunction(value);\n if (field.type === \"TABLE\") {\n if (value.fields !== null) {\n subtableOffsets.push(d.length);\n subtables.push(bytes);\n }\n d.push(...[0, 0]);\n } else {\n for (let j = 0; j < bytes.length; j++) {\n d.push(bytes[j]);\n }\n }\n }\n for (let i = 0; i < subtables.length; i += 1) {\n const o = subtableOffsets[i];\n const offset = d.length;\n check_default.argument(offset < 65536, \"Table \" + table.tableName + \" too big.\");\n d[o] = offset >> 8;\n d[o + 1] = offset & 255;\n for (let j = 0; j < subtables[i].length; j++) {\n d.push(subtables[i][j]);\n }\n }\n return d;\n };\n sizeOf.TABLE = function(table) {\n let numBytes = 0;\n const length = (table.fields || []).length;\n for (let i = 0; i < length; i += 1) {\n const field = table.fields[i];\n const sizeOfFunction = sizeOf[field.type];\n check_default.argument(sizeOfFunction !== void 0, \"No sizeOf function for field type \" + field.type + \" (\" + field.name + \")\");\n let value = table[field.name];\n if (value === void 0) {\n value = field.value;\n }\n numBytes += sizeOfFunction(value);\n if (field.type === \"TABLE\") {\n numBytes += 2;\n }\n }\n return numBytes;\n };\n encode.RECORD = encode.TABLE;\n sizeOf.RECORD = sizeOf.TABLE;\n encode.LITERAL = function(v) {\n return v;\n };\n sizeOf.LITERAL = function(v) {\n return v.length;\n };\n\n // src/table.mjs\n function Table(tableName, fields, options) {\n if (fields && fields.length) {\n for (let i = 0; i < fields.length; i += 1) {\n const field = fields[i];\n this[field.name] = field.value;\n }\n }\n this.tableName = tableName;\n this.fields = fields;\n if (options) {\n const optionKeys = Object.keys(options);\n for (let i = 0; i < optionKeys.length; i += 1) {\n const k = optionKeys[i];\n const v = options[k];\n if (this[k] !== void 0) {\n this[k] = v;\n }\n }\n }\n }\n Table.prototype.encode = function() {\n return encode.TABLE(this);\n };\n Table.prototype.sizeOf = function() {\n return sizeOf.TABLE(this);\n };\n function ushortList(itemName, list, count) {\n if (count === void 0) {\n count = list.length;\n }\n const fields = new Array(list.length + 1);\n fields[0] = { name: itemName + \"Count\", type: \"USHORT\", value: count };\n for (let i = 0; i < list.length; i++) {\n fields[i + 1] = { name: itemName + i, type: \"USHORT\", value: list[i] };\n }\n return fields;\n }\n function tableList(itemName, records, itemCallback) {\n const count = records.length;\n const fields = new Array(count + 1);\n fields[0] = { name: itemName + \"Count\", type: \"USHORT\", value: count };\n for (let i = 0; i < count; i++) {\n fields[i + 1] = { name: itemName + i, type: \"TABLE\", value: itemCallback(records[i], i) };\n }\n return fields;\n }\n function recordList(itemName, records, itemCallback) {\n const count = records.length;\n let fields = [];\n fields[0] = { name: itemName + \"Count\", type: \"USHORT\", value: count };\n for (let i = 0; i < count; i++) {\n fields = fields.concat(itemCallback(records[i], i));\n }\n return fields;\n }\n function Coverage(coverageTable) {\n if (coverageTable.format === 1) {\n Table.call(\n this,\n \"coverageTable\",\n [{ name: \"coverageFormat\", type: \"USHORT\", value: 1 }].concat(ushortList(\"glyph\", coverageTable.glyphs))\n );\n } else if (coverageTable.format === 2) {\n Table.call(\n this,\n \"coverageTable\",\n [{ name: \"coverageFormat\", type: \"USHORT\", value: 2 }].concat(recordList(\"rangeRecord\", coverageTable.ranges, function(RangeRecord, i) {\n return [\n { name: \"startGlyphID\" + i, type: \"USHORT\", value: RangeRecord.start },\n { name: \"endGlyphID\" + i, type: \"USHORT\", value: RangeRecord.end },\n { name: \"startCoverageIndex\" + i, type: \"USHORT\", value: RangeRecord.index }\n ];\n }))\n );\n } else {\n check_default.assert(false, \"Coverage format must be 1 or 2.\");\n }\n }\n Coverage.prototype = Object.create(Table.prototype);\n Coverage.prototype.constructor = Coverage;\n function ScriptList(scriptListTable) {\n Table.call(\n this,\n \"scriptListTable\",\n recordList(\"scriptRecord\", scriptListTable, function(scriptRecord, i) {\n const script = scriptRecord.script;\n let defaultLangSys = script.defaultLangSys;\n check_default.assert(!!defaultLangSys, \"Unable to write GSUB: script \" + scriptRecord.tag + \" has no default language system.\");\n return [\n { name: \"scriptTag\" + i, type: \"TAG\", value: scriptRecord.tag },\n { name: \"script\" + i, type: \"TABLE\", value: new Table(\"scriptTable\", [\n { name: \"defaultLangSys\", type: \"TABLE\", value: new Table(\"defaultLangSys\", [\n { name: \"lookupOrder\", type: \"USHORT\", value: 0 },\n { name: \"reqFeatureIndex\", type: \"USHORT\", value: defaultLangSys.reqFeatureIndex }\n ].concat(ushortList(\"featureIndex\", defaultLangSys.featureIndexes))) }\n ].concat(recordList(\"langSys\", script.langSysRecords, function(langSysRecord, i2) {\n const langSys = langSysRecord.langSys;\n return [\n { name: \"langSysTag\" + i2, type: \"TAG\", value: langSysRecord.tag },\n { name: \"langSys\" + i2, type: \"TABLE\", value: new Table(\"langSys\", [\n { name: \"lookupOrder\", type: \"USHORT\", value: 0 },\n { name: \"reqFeatureIndex\", type: \"USHORT\", value: langSys.reqFeatureIndex }\n ].concat(ushortList(\"featureIndex\", langSys.featureIndexes))) }\n ];\n }))) }\n ];\n })\n );\n }\n ScriptList.prototype = Object.create(Table.prototype);\n ScriptList.prototype.constructor = ScriptList;\n function FeatureList(featureListTable) {\n Table.call(\n this,\n \"featureListTable\",\n recordList(\"featureRecord\", featureListTable, function(featureRecord, i) {\n const feature = featureRecord.feature;\n return [\n { name: \"featureTag\" + i, type: \"TAG\", value: featureRecord.tag },\n { name: \"feature\" + i, type: \"TABLE\", value: new Table(\"featureTable\", [\n { name: \"featureParams\", type: \"USHORT\", value: feature.featureParams }\n ].concat(ushortList(\"lookupListIndex\", feature.lookupListIndexes))) }\n ];\n })\n );\n }\n FeatureList.prototype = Object.create(Table.prototype);\n FeatureList.prototype.constructor = FeatureList;\n function LookupList(lookupListTable, subtableMakers3) {\n Table.call(this, \"lookupListTable\", tableList(\"lookup\", lookupListTable, function(lookupTable) {\n let subtableCallback = subtableMakers3[lookupTable.lookupType];\n check_default.assert(!!subtableCallback, \"Unable to write GSUB lookup type \" + lookupTable.lookupType + \" tables.\");\n return new Table(\"lookupTable\", [\n { name: \"lookupType\", type: \"USHORT\", value: lookupTable.lookupType },\n { name: \"lookupFlag\", type: \"USHORT\", value: lookupTable.lookupFlag }\n ].concat(tableList(\"subtable\", lookupTable.subtables, subtableCallback)));\n }));\n }\n LookupList.prototype = Object.create(Table.prototype);\n LookupList.prototype.constructor = LookupList;\n function ClassDef(classDefTable) {\n if (classDefTable.format === 1) {\n Table.call(\n this,\n \"classDefTable\",\n [\n { name: \"classFormat\", type: \"USHORT\", value: 1 },\n { name: \"startGlyphID\", type: \"USHORT\", value: classDefTable.startGlyph }\n ].concat(ushortList(\"glyph\", classDefTable.classes))\n );\n } else if (classDefTable.format === 2) {\n Table.call(\n this,\n \"classDefTable\",\n [{ name: \"classFormat\", type: \"USHORT\", value: 2 }].concat(recordList(\"rangeRecord\", classDefTable.ranges, function(RangeRecord, i) {\n return [\n { name: \"startGlyphID\" + i, type: \"USHORT\", value: RangeRecord.start },\n { name: \"endGlyphID\" + i, type: \"USHORT\", value: RangeRecord.end },\n { name: \"class\" + i, type: \"USHORT\", value: RangeRecord.classId }\n ];\n }))\n );\n } else {\n check_default.assert(false, \"Class format must be 1 or 2.\");\n }\n }\n ClassDef.prototype = Object.create(Table.prototype);\n ClassDef.prototype.constructor = ClassDef;\n var table_default = {\n Table,\n Record: Table,\n Coverage,\n ClassDef,\n ScriptList,\n FeatureList,\n LookupList,\n ushortList,\n tableList,\n recordList\n };\n\n // src/parse.mjs\n function getByte(dataView, offset) {\n return dataView.getUint8(offset);\n }\n function getUShort(dataView, offset) {\n return dataView.getUint16(offset, false);\n }\n function getShort(dataView, offset) {\n return dataView.getInt16(offset, false);\n }\n function getUInt24(dataView, offset) {\n return (dataView.getUint16(offset) << 8) + dataView.getUint8(offset + 2);\n }\n function getULong(dataView, offset) {\n return dataView.getUint32(offset, false);\n }\n function getLong(dataView, offset) {\n return dataView.getInt32(offset, false);\n }\n function getFixed(dataView, offset) {\n const decimal = dataView.getInt16(offset, false);\n const fraction = dataView.getUint16(offset + 2, false);\n return decimal + fraction / 65535;\n }\n function getTag(dataView, offset) {\n let tag = \"\";\n for (let i = offset; i < offset + 4; i += 1) {\n tag += String.fromCharCode(dataView.getInt8(i));\n }\n return tag;\n }\n function getOffset(dataView, offset, offSize) {\n let v = 0;\n for (let i = 0; i < offSize; i += 1) {\n v <<= 8;\n v += dataView.getUint8(offset + i);\n }\n return v;\n }\n function getBytes(dataView, startOffset, endOffset) {\n const bytes = [];\n for (let i = startOffset; i < endOffset; i += 1) {\n bytes.push(dataView.getUint8(i));\n }\n return bytes;\n }\n function bytesToString(bytes) {\n let s = \"\";\n for (let i = 0; i < bytes.length; i += 1) {\n s += String.fromCharCode(bytes[i]);\n }\n return s;\n }\n var typeOffsets = {\n byte: 1,\n uShort: 2,\n f2dot14: 2,\n short: 2,\n uInt24: 3,\n uLong: 4,\n fixed: 4,\n longDateTime: 8,\n tag: 4\n };\n var masks = {\n LONG_WORDS: 32768,\n WORD_DELTA_COUNT_MASK: 32767,\n SHARED_POINT_NUMBERS: 32768,\n COUNT_MASK: 4095,\n EMBEDDED_PEAK_TUPLE: 32768,\n INTERMEDIATE_REGION: 16384,\n PRIVATE_POINT_NUMBERS: 8192,\n TUPLE_INDEX_MASK: 4095,\n POINTS_ARE_WORDS: 128,\n POINT_RUN_COUNT_MASK: 127,\n DELTAS_ARE_ZERO: 128,\n DELTAS_ARE_WORDS: 64,\n DELTA_RUN_COUNT_MASK: 63,\n INNER_INDEX_BIT_COUNT_MASK: 15,\n MAP_ENTRY_SIZE_MASK: 48\n };\n function Parser(data, offset) {\n this.data = data;\n this.offset = offset;\n this.relativeOffset = 0;\n }\n Parser.prototype.parseByte = function() {\n const v = this.data.getUint8(this.offset + this.relativeOffset);\n this.relativeOffset += 1;\n return v;\n };\n Parser.prototype.parseChar = function() {\n const v = this.data.getInt8(this.offset + this.relativeOffset);\n this.relativeOffset += 1;\n return v;\n };\n Parser.prototype.parseCard8 = Parser.prototype.parseByte;\n Parser.prototype.parseUShort = function() {\n const v = this.data.getUint16(this.offset + this.relativeOffset);\n this.relativeOffset += 2;\n return v;\n };\n Parser.prototype.parseCard16 = Parser.prototype.parseUShort;\n Parser.prototype.parseSID = Parser.prototype.parseUShort;\n Parser.prototype.parseOffset16 = Parser.prototype.parseUShort;\n Parser.prototype.parseShort = function() {\n const v = this.data.getInt16(this.offset + this.relativeOffset);\n this.relativeOffset += 2;\n return v;\n };\n Parser.prototype.parseF2Dot14 = function() {\n const v = this.data.getInt16(this.offset + this.relativeOffset) / 16384;\n this.relativeOffset += 2;\n return v;\n };\n Parser.prototype.parseUInt24 = function() {\n const v = getUInt24(this.data, this.offset + this.relativeOffset);\n this.relativeOffset += 3;\n return v;\n };\n Parser.prototype.parseULong = function() {\n const v = getULong(this.data, this.offset + this.relativeOffset);\n this.relativeOffset += 4;\n return v;\n };\n Parser.prototype.parseLong = function() {\n const v = getLong(this.data, this.offset + this.relativeOffset);\n this.relativeOffset += 4;\n return v;\n };\n Parser.prototype.parseOffset32 = Parser.prototype.parseULong;\n Parser.prototype.parseFixed = function() {\n const v = getFixed(this.data, this.offset + this.relativeOffset);\n this.relativeOffset += 4;\n return v;\n };\n Parser.prototype.parseString = function(length) {\n const dataView = this.data;\n const offset = this.offset + this.relativeOffset;\n let string = \"\";\n this.relativeOffset += length;\n for (let i = 0; i < length; i++) {\n string += String.fromCharCode(dataView.getUint8(offset + i));\n }\n return string;\n };\n Parser.prototype.parseTag = function() {\n return this.parseString(4);\n };\n Parser.prototype.parseLongDateTime = function() {\n let v = getULong(this.data, this.offset + this.relativeOffset + 4);\n v -= 2082844800;\n this.relativeOffset += 8;\n return v;\n };\n Parser.prototype.parseVersion = function(minorBase) {\n const major = getUShort(this.data, this.offset + this.relativeOffset);\n const minor = getUShort(this.data, this.offset + this.relativeOffset + 2);\n this.relativeOffset += 4;\n if (minorBase === void 0) minorBase = 4096;\n return major + minor / minorBase / 10;\n };\n Parser.prototype.skip = function(type, amount) {\n if (amount === void 0) {\n amount = 1;\n }\n this.relativeOffset += typeOffsets[type] * amount;\n };\n Parser.prototype.parseULongList = function(count) {\n if (count === void 0) {\n count = this.parseULong();\n }\n const offsets = new Array(count);\n const dataView = this.data;\n let offset = this.offset + this.relativeOffset;\n for (let i = 0; i < count; i++) {\n offsets[i] = dataView.getUint32(offset);\n offset += 4;\n }\n this.relativeOffset += count * 4;\n return offsets;\n };\n Parser.prototype.parseOffset16List = Parser.prototype.parseUShortList = function(count) {\n if (count === void 0) {\n count = this.parseUShort();\n }\n const offsets = new Array(count);\n const dataView = this.data;\n let offset = this.offset + this.relativeOffset;\n for (let i = 0; i < count; i++) {\n offsets[i] = dataView.getUint16(offset);\n offset += 2;\n }\n this.relativeOffset += count * 2;\n return offsets;\n };\n Parser.prototype.parseShortList = function(count) {\n const list = new Array(count);\n const dataView = this.data;\n let offset = this.offset + this.relativeOffset;\n for (let i = 0; i < count; i++) {\n list[i] = dataView.getInt16(offset);\n offset += 2;\n }\n this.relativeOffset += count * 2;\n return list;\n };\n Parser.prototype.parseByteList = function(count) {\n const list = new Array(count);\n const dataView = this.data;\n let offset = this.offset + this.relativeOffset;\n for (let i = 0; i < count; i++) {\n list[i] = dataView.getUint8(offset++);\n }\n this.relativeOffset += count;\n return list;\n };\n Parser.prototype.parseList = function(count, itemCallback) {\n if (!itemCallback) {\n itemCallback = count;\n count = this.parseUShort();\n }\n const list = new Array(count);\n for (let i = 0; i < count; i++) {\n list[i] = itemCallback.call(this);\n }\n return list;\n };\n Parser.prototype.parseList32 = function(count, itemCallback) {\n if (!itemCallback) {\n itemCallback = count;\n count = this.parseULong();\n }\n const list = new Array(count);\n for (let i = 0; i < count; i++) {\n list[i] = itemCallback.call(this);\n }\n return list;\n };\n Parser.prototype.parseRecordList = function(count, recordDescription) {\n if (!recordDescription) {\n recordDescription = count;\n count = this.parseUShort();\n }\n const records = new Array(count);\n const fields = Object.keys(recordDescription);\n for (let i = 0; i < count; i++) {\n const rec = {};\n for (let j = 0; j < fields.length; j++) {\n const fieldName = fields[j];\n const fieldType = recordDescription[fieldName];\n rec[fieldName] = fieldType.call(this);\n }\n records[i] = rec;\n }\n return records;\n };\n Parser.prototype.parseRecordList32 = function(count, recordDescription) {\n if (!recordDescription) {\n recordDescription = count;\n count = this.parseULong();\n }\n const records = new Array(count);\n const fields = Object.keys(recordDescription);\n for (let i = 0; i < count; i++) {\n const rec = {};\n for (let j = 0; j < fields.length; j++) {\n const fieldName = fields[j];\n const fieldType = recordDescription[fieldName];\n rec[fieldName] = fieldType.call(this);\n }\n records[i] = rec;\n }\n return records;\n };\n Parser.prototype.parseTupleRecords = function(tupleCount, axisCount) {\n let tuples = [];\n for (let i = 0; i < tupleCount; i++) {\n let tuple = [];\n for (let axisIndex = 0; axisIndex < axisCount; axisIndex++) {\n tuple.push(this.parseF2Dot14());\n }\n tuples.push(tuple);\n }\n return tuples;\n };\n Parser.prototype.parseStruct = function(description) {\n if (typeof description === \"function\") {\n return description.call(this);\n } else {\n const fields = Object.keys(description);\n const struct = {};\n for (let j = 0; j < fields.length; j++) {\n const fieldName = fields[j];\n const fieldType = description[fieldName];\n struct[fieldName] = fieldType.call(this);\n }\n return struct;\n }\n };\n Parser.prototype.parseValueRecord = function(valueFormat) {\n if (valueFormat === void 0) {\n valueFormat = this.parseUShort();\n }\n if (valueFormat === 0) {\n return;\n }\n const valueRecord = {};\n if (valueFormat & 1) {\n valueRecord.xPlacement = this.parseShort();\n }\n if (valueFormat & 2) {\n valueRecord.yPlacement = this.parseShort();\n }\n if (valueFormat & 4) {\n valueRecord.xAdvance = this.parseShort();\n }\n if (valueFormat & 8) {\n valueRecord.yAdvance = this.parseShort();\n }\n if (valueFormat & 16) {\n valueRecord.xPlaDevice = void 0;\n this.parseShort();\n }\n if (valueFormat & 32) {\n valueRecord.yPlaDevice = void 0;\n this.parseShort();\n }\n if (valueFormat & 64) {\n valueRecord.xAdvDevice = void 0;\n this.parseShort();\n }\n if (valueFormat & 128) {\n valueRecord.yAdvDevice = void 0;\n this.parseShort();\n }\n return valueRecord;\n };\n Parser.prototype.parseValueRecordList = function() {\n const valueFormat = this.parseUShort();\n const valueCount = this.parseUShort();\n const values = new Array(valueCount);\n for (let i = 0; i < valueCount; i++) {\n values[i] = this.parseValueRecord(valueFormat);\n }\n return values;\n };\n Parser.prototype.parsePointer = function(description) {\n const structOffset = this.parseOffset16();\n if (structOffset > 0) {\n return new Parser(this.data, this.offset + structOffset).parseStruct(description);\n }\n return void 0;\n };\n Parser.prototype.parsePointer32 = function(description) {\n const structOffset = this.parseOffset32();\n if (structOffset > 0) {\n return new Parser(this.data, this.offset + structOffset).parseStruct(description);\n }\n return void 0;\n };\n Parser.prototype.parseListOfLists = function(itemCallback) {\n const offsets = this.parseOffset16List();\n const count = offsets.length;\n const relativeOffset = this.relativeOffset;\n const list = new Array(count);\n for (let i = 0; i < count; i++) {\n const start = offsets[i];\n if (start === 0) {\n list[i] = void 0;\n continue;\n }\n this.relativeOffset = start;\n if (itemCallback) {\n const subOffsets = this.parseOffset16List();\n const subList = new Array(subOffsets.length);\n for (let j = 0; j < subOffsets.length; j++) {\n this.relativeOffset = start + subOffsets[j];\n subList[j] = itemCallback.call(this);\n }\n list[i] = subList;\n } else {\n list[i] = this.parseUShortList();\n }\n }\n this.relativeOffset = relativeOffset;\n return list;\n };\n Parser.prototype.parseCoverage = function() {\n const startOffset = this.offset + this.relativeOffset;\n const format = this.parseUShort();\n const count = this.parseUShort();\n if (format === 1) {\n return {\n format: 1,\n glyphs: this.parseUShortList(count)\n };\n } else if (format === 2) {\n const ranges = new Array(count);\n for (let i = 0; i < count; i++) {\n ranges[i] = {\n start: this.parseUShort(),\n end: this.parseUShort(),\n index: this.parseUShort()\n };\n }\n return {\n format: 2,\n ranges\n };\n }\n throw new Error(\"0x\" + startOffset.toString(16) + \": Coverage format must be 1 or 2.\");\n };\n Parser.prototype.parseClassDef = function() {\n const startOffset = this.offset + this.relativeOffset;\n const format = this.parseUShort();\n if (format === 1) {\n return {\n format: 1,\n startGlyph: this.parseUShort(),\n classes: this.parseUShortList()\n };\n } else if (format === 2) {\n return {\n format: 2,\n ranges: this.parseRecordList({\n start: Parser.uShort,\n end: Parser.uShort,\n classId: Parser.uShort\n })\n };\n }\n console.warn(`0x${startOffset.toString(16)}: This font file uses an invalid ClassDef format of ${format}. It might be corrupted and should be reacquired if it doesn't display as intended.`);\n return {\n format\n };\n };\n Parser.list = function(count, itemCallback) {\n return function() {\n return this.parseList(count, itemCallback);\n };\n };\n Parser.list32 = function(count, itemCallback) {\n return function() {\n return this.parseList32(count, itemCallback);\n };\n };\n Parser.recordList = function(count, recordDescription) {\n return function() {\n return this.parseRecordList(count, recordDescription);\n };\n };\n Parser.recordList32 = function(count, recordDescription) {\n return function() {\n return this.parseRecordList32(count, recordDescription);\n };\n };\n Parser.pointer = function(description) {\n return function() {\n return this.parsePointer(description);\n };\n };\n Parser.pointer32 = function(description) {\n return function() {\n return this.parsePointer32(description);\n };\n };\n Parser.tag = Parser.prototype.parseTag;\n Parser.byte = Parser.prototype.parseByte;\n Parser.uShort = Parser.offset16 = Parser.prototype.parseUShort;\n Parser.uShortList = Parser.prototype.parseUShortList;\n Parser.uInt24 = Parser.prototype.parseUInt24;\n Parser.uLong = Parser.offset32 = Parser.prototype.parseULong;\n Parser.uLongList = Parser.prototype.parseULongList;\n Parser.fixed = Parser.prototype.parseFixed;\n Parser.f2Dot14 = Parser.prototype.parseF2Dot14;\n Parser.struct = Parser.prototype.parseStruct;\n Parser.coverage = Parser.prototype.parseCoverage;\n Parser.classDef = Parser.prototype.parseClassDef;\n var langSysTable = {\n reserved: Parser.uShort,\n reqFeatureIndex: Parser.uShort,\n featureIndexes: Parser.uShortList\n };\n Parser.prototype.parseScriptList = function() {\n return this.parsePointer(Parser.recordList({\n tag: Parser.tag,\n script: Parser.pointer({\n defaultLangSys: Parser.pointer(langSysTable),\n langSysRecords: Parser.recordList({\n tag: Parser.tag,\n langSys: Parser.pointer(langSysTable)\n })\n })\n })) || [];\n };\n Parser.prototype.parseFeatureList = function() {\n return this.parsePointer(Parser.recordList({\n tag: Parser.tag,\n feature: Parser.pointer({\n featureParams: Parser.offset16,\n lookupListIndexes: Parser.uShortList\n })\n })) || [];\n };\n Parser.prototype.parseLookupList = function(lookupTableParsers) {\n return this.parsePointer(Parser.list(Parser.pointer(function() {\n const lookupType = this.parseUShort();\n check_default.argument(1 <= lookupType && lookupType <= 9, \"GPOS/GSUB lookup type \" + lookupType + \" unknown.\");\n const lookupFlag = this.parseUShort();\n const useMarkFilteringSet = lookupFlag & 16;\n return {\n lookupType,\n lookupFlag,\n subtables: this.parseList(Parser.pointer(lookupTableParsers[lookupType])),\n markFilteringSet: useMarkFilteringSet ? this.parseUShort() : void 0\n };\n }))) || [];\n };\n Parser.prototype.parseFeatureVariationsList = function() {\n return this.parsePointer32(function() {\n const majorVersion = this.parseUShort();\n const minorVersion = this.parseUShort();\n check_default.argument(majorVersion === 1 && minorVersion < 1, \"GPOS/GSUB feature variations table unknown.\");\n const featureVariations = this.parseRecordList32({\n conditionSetOffset: Parser.offset32,\n featureTableSubstitutionOffset: Parser.offset32\n });\n return featureVariations;\n }) || [];\n };\n Parser.prototype.parseVariationStore = function() {\n const vsOffset = this.relativeOffset;\n const length = this.parseUShort();\n const variationStore = {\n itemVariationStore: this.parseItemVariationStore()\n };\n this.relativeOffset = vsOffset + length + 2;\n return variationStore;\n };\n Parser.prototype.parseItemVariationStore = function() {\n const itemStoreOffset = this.relativeOffset;\n const iVStore = {\n format: this.parseUShort(),\n variationRegions: [],\n itemVariationSubtables: []\n };\n const variationRegionListOffset = this.parseOffset32();\n const itemVariationDataCount = this.parseUShort();\n const itemVariationDataOffsets = this.parseULongList(itemVariationDataCount);\n this.relativeOffset = itemStoreOffset + variationRegionListOffset;\n iVStore.variationRegions = this.parseVariationRegionList();\n for (let i = 0; i < itemVariationDataCount; i++) {\n const subtableOffset = itemVariationDataOffsets[i];\n this.relativeOffset = itemStoreOffset + subtableOffset;\n iVStore.itemVariationSubtables.push(this.parseItemVariationSubtable());\n }\n return iVStore;\n };\n Parser.prototype.parseVariationRegionList = function() {\n const axisCount = this.parseUShort();\n const regionCount = this.parseUShort();\n return this.parseRecordList(regionCount, {\n regionAxes: Parser.recordList(axisCount, {\n startCoord: Parser.f2Dot14,\n peakCoord: Parser.f2Dot14,\n endCoord: Parser.f2Dot14\n })\n });\n };\n Parser.prototype.parseItemVariationSubtable = function() {\n const itemCount = this.parseUShort();\n const wordDeltaCount = this.parseUShort();\n const regionIndexes = this.parseUShortList();\n const regionIndexCount = regionIndexes.length;\n const subtable = {\n regionIndexes,\n deltaSets: itemCount && regionIndexCount ? this.parseDeltaSets(itemCount, wordDeltaCount, regionIndexCount) : []\n };\n return subtable;\n };\n Parser.prototype.parseDeltaSetIndexMap = function() {\n const format = this.parseByte();\n const entryFormat = this.parseByte();\n const map = [];\n let mapCount = 0;\n switch (format) {\n case 0:\n mapCount = this.parseUShort();\n break;\n case 1:\n mapCount = this.parseULong();\n break;\n default:\n console.error(`unsupported DeltaSetIndexMap format ${format}`);\n }\n if (!mapCount) return {\n format,\n entryFormat\n };\n const bitCount = (entryFormat & masks.INNER_INDEX_BIT_COUNT_MASK) + 1;\n const entrySize = ((entryFormat & masks.MAP_ENTRY_SIZE_MASK) >> 4) + 1;\n for (let n = 0; n < mapCount; n++) {\n let entry;\n if (entrySize === 1) {\n entry = this.parseByte();\n } else if (entrySize === 2) {\n entry = this.parseUShort();\n } else if (entrySize === 3) {\n entry = this.parseUInt24();\n } else if (entrySize === 4) {\n entry = this.parseULong();\n } else {\n throw new Error(`Invalid entry size of ${entrySize}`);\n }\n const outerIndex = entry >> bitCount;\n const innerIndex = entry & (1 << bitCount) - 1;\n map.push({ outerIndex, innerIndex });\n }\n return {\n format,\n entryFormat,\n map\n };\n };\n Parser.prototype.parseDeltaSets = function(itemCount, wordDeltaCount, regionIndexCount) {\n const deltas = Array.from({ length: itemCount }, () => []);\n const longFlag = wordDeltaCount & masks.LONG_WORDS;\n const wordCount = wordDeltaCount & masks.WORD_DELTA_COUNT_MASK;\n if (wordCount > regionIndexCount) {\n throw Error(\"wordCount must be less than or equal to regionIndexCount\");\n }\n const wordParser = (longFlag ? this.parseLong : this.parseShort).bind(this);\n const restParser = (longFlag ? this.parseShort : this.parseChar).bind(this);\n for (let i = 0; i < itemCount; i++) {\n for (let j = 0; j < regionIndexCount; j++) {\n if (j < wordCount) {\n deltas[i].push(wordParser());\n } else {\n deltas[i].push(restParser());\n }\n }\n }\n return deltas;\n };\n Parser.prototype.parseTupleVariationStoreList = function(axisCount, flavor, glyphs) {\n const glyphCount = this.parseUShort();\n const flags = this.parseUShort();\n const offsetSizeIs32Bit = flags & 1;\n const glyphVariationDataArrayOffset = this.parseOffset32();\n const parseOffset = (offsetSizeIs32Bit ? this.parseULong : this.parseUShort).bind(this);\n const glyphVariations = {};\n let currentOffset = parseOffset();\n if (!offsetSizeIs32Bit) currentOffset *= 2;\n let nextOffset;\n for (let i = 0; i < glyphCount; i++) {\n nextOffset = parseOffset();\n if (!offsetSizeIs32Bit) nextOffset *= 2;\n const length = nextOffset - currentOffset;\n glyphVariations[i] = length ? this.parseTupleVariationStore(\n glyphVariationDataArrayOffset + currentOffset,\n axisCount,\n flavor,\n glyphs,\n i\n ) : void 0;\n currentOffset = nextOffset;\n }\n return glyphVariations;\n };\n Parser.prototype.parseTupleVariationStore = function(tableOffset, axisCount, flavor, glyphs, glyphIndex) {\n const relativeOffset = this.relativeOffset;\n this.relativeOffset = tableOffset;\n if (flavor === \"cvar\") {\n this.relativeOffset += 4;\n }\n const tupleVariationCount = this.parseUShort();\n const hasSharedPoints = !!(tupleVariationCount & masks.SHARED_POINT_NUMBERS);\n const count = tupleVariationCount & masks.COUNT_MASK;\n let dataOffset = this.parseOffset16();\n const headers = [];\n let sharedPoints = [];\n for (let h = 0; h < count; h++) {\n const headerData = this.parseTupleVariationHeader(axisCount, flavor);\n headers.push(headerData);\n }\n if (this.relativeOffset !== tableOffset + dataOffset) {\n console.warn(`Unexpected offset after parsing tuple variation headers! Expected ${tableOffset + dataOffset}, actually ${this.relativeOffset}`);\n this.relativeOffset = tableOffset + dataOffset;\n }\n if (hasSharedPoints) {\n sharedPoints = this.parsePackedPointNumbers();\n }\n let serializedDataOffset = this.relativeOffset;\n for (let h = 0; h < count; h++) {\n const header = headers[h];\n header.privatePoints = [];\n this.relativeOffset = serializedDataOffset;\n if (flavor === \"cvar\" && !header.peakTuple) {\n console.warn(\"An embedded peak tuple is required in TupleVariationHeaders for the cvar table.\");\n }\n if (header.flags.privatePointNumbers) {\n header.privatePoints = this.parsePackedPointNumbers();\n }\n delete header.flags;\n const deltasOffset = this.offset;\n const deltasRelativeOffset = this.relativeOffset;\n const defineDeltas = (propertyName) => {\n let _deltas = void 0;\n let _deltasY = void 0;\n const parseDeltas = () => {\n let pointsCount = 0;\n if (flavor === \"gvar\") {\n pointsCount = header.privatePoints.length || sharedPoints.length;\n if (!pointsCount) {\n const glyph = glyphs.get(glyphIndex);\n glyph.path;\n pointsCount = glyph.points.length;\n pointsCount += 4;\n }\n } else if (flavor === \"cvar\") {\n pointsCount = glyphs.length;\n }\n this.offset = deltasOffset;\n this.relativeOffset = deltasRelativeOffset;\n _deltas = this.parsePackedDeltas(pointsCount);\n if (flavor === \"gvar\") {\n _deltasY = this.parsePackedDeltas(pointsCount);\n }\n };\n return {\n configurable: true,\n get: function() {\n if (_deltas === void 0) parseDeltas();\n return propertyName === \"deltasY\" ? _deltasY : _deltas;\n },\n set: function(deltas) {\n if (_deltas === void 0) parseDeltas();\n if (propertyName === \"deltasY\") {\n _deltasY = deltas;\n } else {\n _deltas = deltas;\n }\n }\n };\n };\n Object.defineProperty(header, \"deltas\", defineDeltas.call(this, \"deltas\"));\n if (flavor === \"gvar\") {\n Object.defineProperty(header, \"deltasY\", defineDeltas.call(this, \"deltasY\"));\n }\n serializedDataOffset += header.variationDataSize;\n delete header.variationDataSize;\n }\n this.relativeOffset = relativeOffset;\n const result = {\n headers\n };\n result.sharedPoints = sharedPoints;\n return result;\n };\n Parser.prototype.parseTupleVariationHeader = function(axisCount, flavor) {\n const variationDataSize = this.parseUShort();\n const tupleIndex = this.parseUShort();\n const embeddedPeakTuple = !!(tupleIndex & masks.EMBEDDED_PEAK_TUPLE);\n const intermediateRegion = !!(tupleIndex & masks.INTERMEDIATE_REGION);\n const privatePointNumbers = !!(tupleIndex & masks.PRIVATE_POINT_NUMBERS);\n const sharedTupleRecordsIndex = embeddedPeakTuple ? void 0 : tupleIndex & masks.TUPLE_INDEX_MASK;\n const peakTuple = embeddedPeakTuple ? this.parseTupleRecords(1, axisCount)[0] : void 0;\n const intermediateStartTuple = intermediateRegion ? this.parseTupleRecords(1, axisCount)[0] : void 0;\n const intermediateEndTuple = intermediateRegion ? this.parseTupleRecords(1, axisCount)[0] : void 0;\n const result = {\n variationDataSize,\n peakTuple,\n intermediateStartTuple,\n intermediateEndTuple,\n flags: {\n embeddedPeakTuple,\n intermediateRegion,\n privatePointNumbers\n }\n };\n if (flavor === \"gvar\") {\n result.sharedTupleRecordsIndex = sharedTupleRecordsIndex;\n }\n return result;\n };\n Parser.prototype.parsePackedPointNumbers = function() {\n const countByte1 = this.parseByte();\n const points = [];\n let totalPointCount = countByte1;\n if (countByte1 >= 128) {\n const countByte2 = this.parseByte();\n totalPointCount = (countByte1 & masks.POINT_RUN_COUNT_MASK) << 8 | countByte2;\n }\n let lastPoint = 0;\n while (points.length < totalPointCount) {\n const controlByte = this.parseByte();\n const numbersAre16Bit = !!(controlByte & masks.POINTS_ARE_WORDS);\n let runCount = (controlByte & masks.POINT_RUN_COUNT_MASK) + 1;\n for (let i = 0; i < runCount && points.length < totalPointCount; i++) {\n let pointDelta;\n if (numbersAre16Bit) {\n pointDelta = this.parseUShort();\n } else {\n pointDelta = this.parseByte();\n }\n lastPoint = lastPoint + pointDelta;\n points.push(lastPoint);\n }\n }\n return points;\n };\n Parser.prototype.parsePackedDeltas = function(expectedCount) {\n const deltas = [];\n while (deltas.length < expectedCount) {\n const controlByte = this.parseByte();\n const zeroData = !!(controlByte & masks.DELTAS_ARE_ZERO);\n const deltaWords = !!(controlByte & masks.DELTAS_ARE_WORDS);\n const runCount = (controlByte & masks.DELTA_RUN_COUNT_MASK) + 1;\n for (let i = 0; i < runCount && deltas.length < expectedCount; i++) {\n if (zeroData) {\n deltas.push(0);\n } else if (deltaWords) {\n deltas.push(this.parseShort());\n } else {\n deltas.push(this.parseChar());\n }\n }\n }\n return deltas;\n };\n var parse_default = {\n getByte,\n getCard8: getByte,\n getUShort,\n getCard16: getUShort,\n getShort,\n getUInt24,\n getULong,\n getFixed,\n getTag,\n getOffset,\n getBytes,\n bytesToString,\n Parser\n };\n\n // src/tables/name.mjs\n var nameTableNames = [\n \"copyright\",\n // 0\n \"fontFamily\",\n // 1\n \"fontSubfamily\",\n // 2\n \"uniqueID\",\n // 3\n \"fullName\",\n // 4\n \"version\",\n // 5\n \"postScriptName\",\n // 6\n \"trademark\",\n // 7\n \"manufacturer\",\n // 8\n \"designer\",\n // 9\n \"description\",\n // 10\n \"manufacturerURL\",\n // 11\n \"designerURL\",\n // 12\n \"license\",\n // 13\n \"licenseURL\",\n // 14\n \"reserved\",\n // 15\n \"preferredFamily\",\n // 16\n \"preferredSubfamily\",\n // 17\n \"compatibleFullName\",\n // 18\n \"sampleText\",\n // 19\n \"postScriptFindFontName\",\n // 20\n \"wwsFamily\",\n // 21\n \"wwsSubfamily\"\n // 22\n ];\n var macLanguages = {\n 0: \"en\",\n 1: \"fr\",\n 2: \"de\",\n 3: \"it\",\n 4: \"nl\",\n 5: \"sv\",\n 6: \"es\",\n 7: \"da\",\n 8: \"pt\",\n 9: \"no\",\n 10: \"he\",\n 11: \"ja\",\n 12: \"ar\",\n 13: \"fi\",\n 14: \"el\",\n 15: \"is\",\n 16: \"mt\",\n 17: \"tr\",\n 18: \"hr\",\n 19: \"zh-Hant\",\n 20: \"ur\",\n 21: \"hi\",\n 22: \"th\",\n 23: \"ko\",\n 24: \"lt\",\n 25: \"pl\",\n 26: \"hu\",\n 27: \"es\",\n 28: \"lv\",\n 29: \"se\",\n 30: \"fo\",\n 31: \"fa\",\n 32: \"ru\",\n 33: \"zh\",\n 34: \"nl-BE\",\n 35: \"ga\",\n 36: \"sq\",\n 37: \"ro\",\n 38: \"cz\",\n 39: \"sk\",\n 40: \"si\",\n 41: \"yi\",\n 42: \"sr\",\n 43: \"mk\",\n 44: \"bg\",\n 45: \"uk\",\n 46: \"be\",\n 47: \"uz\",\n 48: \"kk\",\n 49: \"az-Cyrl\",\n 50: \"az-Arab\",\n 51: \"hy\",\n 52: \"ka\",\n 53: \"mo\",\n 54: \"ky\",\n 55: \"tg\",\n 56: \"tk\",\n 57: \"mn-CN\",\n 58: \"mn\",\n 59: \"ps\",\n 60: \"ks\",\n 61: \"ku\",\n 62: \"sd\",\n 63: \"bo\",\n 64: \"ne\",\n 65: \"sa\",\n 66: \"mr\",\n 67: \"bn\",\n 68: \"as\",\n 69: \"gu\",\n 70: \"pa\",\n 71: \"or\",\n 72: \"ml\",\n 73: \"kn\",\n 74: \"ta\",\n 75: \"te\",\n 76: \"si\",\n 77: \"my\",\n 78: \"km\",\n 79: \"lo\",\n 80: \"vi\",\n 81: \"id\",\n 82: \"tl\",\n 83: \"ms\",\n 84: \"ms-Arab\",\n 85: \"am\",\n 86: \"ti\",\n 87: \"om\",\n 88: \"so\",\n 89: \"sw\",\n 90: \"rw\",\n 91: \"rn\",\n 92: \"ny\",\n 93: \"mg\",\n 94: \"eo\",\n 128: \"cy\",\n 129: \"eu\",\n 130: \"ca\",\n 131: \"la\",\n 132: \"qu\",\n 133: \"gn\",\n 134: \"ay\",\n 135: \"tt\",\n 136: \"ug\",\n 137: \"dz\",\n 138: \"jv\",\n 139: \"su\",\n 140: \"gl\",\n 141: \"af\",\n 142: \"br\",\n 143: \"iu\",\n 144: \"gd\",\n 145: \"gv\",\n 146: \"ga\",\n 147: \"to\",\n 148: \"el-polyton\",\n 149: \"kl\",\n 150: \"az\",\n 151: \"nn\"\n };\n var macLanguageToScript = {\n 0: 0,\n // langEnglish → smRoman\n 1: 0,\n // langFrench → smRoman\n 2: 0,\n // langGerman → smRoman\n 3: 0,\n // langItalian → smRoman\n 4: 0,\n // langDutch → smRoman\n 5: 0,\n // langSwedish → smRoman\n 6: 0,\n // langSpanish → smRoman\n 7: 0,\n // langDanish → smRoman\n 8: 0,\n // langPortuguese → smRoman\n 9: 0,\n // langNorwegian → smRoman\n 10: 5,\n // langHebrew → smHebrew\n 11: 1,\n // langJapanese → smJapanese\n 12: 4,\n // langArabic → smArabic\n 13: 0,\n // langFinnish → smRoman\n 14: 6,\n // langGreek → smGreek\n 15: 0,\n // langIcelandic → smRoman (modified)\n 16: 0,\n // langMaltese → smRoman\n 17: 0,\n // langTurkish → smRoman (modified)\n 18: 0,\n // langCroatian → smRoman (modified)\n 19: 2,\n // langTradChinese → smTradChinese\n 20: 4,\n // langUrdu → smArabic\n 21: 9,\n // langHindi → smDevanagari\n 22: 21,\n // langThai → smThai\n 23: 3,\n // langKorean → smKorean\n 24: 29,\n // langLithuanian → smCentralEuroRoman\n 25: 29,\n // langPolish → smCentralEuroRoman\n 26: 29,\n // langHungarian → smCentralEuroRoman\n 27: 29,\n // langEstonian → smCentralEuroRoman\n 28: 29,\n // langLatvian → smCentralEuroRoman\n 29: 0,\n // langSami → smRoman\n 30: 0,\n // langFaroese → smRoman (modified)\n 31: 4,\n // langFarsi → smArabic (modified)\n 32: 7,\n // langRussian → smCyrillic\n 33: 25,\n // langSimpChinese → smSimpChinese\n 34: 0,\n // langFlemish → smRoman\n 35: 0,\n // langIrishGaelic → smRoman (modified)\n 36: 0,\n // langAlbanian → smRoman\n 37: 0,\n // langRomanian → smRoman (modified)\n 38: 29,\n // langCzech → smCentralEuroRoman\n 39: 29,\n // langSlovak → smCentralEuroRoman\n 40: 0,\n // langSlovenian → smRoman (modified)\n 41: 5,\n // langYiddish → smHebrew\n 42: 7,\n // langSerbian → smCyrillic\n 43: 7,\n // langMacedonian → smCyrillic\n 44: 7,\n // langBulgarian → smCyrillic\n 45: 7,\n // langUkrainian → smCyrillic (modified)\n 46: 7,\n // langByelorussian → smCyrillic\n 47: 7,\n // langUzbek → smCyrillic\n 48: 7,\n // langKazakh → smCyrillic\n 49: 7,\n // langAzerbaijani → smCyrillic\n 50: 4,\n // langAzerbaijanAr → smArabic\n 51: 24,\n // langArmenian → smArmenian\n 52: 23,\n // langGeorgian → smGeorgian\n 53: 7,\n // langMoldavian → smCyrillic\n 54: 7,\n // langKirghiz → smCyrillic\n 55: 7,\n // langTajiki → smCyrillic\n 56: 7,\n // langTurkmen → smCyrillic\n 57: 27,\n // langMongolian → smMongolian\n 58: 7,\n // langMongolianCyr → smCyrillic\n 59: 4,\n // langPashto → smArabic\n 60: 4,\n // langKurdish → smArabic\n 61: 4,\n // langKashmiri → smArabic\n 62: 4,\n // langSindhi → smArabic\n 63: 26,\n // langTibetan → smTibetan\n 64: 9,\n // langNepali → smDevanagari\n 65: 9,\n // langSanskrit → smDevanagari\n 66: 9,\n // langMarathi → smDevanagari\n 67: 13,\n // langBengali → smBengali\n 68: 13,\n // langAssamese → smBengali\n 69: 11,\n // langGujarati → smGujarati\n 70: 10,\n // langPunjabi → smGurmukhi\n 71: 12,\n // langOriya → smOriya\n 72: 17,\n // langMalayalam → smMalayalam\n 73: 16,\n // langKannada → smKannada\n 74: 14,\n // langTamil → smTamil\n 75: 15,\n // langTelugu → smTelugu\n 76: 18,\n // langSinhalese → smSinhalese\n 77: 19,\n // langBurmese → smBurmese\n 78: 20,\n // langKhmer → smKhmer\n 79: 22,\n // langLao → smLao\n 80: 30,\n // langVietnamese → smVietnamese\n 81: 0,\n // langIndonesian → smRoman\n 82: 0,\n // langTagalog → smRoman\n 83: 0,\n // langMalayRoman → smRoman\n 84: 4,\n // langMalayArabic → smArabic\n 85: 28,\n // langAmharic → smEthiopic\n 86: 28,\n // langTigrinya → smEthiopic\n 87: 28,\n // langOromo → smEthiopic\n 88: 0,\n // langSomali → smRoman\n 89: 0,\n // langSwahili → smRoman\n 90: 0,\n // langKinyarwanda → smRoman\n 91: 0,\n // langRundi → smRoman\n 92: 0,\n // langNyanja → smRoman\n 93: 0,\n // langMalagasy → smRoman\n 94: 0,\n // langEsperanto → smRoman\n 128: 0,\n // langWelsh → smRoman (modified)\n 129: 0,\n // langBasque → smRoman\n 130: 0,\n // langCatalan → smRoman\n 131: 0,\n // langLatin → smRoman\n 132: 0,\n // langQuechua → smRoman\n 133: 0,\n // langGuarani → smRoman\n 134: 0,\n // langAymara → smRoman\n 135: 7,\n // langTatar → smCyrillic\n 136: 4,\n // langUighur → smArabic\n 137: 26,\n // langDzongkha → smTibetan\n 138: 0,\n // langJavaneseRom → smRoman\n 139: 0,\n // langSundaneseRom → smRoman\n 140: 0,\n // langGalician → smRoman\n 141: 0,\n // langAfrikaans → smRoman\n 142: 0,\n // langBreton → smRoman (modified)\n 143: 28,\n // langInuktitut → smEthiopic (modified)\n 144: 0,\n // langScottishGaelic → smRoman (modified)\n 145: 0,\n // langManxGaelic → smRoman (modified)\n 146: 0,\n // langIrishGaelicScript → smRoman (modified)\n 147: 0,\n // langTongan → smRoman\n 148: 6,\n // langGreekAncient → smRoman\n 149: 0,\n // langGreenlandic → smRoman\n 150: 0,\n // langAzerbaijanRoman → smRoman\n 151: 0\n // langNynorsk → smRoman\n };\n var windowsLanguages = {\n 1078: \"af\",\n 1052: \"sq\",\n 1156: \"gsw\",\n 1118: \"am\",\n 5121: \"ar-DZ\",\n 15361: \"ar-BH\",\n 3073: \"ar\",\n 2049: \"ar-IQ\",\n 11265: \"ar-JO\",\n 13313: \"ar-KW\",\n 12289: \"ar-LB\",\n 4097: \"ar-LY\",\n 6145: \"ary\",\n 8193: \"ar-OM\",\n 16385: \"ar-QA\",\n 1025: \"ar-SA\",\n 10241: \"ar-SY\",\n 7169: \"aeb\",\n 14337: \"ar-AE\",\n 9217: \"ar-YE\",\n 1067: \"hy\",\n 1101: \"as\",\n 2092: \"az-Cyrl\",\n 1068: \"az\",\n 1133: \"ba\",\n 1069: \"eu\",\n 1059: \"be\",\n 2117: \"bn\",\n 1093: \"bn-IN\",\n 8218: \"bs-Cyrl\",\n 5146: \"bs\",\n 1150: \"br\",\n 1026: \"bg\",\n 1027: \"ca\",\n 3076: \"zh-HK\",\n 5124: \"zh-MO\",\n 2052: \"zh\",\n 4100: \"zh-SG\",\n 1028: \"zh-TW\",\n 1155: \"co\",\n 1050: \"hr\",\n 4122: \"hr-BA\",\n 1029: \"cs\",\n 1030: \"da\",\n 1164: \"prs\",\n 1125: \"dv\",\n 2067: \"nl-BE\",\n 1043: \"nl\",\n 3081: \"en-AU\",\n 10249: \"en-BZ\",\n 4105: \"en-CA\",\n 9225: \"en-029\",\n 16393: \"en-IN\",\n 6153: \"en-IE\",\n 8201: \"en-JM\",\n 17417: \"en-MY\",\n 5129: \"en-NZ\",\n 13321: \"en-PH\",\n 18441: \"en-SG\",\n 7177: \"en-ZA\",\n 11273: \"en-TT\",\n 2057: \"en-GB\",\n 1033: \"en\",\n 12297: \"en-ZW\",\n 1061: \"et\",\n 1080: \"fo\",\n 1124: \"fil\",\n 1035: \"fi\",\n 2060: \"fr-BE\",\n 3084: \"fr-CA\",\n 1036: \"fr\",\n 5132: \"fr-LU\",\n 6156: \"fr-MC\",\n 4108: \"fr-CH\",\n 1122: \"fy\",\n 1110: \"gl\",\n 1079: \"ka\",\n 3079: \"de-AT\",\n 1031: \"de\",\n 5127: \"de-LI\",\n 4103: \"de-LU\",\n 2055: \"de-CH\",\n 1032: \"el\",\n 1135: \"kl\",\n 1095: \"gu\",\n 1128: \"ha\",\n 1037: \"he\",\n 1081: \"hi\",\n 1038: \"hu\",\n 1039: \"is\",\n 1136: \"ig\",\n 1057: \"id\",\n 1117: \"iu\",\n 2141: \"iu-Latn\",\n 2108: \"ga\",\n 1076: \"xh\",\n 1077: \"zu\",\n 1040: \"it\",\n 2064: \"it-CH\",\n 1041: \"ja\",\n 1099: \"kn\",\n 1087: \"kk\",\n 1107: \"km\",\n 1158: \"quc\",\n 1159: \"rw\",\n 1089: \"sw\",\n 1111: \"kok\",\n 1042: \"ko\",\n 1088: \"ky\",\n 1108: \"lo\",\n 1062: \"lv\",\n 1063: \"lt\",\n 2094: \"dsb\",\n 1134: \"lb\",\n 1071: \"mk\",\n 2110: \"ms-BN\",\n 1086: \"ms\",\n 1100: \"ml\",\n 1082: \"mt\",\n 1153: \"mi\",\n 1146: \"arn\",\n 1102: \"mr\",\n 1148: \"moh\",\n 1104: \"mn\",\n 2128: \"mn-CN\",\n 1121: \"ne\",\n 1044: \"nb\",\n 2068: \"nn\",\n 1154: \"oc\",\n 1096: \"or\",\n 1123: \"ps\",\n 1045: \"pl\",\n 1046: \"pt\",\n 2070: \"pt-PT\",\n 1094: \"pa\",\n 1131: \"qu-BO\",\n 2155: \"qu-EC\",\n 3179: \"qu\",\n 1048: \"ro\",\n 1047: \"rm\",\n 1049: \"ru\",\n 9275: \"smn\",\n 4155: \"smj-NO\",\n 5179: \"smj\",\n 3131: \"se-FI\",\n 1083: \"se\",\n 2107: \"se-SE\",\n 8251: \"sms\",\n 6203: \"sma-NO\",\n 7227: \"sms\",\n 1103: \"sa\",\n 7194: \"sr-Cyrl-BA\",\n 3098: \"sr\",\n 6170: \"sr-Latn-BA\",\n 2074: \"sr-Latn\",\n 1132: \"nso\",\n 1074: \"tn\",\n 1115: \"si\",\n 1051: \"sk\",\n 1060: \"sl\",\n 11274: \"es-AR\",\n 16394: \"es-BO\",\n 13322: \"es-CL\",\n 9226: \"es-CO\",\n 5130: \"es-CR\",\n 7178: \"es-DO\",\n 12298: \"es-EC\",\n 17418: \"es-SV\",\n 4106: \"es-GT\",\n 18442: \"es-HN\",\n 2058: \"es-MX\",\n 19466: \"es-NI\",\n 6154: \"es-PA\",\n 15370: \"es-PY\",\n 10250: \"es-PE\",\n 20490: \"es-PR\",\n // Microsoft has defined two different language codes for\n // “Spanish with modern sorting” and “Spanish with traditional\n // sorting”. This makes sense for collation APIs, and it would be\n // possible to express this in BCP 47 language tags via Unicode\n // extensions (eg., es-u-co-trad is Spanish with traditional\n // sorting). However, for storing names in fonts, the distinction\n // does not make sense, so we give “es” in both cases.\n 3082: \"es\",\n 1034: \"es\",\n 21514: \"es-US\",\n 14346: \"es-UY\",\n 8202: \"es-VE\",\n 2077: \"sv-FI\",\n 1053: \"sv\",\n 1114: \"syr\",\n 1064: \"tg\",\n 2143: \"tzm\",\n 1097: \"ta\",\n 1092: \"tt\",\n 1098: \"te\",\n 1054: \"th\",\n 1105: \"bo\",\n 1055: \"tr\",\n 1090: \"tk\",\n 1152: \"ug\",\n 1058: \"uk\",\n 1070: \"hsb\",\n 1056: \"ur\",\n 2115: \"uz-Cyrl\",\n 1091: \"uz\",\n 1066: \"vi\",\n 1106: \"cy\",\n 1160: \"wo\",\n 1157: \"sah\",\n 1144: \"ii\",\n 1130: \"yo\"\n };\n function getLanguageCode(platformID, languageID, ltag) {\n switch (platformID) {\n case 0:\n if (languageID === 65535) {\n return \"und\";\n } else if (ltag) {\n return ltag[languageID];\n }\n break;\n case 1:\n return macLanguages[languageID];\n case 3:\n return windowsLanguages[languageID];\n }\n return void 0;\n }\n var utf16 = \"utf-16\";\n var macScriptEncodings = {\n 0: \"macintosh\",\n // smRoman\n 1: \"x-mac-japanese\",\n // smJapanese\n 2: \"x-mac-chinesetrad\",\n // smTradChinese\n 3: \"x-mac-korean\",\n // smKorean\n 6: \"x-mac-greek\",\n // smGreek\n 7: \"x-mac-cyrillic\",\n // smCyrillic\n 9: \"x-mac-devanagai\",\n // smDevanagari\n 10: \"x-mac-gurmukhi\",\n // smGurmukhi\n 11: \"x-mac-gujarati\",\n // smGujarati\n 12: \"x-mac-oriya\",\n // smOriya\n 13: \"x-mac-bengali\",\n // smBengali\n 14: \"x-mac-tamil\",\n // smTamil\n 15: \"x-mac-telugu\",\n // smTelugu\n 16: \"x-mac-kannada\",\n // smKannada\n 17: \"x-mac-malayalam\",\n // smMalayalam\n 18: \"x-mac-sinhalese\",\n // smSinhalese\n 19: \"x-mac-burmese\",\n // smBurmese\n 20: \"x-mac-khmer\",\n // smKhmer\n 21: \"x-mac-thai\",\n // smThai\n 22: \"x-mac-lao\",\n // smLao\n 23: \"x-mac-georgian\",\n // smGeorgian\n 24: \"x-mac-armenian\",\n // smArmenian\n 25: \"x-mac-chinesesimp\",\n // smSimpChinese\n 26: \"x-mac-tibetan\",\n // smTibetan\n 27: \"x-mac-mongolian\",\n // smMongolian\n 28: \"x-mac-ethiopic\",\n // smEthiopic\n 29: \"x-mac-ce\",\n // smCentralEuroRoman\n 30: \"x-mac-vietnamese\",\n // smVietnamese\n 31: \"x-mac-extarabic\"\n // smExtArabic\n };\n var macLanguageEncodings = {\n 15: \"x-mac-icelandic\",\n // langIcelandic\n 17: \"x-mac-turkish\",\n // langTurkish\n 18: \"x-mac-croatian\",\n // langCroatian\n 24: \"x-mac-ce\",\n // langLithuanian\n 25: \"x-mac-ce\",\n // langPolish\n 26: \"x-mac-ce\",\n // langHungarian\n 27: \"x-mac-ce\",\n // langEstonian\n 28: \"x-mac-ce\",\n // langLatvian\n 30: \"x-mac-icelandic\",\n // langFaroese\n 37: \"x-mac-romanian\",\n // langRomanian\n 38: \"x-mac-ce\",\n // langCzech\n 39: \"x-mac-ce\",\n // langSlovak\n 40: \"x-mac-ce\",\n // langSlovenian\n 143: \"x-mac-inuit\",\n // langInuktitut\n 146: \"x-mac-gaelic\"\n // langIrishGaelicScript\n };\n function getEncoding(platformID, encodingID, languageID) {\n switch (platformID) {\n case 0:\n return utf16;\n case 1:\n return macLanguageEncodings[languageID] || macScriptEncodings[encodingID];\n case 3:\n if (encodingID === 1 || encodingID === 10) {\n return utf16;\n }\n break;\n }\n return void 0;\n }\n var platforms = {\n 0: \"unicode\",\n 1: \"macintosh\",\n 2: \"reserved\",\n 3: \"windows\"\n };\n function getPlatform(platformID) {\n return platforms[platformID];\n }\n function parseNameTable(data, start, ltag) {\n const name = {};\n const p = new parse_default.Parser(data, start);\n const format = p.parseUShort();\n const count = p.parseUShort();\n const stringOffset = p.offset + p.parseUShort();\n for (let i = 0; i < count; i++) {\n const platformID = p.parseUShort();\n const encodingID = p.parseUShort();\n const languageID = p.parseUShort();\n const nameID = p.parseUShort();\n const property = nameTableNames[nameID] || nameID;\n const byteLength = p.parseUShort();\n const offset = p.parseUShort();\n const language = getLanguageCode(platformID, languageID, ltag);\n const encoding = getEncoding(platformID, encodingID, languageID);\n const platformName = getPlatform(platformID);\n if (encoding !== void 0 && language !== void 0 && platformName !== void 0) {\n let text;\n if (encoding === utf16) {\n text = decode.UTF16(data, stringOffset + offset, byteLength);\n } else {\n text = decode.MACSTRING(data, stringOffset + offset, byteLength, encoding);\n }\n if (text) {\n let platform = name[platformName];\n if (platform === void 0) {\n platform = name[platformName] = {};\n }\n let translations = platform[property];\n if (translations === void 0) {\n translations = platform[property] = {};\n }\n translations[language] = text;\n }\n }\n }\n if (format === 1) {\n p.parseUShort();\n }\n return name;\n }\n function reverseDict(dict) {\n const result = {};\n for (let key in dict) {\n result[dict[key]] = parseInt(key);\n }\n return result;\n }\n function makeNameRecord(platformID, encodingID, languageID, nameID, length, offset) {\n return new table_default.Record(\"NameRecord\", [\n { name: \"platformID\", type: \"USHORT\", value: platformID },\n { name: \"encodingID\", type: \"USHORT\", value: encodingID },\n { name: \"languageID\", type: \"USHORT\", value: languageID },\n { name: \"nameID\", type: \"USHORT\", value: nameID },\n { name: \"length\", type: \"USHORT\", value: length },\n { name: \"offset\", type: \"USHORT\", value: offset }\n ]);\n }\n function findSubArray(needle, haystack) {\n const needleLength = needle.length;\n const limit = haystack.length - needleLength + 1;\n loop:\n for (let pos = 0; pos < limit; pos++) {\n for (; pos < limit; pos++) {\n for (let k = 0; k < needleLength; k++) {\n if (haystack[pos + k] !== needle[k]) {\n continue loop;\n }\n }\n return pos;\n }\n }\n return -1;\n }\n function addStringToPool(s, pool) {\n let offset = findSubArray(s, pool);\n if (offset < 0) {\n offset = pool.length;\n let i = 0;\n const len = s.length;\n for (; i < len; ++i) {\n pool.push(s[i]);\n }\n }\n return offset;\n }\n function makeNameTable(names, ltag) {\n const platformNameIds = reverseDict(platforms);\n const macLanguageIds = reverseDict(macLanguages);\n const windowsLanguageIds = reverseDict(windowsLanguages);\n const nameRecords = [];\n const stringPool = [];\n for (let platform in names) {\n let nameID;\n const nameIDs = [];\n const namesWithNumericKeys = {};\n const nameTableIds = reverseDict(nameTableNames);\n const platformID = platformNameIds[platform];\n for (let key in names[platform]) {\n let id = nameTableIds[key];\n if (id === void 0) {\n id = key;\n }\n nameID = parseInt(id);\n if (isNaN(nameID)) {\n throw new Error('Name table entry \"' + key + '\" does not exist, see nameTableNames for complete list.');\n }\n namesWithNumericKeys[nameID] = names[platform][key];\n nameIDs.push(nameID);\n }\n for (let i = 0; i < nameIDs.length; i++) {\n nameID = nameIDs[i];\n const translations = namesWithNumericKeys[nameID];\n for (let lang in translations) {\n const text = translations[lang];\n if (platformID === 1 || platformID === 0) {\n let macLanguage = macLanguageIds[lang];\n let macScript = macLanguageToScript[macLanguage];\n const macEncoding = getEncoding(platformID, macScript, macLanguage);\n let macName = encode.MACSTRING(text, macEncoding);\n if (platformID === 0) {\n macLanguage = ltag.indexOf(lang);\n if (macLanguage < 0) {\n macLanguage = ltag.length;\n ltag.push(lang);\n }\n macScript = 4;\n macName = encode.UTF16(text);\n }\n if (macName !== void 0) {\n const macNameOffset = addStringToPool(macName, stringPool);\n nameRecords.push(makeNameRecord(\n platformID,\n macScript,\n macLanguage,\n nameID,\n macName.length,\n macNameOffset\n ));\n }\n }\n if (platformID === 3) {\n const winLanguage = windowsLanguageIds[lang];\n if (winLanguage !== void 0) {\n const winName = encode.UTF16(text);\n const winNameOffset = addStringToPool(winName, stringPool);\n nameRecords.push(makeNameRecord(\n 3,\n 1,\n winLanguage,\n nameID,\n winName.length,\n winNameOffset\n ));\n }\n }\n }\n }\n }\n nameRecords.sort(function(a, b) {\n return a.platformID - b.platformID || a.encodingID - b.encodingID || a.languageID - b.languageID || a.nameID - b.nameID;\n });\n const t = new table_default.Table(\"name\", [\n { name: \"format\", type: \"USHORT\", value: 0 },\n { name: \"count\", type: \"USHORT\", value: nameRecords.length },\n { name: \"stringOffset\", type: \"USHORT\", value: 6 + nameRecords.length * 12 }\n ]);\n for (let r = 0; r < nameRecords.length; r++) {\n t.fields.push({ name: \"record_\" + r, type: \"RECORD\", value: nameRecords[r] });\n }\n t.fields.push({ name: \"strings\", type: \"LITERAL\", value: stringPool });\n return t;\n }\n function getNameByID(names, nameID, allowedStandardIDs = []) {\n if (nameID < 256 && nameID in nameTableNames) {\n if (allowedStandardIDs.length && !allowedStandardIDs.includes(parseInt(nameID))) {\n return void 0;\n }\n nameID = nameTableNames[nameID];\n }\n for (let platform in names) {\n for (let nameKey in names[platform]) {\n if (nameKey === nameID || parseInt(nameKey) === nameID) {\n return names[platform][nameKey];\n }\n }\n }\n return void 0;\n }\n var name_default = { parse: parseNameTable, make: makeNameTable, getNameByID };\n\n // src/tables/cmap.mjs\n function parseCmapTableFormat0(cmap, p, platformID, encodingID) {\n cmap.length = p.parseUShort();\n cmap.language = p.parseUShort() - 1;\n const indexMap = p.parseByteList(cmap.length);\n const glyphIndexMap = Object.assign({}, indexMap);\n const encoding = getEncoding(platformID, encodingID, cmap.language);\n const decodingTable = eightBitMacEncodings[encoding];\n for (let i = 0; i < decodingTable.length; i++) {\n glyphIndexMap[decodingTable.charCodeAt(i)] = indexMap[128 + i];\n }\n cmap.glyphIndexMap = glyphIndexMap;\n }\n function parseCmapTableFormat12or13(cmap, p, format) {\n p.parseUShort();\n cmap.length = p.parseULong();\n cmap.language = p.parseULong();\n let groupCount;\n cmap.groupCount = groupCount = p.parseULong();\n cmap.glyphIndexMap = {};\n for (let i = 0; i < groupCount; i += 1) {\n const startCharCode = p.parseULong();\n const endCharCode = p.parseULong();\n let startGlyphId = p.parseULong();\n for (let c = startCharCode; c <= endCharCode; c += 1) {\n cmap.glyphIndexMap[c] = startGlyphId;\n if (format === 12) {\n startGlyphId++;\n }\n }\n }\n }\n function parseCmapTableFormat4(cmap, p, data, start, offset) {\n cmap.length = p.parseUShort();\n cmap.language = p.parseUShort();\n let segCount;\n cmap.segCount = segCount = p.parseUShort() >> 1;\n p.skip(\"uShort\", 3);\n cmap.glyphIndexMap = {};\n const endCountParser = new parse_default.Parser(data, start + offset + 14);\n const startCountParser = new parse_default.Parser(data, start + offset + 16 + segCount * 2);\n const idDeltaParser = new parse_default.Parser(data, start + offset + 16 + segCount * 4);\n const idRangeOffsetParser = new parse_default.Parser(data, start + offset + 16 + segCount * 6);\n let glyphIndexOffset = start + offset + 16 + segCount * 8;\n for (let i = 0; i < segCount - 1; i += 1) {\n let glyphIndex;\n const endCount = endCountParser.parseUShort();\n const startCount = startCountParser.parseUShort();\n const idDelta = idDeltaParser.parseShort();\n const idRangeOffset = idRangeOffsetParser.parseUShort();\n for (let c = startCount; c <= endCount; c += 1) {\n if (idRangeOffset !== 0) {\n glyphIndexOffset = idRangeOffsetParser.offset + idRangeOffsetParser.relativeOffset - 2;\n glyphIndexOffset += idRangeOffset;\n glyphIndexOffset += (c - startCount) * 2;\n glyphIndex = parse_default.getUShort(data, glyphIndexOffset);\n if (glyphIndex !== 0) {\n glyphIndex = glyphIndex + idDelta & 65535;\n }\n } else {\n glyphIndex = c + idDelta & 65535;\n }\n cmap.glyphIndexMap[c] = glyphIndex;\n }\n }\n }\n function parseCmapTableFormat14(cmap, p) {\n const varSelectorList = {};\n p.skip(\"uLong\");\n const numVarSelectorRecords = p.parseULong();\n for (let i = 0; i < numVarSelectorRecords; i += 1) {\n const varSelector = p.parseUInt24();\n const varSelectorRecord = {\n varSelector\n };\n const defaultUVSOffset = p.parseOffset32();\n const nonDefaultUVSOffset = p.parseOffset32();\n const currentOffset = p.relativeOffset;\n if (defaultUVSOffset) {\n p.relativeOffset = defaultUVSOffset;\n varSelectorRecord.defaultUVS = p.parseStruct({\n ranges: function() {\n return p.parseRecordList32({\n startUnicodeValue: p.parseUInt24,\n additionalCount: p.parseByte\n });\n }\n });\n }\n if (nonDefaultUVSOffset) {\n p.relativeOffset = nonDefaultUVSOffset;\n varSelectorRecord.nonDefaultUVS = p.parseStruct({\n uvsMappings: function() {\n const map = {};\n const list = p.parseRecordList32({\n unicodeValue: p.parseUInt24,\n glyphID: p.parseUShort\n });\n for (let i2 = 0; i2 < list.length; i2 += 1) {\n map[list[i2].unicodeValue] = list[i2];\n }\n return map;\n }\n });\n }\n varSelectorList[varSelector] = varSelectorRecord;\n p.relativeOffset = currentOffset;\n }\n cmap.varSelectorList = varSelectorList;\n }\n function parseCmapTable(data, start) {\n const cmap = {};\n cmap.version = parse_default.getUShort(data, start);\n check_default.argument(cmap.version === 0, \"cmap table version should be 0.\");\n cmap.numTables = parse_default.getUShort(data, start + 2);\n let format14Parser = null;\n let format14offset = -1;\n let offset = -1;\n let platformId = null;\n let encodingId = null;\n const platform0Encodings = [0, 1, 2, 3, 4, 6];\n const platform3Encodings = [0, 1, 10];\n for (let i = cmap.numTables - 1; i >= 0; i -= 1) {\n platformId = parse_default.getUShort(data, start + 4 + i * 8);\n encodingId = parse_default.getUShort(data, start + 4 + i * 8 + 2);\n if (platformId === 3 && platform3Encodings.includes(encodingId) || platformId === 0 && platform0Encodings.includes(encodingId) || platformId === 1 && encodingId === 0) {\n if (offset > 0) continue;\n offset = parse_default.getULong(data, start + 4 + i * 8 + 4);\n if (format14Parser) {\n break;\n }\n } else if (platformId === 0 && encodingId === 5) {\n format14offset = parse_default.getULong(data, start + 4 + i * 8 + 4);\n format14Parser = new parse_default.Parser(data, start + format14offset);\n if (format14Parser.parseUShort() !== 14) {\n format14offset = -1;\n format14Parser = null;\n } else if (offset > 0) {\n break;\n }\n }\n }\n if (offset === -1) {\n throw new Error(\"No valid cmap sub-tables found.\");\n }\n const p = new parse_default.Parser(data, start + offset);\n cmap.format = p.parseUShort();\n if (cmap.format === 0) {\n parseCmapTableFormat0(cmap, p, platformId, encodingId);\n } else if (cmap.format === 12 || cmap.format === 13) {\n parseCmapTableFormat12or13(cmap, p, cmap.format);\n } else if (cmap.format === 4) {\n parseCmapTableFormat4(cmap, p, data, start, offset);\n } else {\n throw new Error(\n \"Only format 0 (platformId 1, encodingId 0), 4, 12 and 14 cmap tables are supported (found format \" + cmap.format + \", platformId \" + platformId + \", encodingId \" + encodingId + \").\"\n );\n }\n if (format14Parser) {\n parseCmapTableFormat14(cmap, format14Parser);\n }\n return cmap;\n }\n function addSegment(t, code, glyphIndex) {\n t.segments.push({\n end: code,\n start: code,\n delta: -(code - glyphIndex),\n offset: 0,\n glyphIndex\n });\n }\n function addTerminatorSegment(t) {\n t.segments.push({\n end: 65535,\n start: 65535,\n delta: 1,\n offset: 0\n });\n }\n function mergeSegments(segments) {\n if (segments.length === 0) return segments;\n const merged = [segments[0]];\n for (let i = 1; i < segments.length; i++) {\n const prev = merged[merged.length - 1];\n const curr = segments[i];\n if (prev.end + 1 === curr.start && prev.delta === curr.delta && curr.end !== 65535) {\n prev.end = curr.end;\n } else {\n merged.push(curr);\n }\n }\n return merged;\n }\n function makeCmapTable(glyphs) {\n let isPlan0Only = true;\n let i;\n for (i = glyphs.length - 1; i > 0; i -= 1) {\n const g = glyphs.get(i);\n if (g.unicode > 65535) {\n isPlan0Only = false;\n break;\n }\n }\n let cmapTable = [\n { name: \"version\", type: \"USHORT\", value: 0 },\n { name: \"numTables\", type: \"USHORT\", value: isPlan0Only ? 1 : 2 },\n // CMAP 4 header\n { name: \"platformID\", type: \"USHORT\", value: 3 },\n { name: \"encodingID\", type: \"USHORT\", value: 1 },\n { name: \"offset\", type: \"ULONG\", value: isPlan0Only ? 12 : 12 + 8 }\n ];\n if (!isPlan0Only)\n cmapTable.push(...[\n // CMAP 12 header\n { name: \"cmap12PlatformID\", type: \"USHORT\", value: 3 },\n // We encode only for PlatformID = 3 (Windows) because it is supported everywhere\n { name: \"cmap12EncodingID\", type: \"USHORT\", value: 10 },\n { name: \"cmap12Offset\", type: \"ULONG\", value: 0 }\n ]);\n cmapTable.push(...[\n // CMAP 4 Subtable\n { name: \"format\", type: \"USHORT\", value: 4 },\n { name: \"cmap4Length\", type: \"USHORT\", value: 0 },\n { name: \"language\", type: \"USHORT\", value: 0 },\n { name: \"segCountX2\", type: \"USHORT\", value: 0 },\n { name: \"searchRange\", type: \"USHORT\", value: 0 },\n { name: \"entrySelector\", type: \"USHORT\", value: 0 },\n { name: \"rangeShift\", type: \"USHORT\", value: 0 }\n ]);\n const t = new table_default.Table(\"cmap\", cmapTable);\n t.segments = [];\n for (i = 0; i < glyphs.length; i += 1) {\n const glyph = glyphs.get(i);\n for (let j = 0; j < glyph.unicodes.length; j += 1) {\n addSegment(t, glyph.unicodes[j], i);\n }\n }\n t.segments.sort(function(a, b) {\n return a.start - b.start;\n });\n t.segments = mergeSegments(t.segments);\n addTerminatorSegment(t);\n const segCount = t.segments.length;\n let segCountToRemove = 0;\n let endCounts = [];\n let startCounts = [];\n let idDeltas = [];\n let idRangeOffsets = [];\n let glyphIds = [];\n let cmap12Groups = [];\n for (i = 0; i < segCount; i += 1) {\n const segment = t.segments[i];\n if (segment.end <= 65535 && segment.start <= 65535) {\n endCounts.push({ name: \"end_\" + i, type: \"USHORT\", value: segment.end });\n startCounts.push({ name: \"start_\" + i, type: \"USHORT\", value: segment.start });\n idDeltas.push({ name: \"idDelta_\" + i, type: \"SHORT\", value: segment.delta });\n idRangeOffsets.push({ name: \"idRangeOffset_\" + i, type: \"USHORT\", value: segment.offset });\n if (segment.glyphId !== void 0) {\n glyphIds.push({ name: \"glyph_\" + i, type: \"USHORT\", value: segment.glyphId });\n }\n } else {\n segCountToRemove += 1;\n }\n if (!isPlan0Only && segment.glyphIndex !== void 0) {\n cmap12Groups.push({ name: \"cmap12Start_\" + i, type: \"ULONG\", value: segment.start });\n cmap12Groups.push({ name: \"cmap12End_\" + i, type: \"ULONG\", value: segment.end });\n cmap12Groups.push({ name: \"cmap12Glyph_\" + i, type: \"ULONG\", value: segment.glyphIndex });\n }\n }\n t.segCountX2 = (segCount - segCountToRemove) * 2;\n t.searchRange = Math.pow(2, Math.floor(Math.log(segCount - segCountToRemove) / Math.log(2))) * 2;\n t.entrySelector = Math.log(t.searchRange / 2) / Math.log(2);\n t.rangeShift = t.segCountX2 - t.searchRange;\n for (let i2 = 0; i2 < endCounts.length; i2++) {\n t.fields.push(endCounts[i2]);\n }\n t.fields.push({ name: \"reservedPad\", type: \"USHORT\", value: 0 });\n for (let i2 = 0; i2 < startCounts.length; i2++) {\n t.fields.push(startCounts[i2]);\n }\n for (let i2 = 0; i2 < idDeltas.length; i2++) {\n t.fields.push(idDeltas[i2]);\n }\n for (let i2 = 0; i2 < idRangeOffsets.length; i2++) {\n t.fields.push(idRangeOffsets[i2]);\n }\n for (let i2 = 0; i2 < glyphIds.length; i2++) {\n t.fields.push(glyphIds[i2]);\n }\n t.cmap4Length = 14 + // Subtable header\n endCounts.length * 2 + 2 + // reservedPad\n startCounts.length * 2 + idDeltas.length * 2 + idRangeOffsets.length * 2 + glyphIds.length * 2;\n if (!isPlan0Only) {\n const cmap12Length = 16 + // Subtable header\n cmap12Groups.length * 4;\n t.cmap12Offset = 12 + 2 * 2 + 4 + t.cmap4Length;\n t.fields.push(...[\n { name: \"cmap12Format\", type: \"USHORT\", value: 12 },\n { name: \"cmap12Reserved\", type: \"USHORT\", value: 0 },\n { name: \"cmap12Length\", type: \"ULONG\", value: cmap12Length },\n { name: \"cmap12Language\", type: \"ULONG\", value: 0 },\n { name: \"cmap12nGroups\", type: \"ULONG\", value: cmap12Groups.length / 3 }\n ]);\n for (let i2 = 0; i2 < cmap12Groups.length; i2++) {\n t.fields.push(cmap12Groups[i2]);\n }\n }\n return t;\n }\n var cmap_default = { parse: parseCmapTable, make: makeCmapTable };\n\n // src/encoding.mjs\n var cffStandardStrings = [\n \".notdef\",\n \"space\",\n \"exclam\",\n \"quotedbl\",\n \"numbersign\",\n \"dollar\",\n \"percent\",\n \"ampersand\",\n \"quoteright\",\n \"parenleft\",\n \"parenright\",\n \"asterisk\",\n \"plus\",\n \"comma\",\n \"hyphen\",\n \"period\",\n \"slash\",\n \"zero\",\n \"one\",\n \"two\",\n \"three\",\n \"four\",\n \"five\",\n \"six\",\n \"seven\",\n \"eight\",\n \"nine\",\n \"colon\",\n \"semicolon\",\n \"less\",\n \"equal\",\n \"greater\",\n \"question\",\n \"at\",\n \"A\",\n \"B\",\n \"C\",\n \"D\",\n \"E\",\n \"F\",\n \"G\",\n \"H\",\n \"I\",\n \"J\",\n \"K\",\n \"L\",\n \"M\",\n \"N\",\n \"O\",\n \"P\",\n \"Q\",\n \"R\",\n \"S\",\n \"T\",\n \"U\",\n \"V\",\n \"W\",\n \"X\",\n \"Y\",\n \"Z\",\n \"bracketleft\",\n \"backslash\",\n \"bracketright\",\n \"asciicircum\",\n \"underscore\",\n \"quoteleft\",\n \"a\",\n \"b\",\n \"c\",\n \"d\",\n \"e\",\n \"f\",\n \"g\",\n \"h\",\n \"i\",\n \"j\",\n \"k\",\n \"l\",\n \"m\",\n \"n\",\n \"o\",\n \"p\",\n \"q\",\n \"r\",\n \"s\",\n \"t\",\n \"u\",\n \"v\",\n \"w\",\n \"x\",\n \"y\",\n \"z\",\n \"braceleft\",\n \"bar\",\n \"braceright\",\n \"asciitilde\",\n \"exclamdown\",\n \"cent\",\n \"sterling\",\n \"fraction\",\n \"yen\",\n \"florin\",\n \"section\",\n \"currency\",\n \"quotesingle\",\n \"quotedblleft\",\n \"guillemotleft\",\n \"guilsinglleft\",\n \"guilsinglright\",\n \"fi\",\n \"fl\",\n \"endash\",\n \"dagger\",\n \"daggerdbl\",\n \"periodcentered\",\n \"paragraph\",\n \"bullet\",\n \"quotesinglbase\",\n \"quotedblbase\",\n \"quotedblright\",\n \"guillemotright\",\n \"ellipsis\",\n \"perthousand\",\n \"questiondown\",\n \"grave\",\n \"acute\",\n \"circumflex\",\n \"tilde\",\n \"macron\",\n \"breve\",\n \"dotaccent\",\n \"dieresis\",\n \"ring\",\n \"cedilla\",\n \"hungarumlaut\",\n \"ogonek\",\n \"caron\",\n \"emdash\",\n \"AE\",\n \"ordfeminine\",\n \"Lslash\",\n \"Oslash\",\n \"OE\",\n \"ordmasculine\",\n \"ae\",\n \"dotlessi\",\n \"lslash\",\n \"oslash\",\n \"oe\",\n \"germandbls\",\n \"onesuperior\",\n \"logicalnot\",\n \"mu\",\n \"trademark\",\n \"Eth\",\n \"onehalf\",\n \"plusminus\",\n \"Thorn\",\n \"onequarter\",\n \"divide\",\n \"brokenbar\",\n \"degree\",\n \"thorn\",\n \"threequarters\",\n \"twosuperior\",\n \"registered\",\n \"minus\",\n \"eth\",\n \"multiply\",\n \"threesuperior\",\n \"copyright\",\n \"Aacute\",\n \"Acircumflex\",\n \"Adieresis\",\n \"Agrave\",\n \"Aring\",\n \"Atilde\",\n \"Ccedilla\",\n \"Eacute\",\n \"Ecircumflex\",\n \"Edieresis\",\n \"Egrave\",\n \"Iacute\",\n \"Icircumflex\",\n \"Idieresis\",\n \"Igrave\",\n \"Ntilde\",\n \"Oacute\",\n \"Ocircumflex\",\n \"Odieresis\",\n \"Ograve\",\n \"Otilde\",\n \"Scaron\",\n \"Uacute\",\n \"Ucircumflex\",\n \"Udieresis\",\n \"Ugrave\",\n \"Yacute\",\n \"Ydieresis\",\n \"Zcaron\",\n \"aacute\",\n \"acircumflex\",\n \"adieresis\",\n \"agrave\",\n \"aring\",\n \"atilde\",\n \"ccedilla\",\n \"eacute\",\n \"ecircumflex\",\n \"edieresis\",\n \"egrave\",\n \"iacute\",\n \"icircumflex\",\n \"idieresis\",\n \"igrave\",\n \"ntilde\",\n \"oacute\",\n \"ocircumflex\",\n \"odieresis\",\n \"ograve\",\n \"otilde\",\n \"scaron\",\n \"uacute\",\n \"ucircumflex\",\n \"udieresis\",\n \"ugrave\",\n \"yacute\",\n \"ydieresis\",\n \"zcaron\",\n \"exclamsmall\",\n \"Hungarumlautsmall\",\n \"dollaroldstyle\",\n \"dollarsuperior\",\n \"ampersandsmall\",\n \"Acutesmall\",\n \"parenleftsuperior\",\n \"parenrightsuperior\",\n \"266 ff\",\n \"onedotenleader\",\n \"zerooldstyle\",\n \"oneoldstyle\",\n \"twooldstyle\",\n \"threeoldstyle\",\n \"fouroldstyle\",\n \"fiveoldstyle\",\n \"sixoldstyle\",\n \"sevenoldstyle\",\n \"eightoldstyle\",\n \"nineoldstyle\",\n \"commasuperior\",\n \"threequartersemdash\",\n \"periodsuperior\",\n \"questionsmall\",\n \"asuperior\",\n \"bsuperior\",\n \"centsuperior\",\n \"dsuperior\",\n \"esuperior\",\n \"isuperior\",\n \"lsuperior\",\n \"msuperior\",\n \"nsuperior\",\n \"osuperior\",\n \"rsuperior\",\n \"ssuperior\",\n \"tsuperior\",\n \"ff\",\n \"ffi\",\n \"ffl\",\n \"parenleftinferior\",\n \"parenrightinferior\",\n \"Circumflexsmall\",\n \"hyphensuperior\",\n \"Gravesmall\",\n \"Asmall\",\n \"Bsmall\",\n \"Csmall\",\n \"Dsmall\",\n \"Esmall\",\n \"Fsmall\",\n \"Gsmall\",\n \"Hsmall\",\n \"Ismall\",\n \"Jsmall\",\n \"Ksmall\",\n \"Lsmall\",\n \"Msmall\",\n \"Nsmall\",\n \"Osmall\",\n \"Psmall\",\n \"Qsmall\",\n \"Rsmall\",\n \"Ssmall\",\n \"Tsmall\",\n \"Usmall\",\n \"Vsmall\",\n \"Wsmall\",\n \"Xsmall\",\n \"Ysmall\",\n \"Zsmall\",\n \"colonmonetary\",\n \"onefitted\",\n \"rupiah\",\n \"Tildesmall\",\n \"exclamdownsmall\",\n \"centoldstyle\",\n \"Lslashsmall\",\n \"Scaronsmall\",\n \"Zcaronsmall\",\n \"Dieresissmall\",\n \"Brevesmall\",\n \"Caronsmall\",\n \"Dotaccentsmall\",\n \"Macronsmall\",\n \"figuredash\",\n \"hypheninferior\",\n \"Ogoneksmall\",\n \"Ringsmall\",\n \"Cedillasmall\",\n \"questiondownsmall\",\n \"oneeighth\",\n \"threeeighths\",\n \"fiveeighths\",\n \"seveneighths\",\n \"onethird\",\n \"twothirds\",\n \"zerosuperior\",\n \"foursuperior\",\n \"fivesuperior\",\n \"sixsuperior\",\n \"sevensuperior\",\n \"eightsuperior\",\n \"ninesuperior\",\n \"zeroinferior\",\n \"oneinferior\",\n \"twoinferior\",\n \"threeinferior\",\n \"fourinferior\",\n \"fiveinferior\",\n \"sixinferior\",\n \"seveninferior\",\n \"eightinferior\",\n \"nineinferior\",\n \"centinferior\",\n \"dollarinferior\",\n \"periodinferior\",\n \"commainferior\",\n \"Agravesmall\",\n \"Aacutesmall\",\n \"Acircumflexsmall\",\n \"Atildesmall\",\n \"Adieresissmall\",\n \"Aringsmall\",\n \"AEsmall\",\n \"Ccedillasmall\",\n \"Egravesmall\",\n \"Eacutesmall\",\n \"Ecircumflexsmall\",\n \"Edieresissmall\",\n \"Igravesmall\",\n \"Iacutesmall\",\n \"Icircumflexsmall\",\n \"Idieresissmall\",\n \"Ethsmall\",\n \"Ntildesmall\",\n \"Ogravesmall\",\n \"Oacutesmall\",\n \"Ocircumflexsmall\",\n \"Otildesmall\",\n \"Odieresissmall\",\n \"OEsmall\",\n \"Oslashsmall\",\n \"Ugravesmall\",\n \"Uacutesmall\",\n \"Ucircumflexsmall\",\n \"Udieresissmall\",\n \"Yacutesmall\",\n \"Thornsmall\",\n \"Ydieresissmall\",\n \"001.000\",\n \"001.001\",\n \"001.002\",\n \"001.003\",\n \"Black\",\n \"Bold\",\n \"Book\",\n \"Light\",\n \"Medium\",\n \"Regular\",\n \"Roman\",\n \"Semibold\"\n ];\n var cffISOAdobeStrings = [\n \".notdef\",\n \"space\",\n \"exclam\",\n \"quotedbl\",\n \"numbersign\",\n \"dollar\",\n \"percent\",\n \"ampersand\",\n \"quoteright\",\n \"parenleft\",\n \"parenright\",\n \"asterisk\",\n \"plus\",\n \"comma\",\n \"hyphen\",\n \"period\",\n \"slash\",\n \"zero\",\n \"one\",\n \"two\",\n \"three\",\n \"four\",\n \"five\",\n \"six\",\n \"seven\",\n \"eight\",\n \"nine\",\n \"colon\",\n \"semicolon\",\n \"less\",\n \"equal\",\n \"greater\",\n \"question\",\n \"at\",\n \"A\",\n \"B\",\n \"C\",\n \"D\",\n \"E\",\n \"F\",\n \"G\",\n \"H\",\n \"I\",\n \"J\",\n \"K\",\n \"L\",\n \"M\",\n \"N\",\n \"O\",\n \"P\",\n \"Q\",\n \"R\",\n \"S\",\n \"T\",\n \"U\",\n \"V\",\n \"W\",\n \"X\",\n \"Y\",\n \"Z\",\n \"bracketleft\",\n \"backslash\",\n \"bracketright\",\n \"asciicircum\",\n \"underscore\",\n \"quoteleft\",\n \"a\",\n \"b\",\n \"c\",\n \"d\",\n \"e\",\n \"f\",\n \"g\",\n \"h\",\n \"i\",\n \"j\",\n \"k\",\n \"l\",\n \"m\",\n \"n\",\n \"o\",\n \"p\",\n \"q\",\n \"r\",\n \"s\",\n \"t\",\n \"u\",\n \"v\",\n \"w\",\n \"x\",\n \"y\",\n \"z\",\n \"braceleft\",\n \"bar\",\n \"braceright\",\n \"asciitilde\",\n \"exclamdown\",\n \"cent\",\n \"sterling\",\n \"fraction\",\n \"yen\",\n \"florin\",\n \"section\",\n \"currency\",\n \"quotesingle\",\n \"quotedblleft\",\n \"guillemotleft\",\n \"guilsinglleft\",\n \"guilsinglright\",\n \"fi\",\n \"fl\",\n \"endash\",\n \"dagger\",\n \"daggerdbl\",\n \"periodcentered\",\n \"paragraph\",\n \"bullet\",\n \"quotesinglbase\",\n \"quotedblbase\",\n \"quotedblright\",\n \"guillemotright\",\n \"ellipsis\",\n \"perthousand\",\n \"questiondown\",\n \"grave\",\n \"acute\",\n \"circumflex\",\n \"tilde\",\n \"macron\",\n \"breve\",\n \"dotaccent\",\n \"dieresis\",\n \"ring\",\n \"cedilla\",\n \"hungarumlaut\",\n \"ogonek\",\n \"caron\",\n \"emdash\",\n \"AE\",\n \"ordfeminine\",\n \"Lslash\",\n \"Oslash\",\n \"OE\",\n \"ordmasculine\",\n \"ae\",\n \"dotlessi\",\n \"lslash\",\n \"oslash\",\n \"oe\",\n \"germandbls\",\n \"onesuperior\",\n \"logicalnot\",\n \"mu\",\n \"trademark\",\n \"Eth\",\n \"onehalf\",\n \"plusminus\",\n \"Thorn\",\n \"onequarter\",\n \"divide\",\n \"brokenbar\",\n \"degree\",\n \"thorn\",\n \"threequarters\",\n \"twosuperior\",\n \"registered\",\n \"minus\",\n \"eth\",\n \"multiply\",\n \"threesuperior\",\n \"copyright\",\n \"Aacute\",\n \"Acircumflex\",\n \"Adieresis\",\n \"Agrave\",\n \"Aring\",\n \"Atilde\",\n \"Ccedilla\",\n \"Eacute\",\n \"Ecircumflex\",\n \"Edieresis\",\n \"Egrave\",\n \"Iacute\",\n \"Icircumflex\",\n \"Idieresis\",\n \"Igrave\",\n \"Ntilde\",\n \"Oacute\",\n \"Ocircumflex\",\n \"Odieresis\",\n \"Ograve\",\n \"Otilde\",\n \"Scaron\",\n \"Uacute\",\n \"Ucircumflex\",\n \"Udieresis\",\n \"Ugrave\",\n \"Yacute\",\n \"Ydieresis\",\n \"Zcaron\",\n \"aacute\",\n \"acircumflex\",\n \"adieresis\",\n \"agrave\",\n \"aring\",\n \"atilde\",\n \"ccedilla\",\n \"eacute\",\n \"ecircumflex\",\n \"edieresis\",\n \"egrave\",\n \"iacute\",\n \"icircumflex\",\n \"idieresis\",\n \"igrave\",\n \"ntilde\",\n \"oacute\",\n \"ocircumflex\",\n \"odieresis\",\n \"ograve\",\n \"otilde\",\n \"scaron\",\n \"uacute\",\n \"ucircumflex\",\n \"udieresis\",\n \"ugrave\",\n \"yacute\",\n \"ydieresis\",\n \"zcaron\"\n ];\n var cffIExpertStrings = [\n \".notdef\",\n \"space\",\n \"exclamsmall\",\n \"Hungarumlautsmall\",\n \"dollaroldstyle\",\n \"dollarsuperior\",\n \"ampersandsmall\",\n \"Acutesmall\",\n \"parenleftsuperior\",\n \"parenrightsuperior\",\n \"twodotenleader\",\n \"onedotenleader\",\n \"comma\",\n \"hyphen\",\n \"period\",\n \"fraction\",\n \"zerooldstyle\",\n \"oneoldstyle\",\n \"twooldstyle\",\n \"threeoldstyle\",\n \"fouroldstyle\",\n \"fiveoldstyle\",\n \"sixoldstyle\",\n \"sevenoldstyle\",\n \"eightoldstyle\",\n \"nineoldstyle\",\n \"colon\",\n \"semicolon\",\n \"commasuperior\",\n \"threequartersemdash\",\n \"periodsuperior\",\n \"questionsmall\",\n \"asuperior\",\n \"bsuperior\",\n \"centsuperior\",\n \"dsuperior\",\n \"esuperior\",\n \"isuperior\",\n \"lsuperior\",\n \"msuperior\",\n \"nsuperior\",\n \"osuperior\",\n \"rsuperior\",\n \"ssuperior\",\n \"tsuperior\",\n \"ff\",\n \"fi\",\n \"fl\",\n \"ffi\",\n \"ffl\",\n \"parenleftinferior\",\n \"parenrightinferior\",\n \"Circumflexsmall\",\n \"hyphensuperior\",\n \"Gravesmall\",\n \"Asmall\",\n \"Bsmall\",\n \"Csmall\",\n \"Dsmall\",\n \"Esmall\",\n \"Fsmall\",\n \"Gsmall\",\n \"Hsmall\",\n \"Ismall\",\n \"Jsmall\",\n \"Ksmall\",\n \"Lsmall\",\n \"Msmall\",\n \"Nsmall\",\n \"Osmall\",\n \"Psmall\",\n \"Qsmall\",\n \"Rsmall\",\n \"Ssmall\",\n \"Tsmall\",\n \"Usmall\",\n \"Vsmall\",\n \"Wsmall\",\n \"Xsmall\",\n \"Ysmall\",\n \"Zsmall\",\n \"colonmonetary\",\n \"onefitted\",\n \"rupiah\",\n \"Tildesmall\",\n \"exclamdownsmall\",\n \"centoldstyle\",\n \"Lslashsmall\",\n \"Scaronsmall\",\n \"Zcaronsmall\",\n \"Dieresissmall\",\n \"Brevesmall\",\n \"Caronsmall\",\n \"Dotaccentsmall\",\n \"Macronsmall\",\n \"figuredash\",\n \"hypheninferior\",\n \"Ogoneksmall\",\n \"Ringsmall\",\n \"Cedillasmall\",\n \"onequarter\",\n \"onehalf\",\n \"threequarters\",\n \"questiondownsmall\",\n \"oneeighth\",\n \"threeeighths\",\n \"fiveeighths\",\n \"seveneighths\",\n \"onethird\",\n \"twothirds\",\n \"zerosuperior\",\n \"onesuperior\",\n \"twosuperior\",\n \"threesuperior\",\n \"foursuperior\",\n \"fivesuperior\",\n \"sixsuperior\",\n \"sevensuperior\",\n \"eightsuperior\",\n \"ninesuperior\",\n \"zeroinferior\",\n \"oneinferior\",\n \"twoinferior\",\n \"threeinferior\",\n \"fourinferior\",\n \"fiveinferior\",\n \"sixinferior\",\n \"seveninferior\",\n \"eightinferior\",\n \"nineinferior\",\n \"centinferior\",\n \"dollarinferior\",\n \"periodinferior\",\n \"commainferior\",\n \"Agravesmall\",\n \"Aacutesmall\",\n \"Acircumflexsmall\",\n \"Atildesmall\",\n \"Adieresissmall\",\n \"Aringsmall\",\n \"AEsmall\",\n \"Ccedillasmall\",\n \"Egravesmall\",\n \"Eacutesmall\",\n \"Ecircumflexsmall\",\n \"Edieresissmall\",\n \"Igravesmall\",\n \"Iacutesmall\",\n \"Icircumflexsmall\",\n \"Idieresissmall\",\n \"Ethsmall\",\n \"Ntildesmall\",\n \"Ogravesmall\",\n \"Oacutesmall\",\n \"Ocircumflexsmall\",\n \"Otildesmall\",\n \"Odieresissmall\",\n \"OEsmall\",\n \"Oslashsmall\",\n \"Ugravesmall\",\n \"Uacutesmall\",\n \"Ucircumflexsmall\",\n \"Udieresissmall\",\n \"Yacutesmall\",\n \"Thornsmall\",\n \"Ydieresissmall\"\n ];\n var cffExpertSubsetStrings = [\n \".notdef\",\n \"space\",\n \"dollaroldstyle\",\n \"dollarsuperior\",\n \"parenleftsuperior\",\n \"parenrightsuperior\",\n \"twodotenleader\",\n \"onedotenleader\",\n \"comma\",\n \"hyphen\",\n \"period\",\n \"fraction\",\n \"zerooldstyle\",\n \"oneoldstyle\",\n \"twooldstyle\",\n \"threeoldstyle\",\n \"fouroldstyle\",\n \"fiveoldstyle\",\n \"sixoldstyle\",\n \"sevenoldstyle\",\n \"eightoldstyle\",\n \"nineoldstyle\",\n \"colon\",\n \"semicolon\",\n \"commasuperior\",\n \"threequartersemdash\",\n \"periodsuperior\",\n \"asuperior\",\n \"bsuperior\",\n \"centsuperior\",\n \"dsuperior\",\n \"esuperior\",\n \"isuperior\",\n \"lsuperior\",\n \"msuperior\",\n \"nsuperior\",\n \"osuperior\",\n \"rsuperior\",\n \"ssuperior\",\n \"tsuperior\",\n \"ff\",\n \"fi\",\n \"fl\",\n \"ffi\",\n \"ffl\",\n \"parenleftinferior\",\n \"parenrightinferior\",\n \"hyphensuperior\",\n \"colonmonetary\",\n \"onefitted\",\n \"rupiah\",\n \"centoldstyle\",\n \"figuredash\",\n \"hypheninferior\",\n \"onequarter\",\n \"onehalf\",\n \"threequarters\",\n \"oneeighth\",\n \"threeeighths\",\n \"fiveeighths\",\n \"seveneighths\",\n \"onethird\",\n \"twothirds\",\n \"zerosuperior\",\n \"onesuperior\",\n \"twosuperior\",\n \"threesuperior\",\n \"foursuperior\",\n \"fivesuperior\",\n \"sixsuperior\",\n \"sevensuperior\",\n \"eightsuperior\",\n \"ninesuperior\",\n \"zeroinferior\",\n \"oneinferior\",\n \"twoinferior\",\n \"threeinferior\",\n \"fourinferior\",\n \"fiveinferior\",\n \"sixinferior\",\n \"seveninferior\",\n \"eightinferior\",\n \"nineinferior\",\n \"centinferior\",\n \"dollarinferior\",\n \"periodinferior\",\n \"commainferior\"\n ];\n var cffStandardEncoding = [\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"space\",\n \"exclam\",\n \"quotedbl\",\n \"numbersign\",\n \"dollar\",\n \"percent\",\n \"ampersand\",\n \"quoteright\",\n \"parenleft\",\n \"parenright\",\n \"asterisk\",\n \"plus\",\n \"comma\",\n \"hyphen\",\n \"period\",\n \"slash\",\n \"zero\",\n \"one\",\n \"two\",\n \"three\",\n \"four\",\n \"five\",\n \"six\",\n \"seven\",\n \"eight\",\n \"nine\",\n \"colon\",\n \"semicolon\",\n \"less\",\n \"equal\",\n \"greater\",\n \"question\",\n \"at\",\n \"A\",\n \"B\",\n \"C\",\n \"D\",\n \"E\",\n \"F\",\n \"G\",\n \"H\",\n \"I\",\n \"J\",\n \"K\",\n \"L\",\n \"M\",\n \"N\",\n \"O\",\n \"P\",\n \"Q\",\n \"R\",\n \"S\",\n \"T\",\n \"U\",\n \"V\",\n \"W\",\n \"X\",\n \"Y\",\n \"Z\",\n \"bracketleft\",\n \"backslash\",\n \"bracketright\",\n \"asciicircum\",\n \"underscore\",\n \"quoteleft\",\n \"a\",\n \"b\",\n \"c\",\n \"d\",\n \"e\",\n \"f\",\n \"g\",\n \"h\",\n \"i\",\n \"j\",\n \"k\",\n \"l\",\n \"m\",\n \"n\",\n \"o\",\n \"p\",\n \"q\",\n \"r\",\n \"s\",\n \"t\",\n \"u\",\n \"v\",\n \"w\",\n \"x\",\n \"y\",\n \"z\",\n \"braceleft\",\n \"bar\",\n \"braceright\",\n \"asciitilde\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"exclamdown\",\n \"cent\",\n \"sterling\",\n \"fraction\",\n \"yen\",\n \"florin\",\n \"section\",\n \"currency\",\n \"quotesingle\",\n \"quotedblleft\",\n \"guillemotleft\",\n \"guilsinglleft\",\n \"guilsinglright\",\n \"fi\",\n \"fl\",\n \"\",\n \"endash\",\n \"dagger\",\n \"daggerdbl\",\n \"periodcentered\",\n \"\",\n \"paragraph\",\n \"bullet\",\n \"quotesinglbase\",\n \"quotedblbase\",\n \"quotedblright\",\n \"guillemotright\",\n \"ellipsis\",\n \"perthousand\",\n \"\",\n \"questiondown\",\n \"\",\n \"grave\",\n \"acute\",\n \"circumflex\",\n \"tilde\",\n \"macron\",\n \"breve\",\n \"dotaccent\",\n \"dieresis\",\n \"\",\n \"ring\",\n \"cedilla\",\n \"\",\n \"hungarumlaut\",\n \"ogonek\",\n \"caron\",\n \"emdash\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"AE\",\n \"\",\n \"ordfeminine\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"Lslash\",\n \"Oslash\",\n \"OE\",\n \"ordmasculine\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"ae\",\n \"\",\n \"\",\n \"\",\n \"dotlessi\",\n \"\",\n \"\",\n \"lslash\",\n \"oslash\",\n \"oe\",\n \"germandbls\"\n ];\n var cffExpertEncoding = [\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"space\",\n \"exclamsmall\",\n \"Hungarumlautsmall\",\n \"\",\n \"dollaroldstyle\",\n \"dollarsuperior\",\n \"ampersandsmall\",\n \"Acutesmall\",\n \"parenleftsuperior\",\n \"parenrightsuperior\",\n \"twodotenleader\",\n \"onedotenleader\",\n \"comma\",\n \"hyphen\",\n \"period\",\n \"fraction\",\n \"zerooldstyle\",\n \"oneoldstyle\",\n \"twooldstyle\",\n \"threeoldstyle\",\n \"fouroldstyle\",\n \"fiveoldstyle\",\n \"sixoldstyle\",\n \"sevenoldstyle\",\n \"eightoldstyle\",\n \"nineoldstyle\",\n \"colon\",\n \"semicolon\",\n \"commasuperior\",\n \"threequartersemdash\",\n \"periodsuperior\",\n \"questionsmall\",\n \"\",\n \"asuperior\",\n \"bsuperior\",\n \"centsuperior\",\n \"dsuperior\",\n \"esuperior\",\n \"\",\n \"\",\n \"isuperior\",\n \"\",\n \"\",\n \"lsuperior\",\n \"msuperior\",\n \"nsuperior\",\n \"osuperior\",\n \"\",\n \"\",\n \"rsuperior\",\n \"ssuperior\",\n \"tsuperior\",\n \"\",\n \"ff\",\n \"fi\",\n \"fl\",\n \"ffi\",\n \"ffl\",\n \"parenleftinferior\",\n \"\",\n \"parenrightinferior\",\n \"Circumflexsmall\",\n \"hyphensuperior\",\n \"Gravesmall\",\n \"Asmall\",\n \"Bsmall\",\n \"Csmall\",\n \"Dsmall\",\n \"Esmall\",\n \"Fsmall\",\n \"Gsmall\",\n \"Hsmall\",\n \"Ismall\",\n \"Jsmall\",\n \"Ksmall\",\n \"Lsmall\",\n \"Msmall\",\n \"Nsmall\",\n \"Osmall\",\n \"Psmall\",\n \"Qsmall\",\n \"Rsmall\",\n \"Ssmall\",\n \"Tsmall\",\n \"Usmall\",\n \"Vsmall\",\n \"Wsmall\",\n \"Xsmall\",\n \"Ysmall\",\n \"Zsmall\",\n \"colonmonetary\",\n \"onefitted\",\n \"rupiah\",\n \"Tildesmall\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"\",\n \"exclamdownsmall\",\n \"centoldstyle\",\n \"Lslashsmall\",\n \"\",\n \"\",\n \"Scaronsmall\",\n \"Zcaronsmall\",\n \"Dieresissmall\",\n \"Brevesmall\",\n \"Caronsmall\",\n \"\",\n \"Dotaccentsmall\",\n \"\",\n \"\",\n \"Macronsmall\",\n \"\",\n \"\",\n \"figuredash\",\n \"hypheninferior\",\n \"\",\n \"\",\n \"Ogoneksmall\",\n \"Ringsmall\",\n \"Cedillasmall\",\n \"\",\n \"\",\n \"\",\n \"onequarter\",\n \"onehalf\",\n \"threequarters\",\n \"questiondownsmall\",\n \"oneeighth\",\n \"threeeighths\",\n \"fiveeighths\",\n \"seveneighths\",\n \"onethird\",\n \"twothirds\",\n \"\",\n \"\",\n \"zerosuperior\",\n \"onesuperior\",\n \"twosuperior\",\n \"threesuperior\",\n \"foursuperior\",\n \"fivesuperior\",\n \"sixsuperior\",\n \"sevensuperior\",\n \"eightsuperior\",\n \"ninesuperior\",\n \"zeroinferior\",\n \"oneinferior\",\n \"twoinferior\",\n \"threeinferior\",\n \"fourinferior\",\n \"fiveinferior\",\n \"sixinferior\",\n \"seveninferior\",\n \"eightinferior\",\n \"nineinferior\",\n \"centinferior\",\n \"dollarinferior\",\n \"periodinferior\",\n \"commainferior\",\n \"Agravesmall\",\n \"Aacutesmall\",\n \"Acircumflexsmall\",\n \"Atildesmall\",\n \"Adieresissmall\",\n \"Aringsmall\",\n \"AEsmall\",\n \"Ccedillasmall\",\n \"Egravesmall\",\n \"Eacutesmall\",\n \"Ecircumflexsmall\",\n \"Edieresissmall\",\n \"Igravesmall\",\n \"Iacutesmall\",\n \"Icircumflexsmall\",\n \"Idieresissmall\",\n \"Ethsmall\",\n \"Ntildesmall\",\n \"Ogravesmall\",\n \"Oacutesmall\",\n \"Ocircumflexsmall\",\n \"Otildesmall\",\n \"Odieresissmall\",\n \"OEsmall\",\n \"Oslashsmall\",\n \"Ugravesmall\",\n \"Uacutesmall\",\n \"Ucircumflexsmall\",\n \"Udieresissmall\",\n \"Yacutesmall\",\n \"Thornsmall\",\n \"Ydieresissmall\"\n ];\n var standardNames = [\n \".notdef\",\n \".null\",\n \"nonmarkingreturn\",\n \"space\",\n \"exclam\",\n \"quotedbl\",\n \"numbersign\",\n \"dollar\",\n \"percent\",\n \"ampersand\",\n \"quotesingle\",\n \"parenleft\",\n \"parenright\",\n \"asterisk\",\n \"plus\",\n \"comma\",\n \"hyphen\",\n \"period\",\n \"slash\",\n \"zero\",\n \"one\",\n \"two\",\n \"three\",\n \"four\",\n \"five\",\n \"six\",\n \"seven\",\n \"eight\",\n \"nine\",\n \"colon\",\n \"semicolon\",\n \"less\",\n \"equal\",\n \"greater\",\n \"question\",\n \"at\",\n \"A\",\n \"B\",\n \"C\",\n \"D\",\n \"E\",\n \"F\",\n \"G\",\n \"H\",\n \"I\",\n \"J\",\n \"K\",\n \"L\",\n \"M\",\n \"N\",\n \"O\",\n \"P\",\n \"Q\",\n \"R\",\n \"S\",\n \"T\",\n \"U\",\n \"V\",\n \"W\",\n \"X\",\n \"Y\",\n \"Z\",\n \"bracketleft\",\n \"backslash\",\n \"bracketright\",\n \"asciicircum\",\n \"underscore\",\n \"grave\",\n \"a\",\n \"b\",\n \"c\",\n \"d\",\n \"e\",\n \"f\",\n \"g\",\n \"h\",\n \"i\",\n \"j\",\n \"k\",\n \"l\",\n \"m\",\n \"n\",\n \"o\",\n \"p\",\n \"q\",\n \"r\",\n \"s\",\n \"t\",\n \"u\",\n \"v\",\n \"w\",\n \"x\",\n \"y\",\n \"z\",\n \"braceleft\",\n \"bar\",\n \"braceright\",\n \"asciitilde\",\n \"Adieresis\",\n \"Aring\",\n \"Ccedilla\",\n \"Eacute\",\n \"Ntilde\",\n \"Odieresis\",\n \"Udieresis\",\n \"aacute\",\n \"agrave\",\n \"acircumflex\",\n \"adieresis\",\n \"atilde\",\n \"aring\",\n \"ccedilla\",\n \"eacute\",\n \"egrave\",\n \"ecircumflex\",\n \"edieresis\",\n \"iacute\",\n \"igrave\",\n \"icircumflex\",\n \"idieresis\",\n \"ntilde\",\n \"oacute\",\n \"ograve\",\n \"ocircumflex\",\n \"odieresis\",\n \"otilde\",\n \"uacute\",\n \"ugrave\",\n \"ucircumflex\",\n \"udieresis\",\n \"dagger\",\n \"degree\",\n \"cent\",\n \"sterling\",\n \"section\",\n \"bullet\",\n \"paragraph\",\n \"germandbls\",\n \"registered\",\n \"copyright\",\n \"trademark\",\n \"acute\",\n \"dieresis\",\n \"notequal\",\n \"AE\",\n \"Oslash\",\n \"infinity\",\n \"plusminus\",\n \"lessequal\",\n \"greaterequal\",\n \"yen\",\n \"mu\",\n \"partialdiff\",\n \"summation\",\n \"product\",\n \"pi\",\n \"integral\",\n \"ordfeminine\",\n \"ordmasculine\",\n \"Omega\",\n \"ae\",\n \"oslash\",\n \"questiondown\",\n \"exclamdown\",\n \"logicalnot\",\n \"radical\",\n \"florin\",\n \"approxequal\",\n \"Delta\",\n \"guillemotleft\",\n \"guillemotright\",\n \"ellipsis\",\n \"nonbreakingspace\",\n \"Agrave\",\n \"Atilde\",\n \"Otilde\",\n \"OE\",\n \"oe\",\n \"endash\",\n \"emdash\",\n \"quotedblleft\",\n \"quotedblright\",\n \"quoteleft\",\n \"quoteright\",\n \"divide\",\n \"lozenge\",\n \"ydieresis\",\n \"Ydieresis\",\n \"fraction\",\n \"currency\",\n \"guilsinglleft\",\n \"guilsinglright\",\n \"fi\",\n \"fl\",\n \"daggerdbl\",\n \"periodcentered\",\n \"quotesinglbase\",\n \"quotedblbase\",\n \"perthousand\",\n \"Acircumflex\",\n \"Ecircumflex\",\n \"Aacute\",\n \"Edieresis\",\n \"Egrave\",\n \"Iacute\",\n \"Icircumflex\",\n \"Idieresis\",\n \"Igrave\",\n \"Oacute\",\n \"Ocircumflex\",\n \"apple\",\n \"Ograve\",\n \"Uacute\",\n \"Ucircumflex\",\n \"Ugrave\",\n \"dotlessi\",\n \"circumflex\",\n \"tilde\",\n \"macron\",\n \"breve\",\n \"dotaccent\",\n \"ring\",\n \"cedilla\",\n \"hungarumlaut\",\n \"ogonek\",\n \"caron\",\n \"Lslash\",\n \"lslash\",\n \"Scaron\",\n \"scaron\",\n \"Zcaron\",\n \"zcaron\",\n \"brokenbar\",\n \"Eth\",\n \"eth\",\n \"Yacute\",\n \"yacute\",\n \"Thorn\",\n \"thorn\",\n \"minus\",\n \"multiply\",\n \"onesuperior\",\n \"twosuperior\",\n \"threesuperior\",\n \"onehalf\",\n \"onequarter\",\n \"threequarters\",\n \"franc\",\n \"Gbreve\",\n \"gbreve\",\n \"Idotaccent\",\n \"Scedilla\",\n \"scedilla\",\n \"Cacute\",\n \"cacute\",\n \"Ccaron\",\n \"ccaron\",\n \"dcroat\"\n ];\n function DefaultEncoding(font) {\n this.font = font;\n }\n DefaultEncoding.prototype.charToGlyphIndex = function(c) {\n const code = c.codePointAt(0);\n const glyphs = this.font.glyphs;\n if (glyphs) {\n for (let i = 0; i < glyphs.length; i += 1) {\n const glyph = glyphs.get(i);\n for (let j = 0; j < glyph.unicodes.length; j += 1) {\n if (glyph.unicodes[j] === code) {\n return i;\n }\n }\n }\n }\n return null;\n };\n function CmapEncoding(cmap) {\n this.cmap = cmap;\n }\n CmapEncoding.prototype.charToGlyphIndex = function(c) {\n return this.cmap.glyphIndexMap[c.codePointAt(0)] || 0;\n };\n function CffEncoding(encoding, charset) {\n this.encoding = encoding;\n this.charset = charset;\n }\n CffEncoding.prototype.charToGlyphIndex = function(s) {\n const code = s.codePointAt(0);\n const charName = this.encoding[code];\n return this.charset.indexOf(charName);\n };\n function GlyphNames(post) {\n switch (post.version) {\n case 1:\n this.names = standardNames.slice();\n break;\n case 2:\n this.names = new Array(post.numberOfGlyphs);\n for (let i = 0; i < post.numberOfGlyphs; i++) {\n if (post.glyphNameIndex[i] < standardNames.length) {\n this.names[i] = standardNames[post.glyphNameIndex[i]];\n } else {\n this.names[i] = post.names[post.glyphNameIndex[i] - standardNames.length];\n }\n }\n break;\n case 2.5:\n this.names = new Array(post.numberOfGlyphs);\n for (let i = 0; i < post.numberOfGlyphs; i++) {\n this.names[i] = standardNames[i + post.glyphNameIndex[i]];\n }\n break;\n case 3:\n this.names = [];\n break;\n default:\n this.names = [];\n break;\n }\n }\n GlyphNames.prototype.nameToGlyphIndex = function(name) {\n return this.names.indexOf(name);\n };\n GlyphNames.prototype.glyphIndexToName = function(gid) {\n return this.names[gid];\n };\n function addGlyphNamesAll(font) {\n let glyph;\n const glyphIndexMap = font.tables.cmap.glyphIndexMap;\n const charCodes = Object.keys(glyphIndexMap);\n for (let i = 0; i < charCodes.length; i += 1) {\n const c = charCodes[i];\n const glyphIndex = glyphIndexMap[c];\n glyph = font.glyphs.get(glyphIndex);\n glyph.addUnicode(parseInt(c));\n }\n for (let i = 0; i < font.glyphs.length; i += 1) {\n glyph = font.glyphs.get(i);\n if (font.cffEncoding) {\n glyph.name = font.cffEncoding.charset[i];\n } else if (font.glyphNames.names) {\n glyph.name = font.glyphNames.glyphIndexToName(i);\n }\n }\n }\n function addGlyphNamesToUnicodeMap(font) {\n font._IndexToUnicodeMap = {};\n const glyphIndexMap = font.tables.cmap.glyphIndexMap;\n const charCodes = Object.keys(glyphIndexMap);\n for (let i = 0; i < charCodes.length; i += 1) {\n const c = charCodes[i];\n let glyphIndex = glyphIndexMap[c];\n if (font._IndexToUnicodeMap[glyphIndex] === void 0) {\n font._IndexToUnicodeMap[glyphIndex] = {\n unicodes: [parseInt(c)]\n };\n } else {\n font._IndexToUnicodeMap[glyphIndex].unicodes.push(parseInt(c));\n }\n }\n }\n function addGlyphNames(font, opt) {\n if (opt.lowMemory) {\n addGlyphNamesToUnicodeMap(font);\n } else {\n addGlyphNamesAll(font);\n }\n }\n\n // src/draw.mjs\n function line(ctx, x1, y1, x2, y2) {\n ctx.beginPath();\n ctx.moveTo(x1, y1);\n ctx.lineTo(x2, y2);\n ctx.stroke();\n }\n var draw_default = { line };\n\n // src/tables/cpal.mjs\n function parseCpalTable(data, start) {\n const p = new Parser(data, start);\n const version = p.parseShort();\n if (version !== 0) {\n console.warn(\"Only CPALv0 is currently fully supported.\");\n }\n const numPaletteEntries = p.parseShort();\n const numPalettes = p.parseShort();\n const numColorRecords = p.parseShort();\n const colorRecordsArrayOffset = p.parseOffset32();\n const colorRecordIndices = p.parseUShortList(numPalettes);\n p.relativeOffset = colorRecordsArrayOffset;\n const colorRecords = p.parseULongList(numColorRecords);\n p.relativeOffset = colorRecordsArrayOffset;\n return {\n version,\n numPaletteEntries,\n colorRecords,\n colorRecordIndices\n };\n }\n function makeCpalTable({ version = 0, numPaletteEntries = 0, colorRecords = [], colorRecordIndices = [0] }) {\n check_default.argument(version === 0, \"Only CPALv0 are supported.\");\n check_default.argument(colorRecords.length, \"No colorRecords given.\");\n check_default.argument(colorRecordIndices.length, \"No colorRecordIndices given.\");\n if (colorRecordIndices.length > 1) {\n check_default.argument(numPaletteEntries, \"Can't infer numPaletteEntries on multiple colorRecordIndices\");\n }\n return new table_default.Table(\"CPAL\", [\n { name: \"version\", type: \"USHORT\", value: version },\n { name: \"numPaletteEntries\", type: \"USHORT\", value: numPaletteEntries || colorRecords.length },\n { name: \"numPalettes\", type: \"USHORT\", value: colorRecordIndices.length },\n { name: \"numColorRecords\", type: \"USHORT\", value: colorRecords.length },\n { name: \"colorRecordsArrayOffset\", type: \"ULONG\", value: 12 + 2 * colorRecordIndices.length },\n ...colorRecordIndices.map((palette, i) => ({ name: \"colorRecordIndices_\" + i, type: \"USHORT\", value: palette })),\n ...colorRecords.map((color, i) => ({ name: \"colorRecords_\" + i, type: \"ULONG\", value: color }))\n ]);\n }\n function parseCPALColor(bgra) {\n var b = (bgra & 4278190080) >> 24;\n var g = (bgra & 16711680) >> 16;\n var r = (bgra & 65280) >> 8;\n var a = bgra & 255;\n b = b + 256 & 255;\n g = g + 256 & 255;\n r = r + 256 & 255;\n a = (a + 256 & 255) / 255;\n return { b, g, r, a };\n }\n function getPaletteColor(font, index, palette = 0, colorFormat = \"hexa\") {\n if (index == 65535) {\n return \"currentColor\";\n }\n const cpalTable = font && font.tables && font.tables.cpal;\n if (!cpalTable) return \"currentColor\";\n if (palette > cpalTable.colorRecordIndices.length - 1) {\n throw new Error(`Palette index out of range (colorRecordIndices.length: ${cpalTable.colorRecordIndices.length}, index: ${index})`);\n }\n if (index > cpalTable.numPaletteEntries) {\n throw new Error(`Color index out of range (numPaletteEntries: ${cpalTable.numPaletteEntries}, index: ${index})`);\n }\n const lookupIndex = cpalTable.colorRecordIndices[palette] + index;\n if (lookupIndex > cpalTable.colorRecords) {\n throw new Error(`Color index out of range (colorRecords.length: ${cpalTable.colorRecords.length}, lookupIndex: ${lookupIndex})`);\n }\n const color = parseCPALColor(cpalTable.colorRecords[lookupIndex]);\n if (colorFormat === \"bgra\") {\n return color;\n }\n return formatColor(color, colorFormat);\n }\n function toHex(d) {\n return (\"0\" + parseInt(d).toString(16)).slice(-2);\n }\n function rgbToHSL(bgra) {\n const r = bgra.r / 255;\n const g = bgra.g / 255;\n const b = bgra.b / 255;\n const max = Math.max(r, g, b), min = Math.min(r, g, b);\n let h, s, l = (max + min) / 2;\n if (max === min) {\n h = s = 0;\n } else {\n const d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n switch (max) {\n case r:\n h = (g - b) / d + (g < b ? 6 : 0);\n break;\n case g:\n h = (b - r) / d + 2;\n break;\n case b:\n h = (r - g) / d + 4;\n break;\n }\n h /= 6;\n }\n return {\n h: h * 360,\n s: s * 100,\n l: l * 100\n };\n }\n function hslToRGB(hsla) {\n let { h, s, l, a } = hsla;\n h = h % 360;\n s /= 100;\n l /= 100;\n const c = (1 - Math.abs(2 * l - 1)) * s;\n const x = c * (1 - Math.abs(h / 60 % 2 - 1));\n const m = l - c / 2;\n let r = 0, g = 0, b = 0;\n if (0 <= h && h < 60) {\n r = c;\n g = x;\n b = 0;\n } else if (60 <= h && h < 120) {\n r = x;\n g = c;\n b = 0;\n } else if (120 <= h && h < 180) {\n r = 0;\n g = c;\n b = x;\n } else if (180 <= h && h < 240) {\n r = 0;\n g = x;\n b = c;\n } else if (240 <= h && h < 300) {\n r = x;\n g = 0;\n b = c;\n } else if (300 <= h && h <= 360) {\n r = c;\n g = 0;\n b = x;\n }\n return {\n r: Math.round((r + m) * 255),\n g: Math.round((g + m) * 255),\n b: Math.round((b + m) * 255),\n a\n };\n }\n function bgraToRaw(color) {\n return parseInt(`0x${toHex(color.b)}${toHex(color.g)}${toHex(color.r)}${toHex(color.a * 255)}`, 16);\n }\n function parseColor(color, targetFormat = \"hexa\") {\n const returnRaw = targetFormat == \"raw\" || targetFormat == \"cpal\";\n const isRaw = Number.isInteger(color);\n let validFormat = true;\n if (isRaw && returnRaw || color === \"currentColor\") {\n return color;\n } else if (typeof color === \"object\") {\n if (targetFormat == \"bgra\") {\n return color;\n }\n if (returnRaw) {\n return bgraToRaw(color);\n }\n } else if (!isRaw && /^#([a-f0-9]{3}|[a-f0-9]{4}|[a-f0-9]{6}|[a-f0-9]{8})$/i.test(color.trim())) {\n color = color.trim().substring(1);\n switch (color.length) {\n case 3:\n color = {\n r: parseInt(color[0].repeat(2), 16),\n g: parseInt(color[1].repeat(2), 16),\n b: parseInt(color[2].repeat(2), 16),\n a: 1\n };\n break;\n case 4:\n color = {\n r: parseInt(color[0].repeat(2), 16),\n g: parseInt(color[1].repeat(2), 16),\n b: parseInt(color[2].repeat(2), 16),\n a: parseInt(color[3].repeat(2), 16) / 255\n };\n break;\n case 6:\n color = {\n r: parseInt(color[0] + color[1], 16),\n g: parseInt(color[2] + color[3], 16),\n b: parseInt(color[4] + color[5], 16),\n a: 1\n };\n break;\n case 8:\n color = {\n r: parseInt(color[0] + color[1], 16),\n g: parseInt(color[2] + color[3], 16),\n b: parseInt(color[4] + color[5], 16),\n a: parseInt(color[6] + color[7], 16) / 255\n };\n break;\n }\n if (targetFormat == \"bgra\") {\n return color;\n }\n } else if (typeof document !== \"undefined\" && /^[a-z]+$/i.test(color)) {\n const ctx = document.createElement(\"canvas\").getContext(\"2d\");\n ctx.fillStyle = color;\n const detectedColor = formatColor(ctx.fillStyle, \"hexa\");\n if (detectedColor === \"#000000ff\" && color.toLowerCase() !== \"black\") {\n validFormat = false;\n } else {\n color = detectedColor;\n }\n } else {\n color = color.trim();\n const rgbaRegex = /rgba?\\(\\s*(?:(\\d*\\.\\d+)(%?)|(\\d+)(%?))\\s*(?:,|\\s*)\\s*(?:(\\d*\\.\\d+)(%?)|(\\d+)(%?))\\s*(?:,|\\s*)\\s*(?:(\\d*\\.\\d+)(%?)|(\\d+)(%?))\\s*(?:(?:,|\\s|\\/)\\s*(?:(0*(?:\\.\\d+)?()|0*1(?:\\.0+)?())|(?:\\.\\d+)|(\\d+)(%)|(\\d*\\.\\d+)(%)))?\\s*\\)/;\n if (rgbaRegex.test(color)) {\n const matches = color.match(rgbaRegex).filter((i) => typeof i !== \"undefined\");\n color = {\n r: Math.round(parseFloat(matches[1]) / (matches[2] ? 100 / 255 : 1)),\n g: Math.round(parseFloat(matches[3]) / (matches[4] ? 100 / 255 : 1)),\n b: Math.round(parseFloat(matches[5]) / (matches[6] ? 100 / 255 : 1)),\n a: !matches[7] ? 1 : parseFloat(matches[7]) / (matches[8] ? 100 : 1)\n };\n } else {\n const hslaRegex = /hsla?\\(\\s*(?:(\\d*\\.\\d+|\\d+)(deg|turn|))\\s*(?:,|\\s*)\\s*(?:(\\d*\\.\\d+)%?|(\\d+)%?)\\s*(?:,|\\s*)\\s*(?:(\\d*\\.\\d+)%?|(\\d+)%?)\\s*(?:(?:,|\\s|\\/)\\s*(?:(0*(?:\\.\\d+)?()|0*1(?:\\.0+)?())|(?:\\.\\d+)|(\\d+)(%)|(\\d*\\.\\d+)(%)))?\\s*\\)/;\n if (hslaRegex.test(color)) {\n const matches = color.match(hslaRegex).filter((i) => typeof i !== \"undefined\");\n color = hslToRGB({\n h: parseFloat(matches[1]) * (matches[2] === \"turn\" ? 360 : 1),\n s: parseFloat(matches[3]),\n l: parseFloat(matches[4]),\n a: !matches[5] ? 1 : parseFloat(matches[5]) / (matches[6] ? 100 : 1)\n });\n } else {\n validFormat = false;\n }\n }\n }\n if (!validFormat) {\n throw new Error(`Invalid color format: ${color}`);\n }\n return formatColor(color, targetFormat);\n }\n function formatColor(bgra, format = \"hexa\") {\n if (bgra === \"currentColor\") return bgra;\n if (Number.isInteger(bgra)) {\n if (format == \"raw\" || format == \"cpal\") {\n return bgra;\n }\n bgra = parseCPALColor(bgra);\n } else if (typeof bgra !== \"object\") {\n bgra = parseColor(bgra, \"bgra\");\n }\n let hsl = [\"hsl\", \"hsla\"].includes(format) ? rgbToHSL(bgra) : null;\n switch (format) {\n case \"rgba\":\n return `rgba(${bgra.r}, ${bgra.g}, ${bgra.b}, ${parseFloat(bgra.a.toFixed(3))})`;\n case \"rgb\":\n return `rgb(${bgra.r}, ${bgra.g}, ${bgra.b})`;\n case \"hex\":\n case \"hex6\":\n case \"hex-6\":\n return `#${toHex(bgra.r)}${toHex(bgra.g)}${toHex(bgra.b)}`;\n case \"hexa\":\n case \"hex8\":\n case \"hex-8\":\n return `#${toHex(bgra.r)}${toHex(bgra.g)}${toHex(bgra.b)}${toHex(bgra.a * 255)}`;\n case \"hsl\":\n return `hsl(${hsl.h.toFixed(2)}, ${hsl.s.toFixed(2)}%, ${hsl.l.toFixed(2)}%)`;\n case \"hsla\":\n return `hsla(${hsl.h.toFixed(2)}, ${hsl.s.toFixed(2)}%, ${hsl.l.toFixed(2)}%, ${parseFloat(bgra.a.toFixed(3))})`;\n case \"bgra\":\n return bgra;\n case \"raw\":\n case \"cpal\":\n return bgraToRaw(bgra);\n default:\n throw new Error(\"Unknown color format: \" + format);\n }\n }\n var cpal_default = { parse: parseCpalTable, make: makeCpalTable, getPaletteColor, parseColor, formatColor };\n\n // src/glyph.mjs\n function getPathDefinition(glyph, path) {\n let _path = path || new path_default();\n return {\n configurable: true,\n get: function() {\n if (typeof _path === \"function\") {\n _path = _path();\n }\n return _path;\n },\n set: function(p) {\n _path = p;\n }\n };\n }\n function Glyph(options) {\n this.bindConstructorValues(options);\n }\n Glyph.prototype.bindConstructorValues = function(options) {\n this.index = options.index || 0;\n if (options.name === \".notdef\") {\n options.unicode = void 0;\n } else if (options.name === \".null\") {\n options.unicode = 0;\n }\n if (options.unicode === 0 && options.name !== \".null\") {\n throw new Error('The unicode value \"0\" is reserved for the glyph name \".null\" and cannot be used by any other glyph.');\n }\n this.name = options.name || null;\n this.unicode = options.unicode;\n this.unicodes = options.unicodes || (options.unicode !== void 0 ? [options.unicode] : []);\n if (\"xMin\" in options) {\n this.xMin = options.xMin;\n }\n if (\"yMin\" in options) {\n this.yMin = options.yMin;\n }\n if (\"xMax\" in options) {\n this.xMax = options.xMax;\n }\n if (\"yMax\" in options) {\n this.yMax = options.yMax;\n }\n if (\"advanceWidth\" in options) {\n this.advanceWidth = options.advanceWidth;\n }\n if (\"leftSideBearing\" in options) {\n this.leftSideBearing = options.leftSideBearing;\n }\n if (\"points\" in options) {\n this.points = options.points;\n }\n Object.defineProperty(this, \"path\", getPathDefinition(this, options.path));\n };\n Glyph.prototype.addUnicode = function(unicode) {\n if (this.unicodes.length === 0) {\n this.unicode = unicode;\n }\n this.unicodes.push(unicode);\n };\n Glyph.prototype.getBoundingBox = function() {\n return this.path.getBoundingBox();\n };\n Glyph.prototype.getPath = function(x, y, fontSize, options, font) {\n x = x !== void 0 ? x : 0;\n y = y !== void 0 ? y : 0;\n fontSize = fontSize !== void 0 ? fontSize : 72;\n options = Object.assign({}, font && font.defaultRenderOptions, options);\n let commands;\n let hPoints;\n let xScale = options.xScale;\n let yScale = options.yScale;\n const scale = 1 / (this.path.unitsPerEm || 1e3) * fontSize;\n let useGlyph = this;\n if (font && font.variation) {\n useGlyph = font.variation.getTransform(this, options.variation);\n commands = useGlyph.path.commands;\n }\n if (options.hinting && font && font.hinting) {\n hPoints = useGlyph.path && font.hinting.exec(useGlyph, fontSize, options);\n }\n if (hPoints) {\n commands = font.hinting.getCommands(hPoints);\n x = Math.round(x);\n y = Math.round(y);\n xScale = yScale = 1;\n } else {\n commands = useGlyph.path.commands;\n if (xScale === void 0) xScale = scale;\n if (yScale === void 0) yScale = scale;\n }\n const p = new path_default();\n if (options.drawSVG) {\n const svgImage = this.getSvgImage(font);\n if (svgImage) {\n const layer = new path_default();\n layer._image = {\n image: svgImage.image,\n x: x + svgImage.leftSideBearing * scale,\n y: y - svgImage.baseline * scale,\n width: svgImage.image.width * scale,\n height: svgImage.image.height * scale\n };\n p._layers = [layer];\n return p;\n }\n }\n if (options.drawLayers) {\n const layers = this.getLayers(font);\n if (layers && layers.length) {\n p._layers = [];\n for (let i = 0; i < layers.length; i += 1) {\n const layer = layers[i];\n let color = getPaletteColor(font, layer.paletteIndex, options.usePalette);\n if (color === \"currentColor\") {\n color = options.fill || \"black\";\n } else {\n color = formatColor(color, options.colorFormat || \"rgba\");\n }\n options = Object.assign({}, options, { fill: color });\n p._layers.push(this.getPath.call(layer.glyph, x, y, fontSize, options, font));\n }\n return p;\n }\n }\n p.fill = options.fill || this.path.fill;\n p.stroke = this.path.stroke;\n p.strokeWidth = this.path.strokeWidth * scale;\n for (let i = 0; i < commands.length; i += 1) {\n const cmd = commands[i];\n if (cmd.type === \"M\") {\n p.moveTo(x + cmd.x * xScale, y + -cmd.y * yScale);\n } else if (cmd.type === \"L\") {\n p.lineTo(x + cmd.x * xScale, y + -cmd.y * yScale);\n } else if (cmd.type === \"Q\") {\n p.quadraticCurveTo(\n x + cmd.x1 * xScale,\n y + -cmd.y1 * yScale,\n x + cmd.x * xScale,\n y + -cmd.y * yScale\n );\n } else if (cmd.type === \"C\") {\n p.curveTo(\n x + cmd.x1 * xScale,\n y + -cmd.y1 * yScale,\n x + cmd.x2 * xScale,\n y + -cmd.y2 * yScale,\n x + cmd.x * xScale,\n y + -cmd.y * yScale\n );\n } else if (cmd.type === \"Z\" && p.stroke && p.strokeWidth) {\n p.closePath();\n }\n }\n return p;\n };\n Glyph.prototype.getLayers = function(font) {\n if (!font) {\n throw new Error(\"The font object is required to read the colr/cpal tables in order to get the layers.\");\n }\n return font.layers.get(this.index);\n };\n Glyph.prototype.getSvgImage = function(font) {\n if (!font) {\n throw new Error(\"The font object is required to read the svg table in order to get the image.\");\n }\n return font.svgImages.get(this.index);\n };\n Glyph.prototype.getContours = function(transformedPoints = null) {\n if (this.points === void 0 && !transformedPoints) {\n return [];\n }\n const contours = [];\n let currentContour = [];\n let points = transformedPoints ? transformedPoints : this.points;\n for (let i = 0; i < points.length; i += 1) {\n const pt = points[i];\n currentContour.push(pt);\n if (pt.lastPointOfContour) {\n contours.push(currentContour);\n currentContour = [];\n }\n }\n check_default.argument(currentContour.length === 0, \"There are still points left in the current contour.\");\n return contours;\n };\n Glyph.prototype.getMetrics = function() {\n const commands = this.path.commands;\n const xCoords = [];\n const yCoords = [];\n for (let i = 0; i < commands.length; i += 1) {\n const cmd = commands[i];\n if (cmd.type !== \"Z\") {\n xCoords.push(cmd.x);\n yCoords.push(cmd.y);\n }\n if (cmd.type === \"Q\" || cmd.type === \"C\") {\n xCoords.push(cmd.x1);\n yCoords.push(cmd.y1);\n }\n if (cmd.type === \"C\") {\n xCoords.push(cmd.x2);\n yCoords.push(cmd.y2);\n }\n }\n const metrics = {\n xMin: Math.min.apply(null, xCoords),\n yMin: Math.min.apply(null, yCoords),\n xMax: Math.max.apply(null, xCoords),\n yMax: Math.max.apply(null, yCoords),\n leftSideBearing: this.leftSideBearing\n };\n if (!isFinite(metrics.xMin)) {\n metrics.xMin = 0;\n }\n if (!isFinite(metrics.xMax)) {\n metrics.xMax = this.advanceWidth;\n }\n if (!isFinite(metrics.yMin)) {\n metrics.yMin = 0;\n }\n if (!isFinite(metrics.yMax)) {\n metrics.yMax = 0;\n }\n metrics.rightSideBearing = this.advanceWidth - metrics.leftSideBearing - (metrics.xMax - metrics.xMin);\n return metrics;\n };\n Glyph.prototype.draw = function(ctx, x, y, fontSize, options, font) {\n options = Object.assign({}, font && font.defaultRenderOptions, options);\n const path = this.getPath(x, y, fontSize, options, font);\n path.draw(ctx);\n };\n Glyph.prototype.drawPoints = function(ctx, x, y, fontSize, options, font) {\n options = Object.assign({}, font && font.defaultRenderOptions, options);\n if (options.drawLayers) {\n const layers = this.getLayers(font);\n if (layers && layers.length) {\n for (let l = 0; l < layers.length; l += 1) {\n if (layers[l].glyph.index !== this.index) {\n this.drawPoints.call(layers[l].glyph, ctx, x, y, fontSize);\n }\n }\n return;\n }\n }\n function drawCircles(l, x2, y2, scale2) {\n ctx.beginPath();\n for (let j = 0; j < l.length; j += 1) {\n ctx.moveTo(x2 + l[j].x * scale2, y2 + l[j].y * scale2);\n ctx.arc(x2 + l[j].x * scale2, y2 + l[j].y * scale2, 2, 0, Math.PI * 2, false);\n }\n ctx.fill();\n }\n x = x !== void 0 ? x : 0;\n y = y !== void 0 ? y : 0;\n fontSize = fontSize !== void 0 ? fontSize : 24;\n const scale = 1 / this.path.unitsPerEm * fontSize;\n const blueCircles = [];\n const redCircles = [];\n const path = this.path;\n let commands = path.commands;\n if (font && font.variation) {\n commands = font.variation.getTransform(this, options.variation).path.commands;\n }\n for (let i = 0; i < commands.length; i += 1) {\n const cmd = commands[i];\n if (cmd.x !== void 0) {\n blueCircles.push({ x: cmd.x, y: -cmd.y });\n }\n if (cmd.x1 !== void 0) {\n redCircles.push({ x: cmd.x1, y: -cmd.y1 });\n }\n if (cmd.x2 !== void 0) {\n redCircles.push({ x: cmd.x2, y: -cmd.y2 });\n }\n }\n ctx.fillStyle = \"blue\";\n drawCircles(blueCircles, x, y, scale);\n ctx.fillStyle = \"red\";\n drawCircles(redCircles, x, y, scale);\n };\n Glyph.prototype.drawMetrics = function(ctx, x, y, fontSize) {\n let scale;\n x = x !== void 0 ? x : 0;\n y = y !== void 0 ? y : 0;\n fontSize = fontSize !== void 0 ? fontSize : 24;\n scale = 1 / this.path.unitsPerEm * fontSize;\n ctx.lineWidth = 1;\n ctx.strokeStyle = \"black\";\n draw_default.line(ctx, x, -1e4, x, 1e4);\n draw_default.line(ctx, -1e4, y, 1e4, y);\n const xMin = this.xMin || 0;\n let yMin = this.yMin || 0;\n const xMax = this.xMax || 0;\n let yMax = this.yMax || 0;\n const advanceWidth = this.advanceWidth || 0;\n ctx.strokeStyle = \"blue\";\n draw_default.line(ctx, x + xMin * scale, -1e4, x + xMin * scale, 1e4);\n draw_default.line(ctx, x + xMax * scale, -1e4, x + xMax * scale, 1e4);\n draw_default.line(ctx, -1e4, y + -yMin * scale, 1e4, y + -yMin * scale);\n draw_default.line(ctx, -1e4, y + -yMax * scale, 1e4, y + -yMax * scale);\n ctx.strokeStyle = \"green\";\n draw_default.line(ctx, x + advanceWidth * scale, -1e4, x + advanceWidth * scale, 1e4);\n };\n Glyph.prototype.toPathData = function(options, font) {\n options = Object.assign({}, { variation: font && font.defaultRenderOptions.variation }, options);\n let useGlyph = this;\n if (font && font.variation) {\n useGlyph = font.variation.getTransform(this, options.variation);\n }\n let usePath = useGlyph.points && options.pointsTransform ? options.pointsTransform(useGlyph.points) : useGlyph.path;\n if (options.pathTransform) {\n usePath = options.pathTransform(usePath);\n }\n return usePath.toPathData(options);\n };\n Glyph.prototype.fromSVG = function(pathData, options = {}) {\n return this.path.fromSVG(pathData, options);\n };\n Glyph.prototype.toSVG = function(options, font) {\n const pathData = this.toPathData.apply(this, [options, font]);\n return this.path.toSVG(options, pathData);\n };\n Glyph.prototype.toDOMElement = function(options, font) {\n options = Object.assign({}, { variation: font && font.defaultRenderOptions.variation }, options);\n let usePath = this.path;\n if (font && font.variation) {\n usePath = font.variation.getTransform(this, options.variation).path;\n }\n return usePath.toDOMElement(options);\n };\n var glyph_default = Glyph;\n\n // src/glyphset.mjs\n function defineDependentProperty(glyph, externalName, internalName) {\n Object.defineProperty(glyph, externalName, {\n get: function() {\n typeof glyph[internalName] === \"undefined\" && glyph.path;\n return glyph[internalName];\n },\n set: function(newValue) {\n glyph[internalName] = newValue;\n },\n enumerable: true,\n configurable: true\n });\n }\n function GlyphSet(font, glyphs) {\n this.font = font;\n this.glyphs = {};\n if (Array.isArray(glyphs)) {\n for (let i = 0; i < glyphs.length; i++) {\n const glyph = glyphs[i];\n glyph.path.unitsPerEm = font.unitsPerEm;\n this.glyphs[i] = glyph;\n }\n }\n this.length = glyphs && glyphs.length || 0;\n }\n if (typeof Symbol !== \"undefined\" && Symbol.iterator) {\n GlyphSet.prototype[Symbol.iterator] = function() {\n let n = -1;\n return {\n next: function() {\n n++;\n const done = n >= this.length - 1;\n return { value: this.get(n), done };\n }.bind(this)\n };\n };\n }\n GlyphSet.prototype.get = function(index) {\n if (this.font._push && this.glyphs[index] === void 0) {\n this.font._push(index);\n if (typeof this.glyphs[index] === \"function\") {\n this.glyphs[index] = this.glyphs[index]();\n }\n let glyph = this.glyphs[index];\n let unicodeObj = this.font._IndexToUnicodeMap[index];\n if (unicodeObj) {\n for (let j = 0; j < unicodeObj.unicodes.length; j++)\n glyph.addUnicode(unicodeObj.unicodes[j]);\n }\n if (this.font.cffEncoding) {\n glyph.name = this.font.cffEncoding.charset[index];\n } else if (this.font.glyphNames.names) {\n glyph.name = this.font.glyphNames.glyphIndexToName(index);\n }\n this.glyphs[index].advanceWidth = this.font._hmtxTableData[index].advanceWidth;\n this.glyphs[index].leftSideBearing = this.font._hmtxTableData[index].leftSideBearing;\n } else {\n if (typeof this.glyphs[index] === \"function\") {\n this.glyphs[index] = this.glyphs[index]();\n }\n }\n return this.glyphs[index];\n };\n GlyphSet.prototype.push = function(index, loader) {\n this.glyphs[index] = loader;\n this.length++;\n };\n function glyphLoader(font, index) {\n return new glyph_default({ index, font });\n }\n function ttfGlyphLoader(font, index, parseGlyph2, data, position, buildPath2) {\n return function() {\n const glyph = new glyph_default({ index, font });\n glyph.path = function() {\n parseGlyph2(glyph, data, position);\n const path = buildPath2(font.glyphs, glyph);\n path.unitsPerEm = font.unitsPerEm;\n return path;\n };\n defineDependentProperty(glyph, \"numberOfContours\", \"_numberOfContours\");\n defineDependentProperty(glyph, \"xMin\", \"_xMin\");\n defineDependentProperty(glyph, \"xMax\", \"_xMax\");\n defineDependentProperty(glyph, \"yMin\", \"_yMin\");\n defineDependentProperty(glyph, \"yMax\", \"_yMax\");\n defineDependentProperty(glyph, \"points\", \"_points\");\n return glyph;\n };\n }\n function cffGlyphLoader(font, index, parseCFFCharstring2, charstring, version) {\n return function() {\n const glyph = new glyph_default({ index, font });\n glyph.path = function() {\n const path = parseCFFCharstring2(font, glyph, charstring, version);\n path.unitsPerEm = font.unitsPerEm;\n return path;\n };\n return glyph;\n };\n }\n var glyphset_default = { GlyphSet, glyphLoader, ttfGlyphLoader, cffGlyphLoader };\n\n // src/tables/cff.mjs\n function equals(a, b) {\n if (a === b) {\n return true;\n } else if (Array.isArray(a) && Array.isArray(b)) {\n if (a.length !== b.length) {\n return false;\n }\n for (let i = 0; i < a.length; i += 1) {\n if (!equals(a[i], b[i])) {\n return false;\n }\n }\n return true;\n } else {\n return false;\n }\n }\n var MAX_CALL_DEPTH = 10;\n function calcCFFSubroutineBias(subrs) {\n let bias;\n if (subrs.length < 1240) {\n bias = 107;\n } else if (subrs.length < 33900) {\n bias = 1131;\n } else {\n bias = 32768;\n }\n return bias;\n }\n function parseCFFIndex(data, start, conversionFn, version) {\n const offsets = [];\n const objects = [];\n const count = version > 1 ? parse_default.getULong(data, start) : parse_default.getCard16(data, start);\n const countLength = version > 1 ? 4 : 2;\n let objectOffset;\n let endOffset;\n if (count !== 0) {\n const offsetSize = parse_default.getByte(data, start + countLength);\n objectOffset = start + (count + 1) * offsetSize + countLength;\n let pos = start + countLength + 1;\n for (let i = 0; i < count + 1; i += 1) {\n offsets.push(parse_default.getOffset(data, pos, offsetSize));\n pos += offsetSize;\n }\n endOffset = objectOffset + offsets[count];\n } else {\n endOffset = start + countLength;\n }\n for (let i = 0; i < offsets.length - 1; i += 1) {\n let value = parse_default.getBytes(data, objectOffset + offsets[i], objectOffset + offsets[i + 1]);\n if (conversionFn) {\n value = conversionFn(value, data, start, version);\n }\n objects.push(value);\n }\n return { objects, startOffset: start, endOffset };\n }\n function parseCFFIndexLowMemory(data, start, version) {\n const offsets = [];\n const count = version > 1 ? parse_default.getULong(data, start) : parse_default.getCard16(data, start);\n const countLength = version > 1 ? 4 : 2;\n let objectOffset;\n let endOffset;\n if (count !== 0) {\n const offsetSize = parse_default.getByte(data, start + countLength);\n objectOffset = start + (count + 1) * offsetSize + countLength;\n let pos = start + countLength + 1;\n for (let i = 0; i < count + 1; i += 1) {\n offsets.push(parse_default.getOffset(data, pos, offsetSize));\n pos += offsetSize;\n }\n endOffset = objectOffset + offsets[count];\n } else {\n endOffset = start + countLength;\n }\n return { offsets, startOffset: start, endOffset };\n }\n function getCffIndexObject(i, offsets, data, start, conversionFn, version) {\n const count = version > 1 ? parse_default.getULong(data, start) : parse_default.getCard16(data, start);\n const countLength = version > 1 ? 4 : 2;\n let objectOffset = 0;\n if (count !== 0) {\n const offsetSize = parse_default.getByte(data, start + countLength);\n objectOffset = start + (count + 1) * offsetSize + countLength;\n }\n let value = parse_default.getBytes(data, objectOffset + offsets[i], objectOffset + offsets[i + 1]);\n if (conversionFn) {\n value = conversionFn(value);\n }\n return value;\n }\n function parseFloatOperand(parser) {\n let s = \"\";\n const eof = 15;\n const lookup = [\"0\", \"1\", \"2\", \"3\", \"4\", \"5\", \"6\", \"7\", \"8\", \"9\", \".\", \"E\", \"E-\", null, \"-\"];\n for (; ; ) {\n const b = parser.parseByte();\n const n1 = b >> 4;\n const n2 = b & 15;\n if (n1 === eof) {\n break;\n }\n s += lookup[n1];\n if (n2 === eof) {\n break;\n }\n s += lookup[n2];\n }\n return parseFloat(s);\n }\n function parseOperand(parser, b0) {\n let b1;\n let b2;\n let b3;\n let b4;\n if (b0 === 28) {\n b1 = parser.parseByte();\n b2 = parser.parseByte();\n return b1 << 8 | b2;\n }\n if (b0 === 29) {\n b1 = parser.parseByte();\n b2 = parser.parseByte();\n b3 = parser.parseByte();\n b4 = parser.parseByte();\n return b1 << 24 | b2 << 16 | b3 << 8 | b4;\n }\n if (b0 === 30) {\n return parseFloatOperand(parser);\n }\n if (b0 >= 32 && b0 <= 246) {\n return b0 - 139;\n }\n if (b0 >= 247 && b0 <= 250) {\n b1 = parser.parseByte();\n return (b0 - 247) * 256 + b1 + 108;\n }\n if (b0 >= 251 && b0 <= 254) {\n b1 = parser.parseByte();\n return -(b0 - 251) * 256 - b1 - 108;\n }\n throw new Error(\"Invalid b0 \" + b0);\n }\n function entriesToObject(entries) {\n const o = {};\n for (let i = 0; i < entries.length; i += 1) {\n const key = entries[i][0];\n const values = entries[i][1];\n let value;\n if (values.length === 1) {\n value = values[0];\n } else {\n value = values;\n }\n if (Object.prototype.hasOwnProperty.call(o, key) && !isNaN(o[key])) {\n throw new Error(\"Object \" + o + \" already has key \" + key);\n }\n o[key] = value;\n }\n return o;\n }\n function parseCFFDict(data, start, size, version) {\n start = start !== void 0 ? start : 0;\n const parser = new parse_default.Parser(data, start);\n const entries = [];\n let operands = [];\n size = size !== void 0 ? size : data.byteLength;\n let operandsStart = version < 2 ? 22 : 28;\n while (parser.relativeOffset < size) {\n let op = parser.parseByte();\n if (op < operandsStart) {\n if (op === 12) {\n op = 1200 + parser.parseByte();\n }\n if (version > 1 && op === 23) {\n parseBlend(operands);\n continue;\n }\n entries.push([op, operands]);\n operands = [];\n } else {\n operands.push(parseOperand(parser, op, version));\n }\n }\n return entriesToObject(entries);\n }\n function getCFFString(strings, index) {\n if (index <= 390) {\n index = cffStandardStrings[index];\n } else if (strings) {\n index = strings[index - 391];\n } else {\n index = void 0;\n }\n return index;\n }\n function interpretDict(dict, meta, strings) {\n const newDict = {};\n let value;\n for (let i = 0; i < meta.length; i += 1) {\n const m = meta[i];\n if (Array.isArray(m.type)) {\n const values = [];\n values.length = m.type.length;\n for (let j = 0; j < m.type.length; j++) {\n value = dict[m.op] !== void 0 ? dict[m.op][j] : void 0;\n if (value === void 0) {\n value = m.value !== void 0 && m.value[j] !== void 0 ? m.value[j] : null;\n }\n if (m.type[j] === \"SID\") {\n value = getCFFString(strings, value);\n }\n values[j] = value;\n }\n newDict[m.name] = values;\n } else {\n value = dict[m.op];\n if (value === void 0) {\n value = m.value !== void 0 ? m.value : null;\n }\n if (m.type === \"SID\") {\n value = getCFFString(strings, value);\n }\n newDict[m.name] = value;\n }\n }\n return newDict;\n }\n function parseCFFHeader(data, start) {\n const header = {};\n header.formatMajor = parse_default.getCard8(data, start);\n header.formatMinor = parse_default.getCard8(data, start + 1);\n if (header.formatMajor > 2) {\n throw new Error(`Unsupported CFF table version ${header.formatMajor}.${header.formatMinor}`);\n }\n header.size = parse_default.getCard8(data, start + 2);\n if (header.formatMajor < 2) {\n header.offsetSize = parse_default.getCard8(data, start + 3);\n header.startOffset = start;\n header.endOffset = start + 4;\n } else {\n header.topDictLength = parse_default.getCard16(data, start + 3);\n header.endOffset = start + 8;\n }\n return header;\n }\n var TOP_DICT_META = [\n { name: \"version\", op: 0, type: \"SID\" },\n { name: \"notice\", op: 1, type: \"SID\" },\n { name: \"copyright\", op: 1200, type: \"SID\" },\n { name: \"fullName\", op: 2, type: \"SID\" },\n { name: \"familyName\", op: 3, type: \"SID\" },\n { name: \"weight\", op: 4, type: \"SID\" },\n { name: \"isFixedPitch\", op: 1201, type: \"number\", value: 0 },\n { name: \"italicAngle\", op: 1202, type: \"number\", value: 0 },\n { name: \"underlinePosition\", op: 1203, type: \"number\", value: -100 },\n { name: \"underlineThickness\", op: 1204, type: \"number\", value: 50 },\n { name: \"paintType\", op: 1205, type: \"number\", value: 0 },\n { name: \"charstringType\", op: 1206, type: \"number\", value: 2 },\n {\n name: \"fontMatrix\",\n op: 1207,\n type: [\"real\", \"real\", \"real\", \"real\", \"real\", \"real\"],\n value: [1e-3, 0, 0, 1e-3, 0, 0]\n },\n { name: \"uniqueId\", op: 13, type: \"number\" },\n { name: \"fontBBox\", op: 5, type: [\"number\", \"number\", \"number\", \"number\"], value: [0, 0, 0, 0] },\n { name: \"strokeWidth\", op: 1208, type: \"number\", value: 0 },\n { name: \"xuid\", op: 14, type: [], value: null },\n { name: \"charset\", op: 15, type: \"offset\", value: 0 },\n { name: \"encoding\", op: 16, type: \"offset\", value: 0 },\n { name: \"charStrings\", op: 17, type: \"offset\", value: 0 },\n { name: \"private\", op: 18, type: [\"number\", \"offset\"], value: [0, 0] },\n { name: \"ros\", op: 1230, type: [\"SID\", \"SID\", \"number\"] },\n { name: \"cidFontVersion\", op: 1231, type: \"number\", value: 0 },\n { name: \"cidFontRevision\", op: 1232, type: \"number\", value: 0 },\n { name: \"cidFontType\", op: 1233, type: \"number\", value: 0 },\n { name: \"cidCount\", op: 1234, type: \"number\", value: 8720 },\n { name: \"uidBase\", op: 1235, type: \"number\" },\n { name: \"fdArray\", op: 1236, type: \"offset\" },\n { name: \"fdSelect\", op: 1237, type: \"offset\" },\n { name: \"fontName\", op: 1238, type: \"SID\" }\n ];\n var TOP_DICT_META_CFF2 = [\n {\n name: \"fontMatrix\",\n op: 1207,\n type: [\"real\", \"real\", \"real\", \"real\", \"real\", \"real\"],\n value: [1e-3, 0, 0, 1e-3, 0, 0]\n },\n { name: \"charStrings\", op: 17, type: \"offset\" },\n { name: \"fdArray\", op: 1236, type: \"offset\" },\n { name: \"fdSelect\", op: 1237, type: \"offset\" },\n { name: \"vstore\", op: 24, type: \"offset\" }\n ];\n var PRIVATE_DICT_META = [\n { name: \"subrs\", op: 19, type: \"offset\", value: 0 },\n { name: \"defaultWidthX\", op: 20, type: \"number\", value: 0 },\n { name: \"nominalWidthX\", op: 21, type: \"number\", value: 0 }\n ];\n var PRIVATE_DICT_META_CFF2 = [\n { name: \"blueValues\", op: 6, type: \"delta\" },\n { name: \"otherBlues\", op: 7, type: \"delta\" },\n { name: \"familyBlues\", op: 7, type: \"delta\" },\n { name: \"familyBlues\", op: 8, type: \"delta\" },\n { name: \"familyOtherBlues\", op: 9, type: \"delta\" },\n { name: \"blueScale\", op: 1209, type: \"number\", value: 0.039625 },\n { name: \"blueShift\", op: 1210, type: \"number\", value: 7 },\n { name: \"blueFuzz\", op: 1211, type: \"number\", value: 1 },\n { name: \"stdHW\", op: 10, type: \"number\" },\n { name: \"stdVW\", op: 11, type: \"number\" },\n { name: \"stemSnapH\", op: 1212, type: \"number\" },\n { name: \"stemSnapV\", op: 1213, type: \"number\" },\n { name: \"languageGroup\", op: 1217, type: \"number\", value: 0 },\n { name: \"expansionFactor\", op: 1218, type: \"number\", value: 0.06 },\n { name: \"vsindex\", op: 22, type: \"number\", value: 0 },\n { name: \"subrs\", op: 19, type: \"offset\" }\n ];\n var FONT_DICT_META = [\n { name: \"private\", op: 18, type: [\"number\", \"offset\"], value: [0, 0] }\n ];\n function parseCFFTopDict(data, start, strings, version) {\n const dict = parseCFFDict(data, start, data.byteLength, version);\n return interpretDict(dict, version > 1 ? TOP_DICT_META_CFF2 : TOP_DICT_META, strings);\n }\n function parseCFFPrivateDict(data, start, size, strings, version) {\n const dict = parseCFFDict(data, start, size, version);\n return interpretDict(dict, version > 1 ? PRIVATE_DICT_META_CFF2 : PRIVATE_DICT_META, strings);\n }\n function parseFontDict(data, start, version) {\n const dict = parseCFFDict(data, start, void 0, version);\n return interpretDict(dict, FONT_DICT_META);\n }\n function gatherCFF2FontDicts(data, start, fdArray) {\n const fontDictArray = [];\n for (let i = 0; i < fdArray.length; i++) {\n const fontDictData = new DataView(new Uint8Array(fdArray[i]).buffer);\n const fontDict = parseFontDict(fontDictData, 0, 2);\n const privateSize = fontDict.private[0];\n const privateOffset = fontDict.private[1];\n if (privateSize !== 0 && privateOffset !== 0) {\n const privateDict = parseCFFPrivateDict(data, privateOffset + start, privateSize, [], 2);\n if (privateDict.subrs) {\n const subrOffset = privateOffset + privateDict.subrs;\n const subrIndex = parseCFFIndex(data, subrOffset + start, void 0, 2);\n fontDict._subrs = subrIndex.objects;\n fontDict._subrsBias = calcCFFSubroutineBias(fontDict._subrs);\n }\n fontDict._privateDict = privateDict;\n }\n fontDictArray.push(fontDict);\n }\n return fontDictArray;\n }\n function gatherCFFTopDicts(data, start, cffIndex, strings, version) {\n const topDictArray = [];\n for (let iTopDict = 0; iTopDict < cffIndex.length; iTopDict += 1) {\n const topDictData = new DataView(new Uint8Array(cffIndex[iTopDict]).buffer);\n const topDict = parseCFFTopDict(topDictData, 0, strings, version);\n topDict._subrs = [];\n topDict._subrsBias = 0;\n topDict._defaultWidthX = 0;\n topDict._nominalWidthX = 0;\n const privateSize = version < 2 ? topDict.private[0] : 0;\n const privateOffset = version < 2 ? topDict.private[1] : 0;\n if (privateSize !== 0 && privateOffset !== 0) {\n const privateDict = parseCFFPrivateDict(data, privateOffset + start, privateSize, strings, version);\n topDict._defaultWidthX = privateDict.defaultWidthX;\n topDict._nominalWidthX = privateDict.nominalWidthX;\n if (privateDict.subrs !== 0) {\n const subrOffset = privateOffset + privateDict.subrs;\n const subrIndex = parseCFFIndex(data, subrOffset + start, void 0, version);\n topDict._subrs = subrIndex.objects;\n topDict._subrsBias = calcCFFSubroutineBias(topDict._subrs);\n }\n topDict._privateDict = privateDict;\n }\n topDictArray.push(topDict);\n }\n return topDictArray;\n }\n function parseCFFCharset(data, start, nGlyphs, strings, isCIDFont) {\n let sid;\n let count;\n const parser = new parse_default.Parser(data, start);\n nGlyphs -= 1;\n const charset = [\".notdef\"];\n const format = parser.parseCard8();\n if (format === 0) {\n for (let i = 0; i < nGlyphs; i += 1) {\n sid = parser.parseSID();\n if (isCIDFont) {\n charset.push(sid);\n } else {\n charset.push(getCFFString(strings, sid) || sid);\n }\n }\n } else if (format === 1) {\n while (charset.length <= nGlyphs) {\n sid = parser.parseSID();\n count = parser.parseCard8();\n for (let i = 0; i <= count; i += 1) {\n if (isCIDFont) {\n charset.push(\"cid\" + (\"00000\" + sid).slice(-5));\n } else {\n charset.push(getCFFString(strings, sid) || sid);\n }\n sid += 1;\n }\n }\n } else if (format === 2) {\n while (charset.length <= nGlyphs) {\n sid = parser.parseSID();\n count = parser.parseCard16();\n for (let i = 0; i <= count; i += 1) {\n if (isCIDFont) {\n charset.push(\"cid\" + (\"00000\" + sid).slice(-5));\n } else {\n charset.push(getCFFString(strings, sid) || sid);\n }\n sid += 1;\n }\n }\n } else {\n throw new Error(\"Unknown charset format \" + format);\n }\n return charset;\n }\n function parseCFFEncoding(data, start) {\n let code;\n const encoding = {};\n const parser = new parse_default.Parser(data, start);\n const format = parser.parseCard8();\n if (format === 0) {\n const nCodes = parser.parseCard8();\n for (let i = 0; i < nCodes; i += 1) {\n code = parser.parseCard8();\n encoding[code] = i;\n }\n } else if (format === 1) {\n const nRanges = parser.parseCard8();\n code = 1;\n for (let i = 0; i < nRanges; i += 1) {\n const first = parser.parseCard8();\n const nLeft = parser.parseCard8();\n for (let j = first; j <= first + nLeft; j += 1) {\n encoding[j] = code;\n code += 1;\n }\n }\n } else {\n throw new Error(\"Unknown encoding format \" + format);\n }\n return encoding;\n }\n function parseBlend(operands) {\n let numberOfBlends = operands.pop();\n while (operands.length > numberOfBlends) {\n operands.pop();\n }\n }\n function applyPaintType(font, path) {\n const paintType = font.tables.cff && font.tables.cff.topDict && font.tables.cff.topDict.paintType || 0;\n if (paintType === 2) {\n path.fill = null;\n path.stroke = \"black\";\n path.strokeWidth = font.tables.cff.topDict.strokeWidth || 0;\n }\n return paintType;\n }\n function parseCFFCharstring(font, glyph, code, version, coords) {\n let c1x;\n let c1y;\n let c2x;\n let c2y;\n const p = new path_default();\n const stack = [];\n let nStems = 0;\n let haveWidth = false;\n let open = false;\n let x = 0;\n let y = 0;\n let subrs;\n let subrsBias;\n let defaultWidthX;\n let nominalWidthX;\n let vsindex = 0;\n let vstore = [];\n let blendVector;\n let callDepth = 0;\n const cffTable = font.tables.cff2 || font.tables.cff;\n defaultWidthX = cffTable.topDict._defaultWidthX;\n nominalWidthX = cffTable.topDict._nominalWidthX;\n coords = coords || font.variation && font.variation.get();\n if (!glyph.getBlendPath) {\n glyph.getBlendPath = function(variationCoords) {\n return parseCFFCharstring(font, glyph, code, version, variationCoords);\n };\n }\n if (font.isCIDFont || version > 1) {\n const fdIndex = cffTable.topDict._fdSelect ? cffTable.topDict._fdSelect[glyph.index] : 0;\n const fdDict = cffTable.topDict._fdArray[fdIndex];\n subrs = fdDict._subrs;\n subrsBias = fdDict._subrsBias;\n if (version > 1) {\n vstore = cffTable.topDict._vstore.itemVariationStore;\n vsindex = fdDict._privateDict.vsindex;\n } else {\n defaultWidthX = fdDict._defaultWidthX;\n nominalWidthX = fdDict._nominalWidthX;\n }\n } else {\n subrs = cffTable.topDict._subrs;\n subrsBias = cffTable.topDict._subrsBias;\n }\n const paintType = applyPaintType(font, p);\n let width = defaultWidthX;\n function newContour(x2, y2) {\n if (open && paintType !== 2) {\n p.closePath();\n }\n p.moveTo(x2, y2);\n open = true;\n }\n function parseStems() {\n let hasWidthArg;\n hasWidthArg = (stack.length & 1) !== 0;\n if (hasWidthArg && !haveWidth) {\n width = stack.shift() + nominalWidthX;\n }\n nStems += stack.length >> 1;\n stack.length = 0;\n haveWidth = true;\n }\n function parse(code2) {\n let b1;\n let b2;\n let b3;\n let b4;\n let codeIndex;\n let subrCode;\n let jpx;\n let jpy;\n let c3x;\n let c3y;\n let c4x;\n let c4y;\n let i = 0;\n while (i < code2.length) {\n let v = code2[i];\n i += 1;\n switch (v) {\n case 1:\n parseStems();\n break;\n case 3:\n parseStems();\n break;\n case 4:\n if (stack.length > 1 && !haveWidth) {\n width = stack.shift() + nominalWidthX;\n haveWidth = true;\n }\n y += stack.pop();\n newContour(x, y);\n break;\n case 5:\n while (stack.length > 0) {\n x += stack.shift();\n y += stack.shift();\n p.lineTo(x, y);\n }\n break;\n case 6:\n while (stack.length > 0) {\n x += stack.shift();\n p.lineTo(x, y);\n if (stack.length === 0) {\n break;\n }\n y += stack.shift();\n p.lineTo(x, y);\n }\n break;\n case 7:\n while (stack.length > 0) {\n y += stack.shift();\n p.lineTo(x, y);\n if (stack.length === 0) {\n break;\n }\n x += stack.shift();\n p.lineTo(x, y);\n }\n break;\n case 8:\n while (stack.length > 0) {\n c1x = x + stack.shift();\n c1y = y + stack.shift();\n c2x = c1x + stack.shift();\n c2y = c1y + stack.shift();\n x = c2x + stack.shift();\n y = c2y + stack.shift();\n p.curveTo(c1x, c1y, c2x, c2y, x, y);\n }\n break;\n case 10:\n codeIndex = stack.pop() + subrsBias;\n subrCode = subrs[codeIndex];\n if (subrCode) {\n if (callDepth >= MAX_CALL_DEPTH) {\n console.warn(\"CFF charstring subroutine call depth exceeded, skipping callsubr\");\n break;\n }\n callDepth++;\n parse(subrCode);\n callDepth--;\n }\n break;\n case 11:\n if (version > 1) {\n console.error(\"CFF CharString operator return (11) is not supported in CFF2\");\n break;\n }\n return;\n case 12:\n v = code2[i];\n i += 1;\n switch (v) {\n case 35:\n c1x = x + stack.shift();\n c1y = y + stack.shift();\n c2x = c1x + stack.shift();\n c2y = c1y + stack.shift();\n jpx = c2x + stack.shift();\n jpy = c2y + stack.shift();\n c3x = jpx + stack.shift();\n c3y = jpy + stack.shift();\n c4x = c3x + stack.shift();\n c4y = c3y + stack.shift();\n x = c4x + stack.shift();\n y = c4y + stack.shift();\n stack.shift();\n p.curveTo(c1x, c1y, c2x, c2y, jpx, jpy);\n p.curveTo(c3x, c3y, c4x, c4y, x, y);\n break;\n case 34:\n c1x = x + stack.shift();\n c1y = y;\n c2x = c1x + stack.shift();\n c2y = c1y + stack.shift();\n jpx = c2x + stack.shift();\n jpy = c2y;\n c3x = jpx + stack.shift();\n c3y = c2y;\n c4x = c3x + stack.shift();\n c4y = y;\n x = c4x + stack.shift();\n p.curveTo(c1x, c1y, c2x, c2y, jpx, jpy);\n p.curveTo(c3x, c3y, c4x, c4y, x, y);\n break;\n case 36:\n c1x = x + stack.shift();\n c1y = y + stack.shift();\n c2x = c1x + stack.shift();\n c2y = c1y + stack.shift();\n jpx = c2x + stack.shift();\n jpy = c2y;\n c3x = jpx + stack.shift();\n c3y = c2y;\n c4x = c3x + stack.shift();\n c4y = c3y + stack.shift();\n x = c4x + stack.shift();\n p.curveTo(c1x, c1y, c2x, c2y, jpx, jpy);\n p.curveTo(c3x, c3y, c4x, c4y, x, y);\n break;\n case 37:\n c1x = x + stack.shift();\n c1y = y + stack.shift();\n c2x = c1x + stack.shift();\n c2y = c1y + stack.shift();\n jpx = c2x + stack.shift();\n jpy = c2y + stack.shift();\n c3x = jpx + stack.shift();\n c3y = jpy + stack.shift();\n c4x = c3x + stack.shift();\n c4y = c3y + stack.shift();\n if (Math.abs(c4x - x) > Math.abs(c4y - y)) {\n x = c4x + stack.shift();\n } else {\n y = c4y + stack.shift();\n }\n p.curveTo(c1x, c1y, c2x, c2y, jpx, jpy);\n p.curveTo(c3x, c3y, c4x, c4y, x, y);\n break;\n default:\n console.log(\"Glyph \" + glyph.index + \": unknown operator 1200\" + v);\n stack.length = 0;\n }\n break;\n case 14:\n if (version > 1) {\n console.error(\"CFF CharString operator endchar (14) is not supported in CFF2\");\n break;\n }\n if (stack.length >= 4) {\n const acharName = cffStandardEncoding[stack.pop()];\n const bcharName = cffStandardEncoding[stack.pop()];\n const ady = stack.pop();\n const adx = stack.pop();\n if (acharName && bcharName) {\n glyph.isComposite = true;\n glyph.components = [];\n const acharGlyphIndex = font.cffEncoding.charset.indexOf(acharName);\n const bcharGlyphIndex = font.cffEncoding.charset.indexOf(bcharName);\n glyph.components.push({\n glyphIndex: bcharGlyphIndex,\n dx: 0,\n dy: 0\n });\n glyph.components.push({\n glyphIndex: acharGlyphIndex,\n dx: adx,\n dy: ady\n });\n p.extend(font.glyphs.get(bcharGlyphIndex).path);\n const acharGlyph = font.glyphs.get(acharGlyphIndex);\n const shiftedCommands = JSON.parse(JSON.stringify(acharGlyph.path.commands));\n for (let i2 = 0; i2 < shiftedCommands.length; i2 += 1) {\n const cmd = shiftedCommands[i2];\n if (cmd.type !== \"Z\") {\n cmd.x += adx;\n cmd.y += ady;\n }\n if (cmd.type === \"Q\" || cmd.type === \"C\") {\n cmd.x1 += adx;\n cmd.y1 += ady;\n }\n if (cmd.type === \"C\") {\n cmd.x2 += adx;\n cmd.y2 += ady;\n }\n }\n p.extend(shiftedCommands);\n }\n } else if (stack.length > 0 && !haveWidth) {\n width = stack.shift() + nominalWidthX;\n haveWidth = true;\n }\n if (open && paintType !== 2) {\n p.closePath();\n open = false;\n }\n break;\n case 15:\n if (version < 2) {\n console.error(\"CFF2 CharString operator vsindex (15) is not supported in CFF\");\n break;\n }\n vsindex = stack.pop();\n break;\n case 16:\n if (version < 2) {\n console.error(\"CFF2 CharString operator blend (16) is not supported in CFF\");\n break;\n }\n if (!blendVector) {\n blendVector = font.variation && coords && font.variation.process.getBlendVector(vstore, vsindex, coords);\n }\n var n = stack.pop();\n var axisCount = blendVector ? blendVector.length : vstore.itemVariationSubtables[vsindex].regionIndexes.length;\n var deltaSetCount = n * axisCount;\n var delta = stack.length - deltaSetCount;\n var deltaSetIndex = delta - n;\n if (blendVector) {\n for (let i2 = 0; i2 < n; i2++) {\n var sum = stack[deltaSetIndex + i2];\n for (let j = 0; j < axisCount; j++) {\n sum += blendVector[j] * stack[delta++];\n }\n stack[deltaSetIndex + i2] = sum;\n }\n }\n while (deltaSetCount--) {\n stack.pop();\n }\n break;\n case 18:\n parseStems();\n break;\n case 19:\n // hintmask\n case 20:\n parseStems();\n i += nStems + 7 >> 3;\n break;\n case 21:\n if (stack.length > 2 && !haveWidth) {\n width = stack.shift() + nominalWidthX;\n haveWidth = true;\n }\n y += stack.pop();\n x += stack.pop();\n newContour(x, y);\n break;\n case 22:\n if (stack.length > 1 && !haveWidth) {\n width = stack.shift() + nominalWidthX;\n haveWidth = true;\n }\n x += stack.pop();\n newContour(x, y);\n break;\n case 23:\n parseStems();\n break;\n case 24:\n while (stack.length > 2) {\n c1x = x + stack.shift();\n c1y = y + stack.shift();\n c2x = c1x + stack.shift();\n c2y = c1y + stack.shift();\n x = c2x + stack.shift();\n y = c2y + stack.shift();\n p.curveTo(c1x, c1y, c2x, c2y, x, y);\n }\n x += stack.shift();\n y += stack.shift();\n p.lineTo(x, y);\n break;\n case 25:\n while (stack.length > 6) {\n x += stack.shift();\n y += stack.shift();\n p.lineTo(x, y);\n }\n c1x = x + stack.shift();\n c1y = y + stack.shift();\n c2x = c1x + stack.shift();\n c2y = c1y + stack.shift();\n x = c2x + stack.shift();\n y = c2y + stack.shift();\n p.curveTo(c1x, c1y, c2x, c2y, x, y);\n break;\n case 26:\n if (stack.length & 1) {\n x += stack.shift();\n }\n while (stack.length > 0) {\n c1x = x;\n c1y = y + stack.shift();\n c2x = c1x + stack.shift();\n c2y = c1y + stack.shift();\n x = c2x;\n y = c2y + stack.shift();\n p.curveTo(c1x, c1y, c2x, c2y, x, y);\n }\n break;\n case 27:\n if (stack.length & 1) {\n y += stack.shift();\n }\n while (stack.length > 0) {\n c1x = x + stack.shift();\n c1y = y;\n c2x = c1x + stack.shift();\n c2y = c1y + stack.shift();\n x = c2x + stack.shift();\n y = c2y;\n p.curveTo(c1x, c1y, c2x, c2y, x, y);\n }\n break;\n case 28:\n b1 = code2[i];\n b2 = code2[i + 1];\n stack.push((b1 << 24 | b2 << 16) >> 16);\n i += 2;\n break;\n case 29:\n codeIndex = stack.pop() + font.gsubrsBias;\n subrCode = font.gsubrs[codeIndex];\n if (subrCode) {\n if (callDepth >= MAX_CALL_DEPTH) {\n console.warn(\"CFF charstring subroutine call depth exceeded, skipping callgsubr\");\n break;\n }\n callDepth++;\n parse(subrCode);\n callDepth--;\n }\n break;\n case 30:\n while (stack.length > 0) {\n c1x = x;\n c1y = y + stack.shift();\n c2x = c1x + stack.shift();\n c2y = c1y + stack.shift();\n x = c2x + stack.shift();\n y = c2y + (stack.length === 1 ? stack.shift() : 0);\n p.curveTo(c1x, c1y, c2x, c2y, x, y);\n if (stack.length === 0) {\n break;\n }\n c1x = x + stack.shift();\n c1y = y;\n c2x = c1x + stack.shift();\n c2y = c1y + stack.shift();\n y = c2y + stack.shift();\n x = c2x + (stack.length === 1 ? stack.shift() : 0);\n p.curveTo(c1x, c1y, c2x, c2y, x, y);\n }\n break;\n case 31:\n while (stack.length > 0) {\n c1x = x + stack.shift();\n c1y = y;\n c2x = c1x + stack.shift();\n c2y = c1y + stack.shift();\n y = c2y + stack.shift();\n x = c2x + (stack.length === 1 ? stack.shift() : 0);\n p.curveTo(c1x, c1y, c2x, c2y, x, y);\n if (stack.length === 0) {\n break;\n }\n c1x = x;\n c1y = y + stack.shift();\n c2x = c1x + stack.shift();\n c2y = c1y + stack.shift();\n x = c2x + stack.shift();\n y = c2y + (stack.length === 1 ? stack.shift() : 0);\n p.curveTo(c1x, c1y, c2x, c2y, x, y);\n }\n break;\n default:\n if (v < 32) {\n console.log(\"Glyph \" + glyph.index + \": unknown operator \" + v);\n } else if (v < 247) {\n stack.push(v - 139);\n } else if (v < 251) {\n b1 = code2[i];\n i += 1;\n stack.push((v - 247) * 256 + b1 + 108);\n } else if (v < 255) {\n b1 = code2[i];\n i += 1;\n stack.push(-(v - 251) * 256 - b1 - 108);\n } else {\n b1 = code2[i];\n b2 = code2[i + 1];\n b3 = code2[i + 2];\n b4 = code2[i + 3];\n i += 4;\n stack.push((b1 << 24 | b2 << 16 | b3 << 8 | b4) / 65536);\n }\n }\n }\n }\n parse(code);\n if (font.variation && coords) {\n p.commands = p.commands.map((c) => {\n const keys = Object.keys(c);\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n if (key === \"type\") continue;\n c[key] = Math.round(c[key]);\n }\n return c;\n });\n }\n if (haveWidth) {\n glyph.advanceWidth = width;\n }\n return p;\n }\n function parseCFFFDSelect(data, start, nGlyphs, fdArrayCount, version) {\n const fdSelect = [];\n let fdIndex;\n const parser = new parse_default.Parser(data, start);\n const format = parser.parseCard8();\n if (format === 0) {\n for (let iGid = 0; iGid < nGlyphs; iGid++) {\n fdIndex = parser.parseCard8();\n if (fdIndex >= fdArrayCount) {\n throw new Error(\"CFF table CID Font FDSelect has bad FD index value \" + fdIndex + \" (FD count \" + fdArrayCount + \")\");\n }\n fdSelect.push(fdIndex);\n }\n } else if (format === 3 || version > 1 && format === 4) {\n const nRanges = format === 4 ? parser.parseULong() : parser.parseCard16();\n let first = format === 4 ? parser.parseULong() : parser.parseCard16();\n if (first !== 0) {\n throw new Error(`CFF Table CID Font FDSelect format ${format} range has bad initial GID ${first}`);\n }\n let next;\n for (let iRange = 0; iRange < nRanges; iRange++) {\n fdIndex = format === 4 ? parser.parseUShort() : parser.parseCard8();\n next = format === 4 ? parser.parseULong() : parser.parseCard16();\n if (fdIndex >= fdArrayCount) {\n throw new Error(\"CFF table CID Font FDSelect has bad FD index value \" + fdIndex + \" (FD count \" + fdArrayCount + \")\");\n }\n if (next > nGlyphs) {\n throw new Error(`CFF Table CID Font FDSelect format ${version} range has bad GID ${next}`);\n }\n for (; first < next; first++) {\n fdSelect.push(fdIndex);\n }\n first = next;\n }\n if (next !== nGlyphs) {\n throw new Error(\"CFF Table CID Font FDSelect format 3 range has bad final (Sentinal) GID \" + next);\n }\n } else {\n throw new Error(\"CFF Table CID Font FDSelect table has unsupported format \" + format);\n }\n return fdSelect;\n }\n function parseCFFTable(data, start, font, opt) {\n let resultTable;\n const header = parseCFFHeader(data, start);\n if (header.formatMajor === 2) {\n resultTable = font.tables.cff2 = {};\n } else {\n resultTable = font.tables.cff = {};\n }\n const nameIndex = header.formatMajor > 1 ? null : parseCFFIndex(data, header.endOffset, parse_default.bytesToString);\n const topDictIndex = header.formatMajor > 1 ? null : parseCFFIndex(data, nameIndex.endOffset);\n const stringIndex = header.formatMajor > 1 ? null : parseCFFIndex(data, topDictIndex.endOffset, parse_default.bytesToString);\n const globalSubrIndex = parseCFFIndex(data, header.formatMajor > 1 ? start + header.size + header.topDictLength : stringIndex.endOffset, void 0, header.formatMajor);\n font.gsubrs = globalSubrIndex.objects;\n font.gsubrsBias = calcCFFSubroutineBias(font.gsubrs);\n let topDict;\n if (header.formatMajor > 1) {\n const topDictOffset = start + header.size;\n const topDictData = parse_default.getBytes(data, topDictOffset, topDictOffset + header.topDictLength);\n topDict = gatherCFFTopDicts(data, 0, [topDictData], void 0, header.formatMajor)[0];\n } else {\n const topDictArray = gatherCFFTopDicts(data, start, topDictIndex.objects, stringIndex.objects, header.formatMajor);\n if (topDictArray.length !== 1) {\n throw new Error(\"CFF table has too many fonts in 'FontSet' - count of fonts NameIndex.length = \" + topDictArray.length);\n }\n topDict = topDictArray[0];\n }\n resultTable.topDict = topDict;\n if (topDict._privateDict) {\n font.defaultWidthX = topDict._privateDict.defaultWidthX;\n font.nominalWidthX = topDict._privateDict.nominalWidthX;\n }\n if (header.formatMajor < 2 && topDict.ros[0] !== void 0 && topDict.ros[1] !== void 0) {\n font.isCIDFont = true;\n }\n if (header.formatMajor > 1) {\n let fdArrayIndexOffset = topDict.fdArray;\n let fdSelectOffset = topDict.fdSelect;\n if (!fdArrayIndexOffset) {\n throw new Error(\"This is a CFF2 font, but FDArray information is missing\");\n }\n const fdArrayIndex = parseCFFIndex(data, start + fdArrayIndexOffset, null, header.formatMajor);\n const fdArray = gatherCFF2FontDicts(data, start, fdArrayIndex.objects);\n topDict._fdArray = fdArray;\n if (fdSelectOffset) {\n topDict._fdSelect = parseCFFFDSelect(data, start + fdSelectOffset, font.numGlyphs, fdArray.length, header.formatMajor);\n }\n } else if (font.isCIDFont) {\n let fdArrayOffset = topDict.fdArray;\n let fdSelectOffset = topDict.fdSelect;\n if (fdArrayOffset === 0 || fdSelectOffset === 0) {\n throw new Error(\"Font is marked as a CID font, but FDArray and/or FDSelect information is missing\");\n }\n fdArrayOffset += start;\n const fdArrayIndex = parseCFFIndex(data, fdArrayOffset);\n const fdArray = gatherCFFTopDicts(data, start, fdArrayIndex.objects, stringIndex.objects, header.formatMajor);\n topDict._fdArray = fdArray;\n fdSelectOffset += start;\n topDict._fdSelect = parseCFFFDSelect(data, fdSelectOffset, font.numGlyphs, fdArray.length, header.formatMajor);\n }\n if (header.formatMajor < 2) {\n const privateDictOffset = start + topDict.private[1];\n const privateDict = parseCFFPrivateDict(data, privateDictOffset, topDict.private[0], stringIndex.objects, header.formatMajor);\n font.defaultWidthX = privateDict.defaultWidthX;\n font.nominalWidthX = privateDict.nominalWidthX;\n if (privateDict.subrs !== 0) {\n const subrOffset = privateDictOffset + privateDict.subrs;\n const subrIndex = parseCFFIndex(data, subrOffset);\n font.subrs = subrIndex.objects;\n font.subrsBias = calcCFFSubroutineBias(font.subrs);\n } else {\n font.subrs = [];\n font.subrsBias = 0;\n }\n }\n let charStringsIndex;\n if (opt.lowMemory) {\n charStringsIndex = parseCFFIndexLowMemory(data, start + topDict.charStrings, header.formatMajor);\n font.nGlyphs = charStringsIndex.offsets.length - (header.formatMajor > 1 ? 1 : 0);\n } else {\n charStringsIndex = parseCFFIndex(data, start + topDict.charStrings, null, header.formatMajor);\n font.nGlyphs = charStringsIndex.objects.length;\n }\n if (header.formatMajor > 1 && font.tables.maxp && font.nGlyphs !== font.tables.maxp.numGlyphs) {\n console.error(`Glyph count in the CFF2 table (${font.nGlyphs}) must correspond to the glyph count in the maxp table (${font.tables.maxp.numGlyphs})`);\n }\n if (header.formatMajor < 2) {\n let charset = [];\n let encoding = [];\n if (topDict.charset === 0) {\n charset = cffISOAdobeStrings;\n } else if (topDict.charset === 1) {\n charset = cffIExpertStrings;\n } else if (topDict.charset === 2) {\n charset = cffExpertSubsetStrings;\n } else {\n charset = parseCFFCharset(data, start + topDict.charset, font.nGlyphs, stringIndex.objects, font.isCIDFont);\n }\n if (topDict.encoding === 0) {\n encoding = cffStandardEncoding;\n } else if (topDict.encoding === 1) {\n encoding = cffExpertEncoding;\n } else {\n encoding = parseCFFEncoding(data, start + topDict.encoding);\n }\n font.cffEncoding = new CffEncoding(encoding, charset);\n font.encoding = font.encoding || font.cffEncoding;\n }\n font.glyphs = new glyphset_default.GlyphSet(font);\n if (opt.lowMemory) {\n font._push = function(i) {\n const charString = getCffIndexObject(i, charStringsIndex.offsets, data, start + topDict.charStrings, void 0, header.formatMajor);\n font.glyphs.push(i, glyphset_default.cffGlyphLoader(font, i, parseCFFCharstring, charString, header.formatMajor));\n };\n } else {\n for (let i = 0; i < font.nGlyphs; i += 1) {\n const charString = charStringsIndex.objects[i];\n font.glyphs.push(i, glyphset_default.cffGlyphLoader(font, i, parseCFFCharstring, charString, header.formatMajor));\n }\n }\n if (topDict.vstore) {\n const p = new parse_default.Parser(data, start + topDict.vstore);\n topDict._vstore = p.parseVariationStore();\n }\n }\n function encodeString(s, strings) {\n let sid;\n let i = cffStandardStrings.indexOf(s);\n if (i >= 0) {\n sid = i;\n }\n i = strings.indexOf(s);\n if (i >= 0) {\n sid = i + cffStandardStrings.length;\n } else {\n sid = cffStandardStrings.length + strings.length;\n strings.push(s);\n }\n return sid;\n }\n function makeHeader() {\n return new table_default.Record(\"Header\", [\n { name: \"major\", type: \"Card8\", value: 1 },\n { name: \"minor\", type: \"Card8\", value: 0 },\n { name: \"hdrSize\", type: \"Card8\", value: 4 },\n { name: \"major\", type: \"Card8\", value: 1 }\n ]);\n }\n function makeNameIndex(fontNames) {\n const t = new table_default.Record(\"Name INDEX\", [\n { name: \"names\", type: \"INDEX\", value: [] }\n ]);\n t.names = [];\n for (let i = 0; i < fontNames.length; i += 1) {\n t.names.push({ name: \"name_\" + i, type: \"NAME\", value: fontNames[i] });\n }\n return t;\n }\n function makeDict(meta, attrs, strings) {\n const m = {};\n for (let i = 0; i < meta.length; i += 1) {\n const entry = meta[i];\n let value = attrs[entry.name];\n if (value !== void 0 && !equals(value, entry.value)) {\n if (entry.type === \"SID\") {\n value = encodeString(value, strings);\n }\n m[entry.op] = { name: entry.name, type: entry.type, value };\n }\n }\n return m;\n }\n function makeTopDict(attrs, strings, version) {\n const t = new table_default.Record(\"Top DICT\", [\n { name: \"dict\", type: \"DICT\", value: {} }\n ]);\n t.dict = makeDict(version > 1 ? TOP_DICT_META_CFF2 : TOP_DICT_META, attrs, strings);\n return t;\n }\n function makeTopDictIndex(topDict) {\n const t = new table_default.Record(\"Top DICT INDEX\", [\n { name: \"topDicts\", type: \"INDEX\", value: [] }\n ]);\n t.topDicts = [{ name: \"topDict_0\", type: \"TABLE\", value: topDict }];\n return t;\n }\n function makeStringIndex(strings) {\n const t = new table_default.Record(\"String INDEX\", [\n { name: \"strings\", type: \"INDEX\", value: [] }\n ]);\n t.strings = [];\n for (let i = 0; i < strings.length; i += 1) {\n t.strings.push({ name: \"string_\" + i, type: \"STRING\", value: strings[i] });\n }\n return t;\n }\n function makeGlobalSubrIndex() {\n return new table_default.Record(\"Global Subr INDEX\", [\n { name: \"subrs\", type: \"INDEX\", value: [] }\n ]);\n }\n function makeCharsets(glyphNames, strings) {\n const t = new table_default.Record(\"Charsets\", [\n { name: \"format\", type: \"Card8\", value: 0 }\n ]);\n for (let i = 0; i < glyphNames.length; i += 1) {\n const glyphName = glyphNames[i];\n const glyphSID = encodeString(glyphName, strings);\n t.fields.push({ name: \"glyph_\" + i, type: \"SID\", value: glyphSID });\n }\n return t;\n }\n function glyphToOps(glyph, version) {\n const ops = [];\n const path = glyph.path;\n if (version < 2) {\n ops.push({ name: \"width\", type: \"NUMBER\", value: glyph.advanceWidth });\n }\n let x = 0;\n let y = 0;\n for (let i = 0; i < path.commands.length; i += 1) {\n let dx;\n let dy;\n let cmd = path.commands[i];\n if (cmd.type === \"Q\") {\n const _13 = 1 / 3;\n const _23 = 2 / 3;\n cmd = {\n type: \"C\",\n x: cmd.x,\n y: cmd.y,\n x1: Math.round(_13 * x + _23 * cmd.x1),\n y1: Math.round(_13 * y + _23 * cmd.y1),\n x2: Math.round(_13 * cmd.x + _23 * cmd.x1),\n y2: Math.round(_13 * cmd.y + _23 * cmd.y1)\n };\n }\n if (cmd.type === \"M\") {\n dx = Math.round(cmd.x - x);\n dy = Math.round(cmd.y - y);\n ops.push({ name: \"dx\", type: \"NUMBER\", value: dx });\n ops.push({ name: \"dy\", type: \"NUMBER\", value: dy });\n ops.push({ name: \"rmoveto\", type: \"OP\", value: 21 });\n x = Math.round(cmd.x);\n y = Math.round(cmd.y);\n } else if (cmd.type === \"L\") {\n dx = Math.round(cmd.x - x);\n dy = Math.round(cmd.y - y);\n ops.push({ name: \"dx\", type: \"NUMBER\", value: dx });\n ops.push({ name: \"dy\", type: \"NUMBER\", value: dy });\n ops.push({ name: \"rlineto\", type: \"OP\", value: 5 });\n x = Math.round(cmd.x);\n y = Math.round(cmd.y);\n } else if (cmd.type === \"C\") {\n const dx1 = Math.round(cmd.x1 - x);\n const dy1 = Math.round(cmd.y1 - y);\n const dx2 = Math.round(cmd.x2 - cmd.x1);\n const dy2 = Math.round(cmd.y2 - cmd.y1);\n dx = Math.round(cmd.x - cmd.x2);\n dy = Math.round(cmd.y - cmd.y2);\n ops.push({ name: \"dx1\", type: \"NUMBER\", value: dx1 });\n ops.push({ name: \"dy1\", type: \"NUMBER\", value: dy1 });\n ops.push({ name: \"dx2\", type: \"NUMBER\", value: dx2 });\n ops.push({ name: \"dy2\", type: \"NUMBER\", value: dy2 });\n ops.push({ name: \"dx\", type: \"NUMBER\", value: dx });\n ops.push({ name: \"dy\", type: \"NUMBER\", value: dy });\n ops.push({ name: \"rrcurveto\", type: \"OP\", value: 8 });\n x = Math.round(cmd.x);\n y = Math.round(cmd.y);\n }\n }\n if (version < 2) {\n ops.push({ name: \"endchar\", type: \"OP\", value: 14 });\n }\n return ops;\n }\n function makeCharStringsIndex(glyphs, version) {\n const t = new table_default.Record(\"CharStrings INDEX\", [\n { name: \"charStrings\", type: \"INDEX\", value: [] }\n ]);\n for (let i = 0; i < glyphs.length; i += 1) {\n const glyph = glyphs.get(i);\n const ops = glyphToOps(glyph, version);\n t.charStrings.push({ name: glyph.name, type: \"CHARSTRING\", value: ops });\n }\n return t;\n }\n function makePrivateDict(attrs, strings, version) {\n const t = new table_default.Record(\"Private DICT\", [\n { name: \"dict\", type: \"DICT\", value: {} }\n ]);\n t.dict = makeDict(version > 1 ? PRIVATE_DICT_META_CFF2 : PRIVATE_DICT_META, attrs, strings);\n return t;\n }\n function makeCFFTable(glyphs, options) {\n const cffVersion = 1;\n const t = new table_default.Table(\"CFF \", [\n { name: \"header\", type: \"RECORD\" },\n { name: \"nameIndex\", type: \"RECORD\" },\n { name: \"topDictIndex\", type: \"RECORD\" },\n { name: \"stringIndex\", type: \"RECORD\" },\n { name: \"globalSubrIndex\", type: \"RECORD\" },\n { name: \"charsets\", type: \"RECORD\" },\n { name: \"charStringsIndex\", type: \"RECORD\" },\n { name: \"privateDict\", type: \"RECORD\" }\n ]);\n const fontScale = 1 / options.unitsPerEm;\n const attrs = {\n version: options.version,\n fullName: options.fullName,\n familyName: options.familyName,\n weight: options.weightName,\n fontBBox: options.fontBBox || [0, 0, 0, 0],\n fontMatrix: [fontScale, 0, 0, fontScale, 0, 0],\n charset: 999,\n encoding: 0,\n charStrings: 999,\n private: [0, 999]\n };\n const topDictOptions = options && options.topDict || {};\n if (cffVersion < 2 && topDictOptions.paintType) {\n attrs.paintType = topDictOptions.paintType;\n attrs.strokeWidth = topDictOptions.strokeWidth || 0;\n }\n const privateAttrs = {};\n const glyphNames = [];\n let glyph;\n for (let i = 1; i < glyphs.length; i += 1) {\n glyph = glyphs.get(i);\n glyphNames.push(glyph.name);\n }\n const strings = [];\n t.header = makeHeader();\n t.nameIndex = makeNameIndex([options.postScriptName]);\n let topDict = makeTopDict(attrs, strings);\n t.topDictIndex = makeTopDictIndex(topDict);\n t.globalSubrIndex = makeGlobalSubrIndex();\n t.charsets = makeCharsets(glyphNames, strings);\n t.charStringsIndex = makeCharStringsIndex(glyphs, cffVersion);\n t.privateDict = makePrivateDict(privateAttrs, strings);\n t.stringIndex = makeStringIndex(strings);\n const startOffset = t.header.sizeOf() + t.nameIndex.sizeOf() + t.topDictIndex.sizeOf() + t.stringIndex.sizeOf() + t.globalSubrIndex.sizeOf();\n attrs.charset = startOffset;\n attrs.encoding = 0;\n attrs.charStrings = attrs.charset + t.charsets.sizeOf();\n attrs.private[1] = attrs.charStrings + t.charStringsIndex.sizeOf();\n topDict = makeTopDict(attrs, strings);\n t.topDictIndex = makeTopDictIndex(topDict);\n return t;\n }\n var cff_default = { parse: parseCFFTable, make: makeCFFTable };\n\n // src/tables/head.mjs\n function parseHeadTable(data, start) {\n const head = {};\n const p = new parse_default.Parser(data, start);\n head.version = p.parseVersion();\n head.fontRevision = Math.round(p.parseFixed() * 1e3) / 1e3;\n head.checkSumAdjustment = p.parseULong();\n head.magicNumber = p.parseULong();\n check_default.argument(head.magicNumber === 1594834165, \"Font header has wrong magic number.\");\n head.flags = p.parseUShort();\n head.unitsPerEm = p.parseUShort();\n head.created = p.parseLongDateTime();\n head.modified = p.parseLongDateTime();\n head.xMin = p.parseShort();\n head.yMin = p.parseShort();\n head.xMax = p.parseShort();\n head.yMax = p.parseShort();\n head.macStyle = p.parseUShort();\n head.lowestRecPPEM = p.parseUShort();\n head.fontDirectionHint = p.parseShort();\n head.indexToLocFormat = p.parseShort();\n head.glyphDataFormat = p.parseShort();\n return head;\n }\n function makeHeadTable(options) {\n const timestamp = Math.round((/* @__PURE__ */ new Date()).getTime() / 1e3) + 2082844800;\n let createdTimestamp = timestamp;\n let macStyle = options.macStyle || 0;\n if (options.createdTimestamp) {\n createdTimestamp = options.createdTimestamp + 2082844800;\n }\n return new table_default.Table(\"head\", [\n { name: \"version\", type: \"FIXED\", value: 65536 },\n { name: \"fontRevision\", type: \"FIXED\", value: 65536 },\n { name: \"checkSumAdjustment\", type: \"ULONG\", value: 0 },\n { name: \"magicNumber\", type: \"ULONG\", value: 1594834165 },\n { name: \"flags\", type: \"USHORT\", value: 0 },\n { name: \"unitsPerEm\", type: \"USHORT\", value: 1e3 },\n { name: \"created\", type: \"LONGDATETIME\", value: createdTimestamp },\n { name: \"modified\", type: \"LONGDATETIME\", value: timestamp },\n { name: \"xMin\", type: \"SHORT\", value: 0 },\n { name: \"yMin\", type: \"SHORT\", value: 0 },\n { name: \"xMax\", type: \"SHORT\", value: 0 },\n { name: \"yMax\", type: \"SHORT\", value: 0 },\n { name: \"macStyle\", type: \"USHORT\", value: macStyle },\n { name: \"lowestRecPPEM\", type: \"USHORT\", value: 0 },\n { name: \"fontDirectionHint\", type: \"SHORT\", value: 2 },\n { name: \"indexToLocFormat\", type: \"SHORT\", value: 0 },\n { name: \"glyphDataFormat\", type: \"SHORT\", value: 0 }\n ], options);\n }\n var head_default = { parse: parseHeadTable, make: makeHeadTable };\n\n // src/tables/hhea.mjs\n function parseHheaTable(data, start) {\n const hhea = {};\n const p = new parse_default.Parser(data, start);\n hhea.version = p.parseVersion();\n hhea.ascender = p.parseShort();\n hhea.descender = p.parseShort();\n hhea.lineGap = p.parseShort();\n hhea.advanceWidthMax = p.parseUShort();\n hhea.minLeftSideBearing = p.parseShort();\n hhea.minRightSideBearing = p.parseShort();\n hhea.xMaxExtent = p.parseShort();\n hhea.caretSlopeRise = p.parseShort();\n hhea.caretSlopeRun = p.parseShort();\n hhea.caretOffset = p.parseShort();\n p.relativeOffset += 8;\n hhea.metricDataFormat = p.parseShort();\n hhea.numberOfHMetrics = p.parseUShort();\n return hhea;\n }\n function makeHheaTable(options) {\n return new table_default.Table(\"hhea\", [\n { name: \"version\", type: \"FIXED\", value: 65536 },\n { name: \"ascender\", type: \"FWORD\", value: 0 },\n { name: \"descender\", type: \"FWORD\", value: 0 },\n { name: \"lineGap\", type: \"FWORD\", value: 0 },\n { name: \"advanceWidthMax\", type: \"UFWORD\", value: 0 },\n { name: \"minLeftSideBearing\", type: \"FWORD\", value: 0 },\n { name: \"minRightSideBearing\", type: \"FWORD\", value: 0 },\n { name: \"xMaxExtent\", type: \"FWORD\", value: 0 },\n { name: \"caretSlopeRise\", type: \"SHORT\", value: 1 },\n { name: \"caretSlopeRun\", type: \"SHORT\", value: 0 },\n { name: \"caretOffset\", type: \"SHORT\", value: 0 },\n { name: \"reserved1\", type: \"SHORT\", value: 0 },\n { name: \"reserved2\", type: \"SHORT\", value: 0 },\n { name: \"reserved3\", type: \"SHORT\", value: 0 },\n { name: \"reserved4\", type: \"SHORT\", value: 0 },\n { name: \"metricDataFormat\", type: \"SHORT\", value: 0 },\n { name: \"numberOfHMetrics\", type: \"USHORT\", value: 0 }\n ], options);\n }\n var hhea_default = { parse: parseHheaTable, make: makeHheaTable };\n\n // src/tables/hmtx.mjs\n function parseHmtxTableAll(data, start, numMetrics, numGlyphs, glyphs) {\n let advanceWidth;\n let leftSideBearing;\n const p = new parse_default.Parser(data, start);\n for (let i = 0; i < numGlyphs; i += 1) {\n if (i < numMetrics) {\n advanceWidth = p.parseUShort();\n leftSideBearing = p.parseShort();\n }\n const glyph = glyphs.get(i);\n glyph.advanceWidth = advanceWidth;\n glyph.leftSideBearing = leftSideBearing;\n }\n }\n function parseHmtxTableOnLowMemory(font, data, start, numMetrics, numGlyphs) {\n font._hmtxTableData = {};\n let advanceWidth;\n let leftSideBearing;\n const p = new parse_default.Parser(data, start);\n for (let i = 0; i < numGlyphs; i += 1) {\n if (i < numMetrics) {\n advanceWidth = p.parseUShort();\n leftSideBearing = p.parseShort();\n }\n font._hmtxTableData[i] = {\n advanceWidth,\n leftSideBearing\n };\n }\n }\n function parseHmtxTable(font, data, start, numMetrics, numGlyphs, glyphs, opt) {\n if (opt.lowMemory)\n parseHmtxTableOnLowMemory(font, data, start, numMetrics, numGlyphs);\n else\n parseHmtxTableAll(data, start, numMetrics, numGlyphs, glyphs);\n }\n function makeHmtxTable(glyphs) {\n const t = new table_default.Table(\"hmtx\", []);\n for (let i = 0; i < glyphs.length; i += 1) {\n const glyph = glyphs.get(i);\n const advanceWidth = glyph.advanceWidth || 0;\n const leftSideBearing = glyph.leftSideBearing || 0;\n t.fields.push({ name: \"advanceWidth_\" + i, type: \"USHORT\", value: advanceWidth });\n t.fields.push({ name: \"leftSideBearing_\" + i, type: \"SHORT\", value: leftSideBearing });\n }\n return t;\n }\n var hmtx_default = { parse: parseHmtxTable, make: makeHmtxTable };\n\n // src/tables/ltag.mjs\n function makeLtagTable(tags) {\n const result = new table_default.Table(\"ltag\", [\n { name: \"version\", type: \"ULONG\", value: 1 },\n { name: \"flags\", type: \"ULONG\", value: 0 },\n { name: \"numTags\", type: \"ULONG\", value: tags.length }\n ]);\n let stringPool = \"\";\n const stringPoolOffset = 12 + tags.length * 4;\n for (let i = 0; i < tags.length; ++i) {\n let pos = stringPool.indexOf(tags[i]);\n if (pos < 0) {\n pos = stringPool.length;\n stringPool += tags[i];\n }\n result.fields.push({ name: \"offset \" + i, type: \"USHORT\", value: stringPoolOffset + pos });\n result.fields.push({ name: \"length \" + i, type: \"USHORT\", value: tags[i].length });\n }\n result.fields.push({ name: \"stringPool\", type: \"CHARARRAY\", value: stringPool });\n return result;\n }\n function parseLtagTable(data, start) {\n const p = new parse_default.Parser(data, start);\n const tableVersion = p.parseULong();\n check_default.argument(tableVersion === 1, \"Unsupported ltag table version.\");\n p.skip(\"uLong\", 1);\n const numTags = p.parseULong();\n const tags = [];\n for (let i = 0; i < numTags; i++) {\n let tag = \"\";\n const offset = start + p.parseUShort();\n const length = p.parseUShort();\n for (let j = offset; j < offset + length; ++j) {\n tag += String.fromCharCode(data.getInt8(j));\n }\n tags.push(tag);\n }\n return tags;\n }\n var ltag_default = { make: makeLtagTable, parse: parseLtagTable };\n\n // src/tables/maxp.mjs\n function parseMaxpTable(data, start) {\n const maxp = {};\n const p = new parse_default.Parser(data, start);\n maxp.version = p.parseVersion();\n maxp.numGlyphs = p.parseUShort();\n if (maxp.version === 1) {\n maxp.maxPoints = p.parseUShort();\n maxp.maxContours = p.parseUShort();\n maxp.maxCompositePoints = p.parseUShort();\n maxp.maxCompositeContours = p.parseUShort();\n maxp.maxZones = p.parseUShort();\n maxp.maxTwilightPoints = p.parseUShort();\n maxp.maxStorage = p.parseUShort();\n maxp.maxFunctionDefs = p.parseUShort();\n maxp.maxInstructionDefs = p.parseUShort();\n maxp.maxStackElements = p.parseUShort();\n maxp.maxSizeOfInstructions = p.parseUShort();\n maxp.maxComponentElements = p.parseUShort();\n maxp.maxComponentDepth = p.parseUShort();\n }\n return maxp;\n }\n function makeMaxpTable(numGlyphs) {\n return new table_default.Table(\"maxp\", [\n { name: \"version\", type: \"FIXED\", value: 20480 },\n { name: \"numGlyphs\", type: \"USHORT\", value: numGlyphs }\n ]);\n }\n var maxp_default = { parse: parseMaxpTable, make: makeMaxpTable };\n\n // src/tables/os2.mjs\n var unicodeRanges = [\n { begin: 0, end: 127 },\n // Basic Latin\n { begin: 128, end: 255 },\n // Latin-1 Supplement\n { begin: 256, end: 383 },\n // Latin Extended-A\n { begin: 384, end: 591 },\n // Latin Extended-B\n { begin: 592, end: 687 },\n // IPA Extensions\n { begin: 688, end: 767 },\n // Spacing Modifier Letters\n { begin: 768, end: 879 },\n // Combining Diacritical Marks\n { begin: 880, end: 1023 },\n // Greek and Coptic\n { begin: 11392, end: 11519 },\n // Coptic\n { begin: 1024, end: 1279 },\n // Cyrillic\n { begin: 1328, end: 1423 },\n // Armenian\n { begin: 1424, end: 1535 },\n // Hebrew\n { begin: 42240, end: 42559 },\n // Vai\n { begin: 1536, end: 1791 },\n // Arabic\n { begin: 1984, end: 2047 },\n // NKo\n { begin: 2304, end: 2431 },\n // Devanagari\n { begin: 2432, end: 2559 },\n // Bengali\n { begin: 2560, end: 2687 },\n // Gurmukhi\n { begin: 2688, end: 2815 },\n // Gujarati\n { begin: 2816, end: 2943 },\n // Oriya\n { begin: 2944, end: 3071 },\n // Tamil\n { begin: 3072, end: 3199 },\n // Telugu\n { begin: 3200, end: 3327 },\n // Kannada\n { begin: 3328, end: 3455 },\n // Malayalam\n { begin: 3584, end: 3711 },\n // Thai\n { begin: 3712, end: 3839 },\n // Lao\n { begin: 4256, end: 4351 },\n // Georgian\n { begin: 6912, end: 7039 },\n // Balinese\n { begin: 4352, end: 4607 },\n // Hangul Jamo\n { begin: 7680, end: 7935 },\n // Latin Extended Additional\n { begin: 7936, end: 8191 },\n // Greek Extended\n { begin: 8192, end: 8303 },\n // General Punctuation\n { begin: 8304, end: 8351 },\n // Superscripts And Subscripts\n { begin: 8352, end: 8399 },\n // Currency Symbol\n { begin: 8400, end: 8447 },\n // Combining Diacritical Marks For Symbols\n { begin: 8448, end: 8527 },\n // Letterlike Symbols\n { begin: 8528, end: 8591 },\n // Number Forms\n { begin: 8592, end: 8703 },\n // Arrows\n { begin: 8704, end: 8959 },\n // Mathematical Operators\n { begin: 8960, end: 9215 },\n // Miscellaneous Technical\n { begin: 9216, end: 9279 },\n // Control Pictures\n { begin: 9280, end: 9311 },\n // Optical Character Recognition\n { begin: 9312, end: 9471 },\n // Enclosed Alphanumerics\n { begin: 9472, end: 9599 },\n // Box Drawing\n { begin: 9600, end: 9631 },\n // Block Elements\n { begin: 9632, end: 9727 },\n // Geometric Shapes\n { begin: 9728, end: 9983 },\n // Miscellaneous Symbols\n { begin: 9984, end: 10175 },\n // Dingbats\n { begin: 12288, end: 12351 },\n // CJK Symbols And Punctuation\n { begin: 12352, end: 12447 },\n // Hiragana\n { begin: 12448, end: 12543 },\n // Katakana\n { begin: 12544, end: 12591 },\n // Bopomofo\n { begin: 12592, end: 12687 },\n // Hangul Compatibility Jamo\n { begin: 43072, end: 43135 },\n // Phags-pa\n { begin: 12800, end: 13055 },\n // Enclosed CJK Letters And Months\n { begin: 13056, end: 13311 },\n // CJK Compatibility\n { begin: 44032, end: 55215 },\n // Hangul Syllables\n { begin: 55296, end: 57343 },\n // Non-Plane 0 *\n { begin: 67840, end: 67871 },\n // Phoenicia\n { begin: 19968, end: 40959 },\n // CJK Unified Ideographs\n { begin: 57344, end: 63743 },\n // Private Use Area (plane 0)\n { begin: 12736, end: 12783 },\n // CJK Strokes\n { begin: 64256, end: 64335 },\n // Alphabetic Presentation Forms\n { begin: 64336, end: 65023 },\n // Arabic Presentation Forms-A\n { begin: 65056, end: 65071 },\n // Combining Half Marks\n { begin: 65040, end: 65055 },\n // Vertical Forms\n { begin: 65104, end: 65135 },\n // Small Form Variants\n { begin: 65136, end: 65279 },\n // Arabic Presentation Forms-B\n { begin: 65280, end: 65519 },\n // Halfwidth And Fullwidth Forms\n { begin: 65520, end: 65535 },\n // Specials\n { begin: 3840, end: 4095 },\n // Tibetan\n { begin: 1792, end: 1871 },\n // Syriac\n { begin: 1920, end: 1983 },\n // Thaana\n { begin: 3456, end: 3583 },\n // Sinhala\n { begin: 4096, end: 4255 },\n // Myanmar\n { begin: 4608, end: 4991 },\n // Ethiopic\n { begin: 5024, end: 5119 },\n // Cherokee\n { begin: 5120, end: 5759 },\n // Unified Canadian Aboriginal Syllabics\n { begin: 5760, end: 5791 },\n // Ogham\n { begin: 5792, end: 5887 },\n // Runic\n { begin: 6016, end: 6143 },\n // Khmer\n { begin: 6144, end: 6319 },\n // Mongolian\n { begin: 10240, end: 10495 },\n // Braille Patterns\n { begin: 40960, end: 42127 },\n // Yi Syllables\n { begin: 5888, end: 5919 },\n // Tagalog\n { begin: 66304, end: 66351 },\n // Old Italic\n { begin: 66352, end: 66383 },\n // Gothic\n { begin: 66560, end: 66639 },\n // Deseret\n { begin: 118784, end: 119039 },\n // Byzantine Musical Symbols\n { begin: 119808, end: 120831 },\n // Mathematical Alphanumeric Symbols\n { begin: 1044480, end: 1048573 },\n // Private Use (plane 15)\n { begin: 65024, end: 65039 },\n // Variation Selectors\n { begin: 917504, end: 917631 },\n // Tags\n { begin: 6400, end: 6479 },\n // Limbu\n { begin: 6480, end: 6527 },\n // Tai Le\n { begin: 6528, end: 6623 },\n // New Tai Lue\n { begin: 6656, end: 6687 },\n // Buginese\n { begin: 11264, end: 11359 },\n // Glagolitic\n { begin: 11568, end: 11647 },\n // Tifinagh\n { begin: 19904, end: 19967 },\n // Yijing Hexagram Symbols\n { begin: 43008, end: 43055 },\n // Syloti Nagri\n { begin: 65536, end: 65663 },\n // Linear B Syllabary\n { begin: 65856, end: 65935 },\n // Ancient Greek Numbers\n { begin: 66432, end: 66463 },\n // Ugaritic\n { begin: 66464, end: 66527 },\n // Old Persian\n { begin: 66640, end: 66687 },\n // Shavian\n { begin: 66688, end: 66735 },\n // Osmanya\n { begin: 67584, end: 67647 },\n // Cypriot Syllabary\n { begin: 68096, end: 68191 },\n // Kharoshthi\n { begin: 119552, end: 119647 },\n // Tai Xuan Jing Symbols\n { begin: 73728, end: 74751 },\n // Cuneiform\n { begin: 119648, end: 119679 },\n // Counting Rod Numerals\n { begin: 7040, end: 7103 },\n // Sundanese\n { begin: 7168, end: 7247 },\n // Lepcha\n { begin: 7248, end: 7295 },\n // Ol Chiki\n { begin: 43136, end: 43231 },\n // Saurashtra\n { begin: 43264, end: 43311 },\n // Kayah Li\n { begin: 43312, end: 43359 },\n // Rejang\n { begin: 43520, end: 43615 },\n // Cham\n { begin: 65936, end: 65999 },\n // Ancient Symbols\n { begin: 66e3, end: 66047 },\n // Phaistos Disc\n { begin: 66208, end: 66271 },\n // Carian\n { begin: 127024, end: 127135 }\n // Domino Tiles\n ];\n function getUnicodeRange(unicode) {\n for (let i = 0; i < unicodeRanges.length; i += 1) {\n const range = unicodeRanges[i];\n if (unicode >= range.begin && unicode < range.end) {\n return i;\n }\n }\n return -1;\n }\n function parseOS2Table(data, start) {\n const os2 = {};\n const p = new parse_default.Parser(data, start);\n os2.version = p.parseUShort();\n os2.xAvgCharWidth = p.parseShort();\n os2.usWeightClass = p.parseUShort();\n os2.usWidthClass = p.parseUShort();\n os2.fsType = p.parseUShort();\n os2.ySubscriptXSize = p.parseShort();\n os2.ySubscriptYSize = p.parseShort();\n os2.ySubscriptXOffset = p.parseShort();\n os2.ySubscriptYOffset = p.parseShort();\n os2.ySuperscriptXSize = p.parseShort();\n os2.ySuperscriptYSize = p.parseShort();\n os2.ySuperscriptXOffset = p.parseShort();\n os2.ySuperscriptYOffset = p.parseShort();\n os2.yStrikeoutSize = p.parseShort();\n os2.yStrikeoutPosition = p.parseShort();\n os2.sFamilyClass = p.parseShort();\n os2.panose = [];\n for (let i = 0; i < 10; i++) {\n os2.panose[i] = p.parseByte();\n }\n os2.ulUnicodeRange1 = p.parseULong();\n os2.ulUnicodeRange2 = p.parseULong();\n os2.ulUnicodeRange3 = p.parseULong();\n os2.ulUnicodeRange4 = p.parseULong();\n os2.achVendID = String.fromCharCode(p.parseByte(), p.parseByte(), p.parseByte(), p.parseByte());\n os2.fsSelection = p.parseUShort();\n os2.usFirstCharIndex = p.parseUShort();\n os2.usLastCharIndex = p.parseUShort();\n os2.sTypoAscender = p.parseShort();\n os2.sTypoDescender = p.parseShort();\n os2.sTypoLineGap = p.parseShort();\n os2.usWinAscent = p.parseUShort();\n os2.usWinDescent = p.parseUShort();\n if (os2.version >= 1) {\n os2.ulCodePageRange1 = p.parseULong();\n os2.ulCodePageRange2 = p.parseULong();\n }\n if (os2.version >= 2) {\n os2.sxHeight = p.parseShort();\n os2.sCapHeight = p.parseShort();\n os2.usDefaultChar = p.parseUShort();\n os2.usBreakChar = p.parseUShort();\n os2.usMaxContent = p.parseUShort();\n }\n return os2;\n }\n function makeOS2Table(options) {\n return new table_default.Table(\"OS/2\", [\n { name: \"version\", type: \"USHORT\", value: 3 },\n { name: \"xAvgCharWidth\", type: \"SHORT\", value: 0 },\n { name: \"usWeightClass\", type: \"USHORT\", value: 0 },\n { name: \"usWidthClass\", type: \"USHORT\", value: 0 },\n { name: \"fsType\", type: \"USHORT\", value: 0 },\n { name: \"ySubscriptXSize\", type: \"SHORT\", value: 650 },\n { name: \"ySubscriptYSize\", type: \"SHORT\", value: 699 },\n { name: \"ySubscriptXOffset\", type: \"SHORT\", value: 0 },\n { name: \"ySubscriptYOffset\", type: \"SHORT\", value: 140 },\n { name: \"ySuperscriptXSize\", type: \"SHORT\", value: 650 },\n { name: \"ySuperscriptYSize\", type: \"SHORT\", value: 699 },\n { name: \"ySuperscriptXOffset\", type: \"SHORT\", value: 0 },\n { name: \"ySuperscriptYOffset\", type: \"SHORT\", value: 479 },\n { name: \"yStrikeoutSize\", type: \"SHORT\", value: 49 },\n { name: \"yStrikeoutPosition\", type: \"SHORT\", value: 258 },\n { name: \"sFamilyClass\", type: \"SHORT\", value: 0 },\n { name: \"bFamilyType\", type: \"BYTE\", value: 0 },\n { name: \"bSerifStyle\", type: \"BYTE\", value: 0 },\n { name: \"bWeight\", type: \"BYTE\", value: 0 },\n { name: \"bProportion\", type: \"BYTE\", value: 0 },\n { name: \"bContrast\", type: \"BYTE\", value: 0 },\n { name: \"bStrokeVariation\", type: \"BYTE\", value: 0 },\n { name: \"bArmStyle\", type: \"BYTE\", value: 0 },\n { name: \"bLetterform\", type: \"BYTE\", value: 0 },\n { name: \"bMidline\", type: \"BYTE\", value: 0 },\n { name: \"bXHeight\", type: \"BYTE\", value: 0 },\n { name: \"ulUnicodeRange1\", type: \"ULONG\", value: 0 },\n { name: \"ulUnicodeRange2\", type: \"ULONG\", value: 0 },\n { name: \"ulUnicodeRange3\", type: \"ULONG\", value: 0 },\n { name: \"ulUnicodeRange4\", type: \"ULONG\", value: 0 },\n { name: \"achVendID\", type: \"CHARARRAY\", value: \"XXXX\" },\n { name: \"fsSelection\", type: \"USHORT\", value: 0 },\n { name: \"usFirstCharIndex\", type: \"USHORT\", value: 0 },\n { name: \"usLastCharIndex\", type: \"USHORT\", value: 0 },\n { name: \"sTypoAscender\", type: \"SHORT\", value: 0 },\n { name: \"sTypoDescender\", type: \"SHORT\", value: 0 },\n { name: \"sTypoLineGap\", type: \"SHORT\", value: 0 },\n { name: \"usWinAscent\", type: \"USHORT\", value: 0 },\n { name: \"usWinDescent\", type: \"USHORT\", value: 0 },\n { name: \"ulCodePageRange1\", type: \"ULONG\", value: 0 },\n { name: \"ulCodePageRange2\", type: \"ULONG\", value: 0 },\n { name: \"sxHeight\", type: \"SHORT\", value: 0 },\n { name: \"sCapHeight\", type: \"SHORT\", value: 0 },\n { name: \"usDefaultChar\", type: \"USHORT\", value: 0 },\n { name: \"usBreakChar\", type: \"USHORT\", value: 0 },\n { name: \"usMaxContext\", type: \"USHORT\", value: 0 }\n ], options);\n }\n var os2_default = { parse: parseOS2Table, make: makeOS2Table, unicodeRanges, getUnicodeRange };\n\n // src/tables/post.mjs\n function parsePostTable(data, start) {\n const post = {};\n const p = new parse_default.Parser(data, start);\n post.version = p.parseVersion();\n post.italicAngle = p.parseFixed();\n post.underlinePosition = p.parseShort();\n post.underlineThickness = p.parseShort();\n post.isFixedPitch = p.parseULong();\n post.minMemType42 = p.parseULong();\n post.maxMemType42 = p.parseULong();\n post.minMemType1 = p.parseULong();\n post.maxMemType1 = p.parseULong();\n switch (post.version) {\n case 1:\n post.names = standardNames.slice();\n break;\n case 2:\n post.numberOfGlyphs = p.parseUShort();\n post.glyphNameIndex = new Array(post.numberOfGlyphs);\n for (let i = 0; i < post.numberOfGlyphs; i++) {\n post.glyphNameIndex[i] = p.parseUShort();\n }\n post.names = [];\n for (let i = 0; i < post.numberOfGlyphs; i++) {\n if (post.glyphNameIndex[i] >= standardNames.length) {\n const nameLength = p.parseChar();\n post.names.push(p.parseString(nameLength));\n }\n }\n break;\n case 2.5:\n post.numberOfGlyphs = p.parseUShort();\n post.offset = new Array(post.numberOfGlyphs);\n for (let i = 0; i < post.numberOfGlyphs; i++) {\n post.offset[i] = p.parseChar();\n }\n break;\n }\n return post;\n }\n function makePostTable(font) {\n const {\n italicAngle = Math.round((font.italicAngle || 0) * 65536),\n underlinePosition = 0,\n underlineThickness = 0,\n isFixedPitch = 0,\n minMemType42 = 0,\n maxMemType42 = 0,\n minMemType1 = 0,\n maxMemType1 = 0\n } = font.tables.post || {};\n return new table_default.Table(\"post\", [\n { name: \"version\", type: \"FIXED\", value: 196608 },\n { name: \"italicAngle\", type: \"FIXED\", value: italicAngle },\n { name: \"underlinePosition\", type: \"FWORD\", value: underlinePosition },\n { name: \"underlineThickness\", type: \"FWORD\", value: underlineThickness },\n { name: \"isFixedPitch\", type: \"ULONG\", value: isFixedPitch },\n { name: \"minMemType42\", type: \"ULONG\", value: minMemType42 },\n { name: \"maxMemType42\", type: \"ULONG\", value: maxMemType42 },\n { name: \"minMemType1\", type: \"ULONG\", value: minMemType1 },\n { name: \"maxMemType1\", type: \"ULONG\", value: maxMemType1 }\n ]);\n }\n var post_default = { parse: parsePostTable, make: makePostTable };\n\n // src/tables/gsub.mjs\n var subtableParsers = new Array(9);\n subtableParsers[1] = function parseLookup1() {\n const start = this.offset + this.relativeOffset;\n const substFormat = this.parseUShort();\n if (substFormat === 1) {\n return {\n substFormat: 1,\n coverage: this.parsePointer(Parser.coverage),\n deltaGlyphId: this.parseShort()\n };\n } else if (substFormat === 2) {\n return {\n substFormat: 2,\n coverage: this.parsePointer(Parser.coverage),\n substitute: this.parseOffset16List()\n };\n }\n check_default.assert(false, \"0x\" + start.toString(16) + \": lookup type 1 format must be 1 or 2.\");\n };\n subtableParsers[2] = function parseLookup2() {\n const substFormat = this.parseUShort();\n check_default.argument(substFormat === 1, \"GSUB Multiple Substitution Subtable identifier-format must be 1\");\n return {\n substFormat,\n coverage: this.parsePointer(Parser.coverage),\n sequences: this.parseListOfLists()\n };\n };\n subtableParsers[3] = function parseLookup3() {\n const substFormat = this.parseUShort();\n check_default.argument(substFormat === 1, \"GSUB Alternate Substitution Subtable identifier-format must be 1\");\n return {\n substFormat,\n coverage: this.parsePointer(Parser.coverage),\n alternateSets: this.parseListOfLists()\n };\n };\n subtableParsers[4] = function parseLookup4() {\n const substFormat = this.parseUShort();\n check_default.argument(substFormat === 1, \"GSUB ligature table identifier-format must be 1\");\n return {\n substFormat,\n coverage: this.parsePointer(Parser.coverage),\n ligatureSets: this.parseListOfLists(function() {\n return {\n ligGlyph: this.parseUShort(),\n components: this.parseUShortList(this.parseUShort() - 1)\n };\n })\n };\n };\n var lookupRecordDesc = {\n sequenceIndex: Parser.uShort,\n lookupListIndex: Parser.uShort\n };\n subtableParsers[5] = function parseLookup5() {\n const start = this.offset + this.relativeOffset;\n const substFormat = this.parseUShort();\n if (substFormat === 1) {\n return {\n substFormat,\n coverage: this.parsePointer(Parser.coverage),\n ruleSets: this.parseListOfLists(function() {\n const glyphCount = this.parseUShort();\n const substCount = this.parseUShort();\n return {\n input: this.parseUShortList(glyphCount - 1),\n lookupRecords: this.parseRecordList(substCount, lookupRecordDesc)\n };\n })\n };\n } else if (substFormat === 2) {\n return {\n substFormat,\n coverage: this.parsePointer(Parser.coverage),\n classDef: this.parsePointer(Parser.classDef),\n classSets: this.parseListOfLists(function() {\n const glyphCount = this.parseUShort();\n const substCount = this.parseUShort();\n return {\n classes: this.parseUShortList(glyphCount - 1),\n lookupRecords: this.parseRecordList(substCount, lookupRecordDesc)\n };\n })\n };\n } else if (substFormat === 3) {\n const glyphCount = this.parseUShort();\n const substCount = this.parseUShort();\n return {\n substFormat,\n coverages: this.parseList(glyphCount, Parser.pointer(Parser.coverage)),\n lookupRecords: this.parseRecordList(substCount, lookupRecordDesc)\n };\n }\n check_default.assert(false, \"0x\" + start.toString(16) + \": lookup type 5 format must be 1, 2 or 3.\");\n };\n subtableParsers[6] = function parseLookup6() {\n const start = this.offset + this.relativeOffset;\n const substFormat = this.parseUShort();\n if (substFormat === 1) {\n return {\n substFormat: 1,\n coverage: this.parsePointer(Parser.coverage),\n chainRuleSets: this.parseListOfLists(function() {\n return {\n backtrack: this.parseUShortList(),\n input: this.parseUShortList(this.parseShort() - 1),\n lookahead: this.parseUShortList(),\n lookupRecords: this.parseRecordList(lookupRecordDesc)\n };\n })\n };\n } else if (substFormat === 2) {\n return {\n substFormat: 2,\n coverage: this.parsePointer(Parser.coverage),\n backtrackClassDef: this.parsePointer(Parser.classDef),\n inputClassDef: this.parsePointer(Parser.classDef),\n lookaheadClassDef: this.parsePointer(Parser.classDef),\n chainClassSet: this.parseListOfLists(function() {\n return {\n backtrack: this.parseUShortList(),\n input: this.parseUShortList(this.parseShort() - 1),\n lookahead: this.parseUShortList(),\n lookupRecords: this.parseRecordList(lookupRecordDesc)\n };\n })\n };\n } else if (substFormat === 3) {\n return {\n substFormat: 3,\n backtrackCoverage: this.parseList(Parser.pointer(Parser.coverage)),\n inputCoverage: this.parseList(Parser.pointer(Parser.coverage)),\n lookaheadCoverage: this.parseList(Parser.pointer(Parser.coverage)),\n lookupRecords: this.parseRecordList(lookupRecordDesc)\n };\n }\n check_default.assert(false, \"0x\" + start.toString(16) + \": lookup type 6 format must be 1, 2 or 3.\");\n };\n subtableParsers[7] = function parseLookup7() {\n const substFormat = this.parseUShort();\n check_default.argument(substFormat === 1, \"GSUB Extension Substitution subtable identifier-format must be 1\");\n const extensionLookupType = this.parseUShort();\n const extensionParser = new Parser(this.data, this.offset + this.parseULong());\n return {\n substFormat: 1,\n lookupType: extensionLookupType,\n extension: subtableParsers[extensionLookupType].call(extensionParser)\n };\n };\n subtableParsers[8] = function parseLookup8() {\n const substFormat = this.parseUShort();\n check_default.argument(substFormat === 1, \"GSUB Reverse Chaining Contextual Single Substitution Subtable identifier-format must be 1\");\n return {\n substFormat,\n coverage: this.parsePointer(Parser.coverage),\n backtrackCoverage: this.parseList(Parser.pointer(Parser.coverage)),\n lookaheadCoverage: this.parseList(Parser.pointer(Parser.coverage)),\n substitutes: this.parseUShortList()\n };\n };\n function parseGsubTable(data, start) {\n start = start || 0;\n const p = new Parser(data, start);\n const tableVersion = p.parseVersion(1);\n check_default.argument(tableVersion === 1 || tableVersion === 1.1, \"Unsupported GSUB table version.\");\n if (tableVersion === 1) {\n return {\n version: tableVersion,\n scripts: p.parseScriptList(),\n features: p.parseFeatureList(),\n lookups: p.parseLookupList(subtableParsers)\n };\n } else {\n return {\n version: tableVersion,\n scripts: p.parseScriptList(),\n features: p.parseFeatureList(),\n lookups: p.parseLookupList(subtableParsers),\n variations: p.parseFeatureVariationsList()\n };\n }\n }\n var subtableMakers = new Array(9);\n subtableMakers[1] = function makeLookup1(subtable) {\n if (subtable.substFormat === 1) {\n return new table_default.Table(\"substitutionTable\", [\n { name: \"substFormat\", type: \"USHORT\", value: 1 },\n { name: \"coverage\", type: \"TABLE\", value: new table_default.Coverage(subtable.coverage) },\n { name: \"deltaGlyphID\", type: \"SHORT\", value: subtable.deltaGlyphId }\n ]);\n } else if (subtable.substFormat === 2) {\n return new table_default.Table(\"substitutionTable\", [\n { name: \"substFormat\", type: \"USHORT\", value: 2 },\n { name: \"coverage\", type: \"TABLE\", value: new table_default.Coverage(subtable.coverage) }\n ].concat(table_default.ushortList(\"substitute\", subtable.substitute)));\n }\n check_default.fail(\"Lookup type 1 substFormat must be 1 or 2.\");\n };\n subtableMakers[2] = function makeLookup2(subtable) {\n check_default.assert(subtable.substFormat === 1, \"Lookup type 2 substFormat must be 1.\");\n return new table_default.Table(\"substitutionTable\", [\n { name: \"substFormat\", type: \"USHORT\", value: 1 },\n { name: \"coverage\", type: \"TABLE\", value: new table_default.Coverage(subtable.coverage) }\n ].concat(table_default.tableList(\"seqSet\", subtable.sequences, function(sequenceSet) {\n return new table_default.Table(\"sequenceSetTable\", table_default.ushortList(\"sequence\", sequenceSet));\n })));\n };\n subtableMakers[3] = function makeLookup3(subtable) {\n check_default.assert(subtable.substFormat === 1, \"Lookup type 3 substFormat must be 1.\");\n return new table_default.Table(\"substitutionTable\", [\n { name: \"substFormat\", type: \"USHORT\", value: 1 },\n { name: \"coverage\", type: \"TABLE\", value: new table_default.Coverage(subtable.coverage) }\n ].concat(table_default.tableList(\"altSet\", subtable.alternateSets, function(alternateSet) {\n return new table_default.Table(\"alternateSetTable\", table_default.ushortList(\"alternate\", alternateSet));\n })));\n };\n subtableMakers[4] = function makeLookup4(subtable) {\n check_default.assert(subtable.substFormat === 1, \"Lookup type 4 substFormat must be 1.\");\n return new table_default.Table(\"substitutionTable\", [\n { name: \"substFormat\", type: \"USHORT\", value: 1 },\n { name: \"coverage\", type: \"TABLE\", value: new table_default.Coverage(subtable.coverage) }\n ].concat(table_default.tableList(\"ligSet\", subtable.ligatureSets, function(ligatureSet) {\n return new table_default.Table(\"ligatureSetTable\", table_default.tableList(\"ligature\", ligatureSet, function(ligature) {\n return new table_default.Table(\n \"ligatureTable\",\n [{ name: \"ligGlyph\", type: \"USHORT\", value: ligature.ligGlyph }].concat(table_default.ushortList(\"component\", ligature.components, ligature.components.length + 1))\n );\n }));\n })));\n };\n subtableMakers[5] = function makeLookup5(subtable) {\n if (subtable.substFormat === 1) {\n return new table_default.Table(\"contextualSubstitutionTable\", [\n { name: \"substFormat\", type: \"USHORT\", value: subtable.substFormat },\n { name: \"coverage\", type: \"TABLE\", value: new table_default.Coverage(subtable.coverage) }\n ].concat(table_default.tableList(\"sequenceRuleSet\", subtable.ruleSets, function(sequenceRuleSet) {\n if (!sequenceRuleSet) {\n return new table_default.Table(\"NULL\", null);\n }\n return new table_default.Table(\"sequenceRuleSetTable\", table_default.tableList(\"sequenceRule\", sequenceRuleSet, function(sequenceRule) {\n let tableData = table_default.ushortList(\"seqLookup\", [], sequenceRule.lookupRecords.length).concat(table_default.ushortList(\"inputSequence\", sequenceRule.input, sequenceRule.input.length + 1));\n [tableData[0], tableData[1]] = [tableData[1], tableData[0]];\n for (let i = 0; i < sequenceRule.lookupRecords.length; i++) {\n const record = sequenceRule.lookupRecords[i];\n tableData = tableData.concat({ name: \"sequenceIndex\" + i, type: \"USHORT\", value: record.sequenceIndex }).concat({ name: \"lookupListIndex\" + i, type: \"USHORT\", value: record.lookupListIndex });\n }\n return new table_default.Table(\"sequenceRuleTable\", tableData);\n }));\n })));\n } else if (subtable.substFormat === 2) {\n return new table_default.Table(\"contextualSubstitutionTable\", [\n { name: \"substFormat\", type: \"USHORT\", value: subtable.substFormat },\n { name: \"coverage\", type: \"TABLE\", value: new table_default.Coverage(subtable.coverage) },\n { name: \"classDef\", type: \"TABLE\", value: new table_default.ClassDef(subtable.classDef) }\n ].concat(table_default.tableList(\"classSeqRuleSet\", subtable.classSets, function(classSeqRuleSet) {\n if (!classSeqRuleSet) {\n return new table_default.Table(\"NULL\", null);\n }\n return new table_default.Table(\"classSeqRuleSetTable\", table_default.tableList(\"classSeqRule\", classSeqRuleSet, function(classSeqRule) {\n let tableData = table_default.ushortList(\"classes\", classSeqRule.classes, classSeqRule.classes.length + 1).concat(table_default.ushortList(\"seqLookupCount\", [], classSeqRule.lookupRecords.length));\n for (let i = 0; i < classSeqRule.lookupRecords.length; i++) {\n const record = classSeqRule.lookupRecords[i];\n tableData = tableData.concat({ name: \"sequenceIndex\" + i, type: \"USHORT\", value: record.sequenceIndex }).concat({ name: \"lookupListIndex\" + i, type: \"USHORT\", value: record.lookupListIndex });\n }\n return new table_default.Table(\"classSeqRuleTable\", tableData);\n }));\n })));\n } else if (subtable.substFormat === 3) {\n let tableData = [\n { name: \"substFormat\", type: \"USHORT\", value: subtable.substFormat }\n ];\n tableData.push({ name: \"inputGlyphCount\", type: \"USHORT\", value: subtable.coverages.length });\n tableData.push({ name: \"substitutionCount\", type: \"USHORT\", value: subtable.lookupRecords.length });\n for (let i = 0; i < subtable.coverages.length; i++) {\n const coverage = subtable.coverages[i];\n tableData.push({ name: \"inputCoverage\" + i, type: \"TABLE\", value: new table_default.Coverage(coverage) });\n }\n for (let i = 0; i < subtable.lookupRecords.length; i++) {\n const record = subtable.lookupRecords[i];\n tableData = tableData.concat({ name: \"sequenceIndex\" + i, type: \"USHORT\", value: record.sequenceIndex }).concat({ name: \"lookupListIndex\" + i, type: \"USHORT\", value: record.lookupListIndex });\n }\n let returnTable = new table_default.Table(\"contextualSubstitutionTable\", tableData);\n return returnTable;\n }\n check_default.assert(false, \"lookup type 5 format must be 1, 2 or 3.\");\n };\n subtableMakers[6] = function makeLookup6(subtable) {\n if (subtable.substFormat === 1) {\n let returnTable = new table_default.Table(\"chainContextTable\", [\n { name: \"substFormat\", type: \"USHORT\", value: subtable.substFormat },\n { name: \"coverage\", type: \"TABLE\", value: new table_default.Coverage(subtable.coverage) }\n ].concat(table_default.tableList(\"chainRuleSet\", subtable.chainRuleSets, function(chainRuleSet) {\n return new table_default.Table(\"chainRuleSetTable\", table_default.tableList(\"chainRule\", chainRuleSet, function(chainRule) {\n let tableData = table_default.ushortList(\"backtrackGlyph\", chainRule.backtrack, chainRule.backtrack.length).concat(table_default.ushortList(\"inputGlyph\", chainRule.input, chainRule.input.length + 1)).concat(table_default.ushortList(\"lookaheadGlyph\", chainRule.lookahead, chainRule.lookahead.length)).concat(table_default.ushortList(\"substitution\", [], chainRule.lookupRecords.length));\n for (let i = 0; i < chainRule.lookupRecords.length; i++) {\n const record = chainRule.lookupRecords[i];\n tableData = tableData.concat({ name: \"sequenceIndex\" + i, type: \"USHORT\", value: record.sequenceIndex }).concat({ name: \"lookupListIndex\" + i, type: \"USHORT\", value: record.lookupListIndex });\n }\n return new table_default.Table(\"chainRuleTable\", tableData);\n }));\n })));\n return returnTable;\n } else if (subtable.substFormat === 2) {\n check_default.assert(false, \"lookup type 6 format 2 is not yet supported.\");\n } else if (subtable.substFormat === 3) {\n let tableData = [\n { name: \"substFormat\", type: \"USHORT\", value: subtable.substFormat }\n ];\n tableData.push({ name: \"backtrackGlyphCount\", type: \"USHORT\", value: subtable.backtrackCoverage.length });\n for (let i = 0; i < subtable.backtrackCoverage.length; i++) {\n const coverage = subtable.backtrackCoverage[i];\n tableData.push({ name: \"backtrackCoverage\" + i, type: \"TABLE\", value: new table_default.Coverage(coverage) });\n }\n tableData.push({ name: \"inputGlyphCount\", type: \"USHORT\", value: subtable.inputCoverage.length });\n for (let i = 0; i < subtable.inputCoverage.length; i++) {\n const coverage = subtable.inputCoverage[i];\n tableData.push({ name: \"inputCoverage\" + i, type: \"TABLE\", value: new table_default.Coverage(coverage) });\n }\n tableData.push({ name: \"lookaheadGlyphCount\", type: \"USHORT\", value: subtable.lookaheadCoverage.length });\n for (let i = 0; i < subtable.lookaheadCoverage.length; i++) {\n const coverage = subtable.lookaheadCoverage[i];\n tableData.push({ name: \"lookaheadCoverage\" + i, type: \"TABLE\", value: new table_default.Coverage(coverage) });\n }\n tableData.push({ name: \"substitutionCount\", type: \"USHORT\", value: subtable.lookupRecords.length });\n for (let i = 0; i < subtable.lookupRecords.length; i++) {\n const record = subtable.lookupRecords[i];\n tableData = tableData.concat({ name: \"sequenceIndex\" + i, type: \"USHORT\", value: record.sequenceIndex }).concat({ name: \"lookupListIndex\" + i, type: \"USHORT\", value: record.lookupListIndex });\n }\n let returnTable = new table_default.Table(\"chainContextTable\", tableData);\n return returnTable;\n }\n check_default.assert(false, \"lookup type 6 format must be 1, 2 or 3.\");\n };\n function makeGsubTable(gsub) {\n return new table_default.Table(\"GSUB\", [\n { name: \"version\", type: \"ULONG\", value: 65536 },\n { name: \"scripts\", type: \"TABLE\", value: new table_default.ScriptList(gsub.scripts) },\n { name: \"features\", type: \"TABLE\", value: new table_default.FeatureList(gsub.features) },\n { name: \"lookups\", type: \"TABLE\", value: new table_default.LookupList(gsub.lookups, subtableMakers) }\n ]);\n }\n var gsub_default = { parse: parseGsubTable, make: makeGsubTable };\n\n // src/tables/meta.mjs\n function parseMetaTable(data, start) {\n const p = new parse_default.Parser(data, start);\n const tableVersion = p.parseULong();\n check_default.argument(tableVersion === 1, \"Unsupported META table version.\");\n p.parseULong();\n p.parseULong();\n const numDataMaps = p.parseULong();\n const tags = {};\n for (let i = 0; i < numDataMaps; i++) {\n const tag = p.parseTag();\n const dataOffset = p.parseULong();\n const dataLength = p.parseULong();\n if (tag === \"appl\" || tag === \"bild\")\n continue;\n const text = decode.UTF8(data, start + dataOffset, dataLength);\n tags[tag] = text;\n }\n return tags;\n }\n function makeMetaTable(tags) {\n const numTags = Object.keys(tags).length;\n let stringPool = \"\";\n const stringPoolOffset = 16 + numTags * 12;\n const result = new table_default.Table(\"meta\", [\n { name: \"version\", type: \"ULONG\", value: 1 },\n { name: \"flags\", type: \"ULONG\", value: 0 },\n { name: \"offset\", type: \"ULONG\", value: stringPoolOffset },\n { name: \"numTags\", type: \"ULONG\", value: numTags }\n ]);\n for (let tag in tags) {\n const pos = stringPool.length;\n stringPool += tags[tag];\n result.fields.push({ name: \"tag \" + tag, type: \"TAG\", value: tag });\n result.fields.push({ name: \"offset \" + tag, type: \"ULONG\", value: stringPoolOffset + pos });\n result.fields.push({ name: \"length \" + tag, type: \"ULONG\", value: tags[tag].length });\n }\n result.fields.push({ name: \"stringPool\", type: \"CHARARRAY\", value: stringPool });\n return result;\n }\n var meta_default = { parse: parseMetaTable, make: makeMetaTable };\n\n // src/tables/colr.mjs\n function parseColrTable(data, start) {\n const p = new Parser(data, start);\n const version = p.parseUShort();\n if (version !== 0) {\n console.warn(\"Only COLRv0 is currently fully supported. A subset of color glyphs might be available in this font if provided in the v0 format.\");\n }\n const numBaseGlyphRecords = p.parseUShort();\n const baseGlyphRecordsOffset = p.parseOffset32();\n const layerRecordsOffset = p.parseOffset32();\n const numLayerRecords = p.parseUShort();\n p.relativeOffset = baseGlyphRecordsOffset;\n const baseGlyphRecords = p.parseRecordList(numBaseGlyphRecords, {\n glyphID: Parser.uShort,\n firstLayerIndex: Parser.uShort,\n numLayers: Parser.uShort\n });\n p.relativeOffset = layerRecordsOffset;\n const layerRecords = p.parseRecordList(numLayerRecords, {\n glyphID: Parser.uShort,\n paletteIndex: Parser.uShort\n });\n return {\n version,\n baseGlyphRecords,\n layerRecords\n };\n }\n function makeColrTable({ version = 0, baseGlyphRecords = [], layerRecords = [] }) {\n check_default.argument(version === 0, \"Only COLRv0 supported.\");\n const baseGlyphRecordsOffset = 14;\n const layerRecordsOffset = baseGlyphRecordsOffset + baseGlyphRecords.length * 6;\n return new table_default.Table(\"COLR\", [\n { name: \"version\", type: \"USHORT\", value: version },\n { name: \"numBaseGlyphRecords\", type: \"USHORT\", value: baseGlyphRecords.length },\n { name: \"baseGlyphRecordsOffset\", type: \"ULONG\", value: baseGlyphRecordsOffset },\n { name: \"layerRecordsOffset\", type: \"ULONG\", value: layerRecordsOffset },\n { name: \"numLayerRecords\", type: \"USHORT\", value: layerRecords.length },\n ...baseGlyphRecords.map((glyph, i) => [\n { name: \"glyphID_\" + i, type: \"USHORT\", value: glyph.glyphID },\n { name: \"firstLayerIndex_\" + i, type: \"USHORT\", value: glyph.firstLayerIndex },\n { name: \"numLayers_\" + i, type: \"USHORT\", value: glyph.numLayers }\n ]).flat(),\n ...layerRecords.map((layer, i) => [\n { name: \"LayerGlyphID_\" + i, type: \"USHORT\", value: layer.glyphID },\n { name: \"paletteIndex_\" + i, type: \"USHORT\", value: layer.paletteIndex }\n ]).flat()\n ]);\n }\n var colr_default = { parse: parseColrTable, make: makeColrTable };\n\n // src/tables/fvar.mjs\n function makeFvarAxis(n, axis) {\n return [\n { name: \"tag_\" + n, type: \"TAG\", value: axis.tag },\n { name: \"minValue_\" + n, type: \"FIXED\", value: axis.minValue << 16 },\n { name: \"defaultValue_\" + n, type: \"FIXED\", value: axis.defaultValue << 16 },\n { name: \"maxValue_\" + n, type: \"FIXED\", value: axis.maxValue << 16 },\n { name: \"flags_\" + n, type: \"USHORT\", value: 0 },\n { name: \"nameID_\" + n, type: \"USHORT\", value: axis.axisNameID }\n ];\n }\n function parseFvarAxis(data, start, names) {\n const axis = {};\n const p = new parse_default.Parser(data, start);\n axis.tag = p.parseTag();\n axis.minValue = p.parseFixed();\n axis.defaultValue = p.parseFixed();\n axis.maxValue = p.parseFixed();\n p.skip(\"uShort\", 1);\n const axisNameID = p.parseUShort();\n axis.axisNameID = axisNameID;\n axis.name = getNameByID(names, axisNameID);\n return axis;\n }\n function makeFvarInstance(n, inst, axes, optionalFields = {}) {\n const fields = [\n { name: \"nameID_\" + n, type: \"USHORT\", value: inst.subfamilyNameID },\n { name: \"flags_\" + n, type: \"USHORT\", value: 0 }\n ];\n for (let i = 0; i < axes.length; ++i) {\n const axisTag = axes[i].tag;\n fields.push({\n name: \"axis_\" + n + \" \" + axisTag,\n type: \"FIXED\",\n value: inst.coordinates[axisTag] << 16\n });\n }\n if (optionalFields && optionalFields.postScriptNameID) {\n fields.push({\n name: \"postScriptNameID_\",\n type: \"USHORT\",\n value: inst.postScriptNameID !== void 0 ? inst.postScriptNameID : 65535\n });\n }\n return fields;\n }\n function parseFvarInstance(data, start, axes, names, instanceSize) {\n const inst = {};\n const p = new parse_default.Parser(data, start);\n const subfamilyNameID = p.parseUShort();\n inst.subfamilyNameID = subfamilyNameID;\n inst.name = getNameByID(names, subfamilyNameID, [2, 17]);\n p.skip(\"uShort\", 1);\n inst.coordinates = {};\n for (let i = 0; i < axes.length; ++i) {\n inst.coordinates[axes[i].tag] = p.parseFixed();\n }\n if (p.relativeOffset === instanceSize) {\n inst.postScriptNameID = void 0;\n inst.postScriptName = void 0;\n return inst;\n }\n const postScriptNameID = p.parseUShort();\n inst.postScriptNameID = postScriptNameID == 65535 ? void 0 : postScriptNameID;\n inst.postScriptName = inst.postScriptNameID !== void 0 ? getNameByID(names, postScriptNameID, [6]) : \"\";\n return inst;\n }\n function makeFvarTable(fvar, names) {\n const result = new table_default.Table(\"fvar\", [\n { name: \"version\", type: \"ULONG\", value: 65536 },\n { name: \"offsetToData\", type: \"USHORT\", value: 0 },\n { name: \"countSizePairs\", type: \"USHORT\", value: 2 },\n { name: \"axisCount\", type: \"USHORT\", value: fvar.axes.length },\n { name: \"axisSize\", type: \"USHORT\", value: 20 },\n { name: \"instanceCount\", type: \"USHORT\", value: fvar.instances.length },\n { name: \"instanceSize\", type: \"USHORT\", value: 4 + fvar.axes.length * 4 }\n ]);\n result.offsetToData = result.sizeOf();\n for (let i = 0; i < fvar.axes.length; i++) {\n result.fields = result.fields.concat(makeFvarAxis(i, fvar.axes[i], names));\n }\n const optionalFields = {};\n for (let j = 0; j < fvar.instances.length; j++) {\n if (fvar.instances[j].postScriptNameID !== void 0) {\n result.instanceSize += 2;\n optionalFields.postScriptNameID = true;\n break;\n }\n }\n for (let j = 0; j < fvar.instances.length; j++) {\n result.fields = result.fields.concat(makeFvarInstance(\n j,\n fvar.instances[j],\n fvar.axes,\n optionalFields\n ));\n }\n return result;\n }\n function parseFvarTable(data, start, names) {\n const p = new parse_default.Parser(data, start);\n const tableVersion = p.parseULong();\n check_default.argument(tableVersion === 65536, \"Unsupported fvar table version.\");\n const offsetToData = p.parseOffset16();\n p.skip(\"uShort\", 1);\n const axisCount = p.parseUShort();\n const axisSize = p.parseUShort();\n const instanceCount = p.parseUShort();\n const instanceSize = p.parseUShort();\n const axes = [];\n for (let i = 0; i < axisCount; i++) {\n axes.push(parseFvarAxis(data, start + offsetToData + i * axisSize, names));\n }\n const instances = [];\n const instanceStart = start + offsetToData + axisCount * axisSize;\n for (let j = 0; j < instanceCount; j++) {\n instances.push(parseFvarInstance(data, instanceStart + j * instanceSize, axes, names, instanceSize));\n }\n return { axes, instances };\n }\n var fvar_default = { make: makeFvarTable, parse: parseFvarTable };\n\n // src/tables/stat.mjs\n var axisRecordStruct = {\n tag: Parser.tag,\n nameID: Parser.uShort,\n ordering: Parser.uShort\n };\n var axisValueParsers = new Array(5);\n axisValueParsers[1] = function axisValueParser1() {\n return {\n axisIndex: this.parseUShort(),\n flags: this.parseUShort(),\n valueNameID: this.parseUShort(),\n value: this.parseFixed()\n };\n };\n axisValueParsers[2] = function axisValueParser2() {\n return {\n axisIndex: this.parseUShort(),\n flags: this.parseUShort(),\n valueNameID: this.parseUShort(),\n nominalValue: this.parseFixed(),\n rangeMinValue: this.parseFixed(),\n rangeMaxValue: this.parseFixed()\n };\n };\n axisValueParsers[3] = function axisValueParser3() {\n return {\n axisIndex: this.parseUShort(),\n flags: this.parseUShort(),\n valueNameID: this.parseUShort(),\n value: this.parseFixed(),\n linkedValue: this.parseFixed()\n };\n };\n axisValueParsers[4] = function axisValueParser4() {\n const axisCount = this.parseUShort();\n return {\n flags: this.parseUShort(),\n valueNameID: this.parseUShort(),\n axisValues: this.parseList(axisCount, function() {\n return {\n axisIndex: this.parseUShort(),\n value: this.parseFixed()\n };\n })\n };\n };\n function parseSTATAxisValue() {\n const valueTableFormat = this.parseUShort();\n const axisValueParser = axisValueParsers[valueTableFormat];\n const formatStub = {\n format: valueTableFormat\n };\n if (axisValueParser === void 0) {\n console.warn(`Unknown axis value table format ${valueTableFormat}`);\n return formatStub;\n }\n return Object.assign(formatStub, this.parseStruct(axisValueParser.bind(this)));\n }\n function parseSTATTable(data, start, fvar) {\n if (!start) {\n start = 0;\n }\n const p = new parse_default.Parser(data, start);\n const tableVersionMajor = p.parseUShort();\n const tableVersionMinor = p.parseUShort();\n if (tableVersionMajor !== 1) {\n console.warn(`Unsupported STAT table version ${tableVersionMajor}.${tableVersionMinor}`);\n }\n const version = [\n tableVersionMajor,\n tableVersionMinor\n ];\n const designAxisSize = p.parseUShort();\n const designAxisCount = p.parseUShort();\n const designAxesOffset = p.parseOffset32();\n const axisValueCount = p.parseUShort();\n const offsetToAxisValueOffsets = p.parseOffset32();\n const elidedFallbackNameID = tableVersionMajor > 1 || tableVersionMinor > 0 ? p.parseUShort() : void 0;\n if (fvar !== void 0) {\n check_default.argument(designAxisCount >= fvar.axes.length, \"STAT axis count must be greater than or equal to fvar axis count\");\n }\n if (axisValueCount > 0) {\n check_default.argument(designAxisCount >= 0, \"STAT axis count must be greater than 0 if STAT axis value count is greater than 0\");\n }\n const axes = [];\n for (let i = 0; i < designAxisCount; i++) {\n p.offset = start + designAxesOffset;\n p.relativeOffset = i * designAxisSize;\n axes.push(p.parseStruct(axisRecordStruct));\n }\n p.offset = start;\n p.relativeOffset = offsetToAxisValueOffsets;\n const valueOffsets = p.parseUShortList(axisValueCount);\n const values = [];\n for (let i = 0; i < axisValueCount; i++) {\n p.offset = start + offsetToAxisValueOffsets;\n p.relativeOffset = valueOffsets[i];\n values.push(parseSTATAxisValue.apply(p));\n }\n return {\n version,\n axes,\n values,\n elidedFallbackNameID\n };\n }\n var axisValueMakers = new Array(5);\n axisValueMakers[1] = function axisValueMaker1(n, table) {\n return [\n { name: `format${n}`, type: \"USHORT\", value: 1 },\n { name: `axisIndex${n}`, type: \"USHORT\", value: table.axisIndex },\n { name: `flags${n}`, type: \"USHORT\", value: table.flags },\n { name: `valueNameID${n}`, type: \"USHORT\", value: table.valueNameID },\n { name: `value${n}`, type: \"FLOAT\", value: table.value }\n ];\n };\n axisValueMakers[2] = function axisValueMaker2(n, table) {\n return [\n { name: `format${n}`, type: \"USHORT\", value: 2 },\n { name: `axisIndex${n}`, type: \"USHORT\", value: table.axisIndex },\n { name: `flags${n}`, type: \"USHORT\", value: table.flags },\n { name: `valueNameID${n}`, type: \"USHORT\", value: table.valueNameID },\n { name: `nominalValue${n}`, type: \"FLOAT\", value: table.nominalValue },\n { name: `rangeMinValue${n}`, type: \"FLOAT\", value: table.rangeMinValue },\n { name: `rangeMaxValue${n}`, type: \"FLOAT\", value: table.rangeMaxValue }\n ];\n };\n axisValueMakers[3] = function axisValueMaker3(n, table) {\n return [\n { name: `format${n}`, type: \"USHORT\", value: 3 },\n { name: `axisIndex${n}`, type: \"USHORT\", value: table.axisIndex },\n { name: `flags${n}`, type: \"USHORT\", value: table.flags },\n { name: `valueNameID${n}`, type: \"USHORT\", value: table.valueNameID },\n { name: `value${n}`, type: \"FLOAT\", value: table.value },\n { name: `linkedValue${n}`, type: \"FLOAT\", value: table.linkedValue }\n ];\n };\n axisValueMakers[4] = function axisValueMaker4(n, table) {\n let returnFields = [\n { name: `format${n}`, type: \"USHORT\", value: 4 },\n { name: `axisCount${n}`, type: \"USHORT\", value: table.axisValues.length },\n { name: `flags${n}`, type: \"USHORT\", value: table.flags },\n { name: `valueNameID${n}`, type: \"USHORT\", value: table.valueNameID }\n ];\n for (let i = 0; i < table.axisValues.length; i++) {\n returnFields = returnFields.concat([\n { name: `format${n}axisIndex${i}`, type: \"USHORT\", value: table.axisValues[i].axisIndex },\n { name: `format${n}value${i}`, type: \"FLOAT\", value: table.axisValues[i].value }\n ]);\n }\n return returnFields;\n };\n function makeSTATAxisRecord(n, axis) {\n return new table_default.Record(\"axisRecord_\" + n, [\n { name: \"axisTag_\" + n, type: \"TAG\", value: axis.tag },\n { name: \"axisNameID_\" + n, type: \"USHORT\", value: axis.nameID },\n { name: \"axisOrdering_\" + n, type: \"USHORT\", value: axis.ordering }\n ]);\n }\n function makeSTATValueTable(n, tableData) {\n const valueTableFormat = tableData.format;\n const axisValueMaker = axisValueMakers[valueTableFormat];\n check_default.argument(axisValueMaker !== void 0, `Unknown axis value table format ${valueTableFormat}`);\n const fields = axisValueMaker(n, tableData);\n return new table_default.Table(\"axisValueTable_\" + n, fields);\n }\n function makeSTATTable(STAT) {\n const result = new table_default.Table(\"STAT\", [\n { name: \"majorVersion\", type: \"USHORT\", value: 1 },\n { name: \"minorVersion\", type: \"USHORT\", value: 2 },\n { name: \"designAxisSize\", type: \"USHORT\", value: 8 },\n { name: \"designAxisCount\", type: \"USHORT\", value: STAT.axes.length },\n { name: \"designAxesOffset\", type: \"ULONG\", value: 0 },\n { name: \"axisValueCount\", type: \"USHORT\", value: STAT.values.length },\n { name: \"offsetToAxisValueOffsets\", type: \"ULONG\", value: 0 },\n { name: \"elidedFallbackNameID\", type: \"USHORT\", value: STAT.elidedFallbackNameID }\n ]);\n result.designAxesOffset = result.offsetToAxisValueOffsets = result.sizeOf();\n for (let i = 0; i < STAT.axes.length; i++) {\n const axisRecord = makeSTATAxisRecord(i, STAT.axes[i]);\n result.offsetToAxisValueOffsets += axisRecord.sizeOf();\n result.fields = result.fields.concat(axisRecord.fields);\n }\n const axisValueOffsets = [];\n let axisValueTables = [];\n let axisValueTableOffset = STAT.values.length * 2;\n for (let j = 0; j < STAT.values.length; j++) {\n const axisValueTable = makeSTATValueTable(j, STAT.values[j]);\n axisValueOffsets.push({\n name: \"offset_\" + j,\n type: \"USHORT\",\n value: axisValueTableOffset\n });\n axisValueTableOffset += axisValueTable.sizeOf();\n axisValueTables = axisValueTables.concat(axisValueTable.fields);\n }\n result.fields = result.fields.concat(axisValueOffsets);\n result.fields = result.fields.concat(axisValueTables);\n return result;\n }\n var stat_default = { make: makeSTATTable, parse: parseSTATTable };\n\n // src/tables/avar.mjs\n function makeAvarAxisValueMap(n, axisValueMap) {\n return new table_default.Record(\"axisValueMap_\" + n, [\n { name: \"fromCoordinate_\" + n, type: \"F2DOT14\", value: axisValueMap.fromCoordinate },\n { name: \"toCoordinate_\" + n, type: \"F2DOT14\", value: axisValueMap.toCoordinate }\n ]);\n }\n function makeAvarSegmentMap(n, axis) {\n const returnTable = new table_default.Record(\"segmentMap_\" + n, [\n { name: \"positionMapCount_\" + n, type: \"USHORT\", value: axis.axisValueMaps.length }\n ]);\n let axisValueMaps = [];\n for (let i = 0; i < axis.axisValueMaps.length; i++) {\n const valueMap = makeAvarAxisValueMap(`${n}_${i}`, axis.axisValueMaps[i]);\n axisValueMaps = axisValueMaps.concat(valueMap.fields);\n }\n returnTable.fields = returnTable.fields.concat(axisValueMaps);\n return returnTable;\n }\n function makeAvarTable(avar, fvar) {\n check_default.argument(avar.axisSegmentMaps.length === fvar.axes.length, \"avar axis count must correspond to fvar axis count\");\n const result = new table_default.Table(\"avar\", [\n { name: \"majorVersion\", type: \"USHORT\", value: 1 },\n { name: \"minorVersion\", type: \"USHORT\", value: 0 },\n { name: \"reserved\", type: \"USHORT\", value: 0 },\n { name: \"axisCount\", type: \"USHORT\", value: avar.axisSegmentMaps.length }\n ]);\n for (let i = 0; i < avar.axisSegmentMaps.length; i++) {\n const axisRecord = makeAvarSegmentMap(i, avar.axisSegmentMaps[i]);\n result.fields = result.fields.concat(axisRecord.fields);\n }\n return result;\n }\n function parseAvarTable(data, start, fvar) {\n if (!start) {\n start = 0;\n }\n const p = new Parser(data, start);\n const tableVersionMajor = p.parseUShort();\n const tableVersionMinor = p.parseUShort();\n if (tableVersionMajor !== 1) {\n console.warn(`Unsupported avar table version ${tableVersionMajor}.${tableVersionMinor}`);\n }\n p.skip(\"uShort\", 1);\n const axisCount = p.parseUShort();\n check_default.argument(axisCount === fvar.axes.length, \"avar axis count must correspond to fvar axis count\");\n const axisSegmentMaps = [];\n for (let i = 0; i < axisCount; i++) {\n const axisValueMaps = [];\n const positionMapCount = p.parseUShort();\n for (let j = 0; j < positionMapCount; j++) {\n const fromCoordinate = p.parseF2Dot14();\n const toCoordinate = p.parseF2Dot14();\n axisValueMaps.push({\n fromCoordinate,\n toCoordinate\n });\n }\n axisSegmentMaps.push({\n axisValueMaps\n });\n }\n return {\n version: [tableVersionMajor, tableVersionMinor],\n axisSegmentMaps\n };\n }\n var avar_default = { make: makeAvarTable, parse: parseAvarTable };\n\n // src/tables/cvar.mjs\n function parseCvarTable(data, start, fvar, cvt) {\n const p = new parse_default.Parser(data, start);\n const cvtVariations = p.parseTupleVariationStore(\n p.relativeOffset,\n fvar.axes.length,\n \"cvar\",\n cvt\n );\n const tableVersionMajor = p.parseUShort();\n const tableVersionMinor = p.parseUShort();\n if (tableVersionMajor !== 1) {\n console.warn(`Unsupported cvar table version ${tableVersionMajor}.${tableVersionMinor}`);\n }\n return {\n version: [tableVersionMajor, tableVersionMinor],\n ...cvtVariations\n };\n }\n function makeCvarTable() {\n console.warn(\"Writing of cvar tables is not yet supported.\");\n }\n var cvar_default = { make: makeCvarTable, parse: parseCvarTable };\n\n // src/tables/gvar.mjs\n function parseGvarTable(data, start, fvar, glyphs) {\n const p = new parse_default.Parser(data, start);\n const tableVersionMajor = p.parseUShort();\n const tableVersionMinor = p.parseUShort();\n if (tableVersionMajor !== 1) {\n console.warn(`Unsupported gvar table version ${tableVersionMajor}.${tableVersionMinor}`);\n }\n const axisCount = p.parseUShort();\n if (axisCount !== fvar.axes.length) {\n console.warn(`axisCount ${axisCount} in gvar table does not match the number of axes ${fvar.axes.length} in the fvar table!`);\n }\n const sharedTupleCount = p.parseUShort();\n const sharedTuples = p.parsePointer32(function() {\n return this.parseTupleRecords(sharedTupleCount, axisCount);\n });\n const glyphVariations = p.parseTupleVariationStoreList(axisCount, \"gvar\", glyphs);\n return {\n version: [tableVersionMajor, tableVersionMinor],\n sharedTuples,\n glyphVariations\n };\n }\n function makeGvarTable() {\n console.warn(\"Writing of gvar tables is not yet supported.\");\n }\n var gvar_default = { make: makeGvarTable, parse: parseGvarTable };\n\n // src/tables/gasp.mjs\n function parseGaspTable(data, start) {\n const gasp = {};\n const p = new parse_default.Parser(data, start);\n gasp.version = p.parseUShort();\n check_default.argument(gasp.version <= 1, \"Unsupported gasp table version.\");\n gasp.numRanges = p.parseUShort();\n gasp.gaspRanges = [];\n for (let i = 0; i < gasp.numRanges; i++) {\n gasp.gaspRanges[i] = {\n rangeMaxPPEM: p.parseUShort(),\n rangeGaspBehavior: p.parseUShort()\n };\n }\n return gasp;\n }\n function makeGaspTable(gasp) {\n const result = new table_default.Table(\"gasp\", [\n { name: \"version\", type: \"USHORT\", value: 1 },\n { name: \"numRanges\", type: \"USHORT\", value: gasp.numRanges }\n ]);\n for (let i in gasp.gaspRanges) {\n result.fields.push({ name: \"rangeMaxPPEM\", type: \"USHORT\", value: gasp.gaspRanges[i].rangeMaxPPEM });\n result.fields.push({ name: \"rangeGaspBehavior\", type: \"USHORT\", value: gasp.gaspRanges[i].rangeGaspBehavior });\n }\n return result;\n }\n var gasp_default = { parse: parseGaspTable, make: makeGaspTable };\n\n // src/tables/svg.mjs\n function parseSvgTable(data, offset) {\n const svgTable = /* @__PURE__ */ new Map();\n const buf = data.buffer;\n const p = new Parser(data, offset);\n const version = p.parseUShort();\n if (version !== 0) return svgTable;\n p.relativeOffset = p.parseOffset32();\n const svgDocumentListOffset = data.byteOffset + offset + p.relativeOffset;\n const numEntries = p.parseUShort();\n const svgDocMap = /* @__PURE__ */ new Map();\n for (let i = 0; i < numEntries; i++) {\n const startGlyphID = p.parseUShort();\n const endGlyphID = p.parseUShort();\n const svgDocOffset = svgDocumentListOffset + p.parseOffset32();\n const svgDocLength = p.parseULong();\n let svgDoc = svgDocMap.get(svgDocOffset);\n if (svgDoc === void 0) {\n svgDoc = new Uint8Array(buf, svgDocOffset, svgDocLength);\n svgDocMap.set(svgDocOffset, svgDoc);\n }\n for (let i2 = startGlyphID; i2 <= endGlyphID; i2++) {\n svgTable.set(i2, svgDoc);\n }\n }\n return svgTable;\n }\n function makeSvgTable(svgTable) {\n const glyphIds = Array.from(svgTable.keys()).sort();\n const documentRecords = [];\n const documentBuffers = [];\n const documentOffsets = /* @__PURE__ */ new Map();\n let nextSvgDocOffset = 0;\n let record = { endGlyphID: null };\n for (let i = 0, l = glyphIds.length; i < l; i++) {\n const glyphId = glyphIds[i];\n const svgDoc = svgTable.get(glyphId);\n let svgDocOffset = documentOffsets.get(svgDoc);\n if (svgDocOffset === void 0) {\n svgDocOffset = nextSvgDocOffset;\n documentBuffers.push(svgDoc);\n documentOffsets.set(svgDoc, svgDocOffset);\n nextSvgDocOffset += svgDoc.byteLength;\n }\n if (glyphId - 1 === record.endGlyphID && svgDocOffset === record.svgDocOffset) {\n record.endGlyphID = glyphId;\n } else {\n record = {\n startGlyphID: glyphId,\n endGlyphID: glyphId,\n svgDocOffset,\n svgDocLength: svgDoc.byteLength\n };\n documentRecords.push(record);\n }\n }\n const numEntries = documentRecords.length;\n const numDocuments = documentBuffers.length;\n const documentsOffset = 2 + numEntries * (2 + 2 + 4 + 4);\n const fields = new Array(3 + 1 + numEntries * 4 + numDocuments);\n let fieldIndex = 0;\n fields[fieldIndex++] = { name: \"version\", type: \"USHORT\", value: 0 };\n fields[fieldIndex++] = { name: \"svgDocumentListOffset\", type: \"ULONG\", value: 2 + 4 + 4 };\n fields[fieldIndex++] = { name: \"reserved\", type: \"ULONG\", value: 0 };\n fields[fieldIndex++] = { name: \"numEntries\", type: \"USHORT\", value: numEntries };\n for (let i = 0; i < numEntries; i++) {\n const namePrefix = \"documentRecord_\" + i;\n const { startGlyphID, endGlyphID, svgDocOffset, svgDocLength } = documentRecords[i];\n fields[fieldIndex++] = { name: namePrefix + \"_startGlyphID\", type: \"USHORT\", value: startGlyphID };\n fields[fieldIndex++] = { name: namePrefix + \"_endGlyphID\", type: \"USHORT\", value: endGlyphID };\n fields[fieldIndex++] = { name: namePrefix + \"_svgDocOffset\", type: \"ULONG\", value: documentsOffset + svgDocOffset };\n fields[fieldIndex++] = { name: namePrefix + \"_svgDocLength\", type: \"ULONG\", value: svgDocLength };\n }\n for (let i = 0; i < numDocuments; i++) {\n fields[fieldIndex++] = { name: \"svgDoc_\" + i, type: \"LITERAL\", value: documentBuffers[i] };\n }\n return new table_default.Table(\"SVG \", fields);\n }\n var svg_default = {\n make: makeSvgTable,\n parse: parseSvgTable\n };\n\n // src/tables/sfnt.mjs\n function log2(v) {\n return Math.log(v) / Math.log(2) | 0;\n }\n function computeCheckSum(bytes) {\n while (bytes.length % 4 !== 0) {\n bytes.push(0);\n }\n let sum = 0;\n for (let i = 0; i < bytes.length; i += 4) {\n sum += (bytes[i] << 24) + (bytes[i + 1] << 16) + (bytes[i + 2] << 8) + bytes[i + 3];\n }\n sum %= Math.pow(2, 32);\n return sum;\n }\n function makeTableRecord(tag, checkSum, offset, length) {\n return new table_default.Record(\"Table Record\", [\n { name: \"tag\", type: \"TAG\", value: tag !== void 0 ? tag : \"\" },\n { name: \"checkSum\", type: \"ULONG\", value: checkSum !== void 0 ? checkSum : 0 },\n { name: \"offset\", type: \"ULONG\", value: offset !== void 0 ? offset : 0 },\n { name: \"length\", type: \"ULONG\", value: length !== void 0 ? length : 0 }\n ]);\n }\n function makeSfntTable(tables) {\n const sfnt = new table_default.Table(\"sfnt\", [\n { name: \"version\", type: \"TAG\", value: \"OTTO\" },\n { name: \"numTables\", type: \"USHORT\", value: 0 },\n { name: \"searchRange\", type: \"USHORT\", value: 0 },\n { name: \"entrySelector\", type: \"USHORT\", value: 0 },\n { name: \"rangeShift\", type: \"USHORT\", value: 0 }\n ]);\n sfnt.tables = tables;\n sfnt.numTables = tables.length;\n const highestPowerOf2 = Math.pow(2, log2(sfnt.numTables));\n sfnt.searchRange = 16 * highestPowerOf2;\n sfnt.entrySelector = log2(highestPowerOf2);\n sfnt.rangeShift = sfnt.numTables * 16 - sfnt.searchRange;\n const recordFields = [];\n const tableFields = [];\n let offset = sfnt.sizeOf() + makeTableRecord().sizeOf() * sfnt.numTables;\n while (offset % 4 !== 0) {\n offset += 1;\n tableFields.push({ name: \"padding\", type: \"BYTE\", value: 0 });\n }\n for (let i = 0; i < tables.length; i += 1) {\n const t = tables[i];\n check_default.argument(t.tableName.length === 4, \"Table name\" + t.tableName + \" is invalid.\");\n const tableLength = t.sizeOf();\n const tableRecord = makeTableRecord(t.tableName, computeCheckSum(t.encode()), offset, tableLength);\n recordFields.push({ name: tableRecord.tag + \" Table Record\", type: \"RECORD\", value: tableRecord });\n tableFields.push({ name: t.tableName + \" table\", type: \"RECORD\", value: t });\n offset += tableLength;\n check_default.argument(!isNaN(offset), \"Something went wrong calculating the offset.\");\n while (offset % 4 !== 0) {\n offset += 1;\n tableFields.push({ name: \"padding\", type: \"BYTE\", value: 0 });\n }\n }\n recordFields.sort(function(r1, r2) {\n if (r1.value.tag > r2.value.tag) {\n return 1;\n } else {\n return -1;\n }\n });\n sfnt.fields = sfnt.fields.concat(recordFields);\n sfnt.fields = sfnt.fields.concat(tableFields);\n return sfnt;\n }\n function metricsForChar(font, chars, notFoundMetrics) {\n for (let i = 0; i < chars.length; i += 1) {\n const glyphIndex = font.charToGlyphIndex(chars[i]);\n if (glyphIndex > 0) {\n const glyph = font.glyphs.get(glyphIndex);\n return glyph.getMetrics();\n }\n }\n return notFoundMetrics;\n }\n function average(vs) {\n let sum = 0;\n for (let i = 0; i < vs.length; i += 1) {\n sum += vs[i];\n }\n return sum / vs.length;\n }\n function fontToSfntTable(font) {\n const xMins = [];\n const yMins = [];\n const xMaxs = [];\n const yMaxs = [];\n const advanceWidths = [];\n const leftSideBearings = [];\n const rightSideBearings = [];\n let firstCharIndex;\n let lastCharIndex = 0;\n let ulUnicodeRange1 = 0;\n let ulUnicodeRange2 = 0;\n let ulUnicodeRange3 = 0;\n let ulUnicodeRange4 = 0;\n for (let i = 0; i < font.glyphs.length; i += 1) {\n const glyph = font.glyphs.get(i);\n const unicode = glyph.unicode | 0;\n if (isNaN(glyph.advanceWidth)) {\n throw new Error(\"Glyph \" + glyph.name + \" (\" + i + \"): advanceWidth is not a number.\");\n }\n if (firstCharIndex > unicode || firstCharIndex === void 0) {\n if (unicode > 0) {\n firstCharIndex = unicode;\n }\n }\n if (lastCharIndex < unicode) {\n lastCharIndex = unicode;\n }\n const position = os2_default.getUnicodeRange(unicode);\n if (position < 32) {\n ulUnicodeRange1 |= 1 << position;\n } else if (position < 64) {\n ulUnicodeRange2 |= 1 << position - 32;\n } else if (position < 96) {\n ulUnicodeRange3 |= 1 << position - 64;\n } else if (position < 123) {\n ulUnicodeRange4 |= 1 << position - 96;\n } else {\n throw new Error(\"Unicode ranges bits > 123 are reserved for internal usage\");\n }\n if (glyph.name === \".notdef\") continue;\n const metrics = glyph.getMetrics();\n xMins.push(metrics.xMin);\n yMins.push(metrics.yMin);\n xMaxs.push(metrics.xMax);\n yMaxs.push(metrics.yMax);\n leftSideBearings.push(metrics.leftSideBearing);\n rightSideBearings.push(metrics.rightSideBearing);\n advanceWidths.push(glyph.advanceWidth);\n }\n const globals = {\n xMin: Math.min.apply(null, xMins),\n yMin: Math.min.apply(null, yMins),\n xMax: Math.max.apply(null, xMaxs),\n yMax: Math.max.apply(null, yMaxs),\n advanceWidthMax: Math.max.apply(null, advanceWidths),\n advanceWidthAvg: average(advanceWidths),\n minLeftSideBearing: Math.min.apply(null, leftSideBearings),\n maxLeftSideBearing: Math.max.apply(null, leftSideBearings),\n minRightSideBearing: Math.min.apply(null, rightSideBearings)\n };\n globals.ascender = font.ascender;\n globals.descender = font.descender;\n let macStyle = 0;\n if (font.weightClass >= 600) {\n macStyle |= font.macStyleValues.BOLD;\n }\n if (font.italicAngle < 0) {\n macStyle |= font.macStyleValues.ITALIC;\n }\n const headTable = head_default.make({\n flags: 3,\n // 00000011 (baseline for font at y=0; left sidebearing point at x=0)\n unitsPerEm: font.unitsPerEm,\n xMin: globals.xMin,\n yMin: globals.yMin,\n xMax: globals.xMax,\n yMax: globals.yMax,\n lowestRecPPEM: 3,\n macStyle,\n createdTimestamp: font.createdTimestamp\n });\n const hheaTable = hhea_default.make({\n ascender: globals.ascender,\n descender: globals.descender,\n advanceWidthMax: globals.advanceWidthMax,\n minLeftSideBearing: globals.minLeftSideBearing,\n minRightSideBearing: globals.minRightSideBearing,\n xMaxExtent: globals.maxLeftSideBearing + (globals.xMax - globals.xMin),\n numberOfHMetrics: font.glyphs.length\n });\n const maxpTable = maxp_default.make(font.glyphs.length);\n const os2Table = os2_default.make(Object.assign({\n xAvgCharWidth: Math.round(globals.advanceWidthAvg),\n usFirstCharIndex: firstCharIndex,\n usLastCharIndex: lastCharIndex,\n ulUnicodeRange1,\n ulUnicodeRange2,\n ulUnicodeRange3,\n ulUnicodeRange4,\n // See http://typophile.com/node/13081 for more info on vertical metrics.\n // We get metrics for typical characters (such as \"x\" for xHeight).\n // We provide some fallback characters if characters are unavailable: their\n // ordering was chosen experimentally.\n sTypoAscender: globals.ascender,\n sTypoDescender: globals.descender,\n sTypoLineGap: 0,\n usWinAscent: globals.yMax,\n usWinDescent: Math.abs(globals.yMin),\n ulCodePageRange1: 1,\n // FIXME: hard-code Latin 1 support for now\n sxHeight: metricsForChar(font, \"xyvw\", { yMax: Math.round(globals.ascender / 2) }).yMax,\n sCapHeight: metricsForChar(font, \"HIKLEFJMNTZBDPRAGOQSUVWXY\", globals).yMax,\n usDefaultChar: font.hasChar(\" \") ? 32 : 0,\n // Use space as the default character, if available.\n usBreakChar: font.hasChar(\" \") ? 32 : 0\n // Use space as the break character, if available.\n }, font.tables.os2));\n const hmtxTable = hmtx_default.make(font.glyphs);\n const cmapTable = cmap_default.make(font.glyphs);\n const englishFamilyName = font.getEnglishName(\"fontFamily\");\n const englishStyleName = font.getEnglishName(\"fontSubfamily\");\n const englishFullName = englishFamilyName + \" \" + englishStyleName;\n let postScriptName = font.getEnglishName(\"postScriptName\");\n if (!postScriptName) {\n postScriptName = englishFamilyName.replace(/\\s/g, \"\") + \"-\" + englishStyleName;\n }\n const names = {};\n for (let n in font.names) {\n names[n] = font.names[n];\n }\n names.unicode = names.unicode || {};\n names.macintosh = names.macintosh || {};\n names.windows = names.windows || {};\n const fontNamesUnicode = font.names.unicode || {};\n const fontNamesMacintosh = font.names.macintosh || {};\n const fontNamesWindows = font.names.windows || {};\n for (const platform in names) {\n names[platform] = names[platform] || {};\n if (!names[platform].uniqueID) {\n const manufacturer = font.getEnglishName(\"manufacturer\") || \"\";\n names[platform].uniqueID = { en: `${manufacturer}: ${englishFullName}` };\n }\n if (!names[platform].postScriptName) {\n names[platform].postScriptName = { en: postScriptName };\n }\n }\n if (!names.unicode.preferredFamily) {\n names.unicode.preferredFamily = fontNamesUnicode.fontFamily || fontNamesMacintosh.fontFamily || fontNamesWindows.fontFamily;\n }\n if (!names.macintosh.preferredFamily) {\n names.macintosh.preferredFamily = fontNamesMacintosh.fontFamily || fontNamesUnicode.fontFamily || fontNamesWindows.fontFamily;\n }\n if (!names.windows.preferredFamily) {\n names.windows.preferredFamily = fontNamesWindows.fontFamily || fontNamesUnicode.fontFamily || fontNamesMacintosh.fontFamily;\n }\n if (!names.unicode.preferredSubfamily) {\n names.unicode.preferredSubfamily = fontNamesUnicode.fontSubfamily || fontNamesMacintosh.fontSubfamily || fontNamesWindows.fontSubfamily;\n }\n if (!names.macintosh.preferredSubfamily) {\n names.macintosh.preferredSubfamily = fontNamesMacintosh.fontSubfamily || fontNamesUnicode.fontSubfamily || fontNamesWindows.fontSubfamily;\n }\n if (!names.windows.preferredSubfamily) {\n names.windows.preferredSubfamily = fontNamesWindows.fontSubfamily || fontNamesUnicode.fontSubfamily || fontNamesMacintosh.fontSubfamily;\n }\n const languageTags = [];\n const nameTable = name_default.make(names, languageTags);\n const ltagTable = languageTags.length > 0 ? ltag_default.make(languageTags) : void 0;\n const postTable = post_default.make(font);\n const cffTable = cff_default.make(font.glyphs, {\n version: font.getEnglishName(\"version\"),\n fullName: englishFullName,\n familyName: englishFamilyName,\n weightName: englishStyleName,\n postScriptName,\n unitsPerEm: font.unitsPerEm,\n fontBBox: [0, globals.yMin, globals.ascender, globals.advanceWidthMax],\n topDict: font.tables.cff && font.tables.cff.topDict || {}\n });\n const metaTable = font.metas && Object.keys(font.metas).length > 0 ? meta_default.make(font.metas) : void 0;\n const tables = [headTable, hheaTable, maxpTable, os2Table, nameTable, cmapTable, postTable, cffTable, hmtxTable];\n if (ltagTable) {\n tables.push(ltagTable);\n }\n const optionalTables = {\n gsub: gsub_default,\n cpal: cpal_default,\n colr: colr_default,\n stat: stat_default,\n avar: avar_default,\n cvar: cvar_default,\n fvar: fvar_default,\n gvar: gvar_default,\n gasp: gasp_default,\n svg: svg_default\n };\n const optionalTableArgs = {\n avar: [font.tables.fvar],\n fvar: [font.names]\n };\n for (let tableName in optionalTables) {\n const table = font.tables[tableName];\n if (table) {\n const tableData = optionalTables[tableName].make.call(font, table, ...optionalTableArgs[tableName] || []);\n if (tableData) {\n tables.push(tableData);\n }\n }\n }\n if (metaTable) {\n tables.push(metaTable);\n }\n const sfntTable = makeSfntTable(tables);\n const bytes = sfntTable.encode();\n const checkSum = computeCheckSum(bytes);\n const tableFields = sfntTable.fields;\n let checkSumAdjusted = false;\n for (let i = 0; i < tableFields.length; i += 1) {\n if (tableFields[i].name === \"head table\") {\n tableFields[i].value.checkSumAdjustment = 2981146554 - checkSum;\n checkSumAdjusted = true;\n break;\n }\n }\n if (!checkSumAdjusted) {\n throw new Error(\"Could not find head table with checkSum to adjust.\");\n }\n return sfntTable;\n }\n var sfnt_default = { make: makeSfntTable, fontToTable: fontToSfntTable, computeCheckSum };\n\n // src/layout.mjs\n function searchTag(arr, tag) {\n let imin = 0;\n let imax = arr.length - 1;\n while (imin <= imax) {\n const imid = imin + imax >>> 1;\n const val = arr[imid].tag;\n if (val === tag) {\n return imid;\n } else if (val < tag) {\n imin = imid + 1;\n } else {\n imax = imid - 1;\n }\n }\n return -imin - 1;\n }\n function binSearch(arr, value) {\n let imin = 0;\n let imax = arr.length - 1;\n while (imin <= imax) {\n const imid = imin + imax >>> 1;\n const val = arr[imid];\n if (val === value) {\n return imid;\n } else if (val < value) {\n imin = imid + 1;\n } else {\n imax = imid - 1;\n }\n }\n return -imin - 1;\n }\n function searchRange(ranges, value) {\n let range;\n let imin = 0;\n let imax = ranges.length - 1;\n while (imin <= imax) {\n const imid = imin + imax >>> 1;\n range = ranges[imid];\n const start = range.start;\n if (start === value) {\n return range;\n } else if (start < value) {\n imin = imid + 1;\n } else {\n imax = imid - 1;\n }\n }\n if (imin > 0) {\n range = ranges[imin - 1];\n if (value > range.end) return 0;\n return range;\n }\n }\n function Layout(font, tableName) {\n this.font = font;\n this.tableName = tableName;\n }\n Layout.prototype = {\n /**\n * Binary search an object by \"tag\" property\n * @instance\n * @function searchTag\n * @memberof opentype.Layout\n * @param {Array} arr\n * @param {string} tag\n * @return {number}\n */\n searchTag,\n /**\n * Binary search in a list of numbers\n * @instance\n * @function binSearch\n * @memberof opentype.Layout\n * @param {Array} arr\n * @param {number} value\n * @return {number}\n */\n binSearch,\n /**\n * Get or create the Layout table (GSUB, GPOS etc).\n * @param {boolean} create - Whether to create a new one.\n * @return {Object} The GSUB or GPOS table.\n */\n getTable: function(create) {\n let layout = this.font.tables[this.tableName];\n if (!layout && create) {\n layout = this.font.tables[this.tableName] = this.createDefaultTable();\n }\n return layout;\n },\n /**\n * Returns all scripts in the substitution table.\n * @instance\n * @return {Array}\n */\n getScriptNames: function() {\n let layout = this.getTable();\n if (!layout) {\n return [];\n }\n return layout.scripts.map(function(script) {\n return script.tag;\n });\n },\n /**\n * Returns the best bet for a script name.\n * Returns 'DFLT' if it exists.\n * If not, returns 'latn' if it exists.\n * If neither exist, returns undefined.\n */\n getDefaultScriptName: function() {\n let layout = this.getTable();\n if (!layout) {\n return;\n }\n let hasLatn = false;\n for (let i = 0; i < layout.scripts.length; i++) {\n const name = layout.scripts[i].tag;\n if (name === \"DFLT\") return name;\n if (name === \"latn\") hasLatn = true;\n }\n if (hasLatn) return \"latn\";\n },\n /**\n * Returns all LangSysRecords in the given script.\n * @instance\n * @param {string} [script='DFLT']\n * @param {boolean} create - forces the creation of this script table if it doesn't exist.\n * @return {Object} An object with tag and script properties.\n */\n getScriptTable: function(script, create) {\n const layout = this.getTable(create);\n if (layout) {\n script = script || \"DFLT\";\n const scripts = layout.scripts;\n const pos = searchTag(layout.scripts, script);\n if (pos >= 0) {\n return scripts[pos].script;\n } else if (create) {\n const scr = {\n tag: script,\n script: {\n defaultLangSys: { reserved: 0, reqFeatureIndex: 65535, featureIndexes: [] },\n langSysRecords: []\n }\n };\n scripts.splice(-1 - pos, 0, scr);\n return scr.script;\n }\n }\n },\n /**\n * Returns a language system table\n * @instance\n * @param {string} [script='DFLT']\n * @param {string} [language='dlft']\n * @param {boolean} create - forces the creation of this langSysTable if it doesn't exist.\n * @return {Object}\n */\n getLangSysTable: function(script, language, create) {\n const scriptTable = this.getScriptTable(script, create);\n if (scriptTable) {\n if (!language || language === \"dflt\" || language === \"DFLT\") {\n return scriptTable.defaultLangSys;\n }\n const pos = searchTag(scriptTable.langSysRecords, language);\n if (pos >= 0) {\n return scriptTable.langSysRecords[pos].langSys;\n } else if (create) {\n const langSysRecord = {\n tag: language,\n langSys: { reserved: 0, reqFeatureIndex: 65535, featureIndexes: [] }\n };\n scriptTable.langSysRecords.splice(-1 - pos, 0, langSysRecord);\n return langSysRecord.langSys;\n }\n }\n },\n /**\n * Get a specific feature table.\n * @instance\n * @param {string} [script='DFLT']\n * @param {string} [language='dlft']\n * @param {string} feature - One of the codes listed at https://www.microsoft.com/typography/OTSPEC/featurelist.htm\n * @param {boolean} create - forces the creation of the feature table if it doesn't exist.\n * @return {Object}\n */\n getFeatureTable: function(script, language, feature, create) {\n const langSysTable2 = this.getLangSysTable(script, language, create);\n if (langSysTable2) {\n let featureRecord;\n const featIndexes = langSysTable2.featureIndexes;\n const allFeatures = this.font.tables[this.tableName].features;\n for (let i = 0; i < featIndexes.length; i++) {\n featureRecord = allFeatures[featIndexes[i]];\n if (featureRecord.tag === feature) {\n return featureRecord.feature;\n }\n }\n if (create) {\n const index = allFeatures.length;\n check_default.assert(index === 0 || feature >= allFeatures[index - 1].tag, \"Features must be added in alphabetical order.\");\n featureRecord = {\n tag: feature,\n feature: { params: 0, lookupListIndexes: [] }\n };\n allFeatures.push(featureRecord);\n featIndexes.push(index);\n return featureRecord.feature;\n }\n }\n },\n /**\n * Get the lookup tables of a given type for a script/language/feature.\n * @instance\n * @param {string} [script='DFLT']\n * @param {string} [language='dlft']\n * @param {string} feature - 4-letter feature code\n * @param {number} lookupType - 1 to 9\n * @param {boolean} create - forces the creation of the lookup table if it doesn't exist, with no subtables.\n * @return {Object[]}\n */\n getLookupTables: function(script, language, feature, lookupType, create) {\n const featureTable = this.getFeatureTable(script, language, feature, create);\n const tables = [];\n if (featureTable) {\n let lookupTable;\n const lookupListIndexes = featureTable.lookupListIndexes;\n const allLookups = this.font.tables[this.tableName].lookups;\n for (let i = 0; i < lookupListIndexes.length; i++) {\n lookupTable = allLookups[lookupListIndexes[i]];\n if (lookupTable.lookupType === lookupType) {\n tables.push(lookupTable);\n }\n }\n if (tables.length === 0 && create) {\n lookupTable = {\n lookupType,\n lookupFlag: 0,\n subtables: [],\n markFilteringSet: void 0\n };\n const index = allLookups.length;\n allLookups.push(lookupTable);\n lookupListIndexes.push(index);\n return [lookupTable];\n }\n }\n return tables;\n },\n /**\n * Find a glyph in a class definition table\n * https://docs.microsoft.com/en-us/typography/opentype/spec/chapter2#class-definition-table\n * @param {object} classDefTable - an OpenType Layout class definition table\n * @param {number} glyphIndex - the index of the glyph to find\n * @returns {number} -1 if not found\n */\n getGlyphClass: function(classDefTable, glyphIndex) {\n switch (classDefTable.format) {\n case 1: {\n if (classDefTable.startGlyph <= glyphIndex && glyphIndex < classDefTable.startGlyph + classDefTable.classes.length) {\n return classDefTable.classes[glyphIndex - classDefTable.startGlyph];\n }\n return 0;\n }\n case 2: {\n const range = searchRange(classDefTable.ranges, glyphIndex);\n return range ? range.classId : 0;\n }\n }\n },\n /**\n * Find a glyph in a coverage table\n * https://docs.microsoft.com/en-us/typography/opentype/spec/chapter2#coverage-table\n * @param {object} coverageTable - an OpenType Layout coverage table\n * @param {number} glyphIndex - the index of the glyph to find\n * @returns {number} -1 if not found\n */\n getCoverageIndex: function(coverageTable, glyphIndex) {\n switch (coverageTable.format) {\n case 1: {\n const index = binSearch(coverageTable.glyphs, glyphIndex);\n return index >= 0 ? index : -1;\n }\n case 2: {\n const range = searchRange(coverageTable.ranges, glyphIndex);\n return range ? range.index + glyphIndex - range.start : -1;\n }\n }\n },\n /**\n * Returns the list of glyph indexes of a coverage table.\n * Format 1: the list is stored raw\n * Format 2: compact list as range records.\n * @instance\n * @param {Object} coverageTable\n * @return {Array}\n */\n expandCoverage: function(coverageTable) {\n if (coverageTable.format === 1) {\n return coverageTable.glyphs;\n } else {\n const glyphs = [];\n const ranges = coverageTable.ranges;\n for (let i = 0; i < ranges.length; i++) {\n const range = ranges[i];\n const start = range.start;\n const end = range.end;\n for (let j = start; j <= end; j++) {\n glyphs.push(j);\n }\n }\n return glyphs;\n }\n }\n };\n var layout_default = Layout;\n\n // src/position.mjs\n function Position(font) {\n layout_default.call(this, font, \"gpos\");\n }\n Position.prototype = layout_default.prototype;\n Position.prototype.init = function() {\n const script = this.getDefaultScriptName();\n this.defaultKerningTables = this.getKerningTables(script);\n };\n Position.prototype.getKerningValue = function(kerningLookups, leftIndex, rightIndex) {\n for (let i = 0; i < kerningLookups.length; i++) {\n const subtables = kerningLookups[i].subtables;\n for (let j = 0; j < subtables.length; j++) {\n const subtable = subtables[j];\n const covIndex = this.getCoverageIndex(subtable.coverage, leftIndex);\n if (covIndex < 0) continue;\n switch (subtable.posFormat) {\n case 1: {\n let pairSet = subtable.pairSets[covIndex];\n for (let k = 0; k < pairSet.length; k++) {\n let pair = pairSet[k];\n if (pair.secondGlyph === rightIndex) {\n return pair.value1 && pair.value1.xAdvance || 0;\n }\n }\n break;\n }\n case 2: {\n const class1 = this.getGlyphClass(subtable.classDef1, leftIndex);\n const class2 = this.getGlyphClass(subtable.classDef2, rightIndex);\n const pair = subtable.classRecords[class1][class2];\n return pair.value1 && pair.value1.xAdvance || 0;\n }\n }\n }\n }\n return 0;\n };\n Position.prototype.getKerningTables = function(script, language) {\n if (this.font.tables.gpos) {\n return this.getLookupTables(script, language, \"kern\", 2);\n }\n };\n var position_default = Position;\n\n // src/util.mjs\n function arraysEqual(ar1, ar2) {\n const n = ar1.length;\n if (n !== ar2.length) {\n return false;\n }\n for (let i = 0; i < n; i++) {\n if (ar1[i] !== ar2[i]) {\n return false;\n }\n }\n return true;\n }\n function binarySearch(array, key, value) {\n let low = 0, high = array.length - 1;\n let result = null;\n while (low <= high) {\n const mid = Math.floor((low + high) / 2);\n const record = array[mid];\n const recordValue = record[key];\n if (recordValue < value) {\n low = mid + 1;\n } else if (recordValue > value) {\n high = mid - 1;\n } else {\n result = record;\n break;\n }\n }\n return result;\n }\n function binarySearchIndex(array, key, value) {\n let low = 0, high = array.length - 1;\n while (low <= high) {\n const mid = Math.floor((low + high) / 2);\n const element = array[mid];\n if (element[key] < value) {\n low = mid + 1;\n } else if (element[key] > value) {\n high = mid - 1;\n } else {\n return mid;\n }\n }\n return -1;\n }\n function binarySearchInsert(array, key, value) {\n let low = 0, high = array.length;\n const compare = (a, b) => a[key] - b[key];\n while (low < high) {\n const mid = low + high >>> 1;\n if (compare(array[mid], value) < 0) low = mid + 1;\n else high = mid;\n }\n array.splice(low, 0, value);\n return low;\n }\n function isGzip(buf) {\n return buf[0] === 31 && buf[1] === 139 && buf[2] === 8;\n }\n function unGzip(gzip) {\n const data = new DataView(gzip.buffer, gzip.byteOffset, gzip.byteLength);\n let start = 10;\n const end = gzip.byteLength - 8;\n const flg = data.getInt8(3);\n if (flg & 4) {\n start += 2 + data.getUint16(start, true);\n }\n if (flg & 8) {\n while (start < end) if (gzip[start++] === 0) break;\n }\n if (flg & 16) {\n while (start < end) if (gzip[start++] === 0) break;\n }\n if (flg & 2) {\n start += 2;\n }\n if (start >= end) throw new Error(\"Can't find compressed blocks\");\n const isize = data.getUint32(data.byteLength - 4, true);\n return tinf_uncompress(gzip.subarray(start, end), new Uint8Array(isize));\n }\n function copyPoint(p) {\n return {\n x: p.x,\n y: p.y,\n onCurve: p.onCurve,\n lastPointOfContour: p.lastPointOfContour\n };\n }\n function copyComponent(c) {\n return {\n glyphIndex: c.glyphIndex,\n xScale: c.xScale,\n scale01: c.scale01,\n scale10: c.scale10,\n yScale: c.yScale,\n dx: c.dx,\n dy: c.dy\n };\n }\n\n // src/substitution.mjs\n function Substitution(font) {\n layout_default.call(this, font, \"gsub\");\n }\n function getSubstFormat(lookupTable, format, defaultSubtable) {\n const subtables = lookupTable.subtables;\n for (let i = 0; i < subtables.length; i++) {\n const subtable = subtables[i];\n if (subtable.substFormat === format) {\n return subtable;\n }\n }\n if (defaultSubtable) {\n subtables.push(defaultSubtable);\n return defaultSubtable;\n }\n return void 0;\n }\n Substitution.prototype = layout_default.prototype;\n Substitution.prototype.createDefaultTable = function() {\n return {\n version: 1,\n scripts: [{\n tag: \"DFLT\",\n script: {\n defaultLangSys: { reserved: 0, reqFeatureIndex: 65535, featureIndexes: [] },\n langSysRecords: []\n }\n }],\n features: [],\n lookups: []\n };\n };\n Substitution.prototype.getSingle = function(feature, script, language) {\n const substitutions = [];\n const lookupTables = this.getLookupTables(script, language, feature, 1);\n for (let idx = 0; idx < lookupTables.length; idx++) {\n const subtables = lookupTables[idx].subtables;\n for (let i = 0; i < subtables.length; i++) {\n const subtable = subtables[i];\n const glyphs = this.expandCoverage(subtable.coverage);\n let j;\n if (subtable.substFormat === 1) {\n const delta = subtable.deltaGlyphId;\n for (j = 0; j < glyphs.length; j++) {\n const glyph = glyphs[j];\n substitutions.push({ sub: glyph, by: glyph + delta });\n }\n } else {\n const substitute = subtable.substitute;\n for (j = 0; j < glyphs.length; j++) {\n substitutions.push({ sub: glyphs[j], by: substitute[j] });\n }\n }\n }\n }\n return substitutions;\n };\n Substitution.prototype.getMultiple = function(feature, script, language) {\n const substitutions = [];\n const lookupTables = this.getLookupTables(script, language, feature, 2);\n for (let idx = 0; idx < lookupTables.length; idx++) {\n const subtables = lookupTables[idx].subtables;\n for (let i = 0; i < subtables.length; i++) {\n const subtable = subtables[i];\n const glyphs = this.expandCoverage(subtable.coverage);\n let j;\n for (j = 0; j < glyphs.length; j++) {\n const glyph = glyphs[j];\n const replacements = subtable.sequences[j];\n substitutions.push({ sub: glyph, by: replacements });\n }\n }\n }\n return substitutions;\n };\n Substitution.prototype.getAlternates = function(feature, script, language) {\n const alternates = [];\n const lookupTables = this.getLookupTables(script, language, feature, 3);\n for (let idx = 0; idx < lookupTables.length; idx++) {\n const subtables = lookupTables[idx].subtables;\n for (let i = 0; i < subtables.length; i++) {\n const subtable = subtables[i];\n const glyphs = this.expandCoverage(subtable.coverage);\n const alternateSets = subtable.alternateSets;\n for (let j = 0; j < glyphs.length; j++) {\n alternates.push({ sub: glyphs[j], by: alternateSets[j] });\n }\n }\n }\n return alternates;\n };\n Substitution.prototype.getLigatures = function(feature, script, language) {\n const ligatures = [];\n const lookupTables = this.getLookupTables(script, language, feature, 4);\n for (let idx = 0; idx < lookupTables.length; idx++) {\n const subtables = lookupTables[idx].subtables;\n for (let i = 0; i < subtables.length; i++) {\n const subtable = subtables[i];\n const glyphs = this.expandCoverage(subtable.coverage);\n const ligatureSets = subtable.ligatureSets;\n for (let j = 0; j < glyphs.length; j++) {\n const startGlyph = glyphs[j];\n const ligSet = ligatureSets[j];\n for (let k = 0; k < ligSet.length; k++) {\n const lig = ligSet[k];\n ligatures.push({\n sub: [startGlyph].concat(lig.components),\n by: lig.ligGlyph\n });\n }\n }\n }\n }\n return ligatures;\n };\n Substitution.prototype.addSingle = function(feature, substitution, script, language) {\n const lookupTable = this.getLookupTables(script, language, feature, 1, true)[0];\n const subtable = getSubstFormat(lookupTable, 2, {\n // lookup type 1 subtable, format 2, coverage format 1\n substFormat: 2,\n coverage: { format: 1, glyphs: [] },\n substitute: []\n });\n check_default.assert(subtable.coverage.format === 1, \"Single: unable to modify coverage table format \" + subtable.coverage.format);\n const coverageGlyph = substitution.sub;\n let pos = this.binSearch(subtable.coverage.glyphs, coverageGlyph);\n if (pos < 0) {\n pos = -1 - pos;\n subtable.coverage.glyphs.splice(pos, 0, coverageGlyph);\n subtable.substitute.splice(pos, 0, 0);\n }\n subtable.substitute[pos] = substitution.by;\n };\n Substitution.prototype.addMultiple = function(feature, substitution, script, language) {\n check_default.assert(substitution.by instanceof Array && substitution.by.length > 1, 'Multiple: \"by\" must be an array of two or more ids');\n const lookupTable = this.getLookupTables(script, language, feature, 2, true)[0];\n const subtable = getSubstFormat(lookupTable, 1, {\n // lookup type 2 subtable, format 1, coverage format 1\n substFormat: 1,\n coverage: { format: 1, glyphs: [] },\n sequences: []\n });\n check_default.assert(subtable.coverage.format === 1, \"Multiple: unable to modify coverage table format \" + subtable.coverage.format);\n const coverageGlyph = substitution.sub;\n let pos = this.binSearch(subtable.coverage.glyphs, coverageGlyph);\n if (pos < 0) {\n pos = -1 - pos;\n subtable.coverage.glyphs.splice(pos, 0, coverageGlyph);\n subtable.sequences.splice(pos, 0, 0);\n }\n subtable.sequences[pos] = substitution.by;\n };\n Substitution.prototype.addAlternate = function(feature, substitution, script, language) {\n const lookupTable = this.getLookupTables(script, language, feature, 3, true)[0];\n const subtable = getSubstFormat(lookupTable, 1, {\n // lookup type 3 subtable, format 1, coverage format 1\n substFormat: 1,\n coverage: { format: 1, glyphs: [] },\n alternateSets: []\n });\n check_default.assert(subtable.coverage.format === 1, \"Alternate: unable to modify coverage table format \" + subtable.coverage.format);\n const coverageGlyph = substitution.sub;\n let pos = this.binSearch(subtable.coverage.glyphs, coverageGlyph);\n if (pos < 0) {\n pos = -1 - pos;\n subtable.coverage.glyphs.splice(pos, 0, coverageGlyph);\n subtable.alternateSets.splice(pos, 0, 0);\n }\n subtable.alternateSets[pos] = substitution.by;\n };\n Substitution.prototype.addLigature = function(feature, ligature, script, language) {\n const lookupTable = this.getLookupTables(script, language, feature, 4, true)[0];\n let subtable = lookupTable.subtables[0];\n if (!subtable) {\n subtable = {\n // lookup type 4 subtable, format 1, coverage format 1\n substFormat: 1,\n coverage: { format: 1, glyphs: [] },\n ligatureSets: []\n };\n lookupTable.subtables[0] = subtable;\n }\n check_default.assert(subtable.coverage.format === 1, \"Ligature: unable to modify coverage table format \" + subtable.coverage.format);\n const coverageGlyph = ligature.sub[0];\n const ligComponents = ligature.sub.slice(1);\n const ligatureTable = {\n ligGlyph: ligature.by,\n components: ligComponents\n };\n let pos = this.binSearch(subtable.coverage.glyphs, coverageGlyph);\n if (pos >= 0) {\n const ligatureSet = subtable.ligatureSets[pos];\n for (let i = 0; i < ligatureSet.length; i++) {\n if (arraysEqual(ligatureSet[i].components, ligComponents)) {\n return;\n }\n }\n ligatureSet.push(ligatureTable);\n } else {\n pos = -1 - pos;\n subtable.coverage.glyphs.splice(pos, 0, coverageGlyph);\n subtable.ligatureSets.splice(pos, 0, [ligatureTable]);\n }\n };\n Substitution.prototype.getFeature = function(feature, script, language) {\n if (/ss\\d\\d/.test(feature)) {\n return this.getSingle(feature, script, language);\n }\n switch (feature) {\n case \"aalt\":\n case \"salt\":\n return this.getSingle(feature, script, language).concat(this.getAlternates(feature, script, language));\n case \"dlig\":\n case \"liga\":\n case \"rlig\":\n return this.getLigatures(feature, script, language);\n case \"ccmp\":\n return this.getMultiple(feature, script, language).concat(this.getLigatures(feature, script, language));\n case \"stch\":\n return this.getMultiple(feature, script, language);\n }\n return void 0;\n };\n Substitution.prototype.add = function(feature, sub, script, language) {\n if (/ss\\d\\d/.test(feature)) {\n return this.addSingle(feature, sub, script, language);\n }\n switch (feature) {\n case \"aalt\":\n case \"salt\":\n if (typeof sub.by === \"number\") {\n return this.addSingle(feature, sub, script, language);\n }\n return this.addAlternate(feature, sub, script, language);\n case \"dlig\":\n case \"liga\":\n case \"rlig\":\n return this.addLigature(feature, sub, script, language);\n case \"ccmp\":\n if (sub.by instanceof Array) {\n return this.addMultiple(feature, sub, script, language);\n }\n return this.addLigature(feature, sub, script, language);\n }\n return void 0;\n };\n var substitution_default = Substitution;\n\n // src/palettes.mjs\n var PaletteManager = class {\n // private properties don't work with reify\n // @TODO: refactor once we migrated to ES6 modules, see https://github.com/opentypejs/opentype.js/pull/579\n // #font = null;\n /**\n * @type {integer} CPAL color used to (pre)fill unset colors in a palette.\n * Format 0xBBGGRRAA\n */\n // defaultValue = 0x000000FF;\n /**\n * \n * @param {opentype.Font} font \n */\n constructor(font) {\n this.defaultValue = 255;\n this.font = font;\n }\n /**\n * Returns the font's cpal table object if present\n * @returns {Object}\n */\n cpal() {\n if (this.font.tables && this.font.tables.cpal) {\n return this.font.tables.cpal;\n }\n return false;\n }\n /**\n * Returns an array of arrays of color values for each palette, optionally in a specified color format\n * @param {string} colorFormat \n * @returns {Array<Array>}\n */\n getAll(colorFormat) {\n const palettes = [];\n const cpal = this.cpal();\n if (!cpal) return palettes;\n for (let i = 0; i < cpal.colorRecordIndices.length; i++) {\n const startIndex = cpal.colorRecordIndices[i];\n const paletteColors = [];\n for (let j = startIndex; j < startIndex + cpal.numPaletteEntries; j++) {\n paletteColors.push(formatColor(cpal.colorRecords[j], colorFormat || \"hexa\"));\n }\n palettes.push(paletteColors);\n }\n return palettes;\n }\n /**\n * Converts a color value string or array of color value strings to CPAL integer color value(s)\n * @param {string|Array<string></string>} color \n * @returns {integer}\n */\n toCPALcolor(color) {\n if (Array.isArray(color)) {\n return color.map((color2) => parseColor(color2, \"raw\"));\n }\n return parseColor(color, \"raw\");\n }\n /**\n * Fills a set of palette colors (from palette index, or a provided array of CPAL color values) with a set of colors, falling back to the default color value, until a given count\n * @param {Array<string>|integer} palette Palette index integer or Array of colors to be filled\n * @param {Array<string|integer>} colors Colors to fill the palette with\n * @param {integer} _colorCount Number of colors to fill the palette with, defaults to the value of the numPaletteEntries field. Used internally by extend() and shouldn't be set manually\n * @returns \n */\n fillPalette(palette, colors = [], _colorCount = this.cpal().numPaletteEntries) {\n palette = Number.isInteger(palette) ? this.get(palette, \"raw\") : palette;\n return Object.assign(Array(_colorCount).fill(this.defaultValue), this.toCPALcolor(palette).concat(this.toCPALcolor(colors)));\n }\n /**\n * Extend existing palettes and numPaletteEntries by a number of color slots\n * @param {integer} num number of additional color slots to add to all palettes\n */\n extend(num) {\n if (this.ensureCPAL(Array(num).fill(this.defaultValue))) {\n return;\n }\n const cpal = this.cpal();\n const newCount = cpal.numPaletteEntries + num;\n const palettes = this.getAll().map((palette) => this.fillPalette(palette, [], newCount));\n cpal.numPaletteEntries = newCount;\n cpal.colorRecords = this.toCPALcolor(palettes.flat());\n this.updateIndices();\n }\n /**\n * Get a specific palette by its zero-based index\n * @param {integer} paletteIndex \n * @param {string} [colorFormat='hexa']\n * @returns {Array}\n */\n get(paletteIndex, colorFormat = \"hexa\") {\n return this.getAll(colorFormat)[paletteIndex] || null;\n }\n /**\n * Get a color from a specific palette by its zero-based index\n * @param {integer} index \n * @param {integer} paletteIndex\n * @param {string} [colorFormat ='hexa']\n * @returns \n */\n getColor(index, paletteIndex = 0, colorFormat = \"hexa\") {\n return getPaletteColor(this.font, index, paletteIndex, colorFormat);\n }\n /**\n * Set one or more colors on a specific palette by its zero-based index\n * @param {integer} index zero-based color index to start filling from\n * @param {string|integer|Array<string|integer>} color color value or array of color values\n * @param {integer} paletteIndex\n * @returns \n */\n setColor(index, colors, paletteIndex = 0) {\n index = parseInt(index);\n paletteIndex = parseInt(paletteIndex);\n let palettes = this.getAll(\"raw\");\n let palette = palettes[paletteIndex];\n if (!palette) {\n throw Error(`paletteIndex ${paletteIndex} out of range`);\n }\n const cpal = this.cpal();\n const colorCount = cpal.numPaletteEntries;\n if (!Array.isArray(colors)) {\n colors = [colors];\n }\n if (colors.length + index > colorCount) {\n this.extend(colors.length + index - colorCount);\n palettes = this.getAll(\"raw\");\n palette = palettes[paletteIndex];\n }\n for (let i = 0; i < colors.length; i++) {\n palette[i + index] = this.toCPALcolor(colors[i]);\n }\n cpal.colorRecords = palettes.flat();\n this.updateIndices();\n }\n /**\n * Add a new palette. \n * @param {Array} colors (optional) colors to add to the palette, differences to existing palettes will be filled with the defaultValue.\n * @returns \n */\n add(colors) {\n if (this.ensureCPAL(colors)) {\n return;\n }\n const cpal = this.cpal();\n const colorCount = cpal.numPaletteEntries;\n if (colors && colors.length) {\n colors = this.toCPALcolor(colors);\n if (colors.length > colorCount) {\n this.extend(colors.length - colorCount);\n } else if (colors.length < colorCount) {\n colors = this.fillPalette(colors);\n }\n cpal.colorRecordIndices.push(cpal.colorRecords.length);\n cpal.colorRecords.push(...colors);\n } else {\n cpal.colorRecordIndices.push(cpal.colorRecords.length);\n cpal.colorRecords.push(...Array(colorCount).fill(this.defaultValue));\n }\n }\n /**\n * deletes a palette by its zero-based index\n * @param {integer} paletteIndex \n */\n delete(paletteIndex) {\n const palettes = this.getAll(\"raw\");\n delete palettes[paletteIndex];\n const cpal = this.cpal();\n cpal.colorRecordIndices.pop();\n cpal.colorRecords = palettes.flat();\n }\n /**\n * Deletes a specific color index in all palettes and updates all layers using that color with the replacement index\n * @param {integer} colorIndex index of the color that should be deleted\n * @param {integer} replacementIndex index (according to the palette before deletion) of the color to replace in layers using the color to be to deleted\n */\n deleteColor(colorIndex, replacementIndex) {\n if (colorIndex === replacementIndex) {\n throw Error(\"replacementIndex cannot be the same as colorIndex\");\n }\n const cpal = this.cpal();\n const palettes = this.getAll(\"raw\");\n const updatedPalettes = [];\n if (replacementIndex > cpal.numPaletteEntries - 1) {\n throw Error(`Replacement index out of range: numPaletteEntries after deletion: ${cpal.numPaletteEntries - 1}, replacementIndex: ${replacementIndex})`);\n }\n for (let i = 0; i < palettes.length; i++) {\n const palette = palettes[i];\n const updatedPalette = palette.filter((color, index) => index !== colorIndex);\n updatedPalettes.push(updatedPalette);\n }\n const colrTable = this.font.tables.colr;\n if (colrTable) {\n const layerRecords = colrTable.layerRecords;\n for (let i = 0; i < layerRecords.length; i++) {\n const currentIndex = layerRecords[i].paletteIndex;\n if (currentIndex > colorIndex) {\n const shiftAmount = 1;\n layerRecords[i].paletteIndex -= shiftAmount;\n } else if (currentIndex === colorIndex) {\n let replacementShift = 0;\n for (let j = 0; j < palettes.length; j++) {\n if (replacementIndex > colorIndex && replacementIndex <= colorIndex + palettes[j].length) {\n replacementShift++;\n break;\n }\n }\n layerRecords[i].paletteIndex = replacementIndex - replacementShift;\n }\n }\n this.font.tables.colr = {\n ...colrTable,\n layerRecords\n };\n }\n const flattenedPalettes = updatedPalettes.flat();\n for (let i = 0; i < palettes.length; i++) {\n cpal.colorRecordIndices[i] -= i;\n }\n cpal.numPaletteEntries = Math.max(0, cpal.numPaletteEntries - 1);\n cpal.colorRecords = this.toCPALcolor(flattenedPalettes);\n }\n /**\n * Makes sure that the CPAL table exists and is populated with default values.\n * @param {Array} colors (optional) colors to populate on creation\n * @returns {Boolean} true if it was created, false if it already existed.\n */\n ensureCPAL(colors) {\n if (!this.cpal()) {\n if (!colors || !colors.length) {\n colors = [this.defaultValue];\n } else {\n colors = this.toCPALcolor(colors);\n }\n this.font.tables.cpal = {\n version: 0,\n numPaletteEntries: colors.length,\n colorRecords: colors,\n colorRecordIndices: [0]\n };\n return true;\n }\n return false;\n }\n /**\n * Mainly used internally. Recalculates the colorRecordIndices array based on the numPaletteEntries and number of palettes\n */\n updateIndices() {\n const cpal = this.cpal();\n const paletteCount = Math.ceil(cpal.colorRecords.length / cpal.numPaletteEntries);\n cpal.colorRecordIndices = [];\n for (let i = 0; i < paletteCount; i++) {\n cpal.colorRecordIndices.push(i * cpal.numPaletteEntries);\n }\n }\n };\n\n // src/layers.mjs\n var LayerManager = class {\n // private properties don't work with reify\n // @TODO: refactor once we migrated to ES6 modules, see https://github.com/opentypejs/opentype.js/pull/579\n // #font = null;\n constructor(font) {\n this.font = font;\n }\n /**\n * Mainly used internally. Ensures that the COLR table exists and is populated with default values\n * @returns the LayerManager's font instance for chaining\n */\n ensureCOLR() {\n if (!this.font.tables.colr) {\n this.font.tables.colr = {\n version: 0,\n baseGlyphRecords: [],\n layerRecords: []\n };\n }\n return this.font;\n }\n /**\n * Gets the layers for a specific glyph\n * @param {integer} glyphIndex\n * @returns {Array<Object>} array of layer objects {glyph, paletteIndex}\n */\n get(glyphIndex) {\n const font = this.font;\n const layers = [];\n const colr = font.tables.colr;\n const cpal = font.tables.cpal;\n if (!colr || !cpal) {\n return layers;\n }\n const baseGlyph = binarySearch(colr.baseGlyphRecords, \"glyphID\", glyphIndex);\n if (!baseGlyph) {\n return layers;\n }\n const firstIndex = baseGlyph.firstLayerIndex;\n const numLayers = baseGlyph.numLayers;\n for (let l = 0; l < numLayers; l++) {\n const layer = colr.layerRecords[firstIndex + l];\n layers.push({\n glyph: font.glyphs.get(layer.glyphID),\n paletteIndex: layer.paletteIndex\n });\n }\n return layers;\n }\n /**\n * Adds one or more layers to a glyph, at the end or at a specific position.\n * @param {integer} glyphIndex glyph index to add the layer(s) to.\n * @param {Array|Object} layers layer object {glyph, paletteIndex}/{glyphID, paletteIndex} or array of layer objects.\n * @param {integer?} position position to insert the layers at (will default to adding at the end).\n */\n add(glyphIndex, layers, position) {\n const currentLayers = this.get(glyphIndex);\n layers = Array.isArray(layers) ? layers : [layers];\n if (position === void 0 || position === Infinity || position > currentLayers.length) {\n position = currentLayers.length;\n } else if (position < 0) {\n position = currentLayers.length + 1 + position % (currentLayers.length + 1);\n if (position >= currentLayers.length + 1) {\n position -= currentLayers.length + 1;\n }\n }\n const newLayers = [];\n for (let i = 0; i < position; i++) {\n const glyphID = Number.isInteger(currentLayers[i].glyph) ? currentLayers[i].glyph : currentLayers[i].glyph.index;\n newLayers.push({\n glyphID,\n paletteIndex: currentLayers[i].paletteIndex\n });\n }\n for (const layer of layers) {\n const glyphID = Number.isInteger(layer.glyph) ? layer.glyph : layer.glyph.index;\n newLayers.push({\n glyphID,\n paletteIndex: layer.paletteIndex\n });\n }\n for (let i = position; i < currentLayers.length; i++) {\n const glyphID = Number.isInteger(currentLayers[i].glyph) ? currentLayers[i].glyph : currentLayers[i].glyph.index;\n newLayers.push({\n glyphID,\n paletteIndex: currentLayers[i].paletteIndex\n });\n }\n this.updateColrTable(glyphIndex, newLayers);\n }\n /**\n * Sets a color glyph layer's paletteIndex property to a new index\n * @param {integer} glyphIndex glyph in the font by zero-based glyph index\n * @param {integer} layerIndex layer in the glyph by zero-based layer index\n * @param {integer} paletteIndex new color to set for the layer by zero-based index in any palette\n */\n setPaletteIndex(glyphIndex, layerIndex, paletteIndex) {\n let layers = this.get(glyphIndex);\n if (layers[layerIndex]) {\n layers = layers.map((layer, index) => ({\n glyphID: layer.glyph.index,\n paletteIndex: index === layerIndex ? paletteIndex : layer.paletteIndex\n }));\n this.updateColrTable(glyphIndex, layers);\n } else {\n console.error(\"Invalid layer index\");\n }\n }\n /**\n * Removes one or more layers from a glyph.\n * @param {integer} glyphIndex glyph index to remove the layer(s) from\n * @param {integer} start index to remove the layer at\n * @param {integer?} end (optional) if provided, removes all layers from start index to (and including) end index\n */\n remove(glyphIndex, start, end = start) {\n let currentLayers = this.get(glyphIndex);\n currentLayers = currentLayers.map((layer) => ({\n glyphID: layer.glyph.index,\n paletteIndex: layer.paletteIndex\n }));\n currentLayers.splice(start, end - start + 1);\n this.updateColrTable(glyphIndex, currentLayers);\n }\n /**\n * Mainly used internally. Mainly used internally. Updates the colr table, adding a baseGlyphRecord if needed,\n * ensuring that it's inserted at the correct position, updating numLayers, and adjusting firstLayerIndex values\n * for all baseGlyphRecords according to any deletions or insertions.\n * @param {integer} glyphIndex \n * @param {Array<Object>} layers array of layer objects {glyphID, paletteIndex}\n */\n updateColrTable(glyphIndex, layers) {\n this.ensureCOLR();\n const font = this.font;\n const colr = font.tables.colr;\n let index = binarySearchIndex(colr.baseGlyphRecords, \"glyphID\", glyphIndex);\n const addBaseGlyph = index === -1;\n if (addBaseGlyph) {\n const newBaseGlyphRecord = { glyphID: glyphIndex, firstLayerIndex: colr.layerRecords.length, numLayers: 0 };\n index = binarySearchInsert(colr.baseGlyphRecords, \"glyphID\", newBaseGlyphRecord);\n }\n const baseGlyphRecord = colr.baseGlyphRecords[index];\n const originalNumLayers = baseGlyphRecord.numLayers;\n const newNumLayers = layers.length;\n const layerDiff = newNumLayers - originalNumLayers;\n if (layerDiff > 0) {\n const newLayers = layers.slice(originalNumLayers).map((layer) => ({\n glyphID: layer.glyphID,\n paletteIndex: layer.paletteIndex\n }));\n colr.layerRecords.splice(baseGlyphRecord.firstLayerIndex + originalNumLayers, 0, ...newLayers);\n } else if (layerDiff < 0) {\n colr.layerRecords.splice(baseGlyphRecord.firstLayerIndex + newNumLayers, -layerDiff);\n }\n for (let i = 0; i < Math.min(originalNumLayers, newNumLayers); i++) {\n colr.layerRecords[baseGlyphRecord.firstLayerIndex + i] = {\n glyphID: layers[i].glyphID,\n paletteIndex: layers[i].paletteIndex\n };\n }\n baseGlyphRecord.numLayers = newNumLayers;\n if (layerDiff !== 0) {\n for (let i = 0; i < colr.baseGlyphRecords.length; i++) {\n const sibling = colr.baseGlyphRecords[i];\n if (i === index || sibling.firstLayerIndex < baseGlyphRecord.firstLayerIndex) continue;\n colr.baseGlyphRecords[i].firstLayerIndex += layerDiff;\n }\n }\n }\n };\n\n // src/svgimages.mjs\n var SVGImageManager = class {\n /**\n * @param {opentype.Font} font\n */\n constructor(font) {\n this.font = font;\n this.cache = /* @__PURE__ */ new WeakMap();\n }\n /**\n * @param {number} glyphIndex\n * @returns {SvgImage | undefined}\n */\n get(glyphIndex) {\n const svgImageCacheEntry = this.getOrCreateSvgImageCacheEntry(glyphIndex);\n return svgImageCacheEntry && svgImageCacheEntry.image;\n }\n /**\n * @param {number} glyphIndex\n * @returns {Promise<SvgImage> | undefined}\n */\n getAsync(glyphIndex) {\n const svgImageCacheEntry = this.getOrCreateSvgImageCacheEntry(glyphIndex);\n return svgImageCacheEntry && svgImageCacheEntry.promise;\n }\n /**\n * @param {number} glyphIndex\n * @returns {SVGImageCacheEntry | undefined}\n */\n getOrCreateSvgImageCacheEntry(glyphIndex) {\n const svg = this.font.tables.svg;\n if (svg === void 0) return;\n const svgBuf = svg.get(glyphIndex);\n if (svgBuf === void 0) return;\n let svgDocCacheEntry = this.cache.get(svgBuf);\n if (svgDocCacheEntry === void 0) {\n svgDocCacheEntry = createSvgDocCacheEntry(svgBuf);\n this.cache.set(svgBuf, svgDocCacheEntry);\n }\n let svgImageCacheEntry = svgDocCacheEntry.images.get(glyphIndex);\n if (svgImageCacheEntry === void 0) {\n svgImageCacheEntry = createSvgImageCacheEntry(this.font, svgDocCacheEntry.template, glyphIndex);\n svgImageCacheEntry.promise.then((svgImage) => {\n svgImageCacheEntry.image = svgImage;\n if (typeof this.font.onGlyphUpdated === \"function\") {\n try {\n this.font.onGlyphUpdated(glyphIndex);\n } catch (error) {\n console.error(\"font.onGlyphUpdated\", glyphIndex, error);\n }\n }\n });\n svgDocCacheEntry.images.set(glyphIndex, svgImageCacheEntry);\n }\n return svgImageCacheEntry;\n }\n };\n function createSvgDocCacheEntry(svgBuf) {\n return {\n template: decodeSvgDocument(svgBuf).then(makeSvgTemplate),\n images: /* @__PURE__ */ new Map()\n };\n }\n function createSvgImageCacheEntry(font, svgTemplatePromise, glyphIndex) {\n return {\n promise: svgTemplatePromise.then((svgTemplate) => {\n let svgText;\n if (typeof svgTemplate === \"string\") {\n svgText = svgTemplate;\n } else {\n svgTemplate[4] = glyphIndex;\n svgText = svgTemplate.join(\"\");\n }\n const svgImage = makeSvgImage(svgText, font.unitsPerEm);\n return svgImage.image.decode().then(() => svgImage);\n }),\n image: void 0\n };\n }\n var decodeSvgDocument = typeof DecompressionStream === \"function\" ? decodeSvgDocumentWithDecompressionStream : decodeSvgDocumentWithTinyInflate;\n function decodeSvgDocumentWithTinyInflate(buf) {\n try {\n return Promise.resolve(new TextDecoder().decode(isGzip(buf) ? unGzip(buf) : buf));\n } catch (error) {\n return Promise.reject(error);\n }\n }\n function decodeSvgDocumentWithDecompressionStream(buf) {\n if (isGzip(buf)) {\n return new Response(new Response(buf).body.pipeThrough(new DecompressionStream(\"gzip\"))).text();\n }\n try {\n return Promise.resolve(new TextDecoder().decode(buf));\n } catch (error) {\n return Promise.reject(error);\n }\n }\n function makeSvgTemplate(text) {\n const documentStart = text.indexOf(\"<svg\");\n const contentStart = text.indexOf(\">\", documentStart + 4) + 1;\n if (/ id=['\"]glyph\\d+['\"]/.test(text.substring(documentStart, contentStart))) {\n return text;\n }\n const contentEnd = text.lastIndexOf(\"</svg>\");\n return [\n text.substring(0, contentStart),\n \"<defs>\",\n text.substring(contentStart, contentEnd),\n '</defs><use href=\"#glyph',\n \"\",\n '\"/>',\n text.substring(contentEnd)\n ];\n }\n function makeSvgImage(text, unitsPerEm) {\n const svgDocument = new DOMParser().parseFromString(text, \"image/svg+xml\");\n const svg = svgDocument.documentElement;\n const viewBoxVal = svg.viewBox.baseVal;\n const widthVal = svg.width.baseVal;\n const heightVal = svg.height.baseVal;\n let xScale = 1;\n let yScale = 1;\n if (viewBoxVal.width > 0 && viewBoxVal.height > 0) {\n if (widthVal.unitType === 1) {\n xScale = widthVal.valueInSpecifiedUnits / viewBoxVal.width;\n yScale = heightVal.unitType === 1 ? heightVal.valueInSpecifiedUnits / viewBoxVal.height : xScale;\n } else if (heightVal.unitType === 1) {\n yScale = heightVal.valueInSpecifiedUnits / viewBoxVal.height;\n xScale = yScale;\n } else if (unitsPerEm) {\n xScale = unitsPerEm / viewBoxVal.width;\n yScale = unitsPerEm / viewBoxVal.height;\n }\n }\n const div = document.createElement(\"div\");\n div.style.position = \"fixed\";\n div.style.visibility = \"hidden\";\n div.appendChild(svg);\n document.body.appendChild(div);\n const bbox = svg.getBBox();\n document.body.removeChild(div);\n const leftSideBearing = (bbox.x - viewBoxVal.x) * xScale;\n const baseline = (viewBoxVal.y - bbox.y) * yScale;\n const width = bbox.width * xScale;\n const height = bbox.height * yScale;\n svg.setAttribute(\"viewBox\", [bbox.x, bbox.y, bbox.width, bbox.height].join(\" \"));\n if (xScale !== 1) svg.setAttribute(\"width\", width);\n if (yScale !== 1) svg.setAttribute(\"height\", height);\n const image = new Image(width, height);\n image.src = \"data:image/svg+xml;charset=utf-8,\" + encodeURIComponent(svg.outerHTML);\n return { leftSideBearing, baseline, image };\n }\n\n // src/tables/glyf.mjs\n var _resolving = /* @__PURE__ */ new WeakMap();\n function parseGlyphCoordinate(p, flag, previousValue, shortVectorBitMask, sameBitMask) {\n let v;\n if ((flag & shortVectorBitMask) > 0) {\n v = p.parseByte();\n if ((flag & sameBitMask) === 0) {\n v = -v;\n }\n v = previousValue + v;\n } else {\n if ((flag & sameBitMask) > 0) {\n v = previousValue;\n } else {\n v = previousValue + p.parseShort();\n }\n }\n return v;\n }\n function parseGlyph(glyph, data, start) {\n const p = new parse_default.Parser(data, start);\n glyph._numberOfContours = p.parseShort();\n glyph._xMin = p.parseShort();\n glyph._yMin = p.parseShort();\n glyph._xMax = p.parseShort();\n glyph._yMax = p.parseShort();\n let flags;\n let flag;\n if (glyph._numberOfContours > 0) {\n const endPointIndices = glyph.endPointIndices = [];\n for (let i = 0; i < glyph._numberOfContours; i += 1) {\n endPointIndices.push(p.parseUShort());\n }\n glyph.instructionLength = p.parseUShort();\n glyph.instructions = [];\n for (let i = 0; i < glyph.instructionLength; i += 1) {\n glyph.instructions.push(p.parseByte());\n }\n const numberOfCoordinates = endPointIndices[endPointIndices.length - 1] + 1;\n flags = [];\n for (let i = 0; i < numberOfCoordinates; i += 1) {\n flag = p.parseByte();\n flags.push(flag);\n if ((flag & 8) > 0) {\n const repeatCount = p.parseByte();\n for (let j = 0; j < repeatCount; j += 1) {\n flags.push(flag);\n i += 1;\n }\n }\n }\n check_default.argument(flags.length === numberOfCoordinates, \"Bad flags.\");\n if (endPointIndices.length > 0) {\n const points = [];\n let point;\n if (numberOfCoordinates > 0) {\n for (let i = 0; i < numberOfCoordinates; i += 1) {\n flag = flags[i];\n point = {};\n point.onCurve = !!(flag & 1);\n point.lastPointOfContour = endPointIndices.indexOf(i) >= 0;\n points.push(point);\n }\n let px = 0;\n for (let i = 0; i < numberOfCoordinates; i += 1) {\n flag = flags[i];\n point = points[i];\n point.x = parseGlyphCoordinate(p, flag, px, 2, 16);\n px = point.x;\n }\n let py = 0;\n for (let i = 0; i < numberOfCoordinates; i += 1) {\n flag = flags[i];\n point = points[i];\n point.y = parseGlyphCoordinate(p, flag, py, 4, 32);\n py = point.y;\n }\n }\n glyph.points = points;\n } else {\n glyph.points = [];\n }\n } else if (glyph._numberOfContours === 0) {\n glyph.points = [];\n } else {\n glyph.isComposite = true;\n glyph.points = [];\n glyph.components = [];\n let moreComponents = true;\n while (moreComponents) {\n flags = p.parseUShort();\n const component = {\n glyphIndex: p.parseUShort(),\n xScale: 1,\n scale01: 0,\n scale10: 0,\n yScale: 1,\n dx: 0,\n dy: 0\n };\n if ((flags & 1) > 0) {\n if ((flags & 2) > 0) {\n component.dx = p.parseShort();\n component.dy = p.parseShort();\n } else {\n component.matchedPoints = [p.parseUShort(), p.parseUShort()];\n }\n } else {\n if ((flags & 2) > 0) {\n component.dx = p.parseChar();\n component.dy = p.parseChar();\n } else {\n component.matchedPoints = [p.parseByte(), p.parseByte()];\n }\n }\n if ((flags & 8) > 0) {\n component.xScale = component.yScale = p.parseF2Dot14();\n } else if ((flags & 64) > 0) {\n component.xScale = p.parseF2Dot14();\n component.yScale = p.parseF2Dot14();\n } else if ((flags & 128) > 0) {\n component.xScale = p.parseF2Dot14();\n component.scale01 = p.parseF2Dot14();\n component.scale10 = p.parseF2Dot14();\n component.yScale = p.parseF2Dot14();\n }\n glyph.components.push(component);\n moreComponents = !!(flags & 32);\n }\n if (flags & 256) {\n glyph.instructionLength = p.parseUShort();\n glyph.instructions = [];\n for (let i = 0; i < glyph.instructionLength; i += 1) {\n glyph.instructions.push(p.parseByte());\n }\n }\n }\n }\n function transformPoints(points, transform) {\n const newPoints = [];\n for (let i = 0; i < points.length; i += 1) {\n const pt = points[i];\n const newPt = {\n x: transform.xScale * pt.x + transform.scale10 * pt.y + transform.dx,\n y: transform.scale01 * pt.x + transform.yScale * pt.y + transform.dy,\n onCurve: pt.onCurve,\n lastPointOfContour: pt.lastPointOfContour\n };\n newPoints.push(newPt);\n }\n return newPoints;\n }\n function getContours(points) {\n const contours = [];\n let currentContour = [];\n for (let i = 0; i < points.length; i += 1) {\n const pt = points[i];\n currentContour.push(pt);\n if (pt.lastPointOfContour) {\n contours.push(currentContour);\n currentContour = [];\n }\n }\n check_default.argument(currentContour.length === 0, \"There are still points left in the current contour.\");\n return contours;\n }\n function getPath(points) {\n const p = new path_default();\n if (!points) {\n return p;\n }\n const contours = getContours(points);\n for (let contourIndex = 0; contourIndex < contours.length; ++contourIndex) {\n const contour = contours[contourIndex];\n let curr = contour[contour.length - 1];\n let next = contour[0];\n if (curr.onCurve) {\n p.moveTo(curr.x, curr.y);\n } else {\n if (next.onCurve) {\n p.moveTo(next.x, next.y);\n } else {\n const start = { x: (curr.x + next.x) * 0.5, y: (curr.y + next.y) * 0.5 };\n p.moveTo(start.x, start.y);\n }\n }\n for (let i = 0; i < contour.length; ++i) {\n curr = next;\n next = contour[(i + 1) % contour.length];\n if (curr.onCurve) {\n p.lineTo(curr.x, curr.y);\n } else {\n let next2 = next;\n if (!next.onCurve) {\n next2 = { x: (curr.x + next.x) * 0.5, y: (curr.y + next.y) * 0.5 };\n }\n p.quadraticCurveTo(curr.x, curr.y, next2.x, next2.y);\n }\n }\n p.closePath();\n }\n return p;\n }\n function buildPath(glyphs, glyph) {\n if (glyph.isComposite) {\n if (!_resolving.has(glyphs)) {\n _resolving.set(glyphs, /* @__PURE__ */ new Set());\n }\n const resolving = _resolving.get(glyphs);\n resolving.add(glyph.index);\n try {\n for (let j = 0; j < glyph.components.length; j += 1) {\n const component = glyph.components[j];\n if (resolving.has(component.glyphIndex)) {\n continue;\n }\n const componentGlyph = glyphs.get(component.glyphIndex);\n componentGlyph.getPath();\n if (componentGlyph.points) {\n let transformedPoints;\n if (component.matchedPoints === void 0) {\n transformedPoints = transformPoints(componentGlyph.points, component);\n } else {\n if (component.matchedPoints[0] > glyph.points.length - 1 || component.matchedPoints[1] > componentGlyph.points.length - 1) {\n throw Error(\"Matched points out of range in \" + glyph.name);\n }\n const firstPt = glyph.points[component.matchedPoints[0]];\n let secondPt = componentGlyph.points[component.matchedPoints[1]];\n const transform = {\n xScale: component.xScale,\n scale01: component.scale01,\n scale10: component.scale10,\n yScale: component.yScale,\n dx: 0,\n dy: 0\n };\n secondPt = transformPoints([secondPt], transform)[0];\n transform.dx = firstPt.x - secondPt.x;\n transform.dy = firstPt.y - secondPt.y;\n transformedPoints = transformPoints(componentGlyph.points, transform);\n }\n glyph.points = glyph.points.concat(transformedPoints);\n }\n }\n } finally {\n resolving.delete(glyph.index);\n }\n }\n return getPath(glyph.points);\n }\n function parseGlyfTableAll(data, start, loca, font) {\n const glyphs = new glyphset_default.GlyphSet(font);\n for (let i = 0; i < loca.length - 1; i += 1) {\n const offset = loca[i];\n const nextOffset = loca[i + 1];\n if (offset !== nextOffset) {\n glyphs.push(i, glyphset_default.ttfGlyphLoader(font, i, parseGlyph, data, start + offset, buildPath));\n } else {\n glyphs.push(i, glyphset_default.glyphLoader(font, i));\n }\n }\n return glyphs;\n }\n function parseGlyfTableOnLowMemory(data, start, loca, font) {\n const glyphs = new glyphset_default.GlyphSet(font);\n font._push = function(i) {\n const offset = loca[i];\n const nextOffset = loca[i + 1];\n if (offset !== nextOffset) {\n glyphs.push(i, glyphset_default.ttfGlyphLoader(font, i, parseGlyph, data, start + offset, buildPath));\n } else {\n glyphs.push(i, glyphset_default.glyphLoader(font, i));\n }\n };\n return glyphs;\n }\n function parseGlyfTable(data, start, loca, font, opt) {\n if (opt.lowMemory)\n return parseGlyfTableOnLowMemory(data, start, loca, font);\n else\n return parseGlyfTableAll(data, start, loca, font);\n }\n var glyf_default = { getPath, parse: parseGlyfTable };\n\n // src/variationprocessor.mjs\n var VariationProcessor = class {\n constructor(font) {\n this.font = font;\n }\n /**\n * Modifies a coords object to make sure that tags have a length of 4\n * @param {Object} coords - variation coordinates\n */\n normalizeCoordTags(coords) {\n for (const tag in coords) {\n if (tag.length < 4) {\n const padded = tag.padEnd(4, \" \");\n coords[padded] === void 0 && (coords[padded] = coords[tag]);\n delete coords[tag];\n }\n }\n }\n /**\n * Normalizes the coordinates from the axis ranges to a range of -1 to 1.\n * @param {Object} coords - The coordinates object to normalize.\n * @returns {Array<number>} The normalized coordinates as an array\n */\n getNormalizedCoords(coords) {\n if (!coords) {\n coords = this.font.variation.get();\n }\n let normalized = [];\n this.normalizeCoordTags(coords);\n for (let i = 0; i < this.fvar().axes.length; i++) {\n const axis = this.fvar().axes[i];\n let tagValue = coords[axis.tag];\n if (tagValue === void 0) {\n tagValue = axis.defaultValue;\n }\n if (tagValue < axis.defaultValue) {\n normalized.push((tagValue - axis.defaultValue + Number.EPSILON) / (axis.defaultValue - axis.minValue + Number.EPSILON));\n } else {\n normalized.push((tagValue - axis.defaultValue + Number.EPSILON) / (axis.maxValue - axis.defaultValue + Number.EPSILON));\n }\n }\n if (this.avar()) {\n for (let i = 0; i < this.avar().axisSegmentMaps.length; i++) {\n let segment = this.avar().axisSegmentMaps[i];\n for (let j = 0; j < segment.axisValueMaps.length; j++) {\n let pair = segment.axisValueMaps[j];\n if (j >= 1 && normalized[i] < pair.fromCoordinate) {\n let prev = segment.axisValueMaps[j - 1];\n normalized[i] = ((normalized[i] - prev.fromCoordinate) * (pair.toCoordinate - prev.toCoordinate) + Number.EPSILON) / (pair.fromCoordinate - prev.fromCoordinate + Number.EPSILON) + prev.toCoordinate;\n break;\n }\n }\n }\n }\n return normalized;\n }\n /**\n * Interpolates points within a glyph if deltas are not provided for all points.\n * @param {Array<Object>} points - The points to be interpolated.\n * @param {Array<Object>} glyphPoints - Reference points from the glyph.\n * @param {Object} deltaMap - A map indicating which points have deltas.\n */\n interpolatePoints(points, glyphPoints, deltaMap) {\n if (points.length === 0) {\n return;\n }\n let pointIndex = 0;\n while (pointIndex < points.length) {\n let firstPoint = pointIndex;\n let endPoint = pointIndex;\n let point = points[endPoint];\n while (!point.lastPointOfContour) {\n point = points[++endPoint];\n }\n while (pointIndex <= endPoint && !deltaMap[pointIndex]) {\n pointIndex++;\n }\n if (pointIndex > endPoint) {\n continue;\n }\n let firstDelta = pointIndex;\n let curDelta = pointIndex;\n pointIndex++;\n while (pointIndex <= endPoint) {\n if (deltaMap[pointIndex]) {\n this.deltaInterpolate(curDelta + 1, pointIndex - 1, curDelta, pointIndex, glyphPoints, points);\n curDelta = pointIndex;\n }\n pointIndex++;\n }\n if (curDelta === firstDelta) {\n this.deltaShift(firstPoint, endPoint, curDelta, glyphPoints, points);\n } else {\n this.deltaInterpolate(curDelta + 1, endPoint, curDelta, firstDelta, glyphPoints, points);\n if (firstDelta > 0) {\n this.deltaInterpolate(firstPoint, firstDelta - 1, curDelta, firstDelta, glyphPoints, points);\n }\n }\n pointIndex = endPoint + 1;\n }\n }\n /**\n * Interpolates delta values between two points.\n * @param {number} p1 - Start point index for interpolation.\n * @param {number} p2 - End point index for interpolation.\n * @param {number} ref1 - Reference point index for the start delta.\n * @param {number} ref2 - Reference point index for the end delta.\n * @param {Array<Object>} glyphPoints - Reference points from the glyph.\n * @param {Array<Object>} points - The points to be adjusted.\n */\n deltaInterpolate(p1, p2, ref1, ref2, glyphPoints, points) {\n if (p1 > p2) {\n return;\n }\n let iterable = [\"x\", \"y\"];\n for (let i = 0; i < iterable.length; i++) {\n let k = iterable[i];\n if (glyphPoints[ref1][k] > glyphPoints[ref2][k]) {\n var p = ref1;\n ref1 = ref2;\n ref2 = p;\n }\n let in1 = glyphPoints[ref1][k];\n let in2 = glyphPoints[ref2][k];\n let out1 = points[ref1][k];\n let out2 = points[ref2][k];\n if (in1 !== in2 || out1 === out2) {\n let scale = in1 === in2 ? 0 : (out2 - out1) / (in2 - in1);\n for (let p3 = p1; p3 <= p2; p3++) {\n let out = glyphPoints[p3][k];\n if (out <= in1) {\n out += out1 - in1;\n } else if (out >= in2) {\n out += out2 - in2;\n } else {\n out = out1 + (out - in1) * scale;\n }\n points[p3][k] = out;\n }\n }\n }\n }\n /**\n * Applies a delta shift to a range of points based on a reference point.\n * @param {number} p1 - Start point index for shifting.\n * @param {number} p2 - End point index for shifting.\n * @param {number} ref - Reference point index.\n * @param {Array<Object>} glyphPoints - Reference points from the glyph.\n * @param {Array<Object>} points - The points to be shifted.\n */\n deltaShift(p1, p2, ref, glyphPoints, points) {\n let deltaX = points[ref].x - glyphPoints[ref].x;\n let deltaY = points[ref].y - glyphPoints[ref].y;\n if (deltaX === 0 && deltaY === 0) {\n return;\n }\n for (let p = p1; p <= p2; p++) {\n if (p !== ref) {\n points[p].x += deltaX;\n points[p].y += deltaY;\n }\n }\n }\n /**\n * Transforms glyph components based on variation data.\n * @param {Glyph} glyph - The composite glyph to transform.\n * @param {Array<Object>} transformedPoints - Points that are already transformed.\n * @param {Object} coords - Variation coordinates.\n * @param {Array<number>} tuplePoints - Points that are part of the tuple.\n * @param {Object} header - Header information from the variation data.\n * @param {number} factor - The scaling factor for the transformation.\n */\n transformComponents(glyph, transformedPoints, coords, tuplePoints, header, factor) {\n let pointsIndex = 0;\n for (let c = 0; c < glyph.components.length; c++) {\n const component = glyph.components[c];\n const componentGlyph = this.font.glyphs.get(component.glyphIndex);\n const componentTransform = copyComponent(component);\n const deltaIndex = tuplePoints.indexOf(c);\n if (deltaIndex > -1) {\n componentTransform.dx += Math.round(header.deltas[deltaIndex] * factor);\n componentTransform.dy += Math.round(header.deltasY[deltaIndex] * factor);\n }\n const transformedComponentPoints = transformPoints(this.getTransform(componentGlyph, coords).points, componentTransform);\n transformedPoints.splice(pointsIndex, transformedComponentPoints.length, ...transformedComponentPoints);\n pointsIndex += componentGlyph.points.length;\n }\n }\n applyTupleVariationStore(variationData, points, coords, flavor = \"gvar\", args = {}) {\n if (!coords) {\n coords = this.font.variation.get();\n }\n const normalizedCoords = this.getNormalizedCoords(coords);\n const { headers, sharedPoints } = variationData;\n const axisCount = this.fvar().axes.length;\n let transformedPoints;\n if (flavor === \"gvar\") {\n transformedPoints = points.map(copyPoint);\n } else if (flavor === \"cvar\") {\n transformedPoints = [...points];\n }\n for (let h = 0; h < headers.length; h++) {\n const header = headers[h];\n let factor = 1;\n for (let a = 0; a < axisCount; a++) {\n let tupleCoords = [0];\n switch (flavor) {\n case \"gvar\":\n tupleCoords = header.peakTuple ? header.peakTuple : this.gvar().sharedTuples[header.sharedTupleRecordsIndex];\n break;\n case \"cvar\":\n tupleCoords = header.peakTuple;\n break;\n }\n if (tupleCoords[a] === 0) {\n continue;\n }\n if (normalizedCoords[a] === 0) {\n factor = 0;\n break;\n }\n if (!header.intermediateStartTuple) {\n if (normalizedCoords[a] < Math.min(0, tupleCoords[a]) || normalizedCoords[a] > Math.max(0, tupleCoords[a])) {\n factor = 0;\n break;\n }\n factor = (factor * normalizedCoords[a] + Number.EPSILON) / (tupleCoords[a] + Number.EPSILON);\n } else {\n if (normalizedCoords[a] < header.intermediateStartTuple[a] || normalizedCoords[a] > header.intermediateEndTuple[a]) {\n factor = 0;\n break;\n } else if (normalizedCoords[a] < tupleCoords[a]) {\n factor = factor * (normalizedCoords[a] - header.intermediateStartTuple[a] + Number.EPSILON) / (tupleCoords[a] - header.intermediateStartTuple[a] + Number.EPSILON);\n } else {\n factor = factor * (header.intermediateEndTuple[a] - normalizedCoords[a] + Number.EPSILON) / (header.intermediateEndTuple[a] - tupleCoords[a] + Number.EPSILON);\n }\n }\n }\n if (factor === 0) {\n continue;\n }\n const tuplePoints = header.privatePoints.length ? header.privatePoints : sharedPoints;\n if (flavor === \"gvar\" && args.glyph && args.glyph.isComposite) {\n this.transformComponents(args.glyph, transformedPoints, coords, tuplePoints, header, factor);\n } else if (tuplePoints.length === 0) {\n for (let i = 0; i < transformedPoints.length; i++) {\n const point = transformedPoints[i];\n if (flavor === \"gvar\") {\n transformedPoints[i] = {\n x: Math.round(point.x + header.deltas[i] * factor),\n y: Math.round(point.y + header.deltasY[i] * factor),\n onCurve: point.onCurve,\n lastPointOfContour: point.lastPointOfContour\n };\n } else if (flavor === \"cvar\") {\n transformedPoints[i] = Math.round(point + header.deltas[i] * factor);\n }\n }\n } else {\n let interpolatedPoints;\n if (flavor === \"gvar\") {\n interpolatedPoints = transformedPoints.map(copyPoint);\n } else if (flavor === \"cvar\") {\n interpolatedPoints = transformedPoints;\n }\n const deltaMap = Array(points.length).fill(false);\n for (let i = 0; i < tuplePoints.length; i++) {\n let pointIndex = tuplePoints[i];\n if (pointIndex < points.length) {\n let point = interpolatedPoints[pointIndex];\n if (flavor === \"gvar\") {\n deltaMap[pointIndex] = true;\n point.x += header.deltas[i] * factor;\n point.y += header.deltasY[i] * factor;\n } else if (flavor === \"cvar\") {\n transformedPoints[pointIndex] = Math.round(point + header.deltas[i] * factor);\n }\n }\n }\n if (flavor === \"gvar\") {\n this.interpolatePoints(interpolatedPoints, transformedPoints, deltaMap);\n for (let i = 0; i < points.length; i++) {\n let deltaX = interpolatedPoints[i].x - transformedPoints[i].x;\n let deltaY = interpolatedPoints[i].y - transformedPoints[i].y;\n transformedPoints[i].x = Math.round(transformedPoints[i].x + deltaX);\n transformedPoints[i].y = Math.round(transformedPoints[i].y + deltaY);\n }\n }\n }\n }\n return transformedPoints;\n }\n /**\n * Retrieves a transformed copy of a glyph based on the provided variation coordinates, or the glyph itself if no variation was applied\n * @param {opentype.Glyph|number} glyph - Glyph or index of glyph to transform.\n * @param {Object} coords - Variation coords object (will fall back to variation coords in the defaultRenderOptions)\n * @returns {opentype.Glyph} - The transformed glyph.\n */\n getTransform(glyph, coords) {\n if (Number.isInteger(glyph)) {\n glyph = this.font.glyphs.get(glyph);\n }\n const hasBlend = glyph.getBlendPath;\n const hasPoints = !!(glyph.points && glyph.points.length);\n let transformedGlyph = glyph;\n if (hasBlend || hasPoints) {\n if (!coords) {\n coords = this.font.variation.get();\n }\n if (hasPoints) {\n const variationData = this.gvar() && this.gvar().glyphVariations[glyph.index];\n if (variationData) {\n const glyphPoints = glyph.points;\n let transformedPoints = this.applyTupleVariationStore(variationData, glyphPoints, coords, \"gvar\", { glyph });\n transformedGlyph = new glyph_default(Object.assign({}, glyph, { points: transformedPoints, path: getPath(transformedPoints) }));\n }\n } else if (hasBlend) {\n const blendPath = glyph.getBlendPath(coords);\n transformedGlyph = new glyph_default(Object.assign({}, glyph, { path: blendPath }));\n }\n }\n if (this.font.tables.hvar) {\n glyph._advanceWidth = typeof glyph._advanceWidth !== \"undefined\" ? glyph._advanceWidth : glyph.advanceWidth;\n glyph.advanceWidth = transformedGlyph.advanceWidth = Math.round(glyph._advanceWidth + this.getVariableAdjustment(transformedGlyph.index, \"hvar\", \"advanceWidth\", coords));\n glyph._leftSideBearing = typeof glyph._leftSideBearing !== \"undefined\" ? glyph._leftSideBearing : glyph.leftSideBearing;\n glyph.leftSideBearing = transformedGlyph.leftSideBearing = Math.round(glyph._leftSideBearing + this.getVariableAdjustment(transformedGlyph.index, \"hvar\", \"lsb\", coords));\n }\n return transformedGlyph;\n }\n getCvarTransform(coords) {\n const cvt = this.font.tables.cvt;\n const variationData = this.cvar();\n if (!cvt || !cvt.length || !variationData || !variationData.headers.length) return cvt;\n return this.applyTupleVariationStore(variationData, cvt, coords, \"cvar\");\n }\n /**\n * Calculates the variable adjustment for a glyph property from variation data.\n * @param {number} gid - Glyph ID.\n * @param {string} tableName - The name of the variation data table.\n * @param {string} parameter - The property to adjust.\n * @param {Object} coords - Variation coordinates.\n * @returns {number} - The calculated adjustment.\n */\n getVariableAdjustment(gid, tableName, parameter, coords) {\n coords = coords || this.font.variation.get();\n let outerIndex, innerIndex;\n const table = this.font.tables[tableName];\n if (!table) {\n throw Error(`trying to get variation adjustment from non-existent table \"${table}\"`);\n }\n if (!table.itemVariationStore) {\n throw Error(`trying to get variation adjustment from table \"${table}\" which does not have an itemVariationStore`);\n }\n const mapSize = table[parameter] && table[parameter].map.length;\n if (mapSize) {\n let i = gid;\n if (i >= mapSize) {\n i = mapSize - 1;\n }\n ({ outerIndex, innerIndex } = table[parameter].map[i]);\n } else {\n outerIndex = 0;\n innerIndex = gid;\n }\n return this.getDelta(table.itemVariationStore, outerIndex, innerIndex, coords);\n }\n /**\n * Retrieves the delta value from a variation store.\n * @param {Object} itemStore - The item variation store.\n * @param {number} outerIndex - The outer index in the variation subtables.\n * @param {number} innerIndex - The inner index in the delta sets.\n * @param {Object} coords - Variation coordinates.\n * @returns {number} - The delta value.\n */\n getDelta(itemStore, outerIndex, innerIndex, coords) {\n if (outerIndex >= itemStore.itemVariationSubtables.length) {\n return 0;\n }\n let varData = itemStore.itemVariationSubtables[outerIndex];\n if (innerIndex >= varData.deltaSets.length) {\n return 0;\n }\n let deltaSet = varData.deltaSets[innerIndex];\n let blendVector = this.getBlendVector(itemStore, outerIndex, coords);\n let netAdjustment = 0;\n for (let master = 0; master < varData.regionIndexes.length; master++) {\n netAdjustment += deltaSet[master] * blendVector[master];\n }\n return netAdjustment;\n }\n /**\n * Calculates the blend vector for a set of variation coordinates.\n * @param {Object} itemStore - The item variation store.\n * @param {number} itemIndex - Index of the current item in the variation subtables.\n * @param {Object} coords - Variation coordinates.\n * @returns {Array<number>} - The blend vector for the given coordinates.\n */\n getBlendVector(itemStore, itemIndex, coords) {\n if (!coords) {\n coords = this.font.variation.get();\n }\n let varData = itemStore.itemVariationSubtables[itemIndex];\n const normalizedCoords = this.getNormalizedCoords(coords);\n let blendVector = [];\n for (let master = 0; master < varData.regionIndexes.length; master++) {\n let scalar = 1;\n let regionIndex = varData.regionIndexes[master];\n let axes = itemStore.variationRegions[regionIndex].regionAxes;\n for (let j = 0; j < axes.length; j++) {\n let axis = axes[j];\n let axisScalar;\n if (axis.startCoord > axis.peakCoord || axis.peakCoord > axis.endCoord) {\n axisScalar = 1;\n } else if (axis.startCoord < 0 && axis.endCoord > 0 && axis.peakCoord !== 0) {\n axisScalar = 1;\n } else if (axis.peakCoord === 0) {\n axisScalar = 1;\n } else if (normalizedCoords[j] < axis.startCoord || normalizedCoords[j] > axis.endCoord) {\n axisScalar = 0;\n } else {\n if (normalizedCoords[j] === axis.peakCoord) {\n axisScalar = 1;\n } else if (normalizedCoords[j] < axis.peakCoord) {\n axisScalar = (normalizedCoords[j] - axis.startCoord + Number.EPSILON) / (axis.peakCoord - axis.startCoord + Number.EPSILON);\n } else {\n axisScalar = (axis.endCoord - normalizedCoords[j] + Number.EPSILON) / (axis.endCoord - axis.peakCoord + Number.EPSILON);\n }\n }\n scalar *= axisScalar;\n }\n blendVector[master] = scalar;\n }\n return blendVector;\n }\n /**\n * Helper method that returns the font's avar table if present\n * @returns {Object|undefined}\n */\n avar() {\n return this.font.tables.avar;\n }\n /**\n * Helper method that returns the font's cvar table if present\n * @returns {Object|undefined}\n */\n cvar() {\n return this.font.tables.cvar;\n }\n /**\n * Helper method that returns the font's fvar table if present\n * @returns {Object|undefined}\n */\n fvar() {\n return this.font.tables.fvar;\n }\n /**\n * Helper method that returns the font's gvar table if present\n * @returns {Object|undefined}\n */\n gvar() {\n return this.font.tables.gvar;\n }\n /**\n * Helper method that returns the font's hvar table if present\n * @returns {Object|undefined}\n */\n hvar() {\n return this.font.tables.hvar;\n }\n };\n\n // src/variation.mjs\n var VariationManager = class {\n constructor(font) {\n this.font = font;\n this.process = new VariationProcessor(this.font);\n this.activateDefaultVariation();\n this.getTransform = this.process.getTransform.bind(this.process);\n }\n /**\n * Tries to determine the default instance and sets its variation data as the font.defaultRenderOptions.\n * If not defaultInstance can be determined, the default coordinates of all axes are used.\n */\n activateDefaultVariation() {\n const defaultInstance = this.getDefaultInstanceIndex();\n if (defaultInstance > -1) {\n this.set(defaultInstance);\n } else {\n this.set(this.getDefaultCoordinates());\n }\n }\n /**\n * Retrieves the default coordinates for the font's variation axes.\n * @returns {Object} An object mapping axis tags to their default values.\n */\n getDefaultCoordinates() {\n return this.fvar().axes.reduce((acc, axis) => {\n acc[axis.tag] = axis.defaultValue;\n return acc;\n }, {});\n }\n /**\n * Gets the index of the default variation instance or -1 if not able to determine\n * @returns {integer} default index or -1\n */\n getDefaultInstanceIndex() {\n const defaultCoordinates = this.getDefaultCoordinates();\n let defaultInstanceIndex = this.getInstanceIndex(defaultCoordinates);\n if (defaultInstanceIndex < 0) {\n defaultInstanceIndex = this.fvar().instances.findIndex((instance) => instance.name && instance.name.en === \"Regular\");\n }\n return defaultInstanceIndex;\n }\n /**\n * Retrieves the index of the variation instance matching the coordinates object or -1 if not able to determine\n * @param {integer|Object} coordinates An object where keys are axis tags and values are the corresponding variation values.\n * @returns {integer} The index of the matching instance or -1 if no match is found.\n */\n getInstanceIndex(coordinates) {\n return this.fvar().instances.findIndex(\n (instance) => Object.keys(coordinates).every(\n (axis) => instance.coordinates[axis] === coordinates[axis]\n )\n );\n }\n /**\n * Retrieves a variation instance by its zero-based index\n * @param {integer} index - zero-based index of the variation instance\n * @returns {Object} - variation instance or null if the index is invalid.\n */\n getInstance(index) {\n return this.fvar().instances && this.fvar().instances[index];\n }\n /**\n * Set the variation coordinates to use by default for rendering in the font.defaultRenderOptions\n * @param {integer|Object} instanceIdOrObject Either the zero-based index of a variation instance or an object with axis tags as keys and variation values as values\n */\n set(instanceIdOrObject) {\n let variationData;\n if (Number.isInteger(instanceIdOrObject)) {\n const instance = this.getInstance(instanceIdOrObject);\n if (!instance) {\n throw Error(`Invalid instance index ${instanceIdOrObject}`);\n }\n variationData = { ...instance.coordinates };\n } else {\n variationData = instanceIdOrObject;\n this.process.normalizeCoordTags(variationData);\n }\n variationData = Object.assign(\n {},\n this.font.defaultRenderOptions.variation,\n variationData\n );\n this.font.defaultRenderOptions = Object.assign(\n {},\n this.font.defaultRenderOptions,\n { variation: variationData }\n );\n }\n /**\n * Returns the variation coordinates currently set in the font.defaultRenderOptions\n * @returns {Object}\n */\n get() {\n return Object.assign({}, this.font.defaultRenderOptions.variation);\n }\n /**\n * Helper method that returns the font's avar table if present\n * @returns {Object|undefined}\n */\n avar() {\n return this.font.tables.avar;\n }\n /**\n * Helper method that returns the font's cvar table if present\n * @returns {Object|undefined}\n */\n cvar() {\n return this.font.tables.cvar;\n }\n /**\n * Helper method that returns the font's fvar table if present\n * @returns {Object|undefined}\n */\n fvar() {\n return this.font.tables.fvar;\n }\n /**\n * Helper method that returns the font's gvar table if present\n * @returns {Object|undefined}\n */\n gvar() {\n return this.font.tables.gvar;\n }\n /**\n * Helper method that returns the font's hvar table if present\n * @returns {Object|undefined}\n */\n hvar() {\n return this.font.tables.hvar;\n }\n };\n\n // src/hintingtt.mjs\n var MAX_INSTRUCTIONS = 1e6;\n var MAX_CALL_DEPTH2 = 64;\n var MAX_LOOP_COUNT = 1e4;\n var instructionTable;\n var exec;\n var execGlyph;\n var execComponent;\n function Hinting(font) {\n this.font = font;\n this.getCommands = function(hPoints) {\n return glyf_default.getPath(hPoints).commands;\n };\n this._fpgmState = this._prepState = void 0;\n this._errorState = 0;\n }\n function roundOff(v) {\n return v;\n }\n function roundToGrid(v) {\n return Math.sign(v) * Math.round(Math.abs(v));\n }\n function roundToDoubleGrid(v) {\n return Math.sign(v) * Math.round(Math.abs(v * 2)) / 2;\n }\n function roundToHalfGrid(v) {\n return Math.sign(v) * (Math.round(Math.abs(v) + 0.5) - 0.5);\n }\n function roundUpToGrid(v) {\n return Math.sign(v) * Math.ceil(Math.abs(v));\n }\n function roundDownToGrid(v) {\n return Math.sign(v) * Math.floor(Math.abs(v));\n }\n var roundSuper = function(v) {\n const period = this.srPeriod;\n let phase = this.srPhase;\n const threshold = this.srThreshold;\n let sign = 1;\n if (v < 0) {\n v = -v;\n sign = -1;\n }\n v += threshold - phase;\n v = Math.trunc(v / period) * period;\n v += phase;\n if (v < 0) return phase * sign;\n return v * sign;\n };\n var xUnitVector = {\n x: 1,\n y: 0,\n axis: \"x\",\n // Gets the projected distance between two points.\n // o1/o2 ... if true, respective original position is used.\n distance: function(p1, p2, o1, o2) {\n return (o1 ? p1.xo : p1.x) - (o2 ? p2.xo : p2.x);\n },\n // Moves point p so the moved position has the same relative\n // position to the moved positions of rp1 and rp2 than the\n // original positions had.\n //\n // See APPENDIX on INTERPOLATE at the bottom of this file.\n interpolate: function(p, rp1, rp2, pv) {\n let do1;\n let do2;\n let doa1;\n let doa2;\n let dm1;\n let dm2;\n let dt;\n if (!pv || pv === this) {\n do1 = p.xo - rp1.xo;\n do2 = p.xo - rp2.xo;\n dm1 = rp1.x - rp1.xo;\n dm2 = rp2.x - rp2.xo;\n doa1 = Math.abs(do1);\n doa2 = Math.abs(do2);\n dt = doa1 + doa2;\n if (dt === 0) {\n p.x = p.xo + (dm1 + dm2) / 2;\n return;\n }\n p.x = p.xo + (dm1 * doa2 + dm2 * doa1) / dt;\n return;\n }\n do1 = pv.distance(p, rp1, true, true);\n do2 = pv.distance(p, rp2, true, true);\n dm1 = pv.distance(rp1, rp1, false, true);\n dm2 = pv.distance(rp2, rp2, false, true);\n doa1 = Math.abs(do1);\n doa2 = Math.abs(do2);\n dt = doa1 + doa2;\n if (dt === 0) {\n xUnitVector.setRelative(p, p, (dm1 + dm2) / 2, pv, true);\n return;\n }\n xUnitVector.setRelative(p, p, (dm1 * doa2 + dm2 * doa1) / dt, pv, true);\n },\n // Slope of line normal to this\n normalSlope: Number.NEGATIVE_INFINITY,\n // Sets the point 'p' relative to point 'rp'\n // by the distance 'd'.\n //\n // See APPENDIX on SETRELATIVE at the bottom of this file.\n //\n // p ... point to set\n // rp ... reference point\n // d ... distance on projection vector\n // pv ... projection vector (undefined = this)\n // org ... if true, uses the original position of rp as reference.\n setRelative: function(p, rp, d, pv, org) {\n if (!pv || pv === this) {\n p.x = (org ? rp.xo : rp.x) + d;\n return;\n }\n const rpx = org ? rp.xo : rp.x;\n const rpy = org ? rp.yo : rp.y;\n const rpdx = rpx + d * pv.x;\n const rpdy = rpy + d * pv.y;\n p.x = rpdx + (p.y - rpdy) / pv.normalSlope;\n },\n // Slope of vector line.\n slope: 0,\n // Touches the point p.\n touch: function(p) {\n p.xTouched = true;\n },\n // Tests if a point p is touched.\n touched: function(p) {\n return p.xTouched;\n },\n // Untouches the point p.\n untouch: function(p) {\n p.xTouched = false;\n }\n };\n var yUnitVector = {\n x: 0,\n y: 1,\n axis: \"y\",\n // Gets the projected distance between two points.\n // o1/o2 ... if true, respective original position is used.\n distance: function(p1, p2, o1, o2) {\n return (o1 ? p1.yo : p1.y) - (o2 ? p2.yo : p2.y);\n },\n // Moves point p so the moved position has the same relative\n // position to the moved positions of rp1 and rp2 than the\n // original positions had.\n //\n // See APPENDIX on INTERPOLATE at the bottom of this file.\n interpolate: function(p, rp1, rp2, pv) {\n let do1;\n let do2;\n let doa1;\n let doa2;\n let dm1;\n let dm2;\n let dt;\n if (!pv || pv === this) {\n do1 = p.yo - rp1.yo;\n do2 = p.yo - rp2.yo;\n dm1 = rp1.y - rp1.yo;\n dm2 = rp2.y - rp2.yo;\n doa1 = Math.abs(do1);\n doa2 = Math.abs(do2);\n dt = doa1 + doa2;\n if (dt === 0) {\n p.y = p.yo + (dm1 + dm2) / 2;\n return;\n }\n p.y = p.yo + (dm1 * doa2 + dm2 * doa1) / dt;\n return;\n }\n do1 = pv.distance(p, rp1, true, true);\n do2 = pv.distance(p, rp2, true, true);\n dm1 = pv.distance(rp1, rp1, false, true);\n dm2 = pv.distance(rp2, rp2, false, true);\n doa1 = Math.abs(do1);\n doa2 = Math.abs(do2);\n dt = doa1 + doa2;\n if (dt === 0) {\n yUnitVector.setRelative(p, p, (dm1 + dm2) / 2, pv, true);\n return;\n }\n yUnitVector.setRelative(p, p, (dm1 * doa2 + dm2 * doa1) / dt, pv, true);\n },\n // Slope of line normal to this.\n normalSlope: 0,\n // Sets the point 'p' relative to point 'rp'\n // by the distance 'd'\n //\n // See APPENDIX on SETRELATIVE at the bottom of this file.\n //\n // p ... point to set\n // rp ... reference point\n // d ... distance on projection vector\n // pv ... projection vector (undefined = this)\n // org ... if true, uses the original position of rp as reference.\n setRelative: function(p, rp, d, pv, org) {\n if (!pv || pv === this) {\n p.y = (org ? rp.yo : rp.y) + d;\n return;\n }\n const rpx = org ? rp.xo : rp.x;\n const rpy = org ? rp.yo : rp.y;\n const rpdx = rpx + d * pv.x;\n const rpdy = rpy + d * pv.y;\n p.y = rpdy + pv.normalSlope * (p.x - rpdx);\n },\n // Slope of vector line.\n slope: Number.POSITIVE_INFINITY,\n // Touches the point p.\n touch: function(p) {\n p.yTouched = true;\n },\n // Tests if a point p is touched.\n touched: function(p) {\n return p.yTouched;\n },\n // Untouches the point p.\n untouch: function(p) {\n p.yTouched = false;\n }\n };\n Object.freeze(xUnitVector);\n Object.freeze(yUnitVector);\n function UnitVector(x, y) {\n this.x = x;\n this.y = y;\n this.axis = void 0;\n this.slope = y / x;\n this.normalSlope = -x / y;\n Object.freeze(this);\n }\n UnitVector.prototype.distance = function(p1, p2, o1, o2) {\n return this.x * xUnitVector.distance(p1, p2, o1, o2) + this.y * yUnitVector.distance(p1, p2, o1, o2);\n };\n UnitVector.prototype.interpolate = function(p, rp1, rp2, pv) {\n let dm1;\n let dm2;\n let do1;\n let do2;\n let doa1;\n let doa2;\n let dt;\n do1 = pv.distance(p, rp1, true, true);\n do2 = pv.distance(p, rp2, true, true);\n dm1 = pv.distance(rp1, rp1, false, true);\n dm2 = pv.distance(rp2, rp2, false, true);\n doa1 = Math.abs(do1);\n doa2 = Math.abs(do2);\n dt = doa1 + doa2;\n if (dt === 0) {\n this.setRelative(p, p, (dm1 + dm2) / 2, pv, true);\n return;\n }\n this.setRelative(p, p, (dm1 * doa2 + dm2 * doa1) / dt, pv, true);\n };\n UnitVector.prototype.setRelative = function(p, rp, d, pv, org) {\n pv = pv || this;\n const rpx = org ? rp.xo : rp.x;\n const rpy = org ? rp.yo : rp.y;\n const rpdx = rpx + d * pv.x;\n const rpdy = rpy + d * pv.y;\n const pvns = pv.normalSlope;\n const fvs = this.slope;\n const px = p.x;\n const py = p.y;\n p.x = (fvs * px - pvns * rpdx + rpdy - py) / (fvs - pvns);\n p.y = fvs * (p.x - px) + py;\n };\n UnitVector.prototype.touch = function(p) {\n p.xTouched = true;\n p.yTouched = true;\n };\n function getUnitVector(x, y) {\n const d = Math.sqrt(x * x + y * y);\n x /= d;\n y /= d;\n if (x === 1 && y === 0) return xUnitVector;\n else if (x === 0 && y === 1) return yUnitVector;\n else return new UnitVector(x, y);\n }\n function HPoint(x, y, lastPointOfContour, onCurve) {\n this.x = this.xo = Math.round(x * 64) / 64;\n this.y = this.yo = Math.round(y * 64) / 64;\n this.lastPointOfContour = lastPointOfContour;\n this.onCurve = onCurve;\n this.prevPointOnContour = void 0;\n this.nextPointOnContour = void 0;\n this.xTouched = false;\n this.yTouched = false;\n Object.preventExtensions(this);\n }\n HPoint.prototype.nextTouched = function(v) {\n let p = this.nextPointOnContour;\n while (!v.touched(p) && p !== this) p = p.nextPointOnContour;\n return p;\n };\n HPoint.prototype.prevTouched = function(v) {\n let p = this.prevPointOnContour;\n while (!v.touched(p) && p !== this) p = p.prevPointOnContour;\n return p;\n };\n var HPZero = Object.freeze(new HPoint(0, 0));\n var defaultState = {\n cvCutIn: 17 / 16,\n // control value cut in\n deltaBase: 9,\n deltaShift: 0.125,\n loop: 1,\n // loops some instructions\n minDis: 1,\n // minimum distance\n autoFlip: true\n };\n function State(env, prog) {\n this.env = env;\n this.stack = [];\n this.prog = prog;\n switch (env) {\n case \"glyf\":\n this.zp0 = this.zp1 = this.zp2 = 1;\n this.rp0 = this.rp1 = this.rp2 = 0;\n /* fall through */\n case \"prep\":\n this.fv = this.pv = this.dpv = xUnitVector;\n this.round = roundToGrid;\n }\n }\n Hinting.prototype.exec = function(glyph, ppem) {\n if (typeof ppem !== \"number\") {\n throw new Error(\"Point size is not a number!\");\n }\n if (this._errorState > 2) return;\n const font = this.font;\n let prepState = this._prepState;\n if (!prepState || prepState.ppem !== ppem) {\n let fpgmState = this._fpgmState;\n if (!fpgmState) {\n State.prototype = defaultState;\n fpgmState = this._fpgmState = new State(\"fpgm\", font.tables.fpgm);\n fpgmState.funcs = [];\n fpgmState.font = font;\n fpgmState.instructionCount = 0;\n fpgmState.callDepth = 0;\n if (false) {\n console.log(\"---EXEC FPGM---\");\n fpgmState.step = -1;\n }\n try {\n exec(fpgmState);\n } catch (e) {\n console.log(\"Hinting error in FPGM:\" + e);\n this._errorState = 3;\n return;\n }\n }\n State.prototype = fpgmState;\n prepState = this._prepState = new State(\"prep\", font.tables.prep);\n prepState.ppem = ppem;\n prepState.instructionCount = 0;\n prepState.callDepth = 0;\n const oCvt = font.variation && font.variation.process.getCvarTransform() || font.tables.cvt;\n if (oCvt) {\n const cvt = prepState.cvt = new Array(oCvt.length);\n const scale = ppem / font.unitsPerEm;\n for (let c = 0; c < oCvt.length; c++) {\n cvt[c] = oCvt[c] * scale;\n }\n } else {\n prepState.cvt = [];\n }\n if (false) {\n console.log(\"---EXEC PREP---\");\n prepState.step = -1;\n }\n try {\n exec(prepState);\n } catch (e) {\n if (this._errorState < 2) {\n console.log(\"Hinting error in PREP:\" + e);\n }\n this._errorState = 2;\n }\n }\n if (this._errorState > 1) return;\n try {\n return execGlyph(glyph, prepState);\n } catch (e) {\n if (this._errorState < 1) {\n console.log(\"Hinting error:\" + e);\n console.log(\"Note: further hinting errors are silenced\");\n }\n this._errorState = 1;\n return void 0;\n }\n };\n execGlyph = function(glyph, prepState) {\n const xScale = prepState.ppem / prepState.font.unitsPerEm;\n const yScale = xScale;\n let components = glyph.components;\n let contours;\n let gZone;\n let state;\n State.prototype = prepState;\n if (!components) {\n state = new State(\"glyf\", glyph.instructions);\n state.instructionCount = 0;\n state.callDepth = 0;\n if (false) {\n console.log(\"---EXEC GLYPH---\");\n state.step = -1;\n }\n execComponent(glyph, state, xScale, yScale);\n gZone = state.gZone;\n } else {\n const font = prepState.font;\n gZone = [];\n contours = [];\n for (let i = 0; i < components.length; i++) {\n const c = components[i];\n const cg = font.glyphs.get(c.glyphIndex);\n state = new State(\"glyf\", cg.instructions);\n state.instructionCount = 0;\n state.callDepth = 0;\n if (false) {\n console.log(\"---EXEC COMP \" + i + \"---\");\n state.step = -1;\n }\n execComponent(cg, state, xScale, yScale);\n const dx = Math.round(c.dx * xScale);\n const dy = Math.round(c.dy * yScale);\n const gz = state.gZone;\n const cc = state.contours;\n for (let pi = 0; pi < gz.length; pi++) {\n const p = gz[pi];\n p.xTouched = p.yTouched = false;\n p.xo = p.x = p.x + dx;\n p.yo = p.y = p.y + dy;\n }\n const gLen = gZone.length;\n gZone.push.apply(gZone, gz);\n for (let j = 0; j < cc.length; j++) {\n contours.push(cc[j] + gLen);\n }\n }\n if (glyph.instructions && !state.inhibitGridFit) {\n state = new State(\"glyf\", glyph.instructions);\n state.gZone = state.z0 = state.z1 = state.z2 = gZone;\n state.contours = contours;\n gZone.push(\n new HPoint(0, 0),\n new HPoint(Math.round(glyph.advanceWidth * xScale), 0)\n );\n if (false) {\n console.log(\"---EXEC COMPOSITE---\");\n state.step = -1;\n }\n exec(state);\n gZone.length -= 2;\n }\n }\n return gZone;\n };\n execComponent = function(glyph, state, xScale, yScale) {\n const points = glyph.points || [];\n const pLen = points.length;\n const gZone = state.gZone = state.z0 = state.z1 = state.z2 = [];\n const contours = state.contours = [];\n let cp;\n for (let i = 0; i < pLen; i++) {\n cp = points[i];\n gZone[i] = new HPoint(\n cp.x * xScale,\n cp.y * yScale,\n cp.lastPointOfContour,\n cp.onCurve\n );\n }\n let sp;\n let np;\n for (let i = 0; i < pLen; i++) {\n cp = gZone[i];\n if (!sp) {\n sp = cp;\n contours.push(i);\n }\n if (cp.lastPointOfContour) {\n cp.nextPointOnContour = sp;\n sp.prevPointOnContour = cp;\n sp = void 0;\n } else {\n np = gZone[i + 1];\n cp.nextPointOnContour = np;\n np.prevPointOnContour = cp;\n }\n }\n if (state.inhibitGridFit) return;\n if (false) {\n console.log(\"PROCESSING GLYPH\", state.stack);\n for (let i = 0; i < pLen; i++) {\n console.log(i, gZone[i].x, gZone[i].y);\n }\n }\n gZone.push(\n new HPoint(0, 0),\n new HPoint(Math.round(glyph.advanceWidth * xScale), 0)\n );\n exec(state);\n gZone.length -= 2;\n if (false) {\n console.log(\"FINISHED GLYPH\", state.stack);\n for (let i = 0; i < pLen; i++) {\n console.log(i, gZone[i].x, gZone[i].y);\n }\n }\n };\n exec = function(state) {\n let prog = state.prog;\n if (!prog) return;\n const pLen = prog.length;\n let ins;\n for (state.ip = 0; state.ip < pLen; state.ip++) {\n if (++state.instructionCount > MAX_INSTRUCTIONS) {\n throw new Error(\n \"Hinting instructions exceeded maximum of \" + MAX_INSTRUCTIONS\n );\n }\n if (false) state.step++;\n ins = instructionTable[prog[state.ip]];\n if (!ins) {\n throw new Error(\n \"unknown instruction: 0x\" + Number(prog[state.ip]).toString(16)\n );\n }\n ins(state);\n }\n };\n function initTZone(state) {\n const tZone = state.tZone = new Array(state.gZone.length);\n for (let i = 0; i < tZone.length; i++) {\n tZone[i] = new HPoint(0, 0);\n }\n }\n function skip(state, handleElse) {\n const prog = state.prog;\n let ip = state.ip;\n let nesting = 1;\n let ins;\n do {\n ins = prog[++ip];\n if (ins === 88)\n nesting++;\n else if (ins === 89)\n nesting--;\n else if (ins === 64)\n ip += prog[ip + 1] + 1;\n else if (ins === 65)\n ip += 2 * prog[ip + 1] + 1;\n else if (ins >= 176 && ins <= 183)\n ip += ins - 176 + 1;\n else if (ins >= 184 && ins <= 191)\n ip += (ins - 184 + 1) * 2;\n else if (handleElse && nesting === 1 && ins === 27)\n break;\n } while (nesting > 0);\n state.ip = ip;\n }\n function SVTCA(v, state) {\n if (false) console.log(state.step, \"SVTCA[\" + v.axis + \"]\");\n state.fv = state.pv = state.dpv = v;\n }\n function SPVTCA(v, state) {\n if (false) console.log(state.step, \"SPVTCA[\" + v.axis + \"]\");\n state.pv = state.dpv = v;\n }\n function SFVTCA(v, state) {\n if (false) console.log(state.step, \"SFVTCA[\" + v.axis + \"]\");\n state.fv = v;\n }\n function SPVTL(a, state) {\n const stack = state.stack;\n const p2i = stack.pop();\n const p1i = stack.pop();\n const p2 = state.z2[p2i];\n const p1 = state.z1[p1i];\n if (false) console.log(\"SPVTL[\" + a + \"]\", p2i, p1i);\n let dx;\n let dy;\n if (!a) {\n dx = p1.x - p2.x;\n dy = p1.y - p2.y;\n } else {\n dx = p2.y - p1.y;\n dy = p1.x - p2.x;\n }\n state.pv = state.dpv = getUnitVector(dx, dy);\n }\n function SFVTL(a, state) {\n const stack = state.stack;\n const p2i = stack.pop();\n const p1i = stack.pop();\n const p2 = state.z2[p2i];\n const p1 = state.z1[p1i];\n if (false) console.log(\"SFVTL[\" + a + \"]\", p2i, p1i);\n let dx;\n let dy;\n if (!a) {\n dx = p1.x - p2.x;\n dy = p1.y - p2.y;\n } else {\n dx = p2.y - p1.y;\n dy = p1.x - p2.x;\n }\n state.fv = getUnitVector(dx, dy);\n }\n function SPVFS(state) {\n const stack = state.stack;\n const y = stack.pop();\n const x = stack.pop();\n if (false) console.log(state.step, \"SPVFS[]\", y, x);\n state.pv = state.dpv = getUnitVector(x, y);\n }\n function SFVFS(state) {\n const stack = state.stack;\n const y = stack.pop();\n const x = stack.pop();\n if (false) console.log(state.step, \"SPVFS[]\", y, x);\n state.fv = getUnitVector(x, y);\n }\n function GPV(state) {\n const stack = state.stack;\n const pv = state.pv;\n if (false) console.log(state.step, \"GPV[]\");\n stack.push(pv.x * 16384);\n stack.push(pv.y * 16384);\n }\n function GFV(state) {\n const stack = state.stack;\n const fv = state.fv;\n if (false) console.log(state.step, \"GFV[]\");\n stack.push(fv.x * 16384);\n stack.push(fv.y * 16384);\n }\n function SFVTPV(state) {\n state.fv = state.pv;\n if (false) console.log(state.step, \"SFVTPV[]\");\n }\n function ISECT(state) {\n const stack = state.stack;\n const pa0i = stack.pop();\n const pa1i = stack.pop();\n const pb0i = stack.pop();\n const pb1i = stack.pop();\n const pi = stack.pop();\n const z0 = state.z0;\n const z1 = state.z1;\n const pa0 = z0[pa0i];\n const pa1 = z0[pa1i];\n const pb0 = z1[pb0i];\n const pb1 = z1[pb1i];\n const p = state.z2[pi];\n if (false) console.log(\"ISECT[], \", pa0i, pa1i, pb0i, pb1i, pi);\n const x1 = pa0.x;\n const y1 = pa0.y;\n const x2 = pa1.x;\n const y2 = pa1.y;\n const x3 = pb0.x;\n const y3 = pb0.y;\n const x4 = pb1.x;\n const y4 = pb1.y;\n const div = (x1 - x2) * (y3 - y4) - (y1 - y2) * (x3 - x4);\n const f1 = x1 * y2 - y1 * x2;\n const f2 = x3 * y4 - y3 * x4;\n p.x = (f1 * (x3 - x4) - f2 * (x1 - x2)) / div;\n p.y = (f1 * (y3 - y4) - f2 * (y1 - y2)) / div;\n }\n function SRP0(state) {\n state.rp0 = state.stack.pop();\n if (false) console.log(state.step, \"SRP0[]\", state.rp0);\n }\n function SRP1(state) {\n state.rp1 = state.stack.pop();\n if (false) console.log(state.step, \"SRP1[]\", state.rp1);\n }\n function SRP2(state) {\n state.rp2 = state.stack.pop();\n if (false) console.log(state.step, \"SRP2[]\", state.rp2);\n }\n function SZP0(state) {\n const n = state.stack.pop();\n if (false) console.log(state.step, \"SZP0[]\", n);\n state.zp0 = n;\n switch (n) {\n case 0:\n if (!state.tZone) initTZone(state);\n state.z0 = state.tZone;\n break;\n case 1:\n state.z0 = state.gZone;\n break;\n default:\n throw new Error(\"Invalid zone pointer\");\n }\n }\n function SZP1(state) {\n const n = state.stack.pop();\n if (false) console.log(state.step, \"SZP1[]\", n);\n state.zp1 = n;\n switch (n) {\n case 0:\n if (!state.tZone) initTZone(state);\n state.z1 = state.tZone;\n break;\n case 1:\n state.z1 = state.gZone;\n break;\n default:\n throw new Error(\"Invalid zone pointer\");\n }\n }\n function SZP2(state) {\n const n = state.stack.pop();\n if (false) console.log(state.step, \"SZP2[]\", n);\n state.zp2 = n;\n switch (n) {\n case 0:\n if (!state.tZone) initTZone(state);\n state.z2 = state.tZone;\n break;\n case 1:\n state.z2 = state.gZone;\n break;\n default:\n throw new Error(\"Invalid zone pointer\");\n }\n }\n function SZPS(state) {\n const n = state.stack.pop();\n if (false) console.log(state.step, \"SZPS[]\", n);\n state.zp0 = state.zp1 = state.zp2 = n;\n switch (n) {\n case 0:\n if (!state.tZone) initTZone(state);\n state.z0 = state.z1 = state.z2 = state.tZone;\n break;\n case 1:\n state.z0 = state.z1 = state.z2 = state.gZone;\n break;\n default:\n throw new Error(\"Invalid zone pointer\");\n }\n }\n function SLOOP(state) {\n state.loop = state.stack.pop();\n if (state.loop > MAX_LOOP_COUNT) {\n state.loop = MAX_LOOP_COUNT;\n }\n if (false) console.log(state.step, \"SLOOP[]\", state.loop);\n }\n function RTG(state) {\n if (false) console.log(state.step, \"RTG[]\");\n state.round = roundToGrid;\n }\n function RTHG(state) {\n if (false) console.log(state.step, \"RTHG[]\");\n state.round = roundToHalfGrid;\n }\n function SMD(state) {\n const d = state.stack.pop();\n if (false) console.log(state.step, \"SMD[]\", d);\n state.minDis = d / 64;\n }\n function ELSE(state) {\n if (false) console.log(state.step, \"ELSE[]\");\n skip(state, false);\n }\n function JMPR(state) {\n const o = state.stack.pop();\n if (false) console.log(state.step, \"JMPR[]\", o);\n state.ip += o - 1;\n }\n function SCVTCI(state) {\n const n = state.stack.pop();\n if (false) console.log(state.step, \"SCVTCI[]\", n);\n state.cvCutIn = n / 64;\n }\n function DUP(state) {\n const stack = state.stack;\n if (false) console.log(state.step, \"DUP[]\");\n stack.push(stack[stack.length - 1]);\n }\n function POP(state) {\n if (false) console.log(state.step, \"POP[]\");\n state.stack.pop();\n }\n function CLEAR(state) {\n if (false) console.log(state.step, \"CLEAR[]\");\n state.stack.length = 0;\n }\n function SWAP(state) {\n const stack = state.stack;\n const a = stack.pop();\n const b = stack.pop();\n if (false) console.log(state.step, \"SWAP[]\");\n stack.push(a);\n stack.push(b);\n }\n function DEPTH(state) {\n const stack = state.stack;\n if (false) console.log(state.step, \"DEPTH[]\");\n stack.push(stack.length);\n }\n function LOOPCALL(state) {\n const stack = state.stack;\n const fn = stack.pop();\n let c = stack.pop();\n if (c > MAX_LOOP_COUNT) c = MAX_LOOP_COUNT;\n if (false) console.log(state.step, \"LOOPCALL[]\", fn, c);\n if (++state.callDepth > MAX_CALL_DEPTH2) {\n throw new Error(\"Hinting call depth exceeded maximum of \" + MAX_CALL_DEPTH2);\n }\n const cip = state.ip;\n const cprog = state.prog;\n state.prog = state.funcs[fn];\n for (let i = 0; i < c; i++) {\n exec(state);\n if (false) console.log(\n ++state.step,\n i + 1 < c ? \"next loopcall\" : \"done loopcall\",\n i\n );\n }\n state.ip = cip;\n state.prog = cprog;\n state.callDepth--;\n }\n function CALL(state) {\n const fn = state.stack.pop();\n if (false) console.log(state.step, \"CALL[]\", fn);\n if (++state.callDepth > MAX_CALL_DEPTH2) {\n throw new Error(\"Hinting call depth exceeded maximum of \" + MAX_CALL_DEPTH2);\n }\n const cip = state.ip;\n const cprog = state.prog;\n state.prog = state.funcs[fn];\n exec(state);\n state.ip = cip;\n state.prog = cprog;\n state.callDepth--;\n if (false) console.log(++state.step, \"returning from\", fn);\n }\n function CINDEX(state) {\n const stack = state.stack;\n const k = stack.pop();\n if (false) console.log(state.step, \"CINDEX[]\", k);\n stack.push(stack[stack.length - k]);\n }\n function MINDEX(state) {\n const stack = state.stack;\n const k = stack.pop();\n if (false) console.log(state.step, \"MINDEX[]\", k);\n stack.push(stack.splice(stack.length - k, 1)[0]);\n }\n function FDEF(state) {\n if (state.env !== \"fpgm\") throw new Error(\"FDEF not allowed here\");\n const stack = state.stack;\n const prog = state.prog;\n let ip = state.ip;\n const fn = stack.pop();\n const ipBegin = ip;\n if (false) console.log(state.step, \"FDEF[]\", fn);\n while (prog[++ip] !== 45) ;\n state.ip = ip;\n state.funcs[fn] = prog.slice(ipBegin + 1, ip);\n }\n function MDAP(round, state) {\n const pi = state.stack.pop();\n const p = state.z0[pi];\n const fv = state.fv;\n const pv = state.pv;\n if (false) console.log(state.step, \"MDAP[\" + round + \"]\", pi);\n let d = pv.distance(p, HPZero);\n if (round) d = state.round(d);\n fv.setRelative(p, HPZero, d, pv);\n fv.touch(p);\n state.rp0 = state.rp1 = pi;\n }\n function IUP(v, state) {\n const z2 = state.z2;\n const pLen = z2.length - 2;\n let cp;\n let pp;\n let np;\n if (false) console.log(state.step, \"IUP[\" + v.axis + \"]\");\n for (let i = 0; i < pLen; i++) {\n cp = z2[i];\n if (v.touched(cp)) continue;\n pp = cp.prevTouched(v);\n if (pp === cp) continue;\n np = cp.nextTouched(v);\n if (pp === np) {\n v.setRelative(cp, cp, v.distance(pp, pp, false, true), v, true);\n }\n v.interpolate(cp, pp, np, v);\n }\n }\n function SHP(a, state) {\n const stack = state.stack;\n const rpi = a ? state.rp1 : state.rp2;\n const rp = (a ? state.z0 : state.z1)[rpi];\n const fv = state.fv;\n const pv = state.pv;\n let loop = state.loop;\n const z2 = state.z2;\n while (loop--) {\n const pi = stack.pop();\n const p = z2[pi];\n const d = pv.distance(rp, rp, false, true);\n fv.setRelative(p, p, d, pv);\n fv.touch(p);\n if (false) {\n console.log(\n state.step,\n (state.loop > 1 ? \"loop \" + (state.loop - loop) + \": \" : \"\") + \"SHP[\" + (a ? \"rp1\" : \"rp2\") + \"]\",\n pi\n );\n }\n }\n state.loop = 1;\n }\n function SHC(a, state) {\n const stack = state.stack;\n const rpi = a ? state.rp1 : state.rp2;\n const rp = (a ? state.z0 : state.z1)[rpi];\n const fv = state.fv;\n const pv = state.pv;\n const ci = stack.pop();\n const sp = state.z2[state.contours[ci]];\n let p = sp;\n if (false) console.log(state.step, \"SHC[\" + a + \"]\", ci);\n const d = pv.distance(rp, rp, false, true);\n do {\n if (p !== rp) fv.setRelative(p, p, d, pv);\n p = p.nextPointOnContour;\n } while (p !== sp);\n }\n function SHZ(a, state) {\n const stack = state.stack;\n const rpi = a ? state.rp1 : state.rp2;\n const rp = (a ? state.z0 : state.z1)[rpi];\n const fv = state.fv;\n const pv = state.pv;\n const e = stack.pop();\n if (false) console.log(state.step, \"SHZ[\" + a + \"]\", e);\n let z;\n switch (e) {\n case 0:\n z = state.tZone;\n break;\n case 1:\n z = state.gZone;\n break;\n default:\n throw new Error(\"Invalid zone\");\n }\n let p;\n const d = pv.distance(rp, rp, false, true);\n const pLen = z.length - 2;\n for (let i = 0; i < pLen; i++) {\n p = z[i];\n fv.setRelative(p, p, d, pv);\n }\n }\n function SHPIX(state) {\n const stack = state.stack;\n let loop = state.loop;\n const fv = state.fv;\n const d = stack.pop() / 64;\n const z2 = state.z2;\n while (loop--) {\n const pi = stack.pop();\n const p = z2[pi];\n if (false) {\n console.log(\n state.step,\n (state.loop > 1 ? \"loop \" + (state.loop - loop) + \": \" : \"\") + \"SHPIX[]\",\n pi,\n d\n );\n }\n fv.setRelative(p, p, d);\n fv.touch(p);\n }\n state.loop = 1;\n }\n function IP(state) {\n const stack = state.stack;\n const rp1i = state.rp1;\n const rp2i = state.rp2;\n let loop = state.loop;\n const rp1 = state.z0[rp1i];\n const rp2 = state.z1[rp2i];\n const fv = state.fv;\n const pv = state.dpv;\n const z2 = state.z2;\n while (loop--) {\n const pi = stack.pop();\n const p = z2[pi];\n if (false) {\n console.log(\n state.step,\n (state.loop > 1 ? \"loop \" + (state.loop - loop) + \": \" : \"\") + \"IP[]\",\n pi,\n rp1i,\n \"<->\",\n rp2i\n );\n }\n fv.interpolate(p, rp1, rp2, pv);\n fv.touch(p);\n }\n state.loop = 1;\n }\n function MSIRP(a, state) {\n const stack = state.stack;\n const d = stack.pop() / 64;\n const pi = stack.pop();\n const p = state.z1[pi];\n const rp0 = state.z0[state.rp0];\n const fv = state.fv;\n const pv = state.pv;\n fv.setRelative(p, rp0, d, pv);\n fv.touch(p);\n if (false) console.log(state.step, \"MSIRP[\" + a + \"]\", d, pi);\n state.rp1 = state.rp0;\n state.rp2 = pi;\n if (a) state.rp0 = pi;\n }\n function ALIGNRP(state) {\n const stack = state.stack;\n const rp0i = state.rp0;\n const rp0 = state.z0[rp0i];\n let loop = state.loop;\n const fv = state.fv;\n const pv = state.pv;\n const z1 = state.z1;\n while (loop--) {\n const pi = stack.pop();\n const p = z1[pi];\n if (false) {\n console.log(\n state.step,\n (state.loop > 1 ? \"loop \" + (state.loop - loop) + \": \" : \"\") + \"ALIGNRP[]\",\n pi\n );\n }\n fv.setRelative(p, rp0, 0, pv);\n fv.touch(p);\n }\n state.loop = 1;\n }\n function RTDG(state) {\n if (false) console.log(state.step, \"RTDG[]\");\n state.round = roundToDoubleGrid;\n }\n function MIAP(round, state) {\n const stack = state.stack;\n const n = stack.pop();\n const pi = stack.pop();\n const p = state.z0[pi];\n const fv = state.fv;\n const pv = state.pv;\n let cv = state.cvt[n];\n if (false) {\n console.log(\n state.step,\n \"MIAP[\" + round + \"]\",\n n,\n \"(\",\n cv,\n \")\",\n pi\n );\n }\n let d = pv.distance(p, HPZero);\n if (round) {\n if (Math.abs(d - cv) < state.cvCutIn) d = cv;\n d = state.round(d);\n }\n fv.setRelative(p, HPZero, d, pv);\n if (state.zp0 === 0) {\n p.xo = p.x;\n p.yo = p.y;\n }\n fv.touch(p);\n state.rp0 = state.rp1 = pi;\n }\n function NPUSHB(state) {\n const prog = state.prog;\n let ip = state.ip;\n const stack = state.stack;\n const n = prog[++ip];\n if (false) console.log(state.step, \"NPUSHB[]\", n);\n for (let i = 0; i < n; i++) stack.push(prog[++ip]);\n state.ip = ip;\n }\n function NPUSHW(state) {\n let ip = state.ip;\n const prog = state.prog;\n const stack = state.stack;\n const n = prog[++ip];\n if (false) console.log(state.step, \"NPUSHW[]\", n);\n for (let i = 0; i < n; i++) {\n let w = prog[++ip] << 8 | prog[++ip];\n if (w & 32768) w = -((w ^ 65535) + 1);\n stack.push(w);\n }\n state.ip = ip;\n }\n function WS(state) {\n const stack = state.stack;\n let store = state.store;\n if (!store) store = state.store = [];\n const v = stack.pop();\n const l = stack.pop();\n if (false) console.log(state.step, \"WS\", v, l);\n store[l] = v;\n }\n function RS(state) {\n const stack = state.stack;\n const store = state.store;\n const l = stack.pop();\n if (false) console.log(state.step, \"RS\", l);\n const v = store && store[l] || 0;\n stack.push(v);\n }\n function WCVTP(state) {\n const stack = state.stack;\n const v = stack.pop();\n const l = stack.pop();\n if (false) console.log(state.step, \"WCVTP\", v, l);\n state.cvt[l] = v / 64;\n }\n function RCVT(state) {\n const stack = state.stack;\n const cvte = stack.pop();\n if (false) console.log(state.step, \"RCVT\", cvte);\n stack.push(state.cvt[cvte] * 64);\n }\n function GC(a, state) {\n const stack = state.stack;\n const pi = stack.pop();\n const p = state.z2[pi];\n if (false) console.log(state.step, \"GC[\" + a + \"]\", pi);\n stack.push(state.dpv.distance(p, HPZero, a, false) * 64);\n }\n function MD(a, state) {\n const stack = state.stack;\n const pi2 = stack.pop();\n const pi1 = stack.pop();\n const p2 = state.z1[pi2];\n const p1 = state.z0[pi1];\n const d = state.dpv.distance(p1, p2, a, a);\n if (false) console.log(state.step, \"MD[\" + a + \"]\", pi2, pi1, \"->\", d);\n state.stack.push(Math.round(d * 64));\n }\n function MPPEM(state) {\n if (false) console.log(state.step, \"MPPEM[]\");\n state.stack.push(state.ppem);\n }\n function FLIPON(state) {\n if (false) console.log(state.step, \"FLIPON[]\");\n state.autoFlip = true;\n }\n function LT(state) {\n const stack = state.stack;\n const e2 = stack.pop();\n const e1 = stack.pop();\n if (false) console.log(state.step, \"LT[]\", e2, e1);\n stack.push(e1 < e2 ? 1 : 0);\n }\n function LTEQ(state) {\n const stack = state.stack;\n const e2 = stack.pop();\n const e1 = stack.pop();\n if (false) console.log(state.step, \"LTEQ[]\", e2, e1);\n stack.push(e1 <= e2 ? 1 : 0);\n }\n function GT(state) {\n const stack = state.stack;\n const e2 = stack.pop();\n const e1 = stack.pop();\n if (false) console.log(state.step, \"GT[]\", e2, e1);\n stack.push(e1 > e2 ? 1 : 0);\n }\n function GTEQ(state) {\n const stack = state.stack;\n const e2 = stack.pop();\n const e1 = stack.pop();\n if (false) console.log(state.step, \"GTEQ[]\", e2, e1);\n stack.push(e1 >= e2 ? 1 : 0);\n }\n function EQ(state) {\n const stack = state.stack;\n const e2 = stack.pop();\n const e1 = stack.pop();\n if (false) console.log(state.step, \"EQ[]\", e2, e1);\n stack.push(e2 === e1 ? 1 : 0);\n }\n function NEQ(state) {\n const stack = state.stack;\n const e2 = stack.pop();\n const e1 = stack.pop();\n if (false) console.log(state.step, \"NEQ[]\", e2, e1);\n stack.push(e2 !== e1 ? 1 : 0);\n }\n function ODD(state) {\n const stack = state.stack;\n const n = stack.pop();\n if (false) console.log(state.step, \"ODD[]\", n);\n stack.push(Math.trunc(n) & 1 ? 1 : 0);\n }\n function EVEN(state) {\n const stack = state.stack;\n const n = stack.pop();\n if (false) console.log(state.step, \"EVEN[]\", n);\n stack.push(Math.trunc(n) & 1 ? 0 : 1);\n }\n function IF(state) {\n let test = state.stack.pop();\n let ins;\n if (false) console.log(state.step, \"IF[]\", test);\n if (!test) {\n skip(state, true);\n if (false) console.log(state.step, ins === 27 ? \"ELSE[]\" : \"EIF[]\");\n }\n }\n function EIF(state) {\n if (false) console.log(state.step, \"EIF[]\");\n }\n function AND(state) {\n const stack = state.stack;\n const e2 = stack.pop();\n const e1 = stack.pop();\n if (false) console.log(state.step, \"AND[]\", e2, e1);\n stack.push(e2 && e1 ? 1 : 0);\n }\n function OR(state) {\n const stack = state.stack;\n const e2 = stack.pop();\n const e1 = stack.pop();\n if (false) console.log(state.step, \"OR[]\", e2, e1);\n stack.push(e2 || e1 ? 1 : 0);\n }\n function NOT(state) {\n const stack = state.stack;\n const e = stack.pop();\n if (false) console.log(state.step, \"NOT[]\", e);\n stack.push(e ? 0 : 1);\n }\n function DELTAP123(b, state) {\n const stack = state.stack;\n const n = stack.pop();\n const fv = state.fv;\n const pv = state.pv;\n const ppem = state.ppem;\n const base = state.deltaBase + (b - 1) * 16;\n const ds = state.deltaShift;\n const z0 = state.z0;\n if (false) console.log(state.step, \"DELTAP[\" + b + \"]\", n, stack);\n for (let i = 0; i < n; i++) {\n const pi = stack.pop();\n const arg = stack.pop();\n const appem = base + ((arg & 240) >> 4);\n if (appem !== ppem) continue;\n let mag = (arg & 15) - 8;\n if (mag >= 0) mag++;\n if (false) console.log(state.step, \"DELTAPFIX\", pi, \"by\", mag * ds);\n const p = z0[pi];\n fv.setRelative(p, p, mag * ds, pv);\n }\n }\n function SDB(state) {\n const stack = state.stack;\n const n = stack.pop();\n if (false) console.log(state.step, \"SDB[]\", n);\n state.deltaBase = n;\n }\n function SDS(state) {\n const stack = state.stack;\n const n = stack.pop();\n if (false) console.log(state.step, \"SDS[]\", n);\n state.deltaShift = Math.pow(0.5, n);\n }\n function ADD(state) {\n const stack = state.stack;\n const n2 = stack.pop();\n const n1 = stack.pop();\n if (false) console.log(state.step, \"ADD[]\", n2, n1);\n stack.push(n1 + n2);\n }\n function SUB(state) {\n const stack = state.stack;\n const n2 = stack.pop();\n const n1 = stack.pop();\n if (false) console.log(state.step, \"SUB[]\", n2, n1);\n stack.push(n1 - n2);\n }\n function DIV(state) {\n const stack = state.stack;\n const n2 = stack.pop();\n const n1 = stack.pop();\n if (false) console.log(state.step, \"DIV[]\", n2, n1);\n stack.push(n1 * 64 / n2);\n }\n function MUL(state) {\n const stack = state.stack;\n const n2 = stack.pop();\n const n1 = stack.pop();\n if (false) console.log(state.step, \"MUL[]\", n2, n1);\n stack.push(n1 * n2 / 64);\n }\n function ABS(state) {\n const stack = state.stack;\n const n = stack.pop();\n if (false) console.log(state.step, \"ABS[]\", n);\n stack.push(Math.abs(n));\n }\n function NEG(state) {\n const stack = state.stack;\n let n = stack.pop();\n if (false) console.log(state.step, \"NEG[]\", n);\n stack.push(-n);\n }\n function FLOOR(state) {\n const stack = state.stack;\n const n = stack.pop();\n if (false) console.log(state.step, \"FLOOR[]\", n);\n stack.push(Math.floor(n / 64) * 64);\n }\n function CEILING(state) {\n const stack = state.stack;\n const n = stack.pop();\n if (false) console.log(state.step, \"CEILING[]\", n);\n stack.push(Math.ceil(n / 64) * 64);\n }\n function ROUND(dt, state) {\n const stack = state.stack;\n const n = stack.pop();\n if (false) console.log(state.step, \"ROUND[]\");\n stack.push(state.round(n / 64) * 64);\n }\n function WCVTF(state) {\n const stack = state.stack;\n const v = stack.pop();\n const l = stack.pop();\n if (false) console.log(state.step, \"WCVTF[]\", v, l);\n state.cvt[l] = v * state.ppem / state.font.unitsPerEm;\n }\n function DELTAC123(b, state) {\n const stack = state.stack;\n const n = stack.pop();\n const ppem = state.ppem;\n const base = state.deltaBase + (b - 1) * 16;\n const ds = state.deltaShift;\n if (false) console.log(state.step, \"DELTAC[\" + b + \"]\", n, stack);\n for (let i = 0; i < n; i++) {\n const c = stack.pop();\n const arg = stack.pop();\n const appem = base + ((arg & 240) >> 4);\n if (appem !== ppem) continue;\n let mag = (arg & 15) - 8;\n if (mag >= 0) mag++;\n const delta = mag * ds;\n if (false) console.log(state.step, \"DELTACFIX\", c, \"by\", delta);\n state.cvt[c] += delta;\n }\n }\n function SROUND(state) {\n let n = state.stack.pop();\n if (false) console.log(state.step, \"SROUND[]\", n);\n state.round = roundSuper;\n let period;\n switch (n & 192) {\n case 0:\n period = 0.5;\n break;\n case 64:\n period = 1;\n break;\n case 128:\n period = 2;\n break;\n default:\n throw new Error(\"invalid SROUND value\");\n }\n state.srPeriod = period;\n switch (n & 48) {\n case 0:\n state.srPhase = 0;\n break;\n case 16:\n state.srPhase = 0.25 * period;\n break;\n case 32:\n state.srPhase = 0.5 * period;\n break;\n case 48:\n state.srPhase = 0.75 * period;\n break;\n default:\n throw new Error(\"invalid SROUND value\");\n }\n n &= 15;\n if (n === 0) state.srThreshold = 0;\n else state.srThreshold = (n / 8 - 0.5) * period;\n }\n function S45ROUND(state) {\n let n = state.stack.pop();\n if (false) console.log(state.step, \"S45ROUND[]\", n);\n state.round = roundSuper;\n let period;\n switch (n & 192) {\n case 0:\n period = Math.sqrt(2) / 2;\n break;\n case 64:\n period = Math.sqrt(2);\n break;\n case 128:\n period = 2 * Math.sqrt(2);\n break;\n default:\n throw new Error(\"invalid S45ROUND value\");\n }\n state.srPeriod = period;\n switch (n & 48) {\n case 0:\n state.srPhase = 0;\n break;\n case 16:\n state.srPhase = 0.25 * period;\n break;\n case 32:\n state.srPhase = 0.5 * period;\n break;\n case 48:\n state.srPhase = 0.75 * period;\n break;\n default:\n throw new Error(\"invalid S45ROUND value\");\n }\n n &= 15;\n if (n === 0) state.srThreshold = 0;\n else state.srThreshold = (n / 8 - 0.5) * period;\n }\n function ROFF(state) {\n if (false) console.log(state.step, \"ROFF[]\");\n state.round = roundOff;\n }\n function RUTG(state) {\n if (false) console.log(state.step, \"RUTG[]\");\n state.round = roundUpToGrid;\n }\n function RDTG(state) {\n if (false) console.log(state.step, \"RDTG[]\");\n state.round = roundDownToGrid;\n }\n function SCANCTRL(state) {\n const n = state.stack.pop();\n if (false) console.log(state.step, \"SCANCTRL[]\", n);\n }\n function SDPVTL(a, state) {\n const stack = state.stack;\n const p2i = stack.pop();\n const p1i = stack.pop();\n const p2 = state.z2[p2i];\n const p1 = state.z1[p1i];\n if (false) console.log(state.step, \"SDPVTL[\" + a + \"]\", p2i, p1i);\n let dx;\n let dy;\n if (!a) {\n dx = p1.x - p2.x;\n dy = p1.y - p2.y;\n } else {\n dx = p2.y - p1.y;\n dy = p1.x - p2.x;\n }\n state.dpv = getUnitVector(dx, dy);\n }\n function GETINFO(state) {\n const stack = state.stack;\n const sel = stack.pop();\n let r = 0;\n if (false) console.log(state.step, \"GETINFO[]\", sel);\n if (sel & 1) r = 35;\n if (sel & 32) r |= 4096;\n stack.push(r);\n }\n function ROLL(state) {\n const stack = state.stack;\n const a = stack.pop();\n const b = stack.pop();\n const c = stack.pop();\n if (false) console.log(state.step, \"ROLL[]\");\n stack.push(b);\n stack.push(a);\n stack.push(c);\n }\n function MAX(state) {\n const stack = state.stack;\n const e2 = stack.pop();\n const e1 = stack.pop();\n if (false) console.log(state.step, \"MAX[]\", e2, e1);\n stack.push(Math.max(e1, e2));\n }\n function MIN(state) {\n const stack = state.stack;\n const e2 = stack.pop();\n const e1 = stack.pop();\n if (false) console.log(state.step, \"MIN[]\", e2, e1);\n stack.push(Math.min(e1, e2));\n }\n function SCANTYPE(state) {\n const n = state.stack.pop();\n if (false) console.log(state.step, \"SCANTYPE[]\", n);\n }\n function INSTCTRL(state) {\n const s = state.stack.pop();\n let v = state.stack.pop();\n if (false) console.log(state.step, \"INSTCTRL[]\", s, v);\n switch (s) {\n case 1:\n state.inhibitGridFit = !!v;\n return;\n case 2:\n state.ignoreCvt = !!v;\n return;\n default:\n throw new Error(\"invalid INSTCTRL[] selector\");\n }\n }\n function PUSHB(n, state) {\n const stack = state.stack;\n const prog = state.prog;\n let ip = state.ip;\n if (false) console.log(state.step, \"PUSHB[\" + n + \"]\");\n for (let i = 0; i < n; i++) stack.push(prog[++ip]);\n state.ip = ip;\n }\n function PUSHW(n, state) {\n let ip = state.ip;\n const prog = state.prog;\n const stack = state.stack;\n if (false) console.log(state.ip, \"PUSHW[\" + n + \"]\");\n for (let i = 0; i < n; i++) {\n let w = prog[++ip] << 8 | prog[++ip];\n if (w & 32768) w = -((w ^ 65535) + 1);\n stack.push(w);\n }\n state.ip = ip;\n }\n function MDRP_MIRP(indirect, setRp0, keepD, ro, dt, state) {\n const stack = state.stack;\n const cvte = indirect && stack.pop();\n const pi = stack.pop();\n const rp0i = state.rp0;\n const rp = state.z0[rp0i];\n const p = state.z1[pi];\n const md = state.minDis;\n const fv = state.fv;\n const pv = state.dpv;\n let od;\n let d;\n let sign;\n let cv;\n d = od = pv.distance(p, rp, true, true);\n sign = d >= 0 ? 1 : -1;\n d = Math.abs(d);\n if (indirect) {\n cv = state.cvt[cvte];\n if (ro && Math.abs(d - cv) < state.cvCutIn) d = cv;\n }\n if (keepD && d < md) d = md;\n if (ro) d = state.round(d);\n fv.setRelative(p, rp, sign * d, pv);\n fv.touch(p);\n if (false) {\n console.log(\n state.step,\n (indirect ? \"MIRP[\" : \"MDRP[\") + (setRp0 ? \"M\" : \"m\") + (keepD ? \">\" : \"_\") + (ro ? \"R\" : \"_\") + (dt === 0 ? \"Gr\" : dt === 1 ? \"Bl\" : dt === 2 ? \"Wh\" : \"\") + \"]\",\n indirect ? cvte + \"(\" + state.cvt[cvte] + \",\" + cv + \")\" : \"\",\n pi,\n \"(d =\",\n od,\n \"->\",\n sign * d,\n \")\"\n );\n }\n state.rp1 = state.rp0;\n state.rp2 = pi;\n if (setRp0) state.rp0 = pi;\n }\n instructionTable = [\n /* 0x00 */\n SVTCA.bind(void 0, yUnitVector),\n /* 0x01 */\n SVTCA.bind(void 0, xUnitVector),\n /* 0x02 */\n SPVTCA.bind(void 0, yUnitVector),\n /* 0x03 */\n SPVTCA.bind(void 0, xUnitVector),\n /* 0x04 */\n SFVTCA.bind(void 0, yUnitVector),\n /* 0x05 */\n SFVTCA.bind(void 0, xUnitVector),\n /* 0x06 */\n SPVTL.bind(void 0, 0),\n /* 0x07 */\n SPVTL.bind(void 0, 1),\n /* 0x08 */\n SFVTL.bind(void 0, 0),\n /* 0x09 */\n SFVTL.bind(void 0, 1),\n /* 0x0A */\n SPVFS,\n /* 0x0B */\n SFVFS,\n /* 0x0C */\n GPV,\n /* 0x0D */\n GFV,\n /* 0x0E */\n SFVTPV,\n /* 0x0F */\n ISECT,\n /* 0x10 */\n SRP0,\n /* 0x11 */\n SRP1,\n /* 0x12 */\n SRP2,\n /* 0x13 */\n SZP0,\n /* 0x14 */\n SZP1,\n /* 0x15 */\n SZP2,\n /* 0x16 */\n SZPS,\n /* 0x17 */\n SLOOP,\n /* 0x18 */\n RTG,\n /* 0x19 */\n RTHG,\n /* 0x1A */\n SMD,\n /* 0x1B */\n ELSE,\n /* 0x1C */\n JMPR,\n /* 0x1D */\n SCVTCI,\n /* 0x1E */\n void 0,\n // TODO SSWCI\n /* 0x1F */\n void 0,\n // TODO SSW\n /* 0x20 */\n DUP,\n /* 0x21 */\n POP,\n /* 0x22 */\n CLEAR,\n /* 0x23 */\n SWAP,\n /* 0x24 */\n DEPTH,\n /* 0x25 */\n CINDEX,\n /* 0x26 */\n MINDEX,\n /* 0x27 */\n void 0,\n // TODO ALIGNPTS\n /* 0x28 */\n void 0,\n /* 0x29 */\n void 0,\n // TODO UTP\n /* 0x2A */\n LOOPCALL,\n /* 0x2B */\n CALL,\n /* 0x2C */\n FDEF,\n /* 0x2D */\n void 0,\n // ENDF (eaten by FDEF)\n /* 0x2E */\n MDAP.bind(void 0, 0),\n /* 0x2F */\n MDAP.bind(void 0, 1),\n /* 0x30 */\n IUP.bind(void 0, yUnitVector),\n /* 0x31 */\n IUP.bind(void 0, xUnitVector),\n /* 0x32 */\n SHP.bind(void 0, 0),\n /* 0x33 */\n SHP.bind(void 0, 1),\n /* 0x34 */\n SHC.bind(void 0, 0),\n /* 0x35 */\n SHC.bind(void 0, 1),\n /* 0x36 */\n SHZ.bind(void 0, 0),\n /* 0x37 */\n SHZ.bind(void 0, 1),\n /* 0x38 */\n SHPIX,\n /* 0x39 */\n IP,\n /* 0x3A */\n MSIRP.bind(void 0, 0),\n /* 0x3B */\n MSIRP.bind(void 0, 1),\n /* 0x3C */\n ALIGNRP,\n /* 0x3D */\n RTDG,\n /* 0x3E */\n MIAP.bind(void 0, 0),\n /* 0x3F */\n MIAP.bind(void 0, 1),\n /* 0x40 */\n NPUSHB,\n /* 0x41 */\n NPUSHW,\n /* 0x42 */\n WS,\n /* 0x43 */\n RS,\n /* 0x44 */\n WCVTP,\n /* 0x45 */\n RCVT,\n /* 0x46 */\n GC.bind(void 0, 0),\n /* 0x47 */\n GC.bind(void 0, 1),\n /* 0x48 */\n void 0,\n // TODO SCFS\n /* 0x49 */\n MD.bind(void 0, 0),\n /* 0x4A */\n MD.bind(void 0, 1),\n /* 0x4B */\n MPPEM,\n /* 0x4C */\n void 0,\n // TODO MPS\n /* 0x4D */\n FLIPON,\n /* 0x4E */\n void 0,\n // TODO FLIPOFF\n /* 0x4F */\n void 0,\n // TODO DEBUG\n /* 0x50 */\n LT,\n /* 0x51 */\n LTEQ,\n /* 0x52 */\n GT,\n /* 0x53 */\n GTEQ,\n /* 0x54 */\n EQ,\n /* 0x55 */\n NEQ,\n /* 0x56 */\n ODD,\n /* 0x57 */\n EVEN,\n /* 0x58 */\n IF,\n /* 0x59 */\n EIF,\n /* 0x5A */\n AND,\n /* 0x5B */\n OR,\n /* 0x5C */\n NOT,\n /* 0x5D */\n DELTAP123.bind(void 0, 1),\n /* 0x5E */\n SDB,\n /* 0x5F */\n SDS,\n /* 0x60 */\n ADD,\n /* 0x61 */\n SUB,\n /* 0x62 */\n DIV,\n /* 0x63 */\n MUL,\n /* 0x64 */\n ABS,\n /* 0x65 */\n NEG,\n /* 0x66 */\n FLOOR,\n /* 0x67 */\n CEILING,\n /* 0x68 */\n ROUND.bind(void 0, 0),\n /* 0x69 */\n ROUND.bind(void 0, 1),\n /* 0x6A */\n ROUND.bind(void 0, 2),\n /* 0x6B */\n ROUND.bind(void 0, 3),\n /* 0x6C */\n void 0,\n // TODO NROUND[ab]\n /* 0x6D */\n void 0,\n // TODO NROUND[ab]\n /* 0x6E */\n void 0,\n // TODO NROUND[ab]\n /* 0x6F */\n void 0,\n // TODO NROUND[ab]\n /* 0x70 */\n WCVTF,\n /* 0x71 */\n DELTAP123.bind(void 0, 2),\n /* 0x72 */\n DELTAP123.bind(void 0, 3),\n /* 0x73 */\n DELTAC123.bind(void 0, 1),\n /* 0x74 */\n DELTAC123.bind(void 0, 2),\n /* 0x75 */\n DELTAC123.bind(void 0, 3),\n /* 0x76 */\n SROUND,\n /* 0x77 */\n S45ROUND,\n /* 0x78 */\n void 0,\n // TODO JROT[]\n /* 0x79 */\n void 0,\n // TODO JROF[]\n /* 0x7A */\n ROFF,\n /* 0x7B */\n void 0,\n /* 0x7C */\n RUTG,\n /* 0x7D */\n RDTG,\n /* 0x7E */\n POP,\n // actually SANGW, supposed to do only a pop though\n /* 0x7F */\n POP,\n // actually AA, supposed to do only a pop though\n /* 0x80 */\n void 0,\n // TODO FLIPPT\n /* 0x81 */\n void 0,\n // TODO FLIPRGON\n /* 0x82 */\n void 0,\n // TODO FLIPRGOFF\n /* 0x83 */\n void 0,\n /* 0x84 */\n void 0,\n /* 0x85 */\n SCANCTRL,\n /* 0x86 */\n SDPVTL.bind(void 0, 0),\n /* 0x87 */\n SDPVTL.bind(void 0, 1),\n /* 0x88 */\n GETINFO,\n /* 0x89 */\n void 0,\n // TODO IDEF\n /* 0x8A */\n ROLL,\n /* 0x8B */\n MAX,\n /* 0x8C */\n MIN,\n /* 0x8D */\n SCANTYPE,\n /* 0x8E */\n INSTCTRL,\n /* 0x8F */\n void 0,\n /* 0x90 */\n void 0,\n /* 0x91 */\n void 0,\n /* 0x92 */\n void 0,\n /* 0x93 */\n void 0,\n /* 0x94 */\n void 0,\n /* 0x95 */\n void 0,\n /* 0x96 */\n void 0,\n /* 0x97 */\n void 0,\n /* 0x98 */\n void 0,\n /* 0x99 */\n void 0,\n /* 0x9A */\n void 0,\n /* 0x9B */\n void 0,\n /* 0x9C */\n void 0,\n /* 0x9D */\n void 0,\n /* 0x9E */\n void 0,\n /* 0x9F */\n void 0,\n /* 0xA0 */\n void 0,\n /* 0xA1 */\n void 0,\n /* 0xA2 */\n void 0,\n /* 0xA3 */\n void 0,\n /* 0xA4 */\n void 0,\n /* 0xA5 */\n void 0,\n /* 0xA6 */\n void 0,\n /* 0xA7 */\n void 0,\n /* 0xA8 */\n void 0,\n /* 0xA9 */\n void 0,\n /* 0xAA */\n void 0,\n /* 0xAB */\n void 0,\n /* 0xAC */\n void 0,\n /* 0xAD */\n void 0,\n /* 0xAE */\n void 0,\n /* 0xAF */\n void 0,\n /* 0xB0 */\n PUSHB.bind(void 0, 1),\n /* 0xB1 */\n PUSHB.bind(void 0, 2),\n /* 0xB2 */\n PUSHB.bind(void 0, 3),\n /* 0xB3 */\n PUSHB.bind(void 0, 4),\n /* 0xB4 */\n PUSHB.bind(void 0, 5),\n /* 0xB5 */\n PUSHB.bind(void 0, 6),\n /* 0xB6 */\n PUSHB.bind(void 0, 7),\n /* 0xB7 */\n PUSHB.bind(void 0, 8),\n /* 0xB8 */\n PUSHW.bind(void 0, 1),\n /* 0xB9 */\n PUSHW.bind(void 0, 2),\n /* 0xBA */\n PUSHW.bind(void 0, 3),\n /* 0xBB */\n PUSHW.bind(void 0, 4),\n /* 0xBC */\n PUSHW.bind(void 0, 5),\n /* 0xBD */\n PUSHW.bind(void 0, 6),\n /* 0xBE */\n PUSHW.bind(void 0, 7),\n /* 0xBF */\n PUSHW.bind(void 0, 8),\n /* 0xC0 */\n MDRP_MIRP.bind(void 0, 0, 0, 0, 0, 0),\n /* 0xC1 */\n MDRP_MIRP.bind(void 0, 0, 0, 0, 0, 1),\n /* 0xC2 */\n MDRP_MIRP.bind(void 0, 0, 0, 0, 0, 2),\n /* 0xC3 */\n MDRP_MIRP.bind(void 0, 0, 0, 0, 0, 3),\n /* 0xC4 */\n MDRP_MIRP.bind(void 0, 0, 0, 0, 1, 0),\n /* 0xC5 */\n MDRP_MIRP.bind(void 0, 0, 0, 0, 1, 1),\n /* 0xC6 */\n MDRP_MIRP.bind(void 0, 0, 0, 0, 1, 2),\n /* 0xC7 */\n MDRP_MIRP.bind(void 0, 0, 0, 0, 1, 3),\n /* 0xC8 */\n MDRP_MIRP.bind(void 0, 0, 0, 1, 0, 0),\n /* 0xC9 */\n MDRP_MIRP.bind(void 0, 0, 0, 1, 0, 1),\n /* 0xCA */\n MDRP_MIRP.bind(void 0, 0, 0, 1, 0, 2),\n /* 0xCB */\n MDRP_MIRP.bind(void 0, 0, 0, 1, 0, 3),\n /* 0xCC */\n MDRP_MIRP.bind(void 0, 0, 0, 1, 1, 0),\n /* 0xCD */\n MDRP_MIRP.bind(void 0, 0, 0, 1, 1, 1),\n /* 0xCE */\n MDRP_MIRP.bind(void 0, 0, 0, 1, 1, 2),\n /* 0xCF */\n MDRP_MIRP.bind(void 0, 0, 0, 1, 1, 3),\n /* 0xD0 */\n MDRP_MIRP.bind(void 0, 0, 1, 0, 0, 0),\n /* 0xD1 */\n MDRP_MIRP.bind(void 0, 0, 1, 0, 0, 1),\n /* 0xD2 */\n MDRP_MIRP.bind(void 0, 0, 1, 0, 0, 2),\n /* 0xD3 */\n MDRP_MIRP.bind(void 0, 0, 1, 0, 0, 3),\n /* 0xD4 */\n MDRP_MIRP.bind(void 0, 0, 1, 0, 1, 0),\n /* 0xD5 */\n MDRP_MIRP.bind(void 0, 0, 1, 0, 1, 1),\n /* 0xD6 */\n MDRP_MIRP.bind(void 0, 0, 1, 0, 1, 2),\n /* 0xD7 */\n MDRP_MIRP.bind(void 0, 0, 1, 0, 1, 3),\n /* 0xD8 */\n MDRP_MIRP.bind(void 0, 0, 1, 1, 0, 0),\n /* 0xD9 */\n MDRP_MIRP.bind(void 0, 0, 1, 1, 0, 1),\n /* 0xDA */\n MDRP_MIRP.bind(void 0, 0, 1, 1, 0, 2),\n /* 0xDB */\n MDRP_MIRP.bind(void 0, 0, 1, 1, 0, 3),\n /* 0xDC */\n MDRP_MIRP.bind(void 0, 0, 1, 1, 1, 0),\n /* 0xDD */\n MDRP_MIRP.bind(void 0, 0, 1, 1, 1, 1),\n /* 0xDE */\n MDRP_MIRP.bind(void 0, 0, 1, 1, 1, 2),\n /* 0xDF */\n MDRP_MIRP.bind(void 0, 0, 1, 1, 1, 3),\n /* 0xE0 */\n MDRP_MIRP.bind(void 0, 1, 0, 0, 0, 0),\n /* 0xE1 */\n MDRP_MIRP.bind(void 0, 1, 0, 0, 0, 1),\n /* 0xE2 */\n MDRP_MIRP.bind(void 0, 1, 0, 0, 0, 2),\n /* 0xE3 */\n MDRP_MIRP.bind(void 0, 1, 0, 0, 0, 3),\n /* 0xE4 */\n MDRP_MIRP.bind(void 0, 1, 0, 0, 1, 0),\n /* 0xE5 */\n MDRP_MIRP.bind(void 0, 1, 0, 0, 1, 1),\n /* 0xE6 */\n MDRP_MIRP.bind(void 0, 1, 0, 0, 1, 2),\n /* 0xE7 */\n MDRP_MIRP.bind(void 0, 1, 0, 0, 1, 3),\n /* 0xE8 */\n MDRP_MIRP.bind(void 0, 1, 0, 1, 0, 0),\n /* 0xE9 */\n MDRP_MIRP.bind(void 0, 1, 0, 1, 0, 1),\n /* 0xEA */\n MDRP_MIRP.bind(void 0, 1, 0, 1, 0, 2),\n /* 0xEB */\n MDRP_MIRP.bind(void 0, 1, 0, 1, 0, 3),\n /* 0xEC */\n MDRP_MIRP.bind(void 0, 1, 0, 1, 1, 0),\n /* 0xED */\n MDRP_MIRP.bind(void 0, 1, 0, 1, 1, 1),\n /* 0xEE */\n MDRP_MIRP.bind(void 0, 1, 0, 1, 1, 2),\n /* 0xEF */\n MDRP_MIRP.bind(void 0, 1, 0, 1, 1, 3),\n /* 0xF0 */\n MDRP_MIRP.bind(void 0, 1, 1, 0, 0, 0),\n /* 0xF1 */\n MDRP_MIRP.bind(void 0, 1, 1, 0, 0, 1),\n /* 0xF2 */\n MDRP_MIRP.bind(void 0, 1, 1, 0, 0, 2),\n /* 0xF3 */\n MDRP_MIRP.bind(void 0, 1, 1, 0, 0, 3),\n /* 0xF4 */\n MDRP_MIRP.bind(void 0, 1, 1, 0, 1, 0),\n /* 0xF5 */\n MDRP_MIRP.bind(void 0, 1, 1, 0, 1, 1),\n /* 0xF6 */\n MDRP_MIRP.bind(void 0, 1, 1, 0, 1, 2),\n /* 0xF7 */\n MDRP_MIRP.bind(void 0, 1, 1, 0, 1, 3),\n /* 0xF8 */\n MDRP_MIRP.bind(void 0, 1, 1, 1, 0, 0),\n /* 0xF9 */\n MDRP_MIRP.bind(void 0, 1, 1, 1, 0, 1),\n /* 0xFA */\n MDRP_MIRP.bind(void 0, 1, 1, 1, 0, 2),\n /* 0xFB */\n MDRP_MIRP.bind(void 0, 1, 1, 1, 0, 3),\n /* 0xFC */\n MDRP_MIRP.bind(void 0, 1, 1, 1, 1, 0),\n /* 0xFD */\n MDRP_MIRP.bind(void 0, 1, 1, 1, 1, 1),\n /* 0xFE */\n MDRP_MIRP.bind(void 0, 1, 1, 1, 1, 2),\n /* 0xFF */\n MDRP_MIRP.bind(void 0, 1, 1, 1, 1, 3)\n ];\n var hintingtt_default = Hinting;\n\n // src/tokenizer.mjs\n function Token(char) {\n this.char = char;\n this.state = {};\n this.activeState = null;\n }\n function ContextRange(startIndex, endOffset, contextName) {\n this.contextName = contextName;\n this.startIndex = startIndex;\n this.endOffset = endOffset;\n }\n function ContextChecker(contextName, checkStart, checkEnd) {\n this.contextName = contextName;\n this.openRange = null;\n this.ranges = [];\n this.checkStart = checkStart;\n this.checkEnd = checkEnd;\n }\n function ContextParams(context, currentIndex) {\n this.context = context;\n this.index = currentIndex;\n this.length = context.length;\n this.current = context[currentIndex];\n this.backtrack = context.slice(0, currentIndex);\n this.lookahead = context.slice(currentIndex + 1);\n }\n function Event(eventId) {\n this.eventId = eventId;\n this.subscribers = [];\n }\n function initializeCoreEvents(events) {\n const coreEvents = [\n \"start\",\n \"end\",\n \"next\",\n \"newToken\",\n \"contextStart\",\n \"contextEnd\",\n \"insertToken\",\n \"removeToken\",\n \"removeRange\",\n \"replaceToken\",\n \"replaceRange\",\n \"composeRUD\",\n \"updateContextsRanges\"\n ];\n for (let i = 0; i < coreEvents.length; i++) {\n const eventId = coreEvents[i];\n Object.defineProperty(this.events, eventId, {\n value: new Event(eventId)\n });\n }\n if (events) {\n for (let i = 0; i < coreEvents.length; i++) {\n const eventId = coreEvents[i];\n const event = events[eventId];\n if (typeof event === \"function\") {\n this.events[eventId].subscribe(event);\n }\n }\n }\n const requiresContextUpdate = [\n \"insertToken\",\n \"removeToken\",\n \"removeRange\",\n \"replaceToken\",\n \"replaceRange\",\n \"composeRUD\"\n ];\n for (let i = 0; i < requiresContextUpdate.length; i++) {\n const eventId = requiresContextUpdate[i];\n this.events[eventId].subscribe(\n this.updateContextsRanges\n );\n }\n }\n function Tokenizer(events) {\n this.tokens = [];\n this.registeredContexts = {};\n this.contextCheckers = [];\n this.events = {};\n this.registeredModifiers = [];\n initializeCoreEvents.call(this, events);\n }\n Token.prototype.setState = function(key, value) {\n this.state[key] = value;\n this.activeState = { key, value: this.state[key] };\n return this.activeState;\n };\n Token.prototype.getState = function(stateId) {\n return this.state[stateId] || null;\n };\n Tokenizer.prototype.inboundIndex = function(index) {\n return index >= 0 && index < this.tokens.length;\n };\n Tokenizer.prototype.composeRUD = function(RUDs) {\n const silent = true;\n const state = RUDs.map((RUD) => this[RUD[0]].apply(this, RUD.slice(1).concat(silent)));\n const hasFAILObject = (obj) => typeof obj === \"object\" && Object.prototype.hasOwnProperty.call(obj, \"FAIL\");\n if (state.every(hasFAILObject)) {\n return {\n FAIL: \"composeRUD: one or more operations hasn't completed successfully\",\n report: state.filter(hasFAILObject)\n };\n }\n this.dispatch(\"composeRUD\", [state.filter((op) => !hasFAILObject(op))]);\n };\n Tokenizer.prototype.replaceRange = function(startIndex, offset, tokens, silent) {\n offset = offset !== null ? offset : this.tokens.length;\n const isTokenType = tokens.every((token) => token instanceof Token);\n if (!isNaN(startIndex) && this.inboundIndex(startIndex) && isTokenType) {\n const replaced = this.tokens.splice.apply(\n this.tokens,\n [startIndex, offset].concat(tokens)\n );\n if (!silent) this.dispatch(\"replaceToken\", [startIndex, offset, tokens]);\n return [replaced, tokens];\n } else {\n return { FAIL: \"replaceRange: invalid tokens or startIndex.\" };\n }\n };\n Tokenizer.prototype.replaceToken = function(index, token, silent) {\n if (!isNaN(index) && this.inboundIndex(index) && token instanceof Token) {\n const replaced = this.tokens.splice(index, 1, token);\n if (!silent) this.dispatch(\"replaceToken\", [index, token]);\n return [replaced[0], token];\n } else {\n return { FAIL: \"replaceToken: invalid token or index.\" };\n }\n };\n Tokenizer.prototype.removeRange = function(startIndex, offset, silent) {\n offset = !isNaN(offset) ? offset : this.tokens.length;\n const tokens = this.tokens.splice(startIndex, offset);\n if (!silent) this.dispatch(\"removeRange\", [tokens, startIndex, offset]);\n return tokens;\n };\n Tokenizer.prototype.removeToken = function(index, silent) {\n if (!isNaN(index) && this.inboundIndex(index)) {\n const token = this.tokens.splice(index, 1);\n if (!silent) this.dispatch(\"removeToken\", [token, index]);\n return token;\n } else {\n return { FAIL: \"removeToken: invalid token index.\" };\n }\n };\n Tokenizer.prototype.insertToken = function(tokens, index, silent) {\n const tokenType = tokens.every(\n (token) => token instanceof Token\n );\n if (tokenType) {\n this.tokens.splice.apply(\n this.tokens,\n [index, 0].concat(tokens)\n );\n if (!silent) this.dispatch(\"insertToken\", [tokens, index]);\n return tokens;\n } else {\n return { FAIL: \"insertToken: invalid token(s).\" };\n }\n };\n Tokenizer.prototype.registerModifier = function(modifierId, condition, modifier) {\n this.events.newToken.subscribe(function(token, contextParams) {\n const conditionParams = [token, contextParams];\n const canApplyModifier = condition === null || condition.apply(this, conditionParams) === true;\n const modifierParams = [token, contextParams];\n if (canApplyModifier) {\n let newStateValue = modifier.apply(this, modifierParams);\n token.setState(modifierId, newStateValue);\n }\n });\n this.registeredModifiers.push(modifierId);\n };\n Event.prototype.subscribe = function(eventHandler) {\n if (typeof eventHandler === \"function\") {\n return this.subscribers.push(eventHandler) - 1;\n } else {\n return { FAIL: `invalid '${this.eventId}' event handler` };\n }\n };\n Event.prototype.unsubscribe = function(subsId) {\n this.subscribers.splice(subsId, 1);\n };\n ContextParams.prototype.setCurrentIndex = function(index) {\n this.index = index;\n this.current = this.context[index];\n this.backtrack = this.context.slice(0, index);\n this.lookahead = this.context.slice(index + 1);\n };\n ContextParams.prototype.get = function(offset) {\n switch (true) {\n case offset === 0:\n return this.current;\n case (offset < 0 && Math.abs(offset) <= this.backtrack.length):\n return this.backtrack.slice(offset)[0];\n case (offset > 0 && offset <= this.lookahead.length):\n return this.lookahead[offset - 1];\n default:\n return null;\n }\n };\n Tokenizer.prototype.rangeToText = function(range) {\n if (range instanceof ContextRange) {\n return this.getRangeTokens(range).map((token) => token.char).join(\"\");\n }\n };\n Tokenizer.prototype.getText = function() {\n return this.tokens.map((token) => token.char).join(\"\");\n };\n Tokenizer.prototype.getContext = function(contextName) {\n let context = this.registeredContexts[contextName];\n return context ? context : null;\n };\n Tokenizer.prototype.on = function(eventName, eventHandler) {\n const event = this.events[eventName];\n if (event) {\n return event.subscribe(eventHandler);\n } else {\n return null;\n }\n };\n Tokenizer.prototype.dispatch = function(eventName, args) {\n const event = this.events[eventName];\n if (event instanceof Event) {\n for (let i = 0; i < event.subscribers.length; i++) {\n const subscriber = event.subscribers[i];\n subscriber.apply(this, args || []);\n }\n }\n };\n Tokenizer.prototype.registerContextChecker = function(contextName, contextStartCheck, contextEndCheck) {\n if (this.getContext(contextName)) return {\n FAIL: `context name '${contextName}' is already registered.`\n };\n if (typeof contextStartCheck !== \"function\") return {\n FAIL: \"missing context start check.\"\n };\n if (typeof contextEndCheck !== \"function\") return {\n FAIL: \"missing context end check.\"\n };\n const contextCheckers = new ContextChecker(\n contextName,\n contextStartCheck,\n contextEndCheck\n );\n this.registeredContexts[contextName] = contextCheckers;\n this.contextCheckers.push(contextCheckers);\n return contextCheckers;\n };\n Tokenizer.prototype.getRangeTokens = function(range) {\n const endIndex = range.startIndex + range.endOffset;\n return [].concat(\n this.tokens.slice(range.startIndex, endIndex)\n );\n };\n Tokenizer.prototype.getContextRanges = function(contextName) {\n const context = this.getContext(contextName);\n if (context) {\n return context.ranges;\n } else {\n return { FAIL: `context checker '${contextName}' is not registered.` };\n }\n };\n Tokenizer.prototype.resetContextsRanges = function() {\n const registeredContexts = this.registeredContexts;\n for (const contextName in registeredContexts) {\n if (Object.prototype.hasOwnProperty.call(registeredContexts, contextName)) {\n const context = registeredContexts[contextName];\n context.ranges = [];\n }\n }\n };\n Tokenizer.prototype.updateContextsRanges = function() {\n this.resetContextsRanges();\n const chars = this.tokens.map((token) => token.char);\n for (let i = 0; i < chars.length; i++) {\n const contextParams = new ContextParams(chars, i);\n this.runContextCheck(contextParams);\n }\n this.dispatch(\"updateContextsRanges\", [this.registeredContexts]);\n };\n Tokenizer.prototype.setEndOffset = function(offset, contextName) {\n const startIndex = this.getContext(contextName).openRange.startIndex;\n let range = new ContextRange(startIndex, offset, contextName);\n const ranges = this.getContext(contextName).ranges;\n range.rangeId = `${contextName}.${ranges.length}`;\n ranges.push(range);\n this.getContext(contextName).openRange = null;\n return range;\n };\n Tokenizer.prototype.runContextCheck = function(contextParams) {\n const index = contextParams.index;\n for (let i = 0; i < this.contextCheckers.length; i++) {\n const contextChecker = this.contextCheckers[i];\n let contextName = contextChecker.contextName;\n let openRange = this.getContext(contextName).openRange;\n if (!openRange && contextChecker.checkStart(contextParams)) {\n openRange = new ContextRange(index, null, contextName);\n this.getContext(contextName).openRange = openRange;\n this.dispatch(\"contextStart\", [contextName, index]);\n }\n if (!!openRange && contextChecker.checkEnd(contextParams)) {\n const offset = index - openRange.startIndex + 1;\n const range = this.setEndOffset(offset, contextName);\n this.dispatch(\"contextEnd\", [contextName, range]);\n }\n }\n };\n Tokenizer.prototype.tokenize = function(text) {\n this.tokens = [];\n this.resetContextsRanges();\n let chars = Array.from(text);\n this.dispatch(\"start\");\n for (let i = 0; i < chars.length; i++) {\n const char = chars[i];\n const contextParams = new ContextParams(chars, i);\n this.dispatch(\"next\", [contextParams]);\n this.runContextCheck(contextParams);\n let token = new Token(char);\n this.tokens.push(token);\n this.dispatch(\"newToken\", [token, contextParams]);\n }\n this.dispatch(\"end\", [this.tokens]);\n return this.tokens;\n };\n var tokenizer_default = Tokenizer;\n\n // src/char.mjs\n function isArabicChar(c) {\n return /[\\u0600-\\u065F\\u066A-\\u06D2\\u06FA-\\u06FF]/.test(c);\n }\n function isIsolatedArabicChar(char) {\n return /[\\u0630\\u0690\\u0621\\u0631\\u0661\\u0671\\u0622\\u0632\\u0672\\u0692\\u06C2\\u0623\\u0673\\u0693\\u06C3\\u0624\\u0694\\u06C4\\u0625\\u0675\\u0695\\u06C5\\u06E5\\u0676\\u0696\\u06C6\\u0627\\u0677\\u0697\\u06C7\\u0648\\u0688\\u0698\\u06C8\\u0689\\u0699\\u06C9\\u068A\\u06CA\\u066B\\u068B\\u06CB\\u068C\\u068D\\u06CD\\u06FD\\u068E\\u06EE\\u06FE\\u062F\\u068F\\u06CF\\u06EF]/.test(char);\n }\n function isTashkeelArabicChar(char) {\n return /[\\u0600-\\u0605\\u060C-\\u060E\\u0610-\\u061B\\u061E\\u064B-\\u065F\\u0670\\u06D6-\\u06DC\\u06DF-\\u06E4\\u06E7\\u06E8\\u06EA-\\u06ED]/.test(char);\n }\n function isThaiChar(c) {\n return /[\\u0E00-\\u0E7F]/.test(c);\n }\n function isLatinChar(c) {\n return /[A-z]/.test(c);\n }\n function isWhiteSpace(c) {\n return /\\s/.test(c);\n }\n\n // src/features/featureQuery.mjs\n function FeatureQuery(font) {\n this.font = font;\n this.features = {};\n }\n function SubstitutionAction(action) {\n this.id = action.id;\n this.tag = action.tag;\n this.substitution = action.substitution;\n }\n function lookupCoverage(glyphIndex, coverage) {\n if (!glyphIndex) return -1;\n switch (coverage.format) {\n case 1:\n return coverage.glyphs.indexOf(glyphIndex);\n case 2: {\n let ranges = coverage.ranges;\n for (let i = 0; i < ranges.length; i++) {\n const range = ranges[i];\n if (glyphIndex >= range.start && glyphIndex <= range.end) {\n let offset = glyphIndex - range.start;\n return range.index + offset;\n }\n }\n break;\n }\n default:\n return -1;\n }\n return -1;\n }\n function singleSubstitutionFormat1(glyphIndex, subtable) {\n let substituteIndex = lookupCoverage(glyphIndex, subtable.coverage);\n if (substituteIndex === -1) return null;\n return glyphIndex + subtable.deltaGlyphId;\n }\n function singleSubstitutionFormat2(glyphIndex, subtable) {\n let substituteIndex = lookupCoverage(glyphIndex, subtable.coverage);\n if (substituteIndex === -1) return null;\n return subtable.substitute[substituteIndex];\n }\n function lookupCoverageList(coverageList, contextParams) {\n let lookupList = [];\n for (let i = 0; i < coverageList.length; i++) {\n const coverage = coverageList[i];\n let glyphIndex = contextParams.current;\n glyphIndex = Array.isArray(glyphIndex) ? glyphIndex[0] : glyphIndex;\n const lookupIndex = lookupCoverage(glyphIndex, coverage);\n if (lookupIndex !== -1) {\n lookupList.push(lookupIndex);\n }\n }\n if (lookupList.length !== coverageList.length) return -1;\n return lookupList;\n }\n function chainingSubstitutionFormat3(contextParams, subtable) {\n const lookupsCount = subtable.inputCoverage.length + subtable.lookaheadCoverage.length + subtable.backtrackCoverage.length;\n if (contextParams.context.length < lookupsCount) return [];\n let inputLookups = lookupCoverageList(\n subtable.inputCoverage,\n contextParams\n );\n if (inputLookups === -1) return [];\n const lookaheadOffset = subtable.inputCoverage.length - 1;\n if (contextParams.lookahead.length < subtable.lookaheadCoverage.length) return [];\n let lookaheadContext = contextParams.lookahead.slice(lookaheadOffset);\n while (lookaheadContext.length && isTashkeelArabicChar(lookaheadContext[0].char)) {\n lookaheadContext.shift();\n }\n const lookaheadParams = new ContextParams(lookaheadContext, 0);\n let lookaheadLookups = lookupCoverageList(\n subtable.lookaheadCoverage,\n lookaheadParams\n );\n let backtrackContext = [].concat(contextParams.backtrack);\n backtrackContext.reverse();\n while (backtrackContext.length && isTashkeelArabicChar(backtrackContext[0].char)) {\n backtrackContext.shift();\n }\n if (backtrackContext.length < subtable.backtrackCoverage.length) return [];\n const backtrackParams = new ContextParams(backtrackContext, 0);\n let backtrackLookups = lookupCoverageList(\n subtable.backtrackCoverage,\n backtrackParams\n );\n const contextRulesMatch = inputLookups.length === subtable.inputCoverage.length && lookaheadLookups.length === subtable.lookaheadCoverage.length && backtrackLookups.length === subtable.backtrackCoverage.length;\n let substitutions = [];\n if (contextRulesMatch) {\n for (let i = 0; i < subtable.lookupRecords.length; i++) {\n const lookupRecord = subtable.lookupRecords[i];\n const lookupListIndex = lookupRecord.lookupListIndex;\n const lookupTable = this.getLookupByIndex(lookupListIndex);\n for (let s = 0; s < lookupTable.subtables.length; s++) {\n let subtable2 = lookupTable.subtables[s];\n let lookup;\n let substitutionType = this.getSubstitutionType(lookupTable, subtable2);\n if (substitutionType === \"71\") {\n substitutionType = this.getSubstitutionType(subtable2, subtable2.extension);\n lookup = this.getLookupMethod(subtable2, subtable2.extension);\n subtable2 = subtable2.extension;\n } else {\n lookup = this.getLookupMethod(lookupTable, subtable2);\n }\n if (substitutionType === \"12\") {\n const glyphIndex = contextParams.get(lookupRecord.sequenceIndex);\n const substitution = lookup(glyphIndex);\n if (substitution) substitutions.push(substitution);\n } else if (substitutionType === \"21\") {\n const glyphIndex = contextParams.get(lookupRecord.sequenceIndex);\n const substitution = lookup(glyphIndex);\n if (substitution) substitutions.push(substitution);\n } else {\n throw new Error(`Substitution type ${substitutionType} is not supported in chaining substitution`);\n }\n }\n }\n }\n return substitutions;\n }\n function ligatureSubstitutionFormat1(contextParams, subtable) {\n let glyphIndex = contextParams.current;\n let ligSetIndex = lookupCoverage(glyphIndex, subtable.coverage);\n if (ligSetIndex === -1) return null;\n let ligature;\n let ligatureSet = subtable.ligatureSets[ligSetIndex];\n for (let s = 0; s < ligatureSet.length; s++) {\n ligature = ligatureSet[s];\n for (let l = 0; l < ligature.components.length; l++) {\n const lookaheadItem = contextParams.lookahead[l];\n const component = ligature.components[l];\n if (lookaheadItem !== component) break;\n if (l === ligature.components.length - 1) return ligature;\n }\n }\n return null;\n }\n function contextSubstitutionFormat1(contextParams, subtable) {\n let glyphId = contextParams.current;\n let ligSetIndex = lookupCoverage(glyphId, subtable.coverage);\n if (ligSetIndex === -1)\n return null;\n for (const ruleSet of subtable.ruleSets) {\n for (const rule of ruleSet) {\n let matched = true;\n for (let i = 0; i < rule.input.length; i++) {\n if (contextParams.lookahead[i] !== rule.input[i]) {\n matched = false;\n break;\n }\n }\n if (matched) {\n let substitutions = [];\n substitutions.push(glyphId);\n for (let i = 0; i < rule.input.length; i++) {\n substitutions.push(rule.input[i]);\n }\n const parser = (substitutions2, lookupRecord) => {\n const { lookupListIndex, sequenceIndex } = lookupRecord;\n const { subtables } = this.getLookupByIndex(lookupListIndex);\n for (const subtable2 of subtables) {\n let ligSetIndex2 = lookupCoverage(substitutions2[sequenceIndex], subtable2.coverage);\n if (ligSetIndex2 !== -1) {\n substitutions2[sequenceIndex] = subtable2.deltaGlyphId;\n }\n }\n };\n for (let i = 0; i < rule.lookupRecords.length; i++) {\n const lookupRecord = rule.lookupRecords[i];\n parser(substitutions, lookupRecord);\n }\n return substitutions;\n }\n }\n }\n return null;\n }\n function contextSubstitutionFormat3(contextParams, subtable) {\n if (contextParams.context.length < subtable.coverages.length) {\n return [];\n }\n for (let i = 0; i < subtable.coverages.length; i++) {\n let glyphIndex = contextParams.get(i);\n glyphIndex = Array.isArray(glyphIndex) ? glyphIndex[0] : glyphIndex;\n if (lookupCoverage(glyphIndex, subtable.coverages[i]) === -1) {\n return [];\n }\n }\n let substitutions = [];\n for (let i = 0; i < subtable.lookupRecords.length; i++) {\n const lookupRecord = subtable.lookupRecords[i];\n const lookupListIndex = lookupRecord.lookupListIndex;\n const lookupTable = this.getLookupByIndex(lookupListIndex);\n for (let s = 0; s < lookupTable.subtables.length; s++) {\n let subtable2 = lookupTable.subtables[s];\n let lookup;\n let substitutionType = this.getSubstitutionType(lookupTable, subtable2);\n if (substitutionType === \"71\") {\n substitutionType = this.getSubstitutionType(subtable2, subtable2.extension);\n lookup = this.getLookupMethod(subtable2, subtable2.extension);\n subtable2 = subtable2.extension;\n } else {\n lookup = this.getLookupMethod(lookupTable, subtable2);\n }\n if (substitutionType === \"12\") {\n const glyphIndex = contextParams.get(lookupRecord.sequenceIndex);\n const substitution = lookup(glyphIndex);\n if (substitution) substitutions.push(substitution);\n } else if (substitutionType === \"21\") {\n const glyphIndex = contextParams.get(lookupRecord.sequenceIndex);\n const substitution = lookup(glyphIndex);\n if (substitution) substitutions.push(substitution);\n }\n }\n }\n return substitutions;\n }\n function decompositionSubstitutionFormat1(glyphIndex, subtable) {\n let substituteIndex = lookupCoverage(glyphIndex, subtable.coverage);\n if (substituteIndex === -1) return null;\n return subtable.sequences[substituteIndex];\n }\n FeatureQuery.prototype.getDefaultScriptFeaturesIndexes = function() {\n const scripts = this.font.tables.gsub.scripts;\n for (let s = 0; s < scripts.length; s++) {\n const script = scripts[s];\n if (script.tag === \"DFLT\") return script.script.defaultLangSys.featureIndexes;\n }\n return [];\n };\n FeatureQuery.prototype.getScriptFeaturesIndexes = function(scriptTag) {\n const tables = this.font.tables;\n if (!tables.gsub) return [];\n if (!scriptTag) return this.getDefaultScriptFeaturesIndexes();\n const scripts = this.font.tables.gsub.scripts;\n for (let i = 0; i < scripts.length; i++) {\n const script = scripts[i];\n if (script.tag === scriptTag && script.script.defaultLangSys) {\n return script.script.defaultLangSys.featureIndexes;\n } else {\n let langSysRecords = script.langSysRecords;\n if (langSysRecords) {\n for (let j = 0; j < langSysRecords.length; j++) {\n const langSysRecord = langSysRecords[j];\n if (langSysRecord.tag === scriptTag) {\n let langSys = langSysRecord.langSys;\n return langSys.featureIndexes;\n }\n }\n }\n }\n }\n return this.getDefaultScriptFeaturesIndexes();\n };\n FeatureQuery.prototype.mapTagsToFeatures = function(features, scriptTag) {\n let tags = {};\n for (let i = 0; i < features.length; i++) {\n const tag = features[i].tag;\n const feature = features[i].feature;\n tags[tag] = feature;\n }\n this.features[scriptTag].tags = tags;\n };\n FeatureQuery.prototype.getScriptFeatures = function(scriptTag) {\n let features = this.features[scriptTag];\n if (Object.prototype.hasOwnProperty.call(this.features, scriptTag)) return features;\n const featuresIndexes = this.getScriptFeaturesIndexes(scriptTag);\n if (!featuresIndexes) return null;\n const gsub = this.font.tables.gsub;\n features = featuresIndexes.map((index) => gsub.features[index]);\n this.features[scriptTag] = features;\n this.mapTagsToFeatures(features, scriptTag);\n return features;\n };\n FeatureQuery.prototype.getSubstitutionType = function(lookupTable, subtable) {\n const lookupType = lookupTable.lookupType.toString();\n const substFormat = subtable.substFormat.toString();\n return lookupType + substFormat;\n };\n FeatureQuery.prototype.getLookupMethod = function(lookupTable, subtable) {\n let substitutionType = this.getSubstitutionType(lookupTable, subtable);\n switch (substitutionType) {\n case \"11\":\n return (glyphIndex) => singleSubstitutionFormat1.apply(\n this,\n [glyphIndex, subtable]\n );\n case \"12\":\n return (glyphIndex) => singleSubstitutionFormat2.apply(\n this,\n [glyphIndex, subtable]\n );\n case \"63\":\n return (contextParams) => chainingSubstitutionFormat3.apply(\n this,\n [contextParams, subtable]\n );\n case \"41\":\n return (contextParams) => ligatureSubstitutionFormat1.apply(\n this,\n [contextParams, subtable]\n );\n case \"21\":\n return (glyphIndex) => decompositionSubstitutionFormat1.apply(\n this,\n [glyphIndex, subtable]\n );\n case \"51\":\n return (contextParams) => contextSubstitutionFormat1.apply(\n this,\n [contextParams, subtable]\n );\n case \"53\":\n return (contextParams) => contextSubstitutionFormat3.apply(\n this,\n [contextParams, subtable]\n );\n default:\n throw new Error(\n `substitutionType : ${substitutionType} lookupType: ${lookupTable.lookupType} - substFormat: ${subtable.substFormat} is not yet supported`\n );\n }\n };\n FeatureQuery.prototype.lookupFeature = function(query) {\n let contextParams = query.contextParams;\n let currentIndex = contextParams.index;\n const feature = this.getFeature({\n tag: query.tag,\n script: query.script\n });\n if (!feature) return new Error(\n `font '${(this.font.names.unicode || this.font.names.windows || this.font.names.macintosh).fullName.en}' doesn't support feature '${query.tag}' for script '${query.script}'.`\n );\n const lookups = this.getFeatureLookups(feature);\n const substitutions = [].concat(contextParams.context);\n for (let l = 0; l < lookups.length; l++) {\n const lookupTable = lookups[l];\n const subtables = this.getLookupSubtables(lookupTable);\n for (let s = 0; s < subtables.length; s++) {\n let subtable = subtables[s];\n let substType = this.getSubstitutionType(lookupTable, subtable);\n let lookup;\n if (substType === \"71\") {\n substType = this.getSubstitutionType(subtable, subtable.extension);\n lookup = this.getLookupMethod(subtable, subtable.extension);\n subtable = subtable.extension;\n } else {\n lookup = this.getLookupMethod(lookupTable, subtable);\n }\n let substitution;\n switch (substType) {\n case \"11\":\n substitution = lookup(contextParams.current);\n if (substitution) {\n substitutions.splice(currentIndex, 1, new SubstitutionAction({\n id: 11,\n tag: query.tag,\n substitution\n }));\n }\n break;\n case \"12\":\n substitution = lookup(contextParams.current);\n if (substitution) {\n substitutions.splice(currentIndex, 1, new SubstitutionAction({\n id: 12,\n tag: query.tag,\n substitution\n }));\n }\n break;\n case \"63\":\n substitution = lookup(contextParams);\n if (Array.isArray(substitution) && substitution.length) {\n substitutions.splice(currentIndex, 1, new SubstitutionAction({\n id: 63,\n tag: query.tag,\n substitution\n }));\n }\n break;\n case \"41\":\n substitution = lookup(contextParams);\n if (substitution) {\n substitutions.splice(currentIndex, 1, new SubstitutionAction({\n id: 41,\n tag: query.tag,\n substitution\n }));\n }\n break;\n case \"21\":\n substitution = lookup(contextParams.current);\n if (substitution) {\n substitutions.splice(currentIndex, 1, new SubstitutionAction({\n id: 21,\n tag: query.tag,\n substitution\n }));\n }\n break;\n case \"51\":\n case \"53\":\n substitution = lookup(contextParams);\n if (Array.isArray(substitution) && substitution.length) {\n substitutions.splice(currentIndex, 1, new SubstitutionAction({\n id: parseInt(substType),\n tag: query.tag,\n substitution\n }));\n }\n break;\n }\n contextParams = new ContextParams(substitutions, currentIndex);\n if (Array.isArray(substitution) && !substitution.length) continue;\n substitution = null;\n }\n }\n return substitutions.length ? substitutions : null;\n };\n FeatureQuery.prototype.supports = function(query) {\n if (!query.script) return false;\n this.getScriptFeatures(query.script);\n const supportedScript = Object.prototype.hasOwnProperty.call(this.features, query.script);\n if (!query.tag) return supportedScript;\n const supportedFeature = this.features[query.script].some((feature) => feature.tag === query.tag);\n return supportedScript && supportedFeature;\n };\n FeatureQuery.prototype.getLookupSubtables = function(lookupTable) {\n return lookupTable.subtables || null;\n };\n FeatureQuery.prototype.getLookupByIndex = function(index) {\n const lookups = this.font.tables.gsub.lookups;\n return lookups[index] || null;\n };\n FeatureQuery.prototype.getFeatureLookups = function(feature) {\n return feature.lookupListIndexes.map(this.getLookupByIndex.bind(this));\n };\n FeatureQuery.prototype.getFeature = function getFeature(query) {\n if (!this.font) return { FAIL: \"No font was found\" };\n if (!Object.prototype.hasOwnProperty.call(this.features, query.script)) {\n this.getScriptFeatures(query.script);\n }\n const scriptFeatures = this.features[query.script];\n if (!scriptFeatures) return { FAIL: `No feature for script ${query.script}` };\n if (!scriptFeatures.tags[query.tag]) return null;\n return this.features[query.script].tags[query.tag];\n };\n var featureQuery_default = FeatureQuery;\n\n // src/features/arab/contextCheck/arabicWord.mjs\n function arabicWordStartCheck(contextParams) {\n const char = contextParams.current;\n const prevChar = contextParams.get(-1);\n return (\n // ? arabic first char\n prevChar === null && isArabicChar(char) || // ? arabic char preceded with a non arabic char\n !isArabicChar(prevChar) && isArabicChar(char)\n );\n }\n function arabicWordEndCheck(contextParams) {\n const nextChar = contextParams.get(1);\n return (\n // ? last arabic char\n nextChar === null || // ? next char is not arabic\n !isArabicChar(nextChar)\n );\n }\n var arabicWord_default = {\n startCheck: arabicWordStartCheck,\n endCheck: arabicWordEndCheck\n };\n\n // src/features/arab/contextCheck/arabicSentence.mjs\n function arabicSentenceStartCheck(contextParams) {\n const char = contextParams.current;\n const prevChar = contextParams.get(-1);\n return (\n // ? an arabic char preceded with a non arabic char\n (isArabicChar(char) || isTashkeelArabicChar(char)) && !isArabicChar(prevChar)\n );\n }\n function arabicSentenceEndCheck(contextParams) {\n const nextChar = contextParams.get(1);\n switch (true) {\n case nextChar === null:\n return true;\n case (!isArabicChar(nextChar) && !isTashkeelArabicChar(nextChar)): {\n const nextIsWhitespace = isWhiteSpace(nextChar);\n if (!nextIsWhitespace) return true;\n if (nextIsWhitespace) {\n let arabicCharAhead = false;\n arabicCharAhead = contextParams.lookahead.some(\n (c) => isArabicChar(c) || isTashkeelArabicChar(c)\n );\n if (!arabicCharAhead) return true;\n }\n break;\n }\n default:\n return false;\n }\n }\n var arabicSentence_default = {\n startCheck: arabicSentenceStartCheck,\n endCheck: arabicSentenceEndCheck\n };\n\n // src/features/applySubstitution.mjs\n function singleSubstitutionFormat12(action, tokens, index) {\n tokens[index].setState(action.tag, action.substitution);\n }\n function singleSubstitutionFormat22(action, tokens, index) {\n tokens[index].setState(action.tag, action.substitution);\n }\n function chainingSubstitutionFormat32(action, tokens, index) {\n for (let i = 0; i < action.substitution.length; i++) {\n const subst = action.substitution[i];\n const token = tokens[index + i];\n if (Array.isArray(subst)) {\n if (subst.length) {\n token.setState(action.tag, subst[0]);\n } else {\n token.setState(\"deleted\", true);\n }\n continue;\n }\n token.setState(action.tag, subst);\n }\n }\n function ligatureSubstitutionFormat12(action, tokens, index) {\n let token = tokens[index];\n token.setState(action.tag, action.substitution.ligGlyph);\n const compsCount = action.substitution.components.length;\n for (let i = 0; i < compsCount; i++) {\n token = tokens[index + i + 1];\n token.setState(\"deleted\", true);\n }\n }\n var SUBSTITUTIONS = {\n 11: singleSubstitutionFormat12,\n 12: singleSubstitutionFormat22,\n 63: chainingSubstitutionFormat32,\n 41: ligatureSubstitutionFormat12,\n 51: chainingSubstitutionFormat32,\n 53: chainingSubstitutionFormat32\n };\n function applySubstitution(action, tokens, index) {\n if (action instanceof SubstitutionAction && SUBSTITUTIONS[action.id]) {\n SUBSTITUTIONS[action.id](action, tokens, index);\n }\n }\n var applySubstitution_default = applySubstitution;\n\n // src/features/arab/arabicPresentationForms.mjs\n function willConnectPrev(charContextParams) {\n let backtrack = [].concat(charContextParams.backtrack);\n for (let i = backtrack.length - 1; i >= 0; i--) {\n const prevChar = backtrack[i];\n const isolated = isIsolatedArabicChar(prevChar);\n const tashkeel = isTashkeelArabicChar(prevChar);\n if (!isolated && !tashkeel) return true;\n if (isolated) return false;\n }\n return false;\n }\n function willConnectNext(charContextParams) {\n if (isIsolatedArabicChar(charContextParams.current)) return false;\n for (let i = 0; i < charContextParams.lookahead.length; i++) {\n const nextChar = charContextParams.lookahead[i];\n const tashkeel = isTashkeelArabicChar(nextChar);\n if (!tashkeel) return true;\n }\n return false;\n }\n function arabicPresentationForms(range) {\n const script = \"arab\";\n const tags = this.featuresTags[script];\n const tokens = this.tokenizer.getRangeTokens(range);\n if (tokens.length === 1) return;\n let contextParams = new ContextParams(\n tokens.map(\n (token) => token.getState(\"glyphIndex\")\n ),\n 0\n );\n const charContextParams = new ContextParams(\n tokens.map(\n (token) => token.char\n ),\n 0\n );\n for (let i = 0; i < tokens.length; i++) {\n const token = tokens[i];\n if (isTashkeelArabicChar(token.char)) continue;\n contextParams.setCurrentIndex(i);\n charContextParams.setCurrentIndex(i);\n let CONNECT = 0;\n if (willConnectPrev(charContextParams)) CONNECT |= 1;\n if (willConnectNext(charContextParams)) CONNECT |= 2;\n let tag;\n switch (CONNECT) {\n case 1:\n tag = \"fina\";\n break;\n case 2:\n tag = \"init\";\n break;\n case 3:\n tag = \"medi\";\n break;\n }\n if (tags.indexOf(tag) === -1) continue;\n let substitutions = this.query.lookupFeature({\n tag,\n script,\n contextParams\n });\n if (substitutions instanceof Error) {\n console.info(substitutions.message);\n continue;\n }\n for (let j = 0; j < substitutions.length; j++) {\n const action = substitutions[j];\n if (action instanceof SubstitutionAction) {\n applySubstitution_default(action, tokens, j);\n contextParams.context[j] = action.substitution;\n }\n }\n }\n }\n var arabicPresentationForms_default = arabicPresentationForms;\n\n // src/features/arab/arabicRequiredLigatures.mjs\n function getContextParams(tokens, index) {\n const context = tokens.map((token) => token.activeState.value);\n return new ContextParams(context, index || 0);\n }\n function arabicRequiredLigatures(range) {\n const script = \"arab\";\n let tokens = this.tokenizer.getRangeTokens(range);\n let contextParams = getContextParams(tokens);\n for (let index = 0; index < contextParams.context.length; index++) {\n contextParams.setCurrentIndex(index);\n let substitutions = this.query.lookupFeature({\n tag: \"rlig\",\n script,\n contextParams\n });\n if (substitutions.length) {\n for (let i = 0; i < substitutions.length; i++) {\n const action = substitutions[i];\n applySubstitution_default(action, tokens, index);\n }\n contextParams = getContextParams(tokens);\n }\n }\n }\n var arabicRequiredLigatures_default = arabicRequiredLigatures;\n\n // src/features/ccmp/contextCheck/ccmpReplacement.mjs\n function ccmpReplacementStartCheck(contextParams) {\n return contextParams.index === 0 && contextParams.context.length > 1;\n }\n function ccmpReplacementEndCheck(contextParams) {\n return contextParams.index === contextParams.context.length - 1;\n }\n var ccmpReplacement_default = {\n startCheck: ccmpReplacementStartCheck,\n endCheck: ccmpReplacementEndCheck\n };\n\n // src/features/ccmp/ccmpReplacementLigatures.mjs\n function getContextParams2(tokens, index) {\n const context = tokens.map((token) => token.activeState.value);\n return new ContextParams(context, index || 0);\n }\n function ccmpReplacementLigatures(range) {\n const script = \"delf\";\n const tag = \"ccmp\";\n let tokens = this.tokenizer.getRangeTokens(range);\n let contextParams = getContextParams2(tokens);\n for (let index = 0; index < contextParams.context.length; index++) {\n if (!this.query.getFeature({ tag, script, contextParams })) {\n continue;\n }\n contextParams.setCurrentIndex(index);\n let substitutions = this.query.lookupFeature({\n tag,\n script,\n contextParams\n });\n if (substitutions.length) {\n for (let i = 0; i < substitutions.length; i++) {\n const action = substitutions[i];\n applySubstitution_default(action, tokens, index);\n }\n contextParams = getContextParams2(tokens);\n }\n }\n }\n var ccmpReplacementLigatures_default = ccmpReplacementLigatures;\n\n // src/features/latn/contextCheck/latinWord.mjs\n function latinWordStartCheck(contextParams) {\n const char = contextParams.current;\n const prevChar = contextParams.get(-1);\n return (\n // ? latin first char\n prevChar === null && isLatinChar(char) || // ? latin char preceded with a non latin char\n !isLatinChar(prevChar) && isLatinChar(char)\n );\n }\n function latinWordEndCheck(contextParams) {\n const nextChar = contextParams.get(1);\n return (\n // ? last latin char\n nextChar === null || // ? next char is not latin\n !isLatinChar(nextChar)\n );\n }\n var latinWord_default = {\n startCheck: latinWordStartCheck,\n endCheck: latinWordEndCheck\n };\n\n // src/features/latn/latinLigatures.mjs\n function getContextParams3(tokens, index) {\n const context = tokens.map((token) => token.activeState.value);\n return new ContextParams(context, index || 0);\n }\n function latinLigature(range) {\n const script = \"latn\";\n let tokens = this.tokenizer.getRangeTokens(range);\n let contextParams = getContextParams3(tokens);\n for (let index = 0; index < contextParams.context.length; index++) {\n contextParams.setCurrentIndex(index);\n let substitutions = this.query.lookupFeature({\n tag: \"liga\",\n script,\n contextParams\n });\n if (substitutions.length) {\n for (let i = 0; i < substitutions.length; i++) {\n const action = substitutions[i];\n applySubstitution_default(action, tokens, index);\n }\n contextParams = getContextParams3(tokens);\n }\n }\n }\n var latinLigatures_default = latinLigature;\n\n // src/features/thai/contextCheck/thaiWord.mjs\n function thaiWordStartCheck(contextParams) {\n const char = contextParams.current;\n const prevChar = contextParams.get(-1);\n return (\n // ? thai first char\n prevChar === null && isThaiChar(char) || // ? thai char preceded with a non thai char\n !isThaiChar(prevChar) && isThaiChar(char)\n );\n }\n function thaiWordEndCheck(contextParams) {\n const nextChar = contextParams.get(1);\n return (\n // ? last thai char\n nextChar === null || // ? next char is not thai\n !isThaiChar(nextChar)\n );\n }\n var thaiWord_default = {\n startCheck: thaiWordStartCheck,\n endCheck: thaiWordEndCheck\n };\n\n // src/features/thai/thaiGlyphComposition.mjs\n function getContextParams4(tokens, index) {\n const context = tokens.map((token) => token.activeState.value);\n return new ContextParams(context, index || 0);\n }\n function thaiGlyphComposition(range) {\n const script = \"thai\";\n let tokens = this.tokenizer.getRangeTokens(range);\n let contextParams = getContextParams4(tokens, 0);\n for (let index = 0; index < contextParams.context.length; index++) {\n contextParams.setCurrentIndex(index);\n let substitutions = this.query.lookupFeature({\n tag: \"ccmp\",\n script,\n contextParams\n });\n if (substitutions.length) {\n for (let i = 0; i < substitutions.length; i++) {\n const action = substitutions[i];\n applySubstitution_default(action, tokens, index);\n }\n contextParams = getContextParams4(tokens, index);\n }\n }\n }\n var thaiGlyphComposition_default = thaiGlyphComposition;\n\n // src/features/thai/thaiLigatures.mjs\n function getContextParams5(tokens, index) {\n const context = tokens.map((token) => token.activeState.value);\n return new ContextParams(context, index || 0);\n }\n function thaiLigatures(range) {\n const script = \"thai\";\n let tokens = this.tokenizer.getRangeTokens(range);\n let contextParams = getContextParams5(tokens, 0);\n for (let index = 0; index < contextParams.context.length; index++) {\n contextParams.setCurrentIndex(index);\n let substitutions = this.query.lookupFeature({\n tag: \"liga\",\n script,\n contextParams\n });\n if (substitutions.length) {\n for (let i = 0; i < substitutions.length; i++) {\n const action = substitutions[i];\n applySubstitution_default(action, tokens, index);\n }\n contextParams = getContextParams5(tokens, index);\n }\n }\n }\n var thaiLigatures_default = thaiLigatures;\n\n // src/features/thai/thaiRequiredLigatures.mjs\n function getContextParams6(tokens, index) {\n const context = tokens.map((token) => token.activeState.value);\n return new ContextParams(context, index || 0);\n }\n function thaiRequiredLigatures(range) {\n const script = \"thai\";\n let tokens = this.tokenizer.getRangeTokens(range);\n let contextParams = getContextParams6(tokens, 0);\n for (let index = 0; index < contextParams.context.length; index++) {\n contextParams.setCurrentIndex(index);\n let substitutions = this.query.lookupFeature({\n tag: \"rlig\",\n script,\n contextParams\n });\n if (substitutions.length) {\n for (let i = 0; i < substitutions.length; i++) {\n const action = substitutions[i];\n applySubstitution_default(action, tokens, index);\n }\n contextParams = getContextParams6(tokens, index);\n }\n }\n }\n var thaiRequiredLigatures_default = thaiRequiredLigatures;\n\n // src/features/unicode/contextCheck/variationSequenceCheck.mjs\n function isVariationSequenceSelector(char) {\n if (char === null) return false;\n const charCode = char.codePointAt(0);\n return (\n // Mongolian Variation Selectors\n charCode >= 6155 && charCode <= 6157 || // Generic Variation Selectors\n charCode >= 65024 && charCode <= 65039 || // Ideographic Variation Sequences\n charCode >= 917760 && charCode <= 917999\n );\n }\n function unicodeVariationSequenceStartCheck(contextParams) {\n const char = contextParams.current;\n const nextChar = contextParams.get(1);\n return nextChar === null && isVariationSequenceSelector(char) || isVariationSequenceSelector(nextChar);\n }\n function unicodeVariationSequenceEndCheck(contextParams) {\n const nextChar = contextParams.get(1);\n return nextChar === null || !isVariationSequenceSelector(nextChar);\n }\n var variationSequenceCheck_default = {\n startCheck: unicodeVariationSequenceStartCheck,\n endCheck: unicodeVariationSequenceEndCheck\n };\n\n // src/features/unicode/variationSequences.mjs\n function unicodeVariationSequence(range) {\n const font = this.query.font;\n const tokens = this.tokenizer.getRangeTokens(range);\n tokens[1].setState(\"deleted\", true);\n if (font.tables.cmap && font.tables.cmap.varSelectorList) {\n const baseCodePoint = tokens[0].char.codePointAt(0);\n const vsCodePoint = tokens[1].char.codePointAt(0);\n const selectorLookup = font.tables.cmap.varSelectorList[vsCodePoint];\n if (selectorLookup !== void 0) {\n if (selectorLookup.nonDefaultUVS) {\n const mappings = selectorLookup.nonDefaultUVS.uvsMappings;\n if (mappings[baseCodePoint]) {\n const replacementGlyphId = mappings[baseCodePoint].glyphID;\n if (font.glyphs.glyphs[replacementGlyphId] !== void 0) {\n tokens[0].setState(\"glyphIndex\", replacementGlyphId);\n }\n }\n }\n }\n }\n }\n var variationSequences_default = unicodeVariationSequence;\n\n // src/bidi.mjs\n function Bidi(baseDir) {\n this.baseDir = baseDir || \"ltr\";\n this.tokenizer = new tokenizer_default();\n this.featuresTags = {};\n }\n Bidi.prototype.setText = function(text) {\n this.text = text;\n };\n Bidi.prototype.contextChecks = {\n ccmpReplacementCheck: ccmpReplacement_default,\n latinWordCheck: latinWord_default,\n arabicWordCheck: arabicWord_default,\n arabicSentenceCheck: arabicSentence_default,\n thaiWordCheck: thaiWord_default,\n unicodeVariationSequenceCheck: variationSequenceCheck_default\n };\n function registerContextChecker(checkId) {\n const check = this.contextChecks[`${checkId}Check`];\n return this.tokenizer.registerContextChecker(\n checkId,\n check.startCheck,\n check.endCheck\n );\n }\n function tokenizeText() {\n registerContextChecker.call(this, \"ccmpReplacement\");\n registerContextChecker.call(this, \"latinWord\");\n registerContextChecker.call(this, \"arabicWord\");\n registerContextChecker.call(this, \"arabicSentence\");\n registerContextChecker.call(this, \"thaiWord\");\n registerContextChecker.call(this, \"unicodeVariationSequence\");\n return this.tokenizer.tokenize(this.text);\n }\n function reverseArabicSentences() {\n const ranges = this.tokenizer.getContextRanges(\"arabicSentence\");\n for (let i = 0; i < ranges.length; i++) {\n const range = ranges[i];\n let rangeTokens = this.tokenizer.getRangeTokens(range);\n this.tokenizer.replaceRange(\n range.startIndex,\n range.endOffset,\n rangeTokens.reverse()\n );\n }\n }\n Bidi.prototype.registerFeatures = function(script, tags) {\n const supportedTags = tags.filter(\n (tag) => this.query.supports({ script, tag })\n );\n if (!Object.prototype.hasOwnProperty.call(this.featuresTags, script)) {\n this.featuresTags[script] = supportedTags;\n } else {\n this.featuresTags[script] = this.featuresTags[script].concat(supportedTags);\n }\n };\n Bidi.prototype.applyFeatures = function(font, features) {\n if (!font) throw new Error(\n \"No valid font was provided to apply features\"\n );\n if (!this.query) this.query = new featureQuery_default(font);\n for (let f = 0; f < features.length; f++) {\n const feature = features[f];\n if (!this.query.supports({ script: feature.script })) continue;\n this.registerFeatures(feature.script, feature.tags);\n }\n };\n Bidi.prototype.registerModifier = function(modifierId, condition, modifier) {\n this.tokenizer.registerModifier(modifierId, condition, modifier);\n };\n function checkGlyphIndexStatus() {\n if (this.tokenizer.registeredModifiers.indexOf(\"glyphIndex\") === -1) {\n throw new Error(\n \"glyphIndex modifier is required to apply arabic presentation features.\"\n );\n }\n }\n function applyArabicPresentationForms() {\n const script = \"arab\";\n if (!Object.prototype.hasOwnProperty.call(this.featuresTags, script)) return;\n checkGlyphIndexStatus.call(this);\n const ranges = this.tokenizer.getContextRanges(\"arabicWord\");\n for (let i = 0; i < ranges.length; i++) {\n const range = ranges[i];\n arabicPresentationForms_default.call(this, range);\n }\n }\n function applyCcmpReplacement() {\n checkGlyphIndexStatus.call(this);\n const ranges = this.tokenizer.getContextRanges(\"ccmpReplacement\");\n for (let i = 0; i < ranges.length; i++) {\n const range = ranges[i];\n ccmpReplacementLigatures_default.call(this, range);\n }\n }\n function applyArabicRequireLigatures() {\n if (!this.hasFeatureEnabled(\"arab\", \"rlig\")) return;\n checkGlyphIndexStatus.call(this);\n const ranges = this.tokenizer.getContextRanges(\"arabicWord\");\n for (let i = 0; i < ranges.length; i++) {\n const range = ranges[i];\n arabicRequiredLigatures_default.call(this, range);\n }\n }\n function applyLatinLigatures() {\n if (!this.hasFeatureEnabled(\"latn\", \"liga\")) return;\n checkGlyphIndexStatus.call(this);\n const ranges = this.tokenizer.getContextRanges(\"latinWord\");\n for (let i = 0; i < ranges.length; i++) {\n const range = ranges[i];\n latinLigatures_default.call(this, range);\n }\n }\n function applyUnicodeVariationSequences() {\n const ranges = this.tokenizer.getContextRanges(\"unicodeVariationSequence\");\n for (let i = 0; i < ranges.length; i++) {\n const range = ranges[i];\n variationSequences_default.call(this, range);\n }\n }\n function applyThaiFeatures() {\n checkGlyphIndexStatus.call(this);\n const ranges = this.tokenizer.getContextRanges(\"thaiWord\");\n for (let i = 0; i < ranges.length; i++) {\n const range = ranges[i];\n if (this.hasFeatureEnabled(\"thai\", \"liga\")) thaiLigatures_default.call(this, range);\n if (this.hasFeatureEnabled(\"thai\", \"rlig\")) thaiRequiredLigatures_default.call(this, range);\n if (this.hasFeatureEnabled(\"thai\", \"ccmp\")) thaiGlyphComposition_default.call(this, range);\n }\n }\n Bidi.prototype.checkContextReady = function(contextId) {\n return !!this.tokenizer.getContext(contextId);\n };\n Bidi.prototype.applyFeaturesToContexts = function() {\n if (this.checkContextReady(\"ccmpReplacement\")) {\n applyCcmpReplacement.call(this);\n }\n if (this.checkContextReady(\"arabicWord\")) {\n applyArabicPresentationForms.call(this);\n applyArabicRequireLigatures.call(this);\n }\n if (this.checkContextReady(\"latinWord\")) {\n applyLatinLigatures.call(this);\n }\n if (this.checkContextReady(\"arabicSentence\")) {\n reverseArabicSentences.call(this);\n }\n if (this.checkContextReady(\"thaiWord\")) {\n applyThaiFeatures.call(this);\n }\n if (this.checkContextReady(\"unicodeVariationSequence\")) {\n applyUnicodeVariationSequences.call(this);\n }\n };\n Bidi.prototype.hasFeatureEnabled = function(script, tag) {\n return (this.featuresTags[script] || []).indexOf(tag) !== -1;\n };\n Bidi.prototype.processText = function(text) {\n if (!this.text || this.text !== text) {\n this.setText(text);\n tokenizeText.call(this);\n this.applyFeaturesToContexts();\n }\n };\n Bidi.prototype.getBidiText = function(text) {\n this.processText(text);\n return this.tokenizer.getText();\n };\n Bidi.prototype.getTextGlyphs = function(text) {\n this.processText(text);\n let indexes = [];\n for (let i = 0; i < this.tokenizer.tokens.length; i++) {\n const token = this.tokenizer.tokens[i];\n if (token.state.deleted) continue;\n const index = token.activeState.value;\n indexes.push(Array.isArray(index) ? index[0] : index);\n }\n return indexes;\n };\n var bidi_default = Bidi;\n\n // src/font.mjs\n function createDefaultNamesInfo(options) {\n return {\n fontFamily: { en: options.familyName || \" \" },\n fontSubfamily: { en: options.styleName || \" \" },\n fullName: { en: options.fullName || options.familyName + \" \" + options.styleName },\n // postScriptName may not contain any whitespace\n postScriptName: { en: options.postScriptName || (options.familyName + options.styleName).replace(/\\s/g, \"\") },\n designer: { en: options.designer || \" \" },\n designerURL: { en: options.designerURL || \" \" },\n manufacturer: { en: options.manufacturer || \" \" },\n manufacturerURL: { en: options.manufacturerURL || \" \" },\n license: { en: options.license || \" \" },\n licenseURL: { en: options.licenseURL || \" \" },\n version: { en: options.version || \"Version 0.1\" },\n description: { en: options.description || \" \" },\n copyright: { en: options.copyright || \" \" },\n trademark: { en: options.trademark || \" \" }\n };\n }\n function Font(options) {\n options = options || {};\n options.tables = options.tables || {};\n if (!options.empty) {\n if (!options.familyName) throw new Error(\"When creating a new Font object, familyName is required.\");\n if (!options.styleName) throw new Error(\"When creating a new Font object, styleName is required.\");\n if (!options.unitsPerEm) throw new Error(\"When creating a new Font object, unitsPerEm is required.\");\n if (!options.ascender) throw new Error(\"When creating a new Font object, ascender is required.\");\n if (options.descender > 0) throw new Error(\"When creating a new Font object, negative descender value is required.\");\n this.names = {};\n this.names.unicode = createDefaultNamesInfo(options);\n this.names.macintosh = createDefaultNamesInfo(options);\n this.names.windows = createDefaultNamesInfo(options);\n this.unitsPerEm = options.unitsPerEm || 1e3;\n this.ascender = options.ascender;\n this.descender = options.descender;\n this.createdTimestamp = options.createdTimestamp;\n this.italicAngle = options.italicAngle || 0;\n this.weightClass = options.weightClass || 0;\n let selection = 0;\n if (options.fsSelection) {\n selection = options.fsSelection;\n } else {\n if (this.italicAngle < 0) {\n selection |= this.fsSelectionValues.ITALIC;\n } else if (this.italicAngle > 0) {\n selection |= this.fsSelectionValues.OBLIQUE;\n }\n if (this.weightClass >= 600) {\n selection |= this.fsSelectionValues.BOLD;\n }\n if (selection === 0) {\n selection = this.fsSelectionValues.REGULAR;\n }\n }\n if (!options.panose || !Array.isArray(options.panose)) {\n options.panose = [0, 0, 0, 0, 0, 0, 0, 0, 0];\n }\n this.tables = Object.assign(options.tables, {\n os2: Object.assign({\n usWeightClass: options.weightClass || this.usWeightClasses.MEDIUM,\n usWidthClass: options.widthClass || this.usWidthClasses.MEDIUM,\n bFamilyType: options.panose[0] || 0,\n bSerifStyle: options.panose[1] || 0,\n bWeight: options.panose[2] || 0,\n bProportion: options.panose[3] || 0,\n bContrast: options.panose[4] || 0,\n bStrokeVariation: options.panose[5] || 0,\n bArmStyle: options.panose[6] || 0,\n bLetterform: options.panose[7] || 0,\n bMidline: options.panose[8] || 0,\n bXHeight: options.panose[9] || 0,\n fsSelection: selection\n }, options.tables.os2)\n });\n }\n this.supported = true;\n this.glyphs = new glyphset_default.GlyphSet(this, options.glyphs || []);\n this.encoding = new DefaultEncoding(this);\n this.position = new position_default(this);\n this.substitution = new substitution_default(this);\n this.tables = this.tables || {};\n this.tables = new Proxy(this.tables, {\n set: (tables, tableName, tableData) => {\n tables[tableName] = tableData;\n if (tables.fvar && (tables.gvar || tables.cff2) && !this.variation) {\n this.variation = new VariationManager(this);\n }\n return true;\n }\n });\n this.palettes = new PaletteManager(this);\n this.layers = new LayerManager(this);\n this.svgImages = new SVGImageManager(this);\n this._push = null;\n this._hmtxTableData = {};\n Object.defineProperty(this, \"hinting\", {\n get: function() {\n if (this._hinting) return this._hinting;\n if (this.outlinesFormat === \"truetype\") {\n return this._hinting = new hintingtt_default(this);\n }\n return null;\n }\n });\n }\n Font.prototype.hasChar = function(c) {\n return this.encoding.charToGlyphIndex(c) > 0;\n };\n Font.prototype.charToGlyphIndex = function(s) {\n return this.encoding.charToGlyphIndex(s);\n };\n Font.prototype.charToGlyph = function(c) {\n const glyphIndex = this.charToGlyphIndex(c);\n let glyph = this.glyphs.get(glyphIndex);\n if (!glyph) {\n glyph = this.glyphs.get(0);\n }\n return glyph;\n };\n Font.prototype.updateFeatures = function(options) {\n return this.defaultRenderOptions.features.map((feature) => {\n if (feature.script === \"latn\") {\n return {\n script: \"latn\",\n tags: feature.tags.filter((tag) => options[tag])\n };\n } else {\n return feature;\n }\n });\n };\n Font.prototype.stringToGlyphIndexes = function(s, options) {\n const bidi = new bidi_default();\n const charToGlyphIndexMod = (token) => this.charToGlyphIndex(token.char);\n bidi.registerModifier(\"glyphIndex\", null, charToGlyphIndexMod);\n let features = options ? this.updateFeatures(options.features) : this.defaultRenderOptions.features;\n bidi.applyFeatures(this, features);\n return bidi.getTextGlyphs(s);\n };\n Font.prototype.stringToGlyphs = function(s, options) {\n const indexes = this.stringToGlyphIndexes(s, options);\n let length = indexes.length;\n const glyphs = new Array(length);\n const notdef = this.glyphs.get(0);\n for (let i = 0; i < length; i += 1) {\n glyphs[i] = this.glyphs.get(indexes[i]) || notdef;\n }\n return glyphs;\n };\n Font.prototype.nameToGlyphIndex = function(name) {\n return this.glyphNames.nameToGlyphIndex(name);\n };\n Font.prototype.nameToGlyph = function(name) {\n const glyphIndex = this.nameToGlyphIndex(name);\n let glyph = this.glyphs.get(glyphIndex);\n if (!glyph) {\n glyph = this.glyphs.get(0);\n }\n return glyph;\n };\n Font.prototype.glyphIndexToName = function(gid) {\n if (!this.glyphNames.glyphIndexToName) {\n return \"\";\n }\n return this.glyphNames.glyphIndexToName(gid);\n };\n Font.prototype.getKerningValue = function(leftGlyph, rightGlyph) {\n leftGlyph = leftGlyph.index || leftGlyph;\n rightGlyph = rightGlyph.index || rightGlyph;\n const gposKerning = this.position.defaultKerningTables;\n if (gposKerning) {\n return this.position.getKerningValue(gposKerning, leftGlyph, rightGlyph);\n }\n return this.kerningPairs[leftGlyph + \",\" + rightGlyph] || 0;\n };\n Font.prototype.defaultRenderOptions = {\n kerning: true,\n features: [\n /**\n * these 4 features are required to render Arabic text properly\n * and shouldn't be turned off when rendering arabic text.\n */\n { script: \"arab\", tags: [\"init\", \"medi\", \"fina\", \"rlig\"] },\n { script: \"latn\", tags: [\"liga\", \"rlig\"] },\n { script: \"thai\", tags: [\"liga\", \"rlig\", \"ccmp\"] }\n ],\n hinting: false,\n usePalette: 0,\n drawLayers: true,\n drawSVG: true\n };\n Font.prototype.forEachGlyph = function(text, x, y, fontSize, options, callback) {\n x = x !== void 0 ? x : 0;\n y = y !== void 0 ? y : 0;\n fontSize = fontSize !== void 0 ? fontSize : 72;\n options = Object.assign({}, this.defaultRenderOptions, options);\n const fontScale = 1 / this.unitsPerEm * fontSize;\n const glyphs = this.stringToGlyphs(text, options);\n let kerningLookups;\n if (options.kerning) {\n const script = options.script || this.position.getDefaultScriptName();\n kerningLookups = this.position.getKerningTables(script, options.language);\n }\n for (let i = 0; i < glyphs.length; i += 1) {\n const glyph = glyphs[i];\n callback.call(this, glyph, x, y, fontSize, options);\n if (glyph.advanceWidth) {\n x += glyph.advanceWidth * fontScale;\n }\n if (options.kerning && i < glyphs.length - 1) {\n const kerningValue = kerningLookups ? this.position.getKerningValue(kerningLookups, glyph.index, glyphs[i + 1].index) : this.getKerningValue(glyph, glyphs[i + 1]);\n x += kerningValue * fontScale;\n }\n if (options.letterSpacing) {\n x += options.letterSpacing * fontSize;\n } else if (options.tracking) {\n x += options.tracking / 1e3 * fontSize;\n }\n }\n return x;\n };\n Font.prototype.getPath = function(text, x, y, fontSize, options) {\n options = Object.assign({}, this.defaultRenderOptions, options);\n const fullPath = new path_default();\n fullPath._layers = [];\n applyPaintType(this, fullPath, fontSize);\n if (fullPath.stroke) {\n const scale = 1 / (fullPath.unitsPerEm || 1e3) * fontSize;\n fullPath.strokeWidth *= scale;\n }\n this.forEachGlyph(text, x, y, fontSize, options, (glyph, gX, gY, gFontSize) => {\n const glyphPath = glyph.getPath(gX, gY, gFontSize, options, this);\n if (options.drawSVG || options.drawLayers) {\n const layers = glyphPath._layers;\n if (layers && layers.length) {\n for (let l = 0; l < layers.length; l++) {\n const layer = layers[l];\n fullPath._layers.push(layer);\n }\n return;\n }\n }\n fullPath.extend(glyphPath);\n });\n return fullPath;\n };\n Font.prototype.getPaths = function(text, x, y, fontSize, options) {\n options = Object.assign({}, this.defaultRenderOptions, options);\n const glyphPaths = [];\n this.forEachGlyph(text, x, y, fontSize, options, function(glyph, gX, gY, gFontSize) {\n const glyphPath = glyph.getPath(gX, gY, gFontSize, options, this);\n glyphPaths.push(glyphPath);\n });\n return glyphPaths;\n };\n Font.prototype.getAdvanceWidth = function(text, fontSize, options) {\n options = Object.assign({}, this.defaultRenderOptions, options);\n return this.forEachGlyph(text, 0, 0, fontSize, options, function() {\n });\n };\n Font.prototype.draw = function(ctx, text, x, y, fontSize, options) {\n const path = this.getPath(text, x, y, fontSize, options);\n path.draw(ctx);\n };\n Font.prototype.drawPoints = function(ctx, text, x, y, fontSize, options) {\n options = Object.assign({}, this.defaultRenderOptions, options);\n this.forEachGlyph(text, x, y, fontSize, options, function(glyph, gX, gY, gFontSize) {\n glyph.drawPoints(ctx, gX, gY, gFontSize, options, this);\n });\n };\n Font.prototype.drawMetrics = function(ctx, text, x, y, fontSize, options) {\n options = Object.assign({}, this.defaultRenderOptions, options);\n this.forEachGlyph(text, x, y, fontSize, options, function(glyph, gX, gY, gFontSize) {\n glyph.drawMetrics(ctx, gX, gY, gFontSize);\n });\n };\n Font.prototype.getEnglishName = function(name) {\n const translations = (this.names.unicode || this.names.macintosh || this.names.windows)[name];\n if (translations) {\n return translations.en;\n }\n };\n Font.prototype.validate = function() {\n const warnings = [];\n const _this = this;\n function assert(predicate, message) {\n if (!predicate) {\n console.warn(`[opentype.js] ${message}`);\n warnings.push(message);\n }\n }\n function assertNamePresent(name) {\n const englishName = _this.getEnglishName(name);\n assert(\n englishName && englishName.trim().length > 0,\n \"No English \" + name + \" specified.\"\n );\n }\n assertNamePresent(\"fontFamily\");\n assertNamePresent(\"weightName\");\n assertNamePresent(\"manufacturer\");\n assertNamePresent(\"copyright\");\n assertNamePresent(\"version\");\n assert(this.unitsPerEm > 0, \"No unitsPerEm specified.\");\n if (this.tables.colr) {\n const baseGlyphs = this.tables.colr.baseGlyphRecords;\n let previousID = -1;\n for (let b = 0; b < baseGlyphs.length; b++) {\n const currentGlyphID = baseGlyphs[b].glyphID;\n assert(previousID < baseGlyphs[b].glyphID, `baseGlyphs must be sorted by GlyphID in ascending order, but glyphID ${currentGlyphID} comes after ${previousID}`);\n if (previousID > baseGlyphs[b].glyphID) {\n break;\n }\n previousID = currentGlyphID;\n }\n }\n return warnings;\n };\n Font.prototype.toTables = function() {\n return sfnt_default.fontToTable(this);\n };\n Font.prototype.toBuffer = function() {\n console.warn(\"Font.toBuffer is deprecated. Use Font.toArrayBuffer instead.\");\n return this.toArrayBuffer();\n };\n Font.prototype.toArrayBuffer = function() {\n const sfntTable = this.toTables();\n const bytes = sfntTable.encode();\n const buffer = new ArrayBuffer(bytes.length);\n const intArray = new Uint8Array(buffer);\n for (let i = 0; i < bytes.length; i++) {\n intArray[i] = bytes[i];\n }\n return buffer;\n };\n Font.prototype.download = function() {\n console.error(\"DEPRECATED: platform-specific actions are to be implemented on user-side\");\n };\n Font.prototype.fsSelectionValues = {\n ITALIC: 1,\n //1\n UNDERSCORE: 2,\n //2\n NEGATIVE: 4,\n //4\n OUTLINED: 8,\n //8\n STRIKEOUT: 16,\n //16\n BOLD: 32,\n //32\n REGULAR: 64,\n //64\n USER_TYPO_METRICS: 128,\n //128\n WWS: 256,\n //256\n OBLIQUE: 512\n //512\n };\n Font.prototype.macStyleValues = {\n BOLD: 1,\n //1\n ITALIC: 2,\n //2\n UNDERLINE: 4,\n //4\n OUTLINED: 8,\n //8\n SHADOW: 16,\n //16\n CONDENSED: 32,\n //32\n EXTENDED: 64\n //64\n };\n Font.prototype.usWidthClasses = {\n ULTRA_CONDENSED: 1,\n EXTRA_CONDENSED: 2,\n CONDENSED: 3,\n SEMI_CONDENSED: 4,\n MEDIUM: 5,\n SEMI_EXPANDED: 6,\n EXPANDED: 7,\n EXTRA_EXPANDED: 8,\n ULTRA_EXPANDED: 9\n };\n Font.prototype.usWeightClasses = {\n THIN: 100,\n EXTRA_LIGHT: 200,\n LIGHT: 300,\n NORMAL: 400,\n MEDIUM: 500,\n SEMI_BOLD: 600,\n BOLD: 700,\n EXTRA_BOLD: 800,\n BLACK: 900\n };\n var font_default = Font;\n\n // src/tables/hvar.mjs\n function parseHvarTable(data, start) {\n const p = new parse_default.Parser(data, start);\n const tableVersionMajor = p.parseUShort();\n const tableVersionMinor = p.parseUShort();\n if (tableVersionMajor !== 1) {\n console.warn(`Unsupported hvar table version ${tableVersionMajor}.${tableVersionMinor}`);\n }\n const version = [\n tableVersionMajor,\n tableVersionMinor\n ];\n const itemVariationStore = p.parsePointer32(function() {\n return this.parseItemVariationStore();\n });\n const advanceWidth = p.parsePointer32(function() {\n return this.parseDeltaSetIndexMap();\n });\n const lsb = p.parsePointer32(function() {\n return this.parseDeltaSetIndexMap();\n });\n const rsb = p.parsePointer32(function() {\n return this.parseDeltaSetIndexMap();\n });\n return {\n version,\n itemVariationStore,\n advanceWidth,\n lsb,\n rsb\n };\n }\n function makeHvarTable() {\n console.warn(\"Writing of hvar tables is not yet supported.\");\n }\n var hvar_default = { make: makeHvarTable, parse: parseHvarTable };\n\n // src/tables/gdef.mjs\n var attachList = function() {\n return {\n coverage: this.parsePointer(Parser.coverage),\n attachPoints: this.parseList(Parser.pointer(Parser.uShortList))\n };\n };\n var caretValue = function() {\n var format = this.parseUShort();\n check_default.argument(\n format === 1 || format === 2 || format === 3,\n \"Unsupported CaretValue table version.\"\n );\n if (format === 1) {\n return { coordinate: this.parseShort() };\n } else if (format === 2) {\n return { pointindex: this.parseShort() };\n } else if (format === 3) {\n return { coordinate: this.parseShort() };\n }\n };\n var ligGlyph = function() {\n return this.parseList(Parser.pointer(caretValue));\n };\n var ligCaretList = function() {\n return {\n coverage: this.parsePointer(Parser.coverage),\n ligGlyphs: this.parseList(Parser.pointer(ligGlyph))\n };\n };\n var markGlyphSets = function() {\n this.parseUShort();\n return this.parseList(Parser.pointer(Parser.coverage));\n };\n function parseGDEFTable(data, start) {\n start = start || 0;\n const p = new Parser(data, start);\n const tableVersion = p.parseVersion(1);\n check_default.argument(\n tableVersion === 1 || tableVersion === 1.2 || tableVersion === 1.3,\n \"Unsupported GDEF table version.\"\n );\n var gdef = {\n version: tableVersion,\n classDef: p.parsePointer(Parser.classDef),\n attachList: p.parsePointer(attachList),\n ligCaretList: p.parsePointer(ligCaretList),\n markAttachClassDef: p.parsePointer(Parser.classDef)\n };\n if (tableVersion >= 1.2) {\n gdef.markGlyphSets = p.parsePointer(markGlyphSets);\n }\n return gdef;\n }\n var gdef_default = { parse: parseGDEFTable };\n\n // src/tables/gpos.mjs\n var subtableParsers2 = new Array(10);\n subtableParsers2[1] = function parseLookup12() {\n const start = this.offset + this.relativeOffset;\n const posformat = this.parseUShort();\n if (posformat === 1) {\n return {\n posFormat: 1,\n coverage: this.parsePointer(Parser.coverage),\n value: this.parseValueRecord()\n };\n } else if (posformat === 2) {\n return {\n posFormat: 2,\n coverage: this.parsePointer(Parser.coverage),\n values: this.parseValueRecordList()\n };\n }\n check_default.assert(false, \"0x\" + start.toString(16) + \": GPOS lookup type 1 format must be 1 or 2.\");\n };\n subtableParsers2[2] = function parseLookup22() {\n const start = this.offset + this.relativeOffset;\n const posFormat = this.parseUShort();\n check_default.assert(posFormat === 1 || posFormat === 2, \"0x\" + start.toString(16) + \": GPOS lookup type 2 format must be 1 or 2.\");\n const coverage = this.parsePointer(Parser.coverage);\n const valueFormat1 = this.parseUShort();\n const valueFormat2 = this.parseUShort();\n if (posFormat === 1) {\n return {\n posFormat,\n coverage,\n valueFormat1,\n valueFormat2,\n pairSets: this.parseList(Parser.pointer(Parser.list(function() {\n return {\n // pairValueRecord\n secondGlyph: this.parseUShort(),\n value1: this.parseValueRecord(valueFormat1),\n value2: this.parseValueRecord(valueFormat2)\n };\n })))\n };\n } else if (posFormat === 2) {\n const classDef1 = this.parsePointer(Parser.classDef);\n const classDef2 = this.parsePointer(Parser.classDef);\n const class1Count = this.parseUShort();\n const class2Count = this.parseUShort();\n return {\n // Class Pair Adjustment\n posFormat,\n coverage,\n valueFormat1,\n valueFormat2,\n classDef1,\n classDef2,\n class1Count,\n class2Count,\n classRecords: this.parseList(class1Count, Parser.list(class2Count, function() {\n return {\n value1: this.parseValueRecord(valueFormat1),\n value2: this.parseValueRecord(valueFormat2)\n };\n }))\n };\n }\n };\n subtableParsers2[3] = function parseLookup32() {\n return { error: \"GPOS Lookup 3 not supported\" };\n };\n subtableParsers2[4] = function parseLookup42() {\n return { error: \"GPOS Lookup 4 not supported\" };\n };\n subtableParsers2[5] = function parseLookup52() {\n return { error: \"GPOS Lookup 5 not supported\" };\n };\n subtableParsers2[6] = function parseLookup62() {\n return { error: \"GPOS Lookup 6 not supported\" };\n };\n subtableParsers2[7] = function parseLookup72() {\n return { error: \"GPOS Lookup 7 not supported\" };\n };\n subtableParsers2[8] = function parseLookup82() {\n return { error: \"GPOS Lookup 8 not supported\" };\n };\n subtableParsers2[9] = function parseLookup9() {\n return { error: \"GPOS Lookup 9 not supported\" };\n };\n function parseGposTable(data, start) {\n start = start || 0;\n const p = new Parser(data, start);\n const tableVersion = p.parseVersion(1);\n check_default.argument(tableVersion === 1 || tableVersion === 1.1, \"Unsupported GPOS table version \" + tableVersion);\n if (tableVersion === 1) {\n return {\n version: tableVersion,\n scripts: p.parseScriptList(),\n features: p.parseFeatureList(),\n lookups: p.parseLookupList(subtableParsers2)\n };\n } else {\n return {\n version: tableVersion,\n scripts: p.parseScriptList(),\n features: p.parseFeatureList(),\n lookups: p.parseLookupList(subtableParsers2),\n variations: p.parseFeatureVariationsList()\n };\n }\n }\n var subtableMakers2 = new Array(10);\n function makeGposTable(gpos) {\n return new table_default.Table(\"GPOS\", [\n { name: \"version\", type: \"ULONG\", value: 65536 },\n { name: \"scripts\", type: \"TABLE\", value: new table_default.ScriptList(gpos.scripts) },\n { name: \"features\", type: \"TABLE\", value: new table_default.FeatureList(gpos.features) },\n { name: \"lookups\", type: \"TABLE\", value: new table_default.LookupList(gpos.lookups, subtableMakers2) }\n ]);\n }\n var gpos_default = { parse: parseGposTable, make: makeGposTable };\n\n // src/tables/kern.mjs\n function parseWindowsKernTable(p) {\n const pairs = {};\n p.skip(\"uShort\");\n const subtableVersion = p.parseUShort();\n check_default.argument(subtableVersion === 0, \"Unsupported kern sub-table version.\");\n p.skip(\"uShort\", 2);\n const nPairs = p.parseUShort();\n p.skip(\"uShort\", 3);\n for (let i = 0; i < nPairs; i += 1) {\n const leftIndex = p.parseUShort();\n const rightIndex = p.parseUShort();\n const value = p.parseShort();\n pairs[leftIndex + \",\" + rightIndex] = value;\n }\n return pairs;\n }\n function parseMacKernTable(p) {\n const pairs = {};\n p.skip(\"uShort\");\n const nTables = p.parseULong();\n if (nTables > 1) {\n console.warn(\"Only the first kern subtable is supported.\");\n }\n p.skip(\"uLong\");\n const coverage = p.parseUShort();\n const subtableVersion = coverage & 255;\n p.skip(\"uShort\");\n if (subtableVersion === 0) {\n const nPairs = p.parseUShort();\n p.skip(\"uShort\", 3);\n for (let i = 0; i < nPairs; i += 1) {\n const leftIndex = p.parseUShort();\n const rightIndex = p.parseUShort();\n const value = p.parseShort();\n pairs[leftIndex + \",\" + rightIndex] = value;\n }\n }\n return pairs;\n }\n function parseKernTable(data, start) {\n const p = new parse_default.Parser(data, start);\n const tableVersion = p.parseUShort();\n if (tableVersion === 0) {\n return parseWindowsKernTable(p);\n } else if (tableVersion === 1) {\n return parseMacKernTable(p);\n } else {\n throw new Error(\"Unsupported kern table version (\" + tableVersion + \").\");\n }\n }\n var kern_default = { parse: parseKernTable };\n\n // src/tables/loca.mjs\n function parseLocaTable(data, start, numGlyphs, shortVersion) {\n const p = new parse_default.Parser(data, start);\n const parseFn = shortVersion ? p.parseUShort : p.parseULong;\n const glyphOffsets = [];\n for (let i = 0; i < numGlyphs + 1; i += 1) {\n let glyphOffset = parseFn.call(p);\n if (shortVersion) {\n glyphOffset *= 2;\n }\n glyphOffsets.push(glyphOffset);\n }\n return glyphOffsets;\n }\n var loca_default = { parse: parseLocaTable };\n\n // src/opentype.mjs\n function parseOpenTypeTableEntries(data, numTables) {\n const tableEntries = [];\n let p = 12;\n for (let i = 0; i < numTables; i += 1) {\n const tag = parse_default.getTag(data, p);\n const checksum = parse_default.getULong(data, p + 4);\n const offset = parse_default.getULong(data, p + 8);\n const length = parse_default.getULong(data, p + 12);\n tableEntries.push({ tag, checksum, offset, length, compression: false });\n p += 16;\n }\n return tableEntries;\n }\n function parseWOFFTableEntries(data, numTables) {\n const tableEntries = [];\n let p = 44;\n for (let i = 0; i < numTables; i += 1) {\n const tag = parse_default.getTag(data, p);\n const offset = parse_default.getULong(data, p + 4);\n const compLength = parse_default.getULong(data, p + 8);\n const origLength = parse_default.getULong(data, p + 12);\n let compression;\n if (compLength < origLength) {\n compression = \"WOFF\";\n } else {\n compression = false;\n }\n tableEntries.push({\n tag,\n offset,\n compression,\n compressedLength: compLength,\n length: origLength\n });\n p += 20;\n }\n return tableEntries;\n }\n function uncompressTable(data, tableEntry) {\n if (tableEntry.compression === \"WOFF\") {\n const inBuffer = new Uint8Array(data.buffer, tableEntry.offset + 2, tableEntry.compressedLength - 2);\n const outBuffer = new Uint8Array(tableEntry.length);\n tinf_uncompress(inBuffer, outBuffer);\n if (outBuffer.byteLength !== tableEntry.length) {\n throw new Error(\"Decompression error: \" + tableEntry.tag + \" decompressed length doesn't match recorded length\");\n }\n const view = new DataView(outBuffer.buffer, 0);\n return { data: view, offset: 0 };\n } else {\n return { data, offset: tableEntry.offset };\n }\n }\n function parseBuffer(buffer, opt = {}) {\n let indexToLocFormat;\n let ltagTable;\n const font = new font_default({ empty: true });\n if (buffer.constructor !== ArrayBuffer) {\n buffer = new Uint8Array(buffer).buffer;\n }\n const data = new DataView(buffer, 0);\n let numTables;\n let tableEntries = [];\n const signature = parse_default.getTag(data, 0);\n if (signature === String.fromCharCode(0, 1, 0, 0) || signature === \"true\" || signature === \"typ1\") {\n font.outlinesFormat = \"truetype\";\n numTables = parse_default.getUShort(data, 4);\n tableEntries = parseOpenTypeTableEntries(data, numTables);\n } else if (signature === \"OTTO\") {\n font.outlinesFormat = \"cff\";\n numTables = parse_default.getUShort(data, 4);\n tableEntries = parseOpenTypeTableEntries(data, numTables);\n } else if (signature === \"wOFF\") {\n const flavor = parse_default.getTag(data, 4);\n if (flavor === String.fromCharCode(0, 1, 0, 0)) {\n font.outlinesFormat = \"truetype\";\n } else if (flavor === \"OTTO\") {\n font.outlinesFormat = \"cff\";\n } else {\n throw new Error(\"Unsupported OpenType flavor \" + signature);\n }\n numTables = parse_default.getUShort(data, 12);\n tableEntries = parseWOFFTableEntries(data, numTables);\n } else if (signature === \"wOF2\") {\n const issue = \"https://github.com/opentypejs/opentype.js/issues/183#issuecomment-1147228025\";\n throw new Error(\"WOFF2 require an external decompressor library, see examples at: \" + issue);\n } else {\n throw new Error(\"Unsupported OpenType signature \" + signature);\n }\n let cffTableEntry;\n let cff2TableEntry;\n let fvarTableEntry;\n let statTableEntry;\n let gvarTableEntry;\n let cvarTableEntry;\n let avarTableEntry;\n let glyfTableEntry;\n let gdefTableEntry;\n let gposTableEntry;\n let gsubTableEntry;\n let hmtxTableEntry;\n let hvarTableEntry;\n let kernTableEntry;\n let locaTableEntry;\n let nameTableEntry;\n let metaTableEntry;\n let p;\n for (let i = 0; i < numTables; i += 1) {\n const tableEntry = tableEntries[i];\n let table;\n switch (tableEntry.tag) {\n case \"avar\":\n avarTableEntry = tableEntry;\n break;\n case \"cmap\":\n table = uncompressTable(data, tableEntry);\n font.tables.cmap = cmap_default.parse(table.data, table.offset);\n font.encoding = new CmapEncoding(font.tables.cmap);\n break;\n case \"cvt \":\n table = uncompressTable(data, tableEntry);\n p = new parse_default.Parser(table.data, table.offset);\n font.tables.cvt = p.parseShortList(tableEntry.length / 2);\n break;\n case \"fvar\":\n fvarTableEntry = tableEntry;\n break;\n case \"STAT\":\n statTableEntry = tableEntry;\n break;\n case \"gvar\":\n gvarTableEntry = tableEntry;\n break;\n case \"cvar\":\n cvarTableEntry = tableEntry;\n break;\n case \"fpgm\":\n table = uncompressTable(data, tableEntry);\n p = new parse_default.Parser(table.data, table.offset);\n font.tables.fpgm = p.parseByteList(tableEntry.length);\n break;\n case \"head\":\n table = uncompressTable(data, tableEntry);\n font.tables.head = head_default.parse(table.data, table.offset);\n font.unitsPerEm = font.tables.head.unitsPerEm;\n indexToLocFormat = font.tables.head.indexToLocFormat;\n break;\n case \"hhea\":\n table = uncompressTable(data, tableEntry);\n font.tables.hhea = hhea_default.parse(table.data, table.offset);\n font.ascender = font.tables.hhea.ascender;\n font.descender = font.tables.hhea.descender;\n font.numberOfHMetrics = font.tables.hhea.numberOfHMetrics;\n break;\n case \"HVAR\":\n hvarTableEntry = tableEntry;\n break;\n case \"hmtx\":\n hmtxTableEntry = tableEntry;\n break;\n case \"ltag\":\n table = uncompressTable(data, tableEntry);\n ltagTable = ltag_default.parse(table.data, table.offset);\n break;\n case \"COLR\":\n table = uncompressTable(data, tableEntry);\n font.tables.colr = colr_default.parse(table.data, table.offset);\n break;\n case \"CPAL\":\n table = uncompressTable(data, tableEntry);\n font.tables.cpal = cpal_default.parse(table.data, table.offset);\n break;\n case \"maxp\":\n table = uncompressTable(data, tableEntry);\n font.tables.maxp = maxp_default.parse(table.data, table.offset);\n font.numGlyphs = font.tables.maxp.numGlyphs;\n break;\n case \"name\":\n nameTableEntry = tableEntry;\n break;\n case \"OS/2\":\n table = uncompressTable(data, tableEntry);\n font.tables.os2 = os2_default.parse(table.data, table.offset);\n break;\n case \"post\":\n table = uncompressTable(data, tableEntry);\n font.tables.post = post_default.parse(table.data, table.offset);\n font.glyphNames = new GlyphNames(font.tables.post);\n break;\n case \"prep\":\n table = uncompressTable(data, tableEntry);\n p = new parse_default.Parser(table.data, table.offset);\n font.tables.prep = p.parseByteList(tableEntry.length);\n break;\n case \"glyf\":\n glyfTableEntry = tableEntry;\n break;\n case \"loca\":\n locaTableEntry = tableEntry;\n break;\n case \"CFF \":\n cffTableEntry = tableEntry;\n break;\n case \"CFF2\":\n cff2TableEntry = tableEntry;\n break;\n case \"kern\":\n kernTableEntry = tableEntry;\n break;\n case \"GDEF\":\n gdefTableEntry = tableEntry;\n break;\n case \"GPOS\":\n gposTableEntry = tableEntry;\n break;\n case \"GSUB\":\n gsubTableEntry = tableEntry;\n break;\n case \"meta\":\n metaTableEntry = tableEntry;\n break;\n case \"gasp\":\n try {\n table = uncompressTable(data, tableEntry);\n font.tables.gasp = gasp_default.parse(table.data, table.offset);\n } catch (e) {\n console.warn(\"Failed to parse gasp table, skipping.\");\n console.warn(e);\n }\n break;\n case \"SVG \":\n table = uncompressTable(data, tableEntry);\n font.tables.svg = svg_default.parse(table.data, table.offset);\n break;\n default:\n break;\n }\n }\n const nameTable = uncompressTable(data, nameTableEntry);\n font.tables.name = name_default.parse(nameTable.data, nameTable.offset, ltagTable);\n font.names = font.tables.name;\n if (glyfTableEntry && locaTableEntry) {\n const shortVersion = indexToLocFormat === 0;\n const locaTable = uncompressTable(data, locaTableEntry);\n const locaOffsets = loca_default.parse(locaTable.data, locaTable.offset, font.numGlyphs, shortVersion);\n const glyfTable = uncompressTable(data, glyfTableEntry);\n font.glyphs = glyf_default.parse(glyfTable.data, glyfTable.offset, locaOffsets, font, opt);\n } else if (cffTableEntry) {\n const cffTable = uncompressTable(data, cffTableEntry);\n cff_default.parse(cffTable.data, cffTable.offset, font, opt);\n } else if (cff2TableEntry) {\n const cffTable2 = uncompressTable(data, cff2TableEntry);\n cff_default.parse(cffTable2.data, cffTable2.offset, font, opt);\n } else {\n throw new Error(\"Font doesn't contain TrueType, CFF or CFF2 outlines.\");\n }\n const hmtxTable = uncompressTable(data, hmtxTableEntry);\n hmtx_default.parse(font, hmtxTable.data, hmtxTable.offset, font.numberOfHMetrics, font.numGlyphs, font.glyphs, opt);\n addGlyphNames(font, opt);\n if (kernTableEntry) {\n const kernTable = uncompressTable(data, kernTableEntry);\n font.kerningPairs = kern_default.parse(kernTable.data, kernTable.offset);\n } else {\n font.kerningPairs = {};\n }\n if (gdefTableEntry) {\n const gdefTable = uncompressTable(data, gdefTableEntry);\n font.tables.gdef = gdef_default.parse(gdefTable.data, gdefTable.offset);\n }\n if (gposTableEntry) {\n const gposTable = uncompressTable(data, gposTableEntry);\n font.tables.gpos = gpos_default.parse(gposTable.data, gposTable.offset);\n font.position.init();\n }\n if (gsubTableEntry) {\n const gsubTable = uncompressTable(data, gsubTableEntry);\n font.tables.gsub = gsub_default.parse(gsubTable.data, gsubTable.offset);\n }\n if (fvarTableEntry) {\n const fvarTable = uncompressTable(data, fvarTableEntry);\n font.tables.fvar = fvar_default.parse(fvarTable.data, fvarTable.offset, font.names);\n }\n if (statTableEntry) {\n const statTable = uncompressTable(data, statTableEntry);\n font.tables.stat = stat_default.parse(statTable.data, statTable.offset, font.tables.fvar);\n }\n if (gvarTableEntry) {\n if (!fvarTableEntry) {\n console.warn(\"This font provides a gvar table, but no fvar table, which is required for variable fonts.\");\n }\n if (!glyfTableEntry) {\n console.warn(\"This font provides a gvar table, but no glyf table. Glyph variation only works with TrueType outlines.\");\n }\n const gvarTable = uncompressTable(data, gvarTableEntry);\n font.tables.gvar = gvar_default.parse(gvarTable.data, gvarTable.offset, font.tables.fvar, font.glyphs);\n }\n if (cvarTableEntry) {\n if (!fvarTableEntry) {\n console.warn(\"This font provides a cvar table, but no fvar table, which is required for variable fonts.\");\n }\n if (!font.tables.cvt) {\n console.warn(\"This font provides a cvar table, but no cvt table which could be made variable.\");\n }\n if (!glyfTableEntry) {\n console.warn(\"This font provides a gvar table, but no glyf table. Glyph variation only works with TrueType outlines.\");\n }\n const cvarTable = uncompressTable(data, cvarTableEntry);\n font.tables.cvar = cvar_default.parse(cvarTable.data, cvarTable.offset, font.tables.fvar, font.tables.cvt || []);\n }\n if (avarTableEntry) {\n if (!fvarTableEntry) {\n console.warn(\"This font provides an avar table, but no fvar table, which is required for variable fonts.\");\n }\n const avarTable = uncompressTable(data, avarTableEntry);\n font.tables.avar = avar_default.parse(avarTable.data, avarTable.offset, font.tables.fvar);\n }\n if (hvarTableEntry) {\n if (!fvarTableEntry) {\n console.warn(\"This font provides an HVAR table, but no fvar table, which is required for variable fonts.\");\n }\n if (!hmtxTableEntry) {\n console.warn(\"This font provides an HVAR table, but no hmtx table to vary.\");\n }\n const hvarTable = uncompressTable(data, hvarTableEntry);\n font.tables.hvar = hvar_default.parse(hvarTable.data, hvarTable.offset, font.tables.fvar);\n }\n if (metaTableEntry) {\n const metaTable = uncompressTable(data, metaTableEntry);\n font.tables.meta = meta_default.parse(metaTable.data, metaTable.offset);\n font.metas = font.tables.meta;\n }\n font.palettes = new PaletteManager(font);\n return font;\n }\n function load() {\n console.error(\"DEPRECATED! migrate to: opentype.parse(buffer, opt) See: https://github.com/opentypejs/opentype.js/issues/675\");\n }\n function loadSync() {\n console.error('DEPRECATED! migrate to: opentype.parse(require(\"fs\").readFileSync(url), opt)');\n }\n return __toCommonJS(opentype_exports);\n})();\n(function (root, factory) { if (typeof define === 'function' && define.amd)define(factory); else if (typeof module === 'object' && module.exports)module.exports = factory(); else root.opentype = factory(); }(typeof self !== 'undefined' ? self : this, () => ({...opentype,'default':opentype})));\n"],"x_google_ignoreList":[0],"mappings":"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AAM;GACN,OAAO;GACP,MAAM;GACN,OAAO;GACP,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,OAAO;GACP,MAAM;GACN,MAAM;GACN,OAAO;GACP,MAAM;GACN,MAAM;GACN,OAAO;GACP,MAAM;GACN,OAAO;GACP,OAAO;GACP,MAAM;GACN,OAAO;GACP,MAAM;GACN,MAAM;GACN,OAAO;GACP,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,MAAM;GACN,M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AAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAM;GAE1B;IAAE,OAAO;IAAM,KAAK;IAAO;GAE3B;IAAE,OAAO;IAAO,KAAK;IAAO;GAE5B;IAAE,OAAO;IAAO,KAAK;IAAO;GAE5B;IAAE,OAAO;IAAO,KAAK;IAAO;GAE5B;IAAE,OAAO;IAAO,KAAK;IAAO;GAE5B;IAAE,OAAO;IAAO,KAAK;IAAO;GAE5B;IAAE,OAAO;IAAO,KAAK;IAAO;GAE5B;IAAE,OAAO;IAAO,KAAK;IAAO;GAE5B;IAAE,OAAO;IAAO,KAAK;IAAO;GAE5B;IAAE,OAAO;IAAO,KAAK;IAAO;GAE5B;IAAE,OAAO;IAAO,KAAK;IAAO;GAE5B;IAAE,OAAO;IAAO,KAAK;IAAO;GAE5B;IAAE,OAAO;IAAO,KAAK;IAAO;GAE5B;IAAE,OAAO;IAAO,KAAK;IAAO;GAE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,GAAG,EAAE;GAErB,GAAM,KAAK,KAAK,GAAG,EAAE;GAErB,GAAM,KAAK,KAAK,GAAG,EAAE;GAErB,GAAM,KAAK,KAAK,GAAG,EAAE;GAErB,GAAM,KAAK,KAAK,GAAG,EAAE;GAErB,GAAM,KAAK,KAAK,GAAG,EAAE;GAErB,GAAM,KAAK,KAAK,GAAG,EAAE;GAErB,GAAM,KAAK,KAAK,GAAG,EAAE;GAErB,GAAM,KAAK,KAAK,GAAG,EAAE;GAErB,GAAM,KAAK,KAAK,GAAG,EAAE;GAErB,GAAM,KAAK,KAAK,GAAG,EAAE;GAErB,GAAM,KAAK,KAAK,GAAG,EAAE;GAErB,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG,GAAG,GAAG,EAAE;GAErC,EAAU,KAAK,KAAK,GAAG,GAAG,GAAG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"}