occam-query 4.0.2 → 4.1.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.
- package/example.js +222 -203
- package/lib/query.js +20 -1
- package/package.json +1 -1
- package/src/query.js +21 -0
package/lib/query.js
CHANGED
|
@@ -9,6 +9,7 @@ Object.defineProperty(exports, "default", {
|
|
|
9
9
|
}
|
|
10
10
|
});
|
|
11
11
|
var _necessary = require("necessary");
|
|
12
|
+
var _expression = /*#__PURE__*/ _interop_require_default(require("./expression"));
|
|
12
13
|
var _array = require("./utilities/array");
|
|
13
14
|
function _class_call_check(instance, Constructor) {
|
|
14
15
|
if (!(instance instanceof Constructor)) {
|
|
@@ -29,6 +30,11 @@ function _create_class(Constructor, protoProps, staticProps) {
|
|
|
29
30
|
if (staticProps) _defineProperties(Constructor, staticProps);
|
|
30
31
|
return Constructor;
|
|
31
32
|
}
|
|
33
|
+
function _interop_require_default(obj) {
|
|
34
|
+
return obj && obj.__esModule ? obj : {
|
|
35
|
+
default: obj
|
|
36
|
+
};
|
|
37
|
+
}
|
|
32
38
|
var WILDCARD_CHARACTER = _necessary.characters.WILDCARD_CHARACTER;
|
|
33
39
|
var Query = /*#__PURE__*/ function() {
|
|
34
40
|
function Query(spread, subQuery, ruleNames, tokenTypes, maximumDepth, infiniteDescent, intermediateNodes) {
|
|
@@ -171,6 +177,19 @@ var Query = /*#__PURE__*/ function() {
|
|
|
171
177
|
var spread = subExpression.getSpread(), subQuery = subQueryFromSubExpression(subExpression), ruleNames = subExpression.getRuleNames(), tokenTypes = subExpression.getTokenTypes(), maximumDepth = Infinity, infiniteDescent = subExpression.isInfiniteDescent(), intermediateNodes = [], query = new Query(spread, subQuery, ruleNames, tokenTypes, maximumDepth, infiniteDescent, intermediateNodes);
|
|
172
178
|
return query;
|
|
173
179
|
}
|
|
180
|
+
},
|
|
181
|
+
{
|
|
182
|
+
key: "fromExpressionString",
|
|
183
|
+
value: function fromExpressionString(expressionString) {
|
|
184
|
+
var maximumDepth = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : Infinity;
|
|
185
|
+
var query = null;
|
|
186
|
+
var expression = _expression.default.fromExpressionString(expressionString);
|
|
187
|
+
if (expression !== null) {
|
|
188
|
+
var spread = expression.getSpread(), subQuery = subQueryFromExpression(expression), ruleNames = expression.getRuleNames(), tokenTypes = expression.getTokenTypes(), infiniteDescent = expression.isInfiniteDescent(), intermediateNodes = [];
|
|
189
|
+
query = new Query(spread, subQuery, ruleNames, tokenTypes, maximumDepth, infiniteDescent, intermediateNodes);
|
|
190
|
+
}
|
|
191
|
+
return query;
|
|
192
|
+
}
|
|
174
193
|
}
|
|
175
194
|
]);
|
|
176
195
|
return Query;
|
|
@@ -194,4 +213,4 @@ function subQueryFromSubExpression(subExpression) {
|
|
|
194
213
|
return subQuery;
|
|
195
214
|
}
|
|
196
215
|
|
|
197
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/query.js"],"sourcesContent":["\"use strict\";\n\nimport { characters } from \"necessary\";\n\nimport { push, clear, includes } from \"./utilities/array\";\n\nconst { WILDCARD_CHARACTER } = characters;\n\nexport default class Query {\n  constructor(spread, subQuery, ruleNames, tokenTypes, maximumDepth, infiniteDescent, intermediateNodes) {\n    this.spread = spread;\n    this.subQuery = subQuery;\n    this.ruleNames = ruleNames;\n    this.tokenTypes = tokenTypes;\n    this.maximumDepth = maximumDepth;\n    this.infiniteDescent = infiniteDescent;\n    this.intermediateNodes = intermediateNodes;\n  }\n\n  getSpread() {\n    return this.sprea;\n  }\n\n  getSubQuery() {\n    return this.subQuery;\n  }\n\n  getRuleNames() {\n    return this.ruleNames;\n  }\n\n  getTokenTypes() {\n    return this.tokenTypes;\n  }\n\n  getMaximumDepth() {\n    return this.maximumDepth;\n  }\n\n  isInfiniteDescent() {\n    return this.infiniteDescent;\n  }\n\n  getIntermediateNodes() {\n    return this.intermediateNodes;\n  }\n\n  execute(node, depth = 0, maximumDepth = this.maximumDepth) {\n    const nodes = [];\n\n    this.clear();\n\n    this.find(node, depth, maximumDepth);\n\n    this.apply(nodes, depth, maximumDepth);\n\n    return nodes;\n  }\n\n  clear() {\n    clear(this.intermediateNodes);\n  }\n\n  find(node, depth, maximumDepth) {\n    if (depth > maximumDepth) {\n      return;\n    }\n\n    const nodeTerminalNode = node.isTerminalNode(),\n          nodeNonTerminalNode = !nodeTerminalNode;\n\n    let found;\n\n    if (nodeTerminalNode) {\n      const terminalNode = node,  ///\n            types = this.tokenTypes,  ///\n            type = terminalNode.getType();\n\n      found = includes(types, type, WILDCARD_CHARACTER);\n    }\n\n    if (nodeNonTerminalNode) {\n      const nonTerminalNode = node, ///\n            ruleName = nonTerminalNode.getRuleName();\n\n      found = includes(this.ruleNames, ruleName, WILDCARD_CHARACTER);\n    }\n\n    if (found) {\n      const intermediateNode = node; ///\n\n      this.intermediateNodes.push(intermediateNode);\n    }\n\n    if (this.infiniteDescent) {\n      if (nodeNonTerminalNode) {\n        depth++;\n\n        const nonTerminalNode = node, ///\n              childNodes = nonTerminalNode.getChildNodes();\n\n        childNodes.forEach((childNode) => {\n          this.find(childNode, depth, maximumDepth);\n        });\n      }\n    }\n  }\n\n  apply(nodes, depth, maximumDepth) {\n    this.spread.adjustNodes(this.intermediateNodes);\n\n    if (this.subQuery === null) {\n      push(nodes, this.intermediateNodes);\n    } else {\n      this.intermediateNodes.forEach((intermediateNode) => {\n        const intermediateNodeNonTerminalNode = intermediateNode.isNonTerminalNode();\n\n        if (intermediateNodeNonTerminalNode) {\n          depth++;\n\n          const nonTerminalNode = intermediateNode, ///\n                childNodes = nonTerminalNode.getChildNodes();\n\n          this.subQuery.clear();\n\n          childNodes.forEach((childNode) => {\n            this.subQuery.find(childNode, depth, maximumDepth);\n          });\n\n          this.subQuery.apply(nodes, depth, maximumDepth);\n        }\n      });\n    }\n  }\n\n  static fromExpression(expression, maximumDepth = Infinity) {\n    const spread = expression.getSpread(),\n          subQuery = subQueryFromExpression(expression),\n          ruleNames = expression.getRuleNames(),\n          tokenTypes = expression.getTokenTypes(),\n          infiniteDescent = expression.isInfiniteDescent(),\n          intermediateNodes = [],\n          query = new Query(spread, subQuery, ruleNames, tokenTypes, maximumDepth, infiniteDescent, intermediateNodes);\n\n    return query;\n  }\n\n  static fromSubExpression(subExpression) {\n    const spread = subExpression.getSpread(),\n          subQuery = subQueryFromSubExpression(subExpression),\n          ruleNames = subExpression.getRuleNames(),\n          tokenTypes = subExpression.getTokenTypes(),\n          maximumDepth = Infinity,\n          infiniteDescent = subExpression.isInfiniteDescent(),\n          intermediateNodes = [],\n          query = new Query(spread, subQuery, ruleNames, tokenTypes, maximumDepth, infiniteDescent, intermediateNodes);\n\n    return query;\n  }\n}\n\nfunction subQueryFromExpression(expression) {\n  let subQuery = null;\n\n  const subExpression = expression.getSubExpression();\n\n  if (subExpression !== null) {\n    const query = Query.fromSubExpression(subExpression);\n\n    subQuery = query; ///\n  }\n\n  return subQuery;\n}\n\nfunction subQueryFromSubExpression(subExpression) {\n  let subQuery = null;\n\n  subExpression = subExpression.getSubExpression(); ///\n\n  if (subExpression !== null) {\n    const query = Query.fromSubExpression(subExpression);\n\n    subQuery = query; ///\n  }\n\n  return subQuery;\n}\n"],"names":["Query","WILDCARD_CHARACTER","characters","spread","subQuery","ruleNames","tokenTypes","maximumDepth","infiniteDescent","intermediateNodes","getSpread","sprea","getSubQuery","getRuleNames","getTokenTypes","getMaximumDepth","isInfiniteDescent","getIntermediateNodes","execute","node","depth","nodes","clear","find","apply","nodeTerminalNode","isTerminalNode","nodeNonTerminalNode","found","terminalNode","types","type","getType","includes","nonTerminalNode","ruleName","getRuleName","intermediateNode","push","childNodes","getChildNodes","forEach","childNode","adjustNodes","intermediateNodeNonTerminalNode","isNonTerminalNode","fromExpression","expression","Infinity","subQueryFromExpression","query","fromSubExpression","subExpression","subQueryFromSubExpression","getSubExpression"],"mappings":"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"}
|
|
216
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/query.js"],"sourcesContent":["\"use strict\";\n\nimport { characters } from \"necessary\";\n\nimport Expression from \"./expression\";\n\nimport { push, clear, includes } from \"./utilities/array\";\n\nconst { WILDCARD_CHARACTER } = characters;\n\nexport default class Query {\n  constructor(spread, subQuery, ruleNames, tokenTypes, maximumDepth, infiniteDescent, intermediateNodes) {\n    this.spread = spread;\n    this.subQuery = subQuery;\n    this.ruleNames = ruleNames;\n    this.tokenTypes = tokenTypes;\n    this.maximumDepth = maximumDepth;\n    this.infiniteDescent = infiniteDescent;\n    this.intermediateNodes = intermediateNodes;\n  }\n\n  getSpread() {\n    return this.sprea;\n  }\n\n  getSubQuery() {\n    return this.subQuery;\n  }\n\n  getRuleNames() {\n    return this.ruleNames;\n  }\n\n  getTokenTypes() {\n    return this.tokenTypes;\n  }\n\n  getMaximumDepth() {\n    return this.maximumDepth;\n  }\n\n  isInfiniteDescent() {\n    return this.infiniteDescent;\n  }\n\n  getIntermediateNodes() {\n    return this.intermediateNodes;\n  }\n\n  execute(node, depth = 0, maximumDepth = this.maximumDepth) {\n    const nodes = [];\n\n    this.clear();\n\n    this.find(node, depth, maximumDepth);\n\n    this.apply(nodes, depth, maximumDepth);\n\n    return nodes;\n  }\n\n  clear() {\n    clear(this.intermediateNodes);\n  }\n\n  find(node, depth, maximumDepth) {\n    if (depth > maximumDepth) {\n      return;\n    }\n\n    const nodeTerminalNode = node.isTerminalNode(),\n          nodeNonTerminalNode = !nodeTerminalNode;\n\n    let found;\n\n    if (nodeTerminalNode) {\n      const terminalNode = node,  ///\n            types = this.tokenTypes,  ///\n            type = terminalNode.getType();\n\n      found = includes(types, type, WILDCARD_CHARACTER);\n    }\n\n    if (nodeNonTerminalNode) {\n      const nonTerminalNode = node, ///\n            ruleName = nonTerminalNode.getRuleName();\n\n      found = includes(this.ruleNames, ruleName, WILDCARD_CHARACTER);\n    }\n\n    if (found) {\n      const intermediateNode = node; ///\n\n      this.intermediateNodes.push(intermediateNode);\n    }\n\n    if (this.infiniteDescent) {\n      if (nodeNonTerminalNode) {\n        depth++;\n\n        const nonTerminalNode = node, ///\n              childNodes = nonTerminalNode.getChildNodes();\n\n        childNodes.forEach((childNode) => {\n          this.find(childNode, depth, maximumDepth);\n        });\n      }\n    }\n  }\n\n  apply(nodes, depth, maximumDepth) {\n    this.spread.adjustNodes(this.intermediateNodes);\n\n    if (this.subQuery === null) {\n      push(nodes, this.intermediateNodes);\n    } else {\n      this.intermediateNodes.forEach((intermediateNode) => {\n        const intermediateNodeNonTerminalNode = intermediateNode.isNonTerminalNode();\n\n        if (intermediateNodeNonTerminalNode) {\n          depth++;\n\n          const nonTerminalNode = intermediateNode, ///\n                childNodes = nonTerminalNode.getChildNodes();\n\n          this.subQuery.clear();\n\n          childNodes.forEach((childNode) => {\n            this.subQuery.find(childNode, depth, maximumDepth);\n          });\n\n          this.subQuery.apply(nodes, depth, maximumDepth);\n        }\n      });\n    }\n  }\n\n  static fromExpression(expression, maximumDepth = Infinity) {\n    const spread = expression.getSpread(),\n          subQuery = subQueryFromExpression(expression),\n          ruleNames = expression.getRuleNames(),\n          tokenTypes = expression.getTokenTypes(),\n          infiniteDescent = expression.isInfiniteDescent(),\n          intermediateNodes = [],\n          query = new Query(spread, subQuery, ruleNames, tokenTypes, maximumDepth, infiniteDescent, intermediateNodes);\n\n    return query;\n  }\n\n  static fromSubExpression(subExpression) {\n    const spread = subExpression.getSpread(),\n          subQuery = subQueryFromSubExpression(subExpression),\n          ruleNames = subExpression.getRuleNames(),\n          tokenTypes = subExpression.getTokenTypes(),\n          maximumDepth = Infinity,\n          infiniteDescent = subExpression.isInfiniteDescent(),\n          intermediateNodes = [],\n          query = new Query(spread, subQuery, ruleNames, tokenTypes, maximumDepth, infiniteDescent, intermediateNodes);\n\n    return query;\n  }\n\n  static fromExpressionString(expressionString, maximumDepth = Infinity) {\n    let query = null;\n\n    const expression = Expression.fromExpressionString(expressionString);\n\n    if (expression !== null) {\n      const spread = expression.getSpread(),\n            subQuery = subQueryFromExpression(expression),\n            ruleNames = expression.getRuleNames(),\n            tokenTypes = expression.getTokenTypes(),\n            infiniteDescent = expression.isInfiniteDescent(),\n            intermediateNodes = [];\n\n      query = new Query(spread, subQuery, ruleNames, tokenTypes, maximumDepth, infiniteDescent, intermediateNodes);\n    }\n\n    return query;\n  }\n}\n\nfunction subQueryFromExpression(expression) {\n  let subQuery = null;\n\n  const subExpression = expression.getSubExpression();\n\n  if (subExpression !== null) {\n    const query = Query.fromSubExpression(subExpression);\n\n    subQuery = query; ///\n  }\n\n  return subQuery;\n}\n\nfunction subQueryFromSubExpression(subExpression) {\n  let subQuery = null;\n\n  subExpression = subExpression.getSubExpression(); ///\n\n  if (subExpression !== null) {\n    const query = Query.fromSubExpression(subExpression);\n\n    subQuery = query; ///\n  }\n\n  return subQuery;\n}\n"],"names":["Query","WILDCARD_CHARACTER","characters","spread","subQuery","ruleNames","tokenTypes","maximumDepth","infiniteDescent","intermediateNodes","getSpread","sprea","getSubQuery","getRuleNames","getTokenTypes","getMaximumDepth","isInfiniteDescent","getIntermediateNodes","execute","node","depth","nodes","clear","find","apply","nodeTerminalNode","isTerminalNode","nodeNonTerminalNode","found","terminalNode","types","type","getType","includes","nonTerminalNode","ruleName","getRuleName","intermediateNode","push","childNodes","getChildNodes","forEach","childNode","adjustNodes","intermediateNodeNonTerminalNode","isNonTerminalNode","fromExpression","expression","Infinity","subQueryFromExpression","query","fromSubExpression","subExpression","subQueryFromSubExpression","fromExpressionString","expressionString","Expression","getSubExpression"],"mappings":"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"}
|
package/package.json
CHANGED
package/src/query.js
CHANGED
|
@@ -2,6 +2,8 @@
|
|
|
2
2
|
|
|
3
3
|
import { characters } from "necessary";
|
|
4
4
|
|
|
5
|
+
import Expression from "./expression";
|
|
6
|
+
|
|
5
7
|
import { push, clear, includes } from "./utilities/array";
|
|
6
8
|
|
|
7
9
|
const { WILDCARD_CHARACTER } = characters;
|
|
@@ -157,6 +159,25 @@ export default class Query {
|
|
|
157
159
|
|
|
158
160
|
return query;
|
|
159
161
|
}
|
|
162
|
+
|
|
163
|
+
static fromExpressionString(expressionString, maximumDepth = Infinity) {
|
|
164
|
+
let query = null;
|
|
165
|
+
|
|
166
|
+
const expression = Expression.fromExpressionString(expressionString);
|
|
167
|
+
|
|
168
|
+
if (expression !== null) {
|
|
169
|
+
const spread = expression.getSpread(),
|
|
170
|
+
subQuery = subQueryFromExpression(expression),
|
|
171
|
+
ruleNames = expression.getRuleNames(),
|
|
172
|
+
tokenTypes = expression.getTokenTypes(),
|
|
173
|
+
infiniteDescent = expression.isInfiniteDescent(),
|
|
174
|
+
intermediateNodes = [];
|
|
175
|
+
|
|
176
|
+
query = new Query(spread, subQuery, ruleNames, tokenTypes, maximumDepth, infiniteDescent, intermediateNodes);
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
return query;
|
|
180
|
+
}
|
|
160
181
|
}
|
|
161
182
|
|
|
162
183
|
function subQueryFromExpression(expression) {
|