site/node_modules/mathjax-full/js/a11y/complexity/visitor.js
2024-10-14 08:09:33 +02:00

209 lines
No EOL
9.1 KiB
JavaScript

"use strict";
var __extends = (this && this.__extends) || (function () {
var extendStatics = function (d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
return extendStatics(d, b);
};
return function (d, b) {
if (typeof b !== "function" && b !== null)
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
var __values = (this && this.__values) || function(o) {
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
if (m) return m.call(o);
if (o && typeof o.length === "number") return {
next: function () {
if (o && i >= o.length) o = void 0;
return { value: o && o[i++], done: !o };
}
};
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.ComplexityVisitor = void 0;
var MmlVisitor_js_1 = require("../../core/MmlTree/MmlVisitor.js");
var collapse_js_1 = require("./collapse.js");
var Options_js_1 = require("../../util/Options.js");
var ComplexityVisitor = (function (_super) {
__extends(ComplexityVisitor, _super);
function ComplexityVisitor(factory, options) {
var _this = _super.call(this, factory) || this;
_this.complexity = {
text: .5,
token: .5,
child: 1,
script: .8,
sqrt: 2,
subsup: 2,
underover: 2,
fraction: 2,
enclose: 2,
action: 2,
phantom: 0,
xml: 2,
glyph: 2
};
var CLASS = _this.constructor;
_this.options = (0, Options_js_1.userOptions)((0, Options_js_1.defaultOptions)({}, CLASS.OPTIONS), options);
_this.collapse = new _this.options.Collapse(_this);
_this.factory = factory;
return _this;
}
ComplexityVisitor.prototype.visitTree = function (node) {
_super.prototype.visitTree.call(this, node, true);
if (this.options.makeCollapsible) {
this.collapse.makeCollapse(node);
}
};
ComplexityVisitor.prototype.visitNode = function (node, save) {
if (node.attributes.get('data-semantic-complexity'))
return;
return _super.prototype.visitNode.call(this, node, save);
};
ComplexityVisitor.prototype.visitDefault = function (node, save) {
var complexity;
if (node.isToken) {
var text = node.getText();
complexity = this.complexity.text * text.length + this.complexity.token;
}
else {
complexity = this.childrenComplexity(node);
}
return this.setComplexity(node, complexity, save);
};
ComplexityVisitor.prototype.visitMfracNode = function (node, save) {
var complexity = this.childrenComplexity(node) * this.complexity.script + this.complexity.fraction;
return this.setComplexity(node, complexity, save);
};
ComplexityVisitor.prototype.visitMsqrtNode = function (node, save) {
var complexity = this.childrenComplexity(node) + this.complexity.sqrt;
return this.setComplexity(node, complexity, save);
};
ComplexityVisitor.prototype.visitMrootNode = function (node, save) {
var complexity = this.childrenComplexity(node) + this.complexity.sqrt
- (1 - this.complexity.script) * this.getComplexity(node.childNodes[1]);
return this.setComplexity(node, complexity, save);
};
ComplexityVisitor.prototype.visitMphantomNode = function (node, save) {
return this.setComplexity(node, this.complexity.phantom, save);
};
ComplexityVisitor.prototype.visitMsNode = function (node, save) {
var text = node.attributes.get('lquote')
+ node.getText()
+ node.attributes.get('rquote');
var complexity = text.length * this.complexity.text;
return this.setComplexity(node, complexity, save);
};
ComplexityVisitor.prototype.visitMsubsupNode = function (node, save) {
_super.prototype.visitDefault.call(this, node, true);
var sub = node.childNodes[node.sub];
var sup = node.childNodes[node.sup];
var base = node.childNodes[node.base];
var complexity = Math.max(sub ? this.getComplexity(sub) : 0, sup ? this.getComplexity(sup) : 0) * this.complexity.script;
complexity += this.complexity.child * ((sub ? 1 : 0) + (sup ? 1 : 0));
complexity += (base ? this.getComplexity(base) + this.complexity.child : 0);
complexity += this.complexity.subsup;
return this.setComplexity(node, complexity, save);
};
ComplexityVisitor.prototype.visitMsubNode = function (node, save) {
return this.visitMsubsupNode(node, save);
};
ComplexityVisitor.prototype.visitMsupNode = function (node, save) {
return this.visitMsubsupNode(node, save);
};
ComplexityVisitor.prototype.visitMunderoverNode = function (node, save) {
_super.prototype.visitDefault.call(this, node, true);
var under = node.childNodes[node.under];
var over = node.childNodes[node.over];
var base = node.childNodes[node.base];
var complexity = Math.max(under ? this.getComplexity(under) : 0, over ? this.getComplexity(over) : 0) * this.complexity.script;
if (base) {
complexity = Math.max(this.getComplexity(base), complexity);
}
complexity += this.complexity.child * ((under ? 1 : 0) + (over ? 1 : 0) + (base ? 1 : 0));
complexity += this.complexity.underover;
return this.setComplexity(node, complexity, save);
};
ComplexityVisitor.prototype.visitMunderNode = function (node, save) {
return this.visitMunderoverNode(node, save);
};
ComplexityVisitor.prototype.visitMoverNode = function (node, save) {
return this.visitMunderoverNode(node, save);
};
ComplexityVisitor.prototype.visitMencloseNode = function (node, save) {
var complexity = this.childrenComplexity(node) + this.complexity.enclose;
return this.setComplexity(node, complexity, save);
};
ComplexityVisitor.prototype.visitMactionNode = function (node, save) {
this.childrenComplexity(node);
var complexity = this.getComplexity(node.selected);
return this.setComplexity(node, complexity, save);
};
ComplexityVisitor.prototype.visitMsemanticsNode = function (node, save) {
var child = node.childNodes[0];
var complexity = 0;
if (child) {
this.visitNode(child, true);
complexity = this.getComplexity(child);
}
return this.setComplexity(node, complexity, save);
};
ComplexityVisitor.prototype.visitAnnotationNode = function (node, save) {
return this.setComplexity(node, this.complexity.xml, save);
};
ComplexityVisitor.prototype.visitAnnotation_xmlNode = function (node, save) {
return this.setComplexity(node, this.complexity.xml, save);
};
ComplexityVisitor.prototype.visitMglyphNode = function (node, save) {
return this.setComplexity(node, this.complexity.glyph, save);
};
ComplexityVisitor.prototype.getComplexity = function (node) {
var collapsed = node.getProperty('collapsedComplexity');
return (collapsed != null ? collapsed : node.attributes.get('data-semantic-complexity'));
};
ComplexityVisitor.prototype.setComplexity = function (node, complexity, save) {
if (save) {
if (this.options.identifyCollapsible) {
complexity = this.collapse.check(node, complexity);
}
node.attributes.set('data-semantic-complexity', complexity);
}
return complexity;
};
ComplexityVisitor.prototype.childrenComplexity = function (node) {
var e_1, _a;
_super.prototype.visitDefault.call(this, node, true);
var complexity = 0;
try {
for (var _b = __values(node.childNodes), _c = _b.next(); !_c.done; _c = _b.next()) {
var child = _c.value;
complexity += this.getComplexity(child);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
if (node.childNodes.length > 1) {
complexity += node.childNodes.length * this.complexity.child;
}
return complexity;
};
ComplexityVisitor.OPTIONS = {
identifyCollapsible: true,
makeCollapsible: true,
Collapse: collapse_js_1.Collapse
};
return ComplexityVisitor;
}(MmlVisitor_js_1.MmlVisitor));
exports.ComplexityVisitor = ComplexityVisitor;
//# sourceMappingURL=visitor.js.map