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/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":"AAAA;;;;;;;eAUqBA;;;yBARM;iEAEJ;qBAEe;;;;;;;;;;;;;;;;;;;;;;;;;AAEtC,IAAM,AAAEC,qBAAuBC,qBAAU,CAAjCD;AAEO,IAAA,AAAMD,sBAAN;aAAMA,MACPG,MAAM,EAAEC,QAAQ,EAAEC,SAAS,EAAEC,UAAU,EAAEC,YAAY,EAAEC,eAAe,EAAEC,iBAAiB;gCADlFT;QAEjB,IAAI,CAACG,MAAM,GAAGA;QACd,IAAI,CAACC,QAAQ,GAAGA;QAChB,IAAI,CAACC,SAAS,GAAGA;QACjB,IAAI,CAACC,UAAU,GAAGA;QAClB,IAAI,CAACC,YAAY,GAAGA;QACpB,IAAI,CAACC,eAAe,GAAGA;QACvB,IAAI,CAACC,iBAAiB,GAAGA;;kBARRT;;YAWnBU,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACC,KAAK;YACnB;;;YAEAC,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACR,QAAQ;YACtB;;;YAEAS,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACR,SAAS;YACvB;;;YAEAS,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACR,UAAU;YACxB;;;YAEAS,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACR,YAAY;YAC1B;;;YAEAS,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACR,eAAe;YAC7B;;;YAEAS,KAAAA;mBAAAA,SAAAA;gBACE,OAAO,IAAI,CAACR,iBAAiB;YAC/B;;;YAEAS,KAAAA;mBAAAA,SAAAA,QAAQC,IAAI;oBAAEC,QAAAA,iEAAQ,GAAGb,eAAAA,iEAAe,IAAI,CAACA,YAAY;gBACvD,IAAMc,QAAQ,EAAE;gBAEhB,IAAI,CAACC,KAAK;gBAEV,IAAI,CAACC,IAAI,CAACJ,MAAMC,OAAOb;gBAEvB,IAAI,CAACiB,KAAK,CAACH,OAAOD,OAAOb;gBAEzB,OAAOc;YACT;;;YAEAC,KAAAA;mBAAAA,SAAAA;gBACEA,IAAAA,YAAK,EAAC,IAAI,CAACb,iBAAiB;YAC9B;;;YAEAc,KAAAA;mBAAAA,SAAAA,KAAKJ,IAAI,EAAEC,KAAK,EAAEb,YAAY;;gBAC5B,IAAIa,QAAQb,cAAc;oBACxB;gBACF;gBAEA,IAAMkB,mBAAmBN,KAAKO,cAAc,IACtCC,sBAAsB,CAACF;gBAE7B,IAAIG;gBAEJ,IAAIH,kBAAkB;oBACpB,IAAMI,eAAeV,MACfW,QAAQ,IAAI,CAACxB,UAAU,EACvByB,OAAOF,aAAaG,OAAO;oBAEjCJ,QAAQK,IAAAA,eAAQ,EAACH,OAAOC,MAAM9B;gBAChC;gBAEA,IAAI0B,qBAAqB;oBACvB,IAAMO,kBAAkBf,MAClBgB,WAAWD,gBAAgBE,WAAW;oBAE5CR,QAAQK,IAAAA,eAAQ,EAAC,IAAI,CAAC5B,SAAS,EAAE8B,UAAUlC;gBAC7C;gBAEA,IAAI2B,OAAO;oBACT,IAAMS,mBAAmBlB,MAAM,GAAG;oBAElC,IAAI,CAACV,iBAAiB,CAAC6B,IAAI,CAACD;gBAC9B;gBAEA,IAAI,IAAI,CAAC7B,eAAe,EAAE;oBACxB,IAAImB,qBAAqB;wBACvBP;wBAEA,IAAMc,mBAAkBf,MAClBoB,aAAaL,iBAAgBM,aAAa;wBAEhDD,WAAWE,OAAO,CAAC,SAACC;4BAClB,MAAKnB,IAAI,CAACmB,WAAWtB,OAAOb;wBAC9B;oBACF;gBACF;YACF;;;YAEAiB,KAAAA;mBAAAA,SAAAA,MAAMH,KAAK,EAAED,KAAK,EAAEb,YAAY;;gBAC9B,IAAI,CAACJ,MAAM,CAACwC,WAAW,CAAC,IAAI,CAAClC,iBAAiB;gBAE9C,IAAI,IAAI,CAACL,QAAQ,KAAK,MAAM;oBAC1BkC,IAAAA,WAAI,EAACjB,OAAO,IAAI,CAACZ,iBAAiB;gBACpC,OAAO;oBACL,IAAI,CAACA,iBAAiB,CAACgC,OAAO,CAAC,SAACJ;wBAC9B,IAAMO,kCAAkCP,iBAAiBQ,iBAAiB;wBAE1E,IAAID,iCAAiC;4BACnCxB;4BAEA,IAAMc,kBAAkBG,kBAClBE,aAAaL,gBAAgBM,aAAa;4BAEhD,MAAKpC,QAAQ,CAACkB,KAAK;4BAEnBiB,WAAWE,OAAO,CAAC,SAACC;gCAClB,MAAKtC,QAAQ,CAACmB,IAAI,CAACmB,WAAWtB,OAAOb;4BACvC;4BAEA,MAAKH,QAAQ,CAACoB,KAAK,CAACH,OAAOD,OAAOb;wBACpC;oBACF;gBACF;YACF;;;;YAEOuC,KAAAA;mBAAP,SAAOA,eAAeC,UAAU;oBAAExC,eAAAA,iEAAeyC;gBAC/C,IAAM7C,SAAS4C,WAAWrC,SAAS,IAC7BN,WAAW6C,uBAAuBF,aAClC1C,YAAY0C,WAAWlC,YAAY,IACnCP,aAAayC,WAAWjC,aAAa,IACrCN,kBAAkBuC,WAAW/B,iBAAiB,IAC9CP,oBAAoB,EAAE,EACtByC,QAAQ,IAtIGlD,MAsIOG,QAAQC,UAAUC,WAAWC,YAAYC,cAAcC,iBAAiBC;gBAEhG,OAAOyC;YACT;;;YAEOC,KAAAA;mBAAP,SAAOA,kBAAkBC,aAAa;gBACpC,IAAMjD,SAASiD,cAAc1C,SAAS,IAChCN,WAAWiD,0BAA0BD,gBACrC/C,YAAY+C,cAAcvC,YAAY,IACtCP,aAAa8C,cAActC,aAAa,IACxCP,eAAeyC,UACfxC,kBAAkB4C,cAAcpC,iBAAiB,IACjDP,oBAAoB,EAAE,EACtByC,QAAQ,IAnJGlD,MAmJOG,QAAQC,UAAUC,WAAWC,YAAYC,cAAcC,iBAAiBC;gBAEhG,OAAOyC;YACT;;;YAEOI,KAAAA;mBAAP,SAAOA,qBAAqBC,gBAAgB;oBAAEhD,eAAAA,iEAAeyC;gBAC3D,IAAIE,QAAQ;gBAEZ,IAAMH,aAAaS,mBAAU,CAACF,oBAAoB,CAACC;gBAEnD,IAAIR,eAAe,MAAM;oBACvB,IAAM5C,SAAS4C,WAAWrC,SAAS,IAC7BN,WAAW6C,uBAAuBF,aAClC1C,YAAY0C,WAAWlC,YAAY,IACnCP,aAAayC,WAAWjC,aAAa,IACrCN,kBAAkBuC,WAAW/B,iBAAiB,IAC9CP,oBAAoB,EAAE;oBAE5ByC,QAAQ,IArKOlD,MAqKGG,QAAQC,UAAUC,WAAWC,YAAYC,cAAcC,iBAAiBC;gBAC5F;gBAEA,OAAOyC;YACT;;;WAzKmBlD;;AA4KrB,SAASiD,uBAAuBF,UAAU;IACxC,IAAI3C,WAAW;IAEf,IAAMgD,gBAAgBL,WAAWU,gBAAgB;IAEjD,IAAIL,kBAAkB,MAAM;QAC1B,IAAMF,QAAQlD,MAAMmD,iBAAiB,CAACC;QAEtChD,WAAW8C,OAAO,GAAG;IACvB;IAEA,OAAO9C;AACT;AAEA,SAASiD,0BAA0BD,aAAa;IAC9C,IAAIhD,WAAW;IAEfgD,gBAAgBA,cAAcK,gBAAgB,IAAI,GAAG;IAErD,IAAIL,kBAAkB,MAAM;QAC1B,IAAMF,QAAQlD,MAAMmD,iBAAiB,CAACC;QAEtChD,WAAW8C,OAAO,GAAG;IACvB;IAEA,OAAO9C;AACT"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "occam-query",
3
3
  "author": "James Smith",
4
- "version": "4.0.2",
4
+ "version": "4.1.0",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/occam-query",
7
7
  "description": "Occam's query functionality.",
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) {