UNPKG

speech-rule-engine

Version:

A standalone speech rule engine for XML structures, based on the original engine from ChromeVox.

249 lines 7.94 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || (function () { var ownKeys = function(o) { ownKeys = Object.getOwnPropertyNames || function (o) { var ar = []; for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k; return ar; }; return ownKeys(o); }; return function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]); __setModuleDefault(result, mod); return result; }; })(); Object.defineProperty(exports, "__esModule", { value: true }); exports.MMLTAGS = void 0; exports.hasMathTag = hasMathTag; exports.hasIgnoreTag = hasIgnoreTag; exports.hasEmptyTag = hasEmptyTag; exports.hasDisplayTag = hasDisplayTag; exports.isOrphanedGlyph = isOrphanedGlyph; exports.purgeNodes = purgeNodes; exports.isZeroLength = isZeroLength; exports.addAttributes = addAttributes; exports.getEmbellishedInner = getEmbellishedInner; exports.sliceNodes = sliceNodes; exports.partitionNodes = partitionNodes; const DomUtil = __importStar(require("../common/dom_util.js")); var MMLTAGS; (function (MMLTAGS) { MMLTAGS["ANNOTATION"] = "ANNOTATION"; MMLTAGS["ANNOTATIONXML"] = "ANNOTATION-XML"; MMLTAGS["MACTION"] = "MACTION"; MMLTAGS["MALIGNGROUP"] = "MALIGNGROUP"; MMLTAGS["MALIGNMARK"] = "MALIGNMARK"; MMLTAGS["MATH"] = "MATH"; MMLTAGS["MENCLOSE"] = "MENCLOSE"; MMLTAGS["MERROR"] = "MERROR"; MMLTAGS["MFENCED"] = "MFENCED"; MMLTAGS["MFRAC"] = "MFRAC"; MMLTAGS["MGLYPH"] = "MGLYPH"; MMLTAGS["MI"] = "MI"; MMLTAGS["MLABELEDTR"] = "MLABELEDTR"; MMLTAGS["MMULTISCRIPTS"] = "MMULTISCRIPTS"; MMLTAGS["MN"] = "MN"; MMLTAGS["MO"] = "MO"; MMLTAGS["MOVER"] = "MOVER"; MMLTAGS["MPADDED"] = "MPADDED"; MMLTAGS["MPHANTOM"] = "MPHANTOM"; MMLTAGS["MPRESCRIPTS"] = "MPRESCRIPTS"; MMLTAGS["MROOT"] = "MROOT"; MMLTAGS["MROW"] = "MROW"; MMLTAGS["MS"] = "MS"; MMLTAGS["MSPACE"] = "MSPACE"; MMLTAGS["MSQRT"] = "MSQRT"; MMLTAGS["MSTYLE"] = "MSTYLE"; MMLTAGS["MSUB"] = "MSUB"; MMLTAGS["MSUBSUP"] = "MSUBSUP"; MMLTAGS["MSUP"] = "MSUP"; MMLTAGS["MTABLE"] = "MTABLE"; MMLTAGS["MTD"] = "MTD"; MMLTAGS["MTEXT"] = "MTEXT"; MMLTAGS["MTR"] = "MTR"; MMLTAGS["MUNDER"] = "MUNDER"; MMLTAGS["MUNDEROVER"] = "MUNDEROVER"; MMLTAGS["NONE"] = "NONE"; MMLTAGS["SEMANTICS"] = "SEMANTICS"; })(MMLTAGS || (exports.MMLTAGS = MMLTAGS = {})); const ALLTAGS = Object.values(MMLTAGS); const LEAFTAGS = [ MMLTAGS.MO, MMLTAGS.MI, MMLTAGS.MN, MMLTAGS.MTEXT, MMLTAGS.MS, MMLTAGS.MSPACE ]; const IGNORETAGS = [ MMLTAGS.MERROR, MMLTAGS.MPHANTOM, MMLTAGS.MALIGNGROUP, MMLTAGS.MALIGNMARK, MMLTAGS.MPRESCRIPTS, MMLTAGS.ANNOTATION, MMLTAGS.ANNOTATIONXML ]; const EMPTYTAGS = [ MMLTAGS.MATH, MMLTAGS.MROW, MMLTAGS.MPADDED, MMLTAGS.MACTION, MMLTAGS.NONE, MMLTAGS.MSTYLE, MMLTAGS.SEMANTICS ]; const DISPLAYTAGS = [MMLTAGS.MROOT, MMLTAGS.MSQRT]; const directSpeechKeys = ['aria-label', 'exact-speech', 'alt']; function hasMathTag(node) { return !!node && DomUtil.tagName(node) === MMLTAGS.MATH; } function hasLeafTag(node) { return !!node && LEAFTAGS.includes(DomUtil.tagName(node)); } function hasIgnoreTag(node) { return (!!node && (IGNORETAGS.includes(DomUtil.tagName(node)) || !ALLTAGS.includes(DomUtil.tagName(node)))); } function hasEmptyTag(node) { return !!node && EMPTYTAGS.includes(DomUtil.tagName(node)); } function hasDisplayTag(node) { return !!node && DISPLAYTAGS.includes(DomUtil.tagName(node)); } function isOrphanedGlyph(node) { return (!!node && DomUtil.tagName(node) === MMLTAGS.MGLYPH && !hasLeafTag(node.parentNode)); } function purgeNodes(nodes) { const nodeArray = []; for (let i = 0, node; (node = nodes[i]); i++) { if (node.nodeType !== DomUtil.NodeType.ELEMENT_NODE) { continue; } const tagName = DomUtil.tagName(node); if (IGNORETAGS.includes(tagName)) { continue; } if (EMPTYTAGS.includes(tagName) && node.childNodes.length === 0) { continue; } nodeArray.push(node); } return nodeArray; } function isZeroLength(length) { if (!length) { return false; } const negativeNamedSpaces = [ 'negativeveryverythinmathspace', 'negativeverythinmathspace', 'negativethinmathspace', 'negativemediummathspace', 'negativethickmathspace', 'negativeverythickmathspace', 'negativeveryverythickmathspace' ]; if (negativeNamedSpaces.includes(length)) { return true; } const value = length.match(/[0-9.]+/); if (!value) { return false; } return parseFloat(value[0]) === 0; } function addAttributes(to, from) { var _a; if ((_a = from.attributes) === null || _a === void 0 ? void 0 : _a.length) { const attrs = from.attributes; for (let i = attrs.length - 1; i >= 0; i--) { const key = attrs[i].name; if (key.match(/^ext/)) { to.attributes[key] = attrs[i].value; to.nobreaking = true; } if (directSpeechKeys.includes(key)) { to.attributes['ext-speech'] = attrs[i].value; to.nobreaking = true; } if (key.match(/texclass$/)) { to.attributes['texclass'] = attrs[i].value; } if (key.toLowerCase() === 'data-latex') { to.attributes['latex'] = attrs[i].value; } if (key === 'href') { to.attributes['href'] = attrs[i].value; to.nobreaking = true; } } } } function getEmbellishedInner(node) { if (node && node.embellished && node.childNodes.length > 0) { return getEmbellishedInner(node.childNodes[0]); } return node; } function sliceNodes(nodes, pred, opt_reverse) { if (opt_reverse) { nodes.reverse(); } const head = []; for (let i = 0, node; (node = nodes[i]); i++) { if (pred(node)) { if (opt_reverse) { return { head: nodes.slice(i + 1).reverse(), div: node, tail: head.reverse() }; } return { head: head, div: node, tail: nodes.slice(i + 1) }; } head.push(node); } if (opt_reverse) { return { head: [], div: null, tail: head.reverse() }; } return { head: head, div: null, tail: [] }; } function partitionNodes(nodes, pred) { let restNodes = nodes; const rel = []; const comp = []; let result = null; do { result = sliceNodes(restNodes, pred); comp.push(result.head); rel.push(result.div); restNodes = result.tail; } while (result.div); rel.pop(); return { rel: rel, comp: comp }; } //# sourceMappingURL=semantic_util.js.map