occam-custom-grammars 5.0.1228 → 5.0.1230

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.
@@ -0,0 +1,107 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ function _export(target, all) {
6
+ for(var name in all)Object.defineProperty(target, name, {
7
+ enumerable: true,
8
+ get: Object.getOwnPropertyDescriptor(all, name).get
9
+ });
10
+ }
11
+ _export(exports, {
12
+ get validateBNF () {
13
+ return validateBNF;
14
+ },
15
+ get validateVocabulary () {
16
+ return validateVocabulary;
17
+ }
18
+ });
19
+ var _necessary = require("necessary");
20
+ var _typesMap = /*#__PURE__*/ _interop_require_default(require("../typesMap"));
21
+ var _nominal = require("../utilities/nominal");
22
+ var _constants = require("../constants");
23
+ var _query = require("../utilities/query");
24
+ var _grammar = require("../utilities/grammar");
25
+ function _interop_require_default(obj) {
26
+ return obj && obj.__esModule ? obj : {
27
+ default: obj
28
+ };
29
+ }
30
+ var first = _necessary.arrayUtilities.first, second = _necessary.arrayUtilities.second;
31
+ var expressionNodesQuery = (0, _query.nodesQuery)("//expression"), ruleNameTerminalNodeQuery = (0, _query.nodeQuery)("/document/rule/name/@*!"), stringLiteralTerminalNodesQuery = (0, _query.nodesQuery)("//stringLiteral/@*!"), significantTokenTypeTerminalNodesQuery = (0, _query.nodesQuery)("//significantTokenType/@*!");
32
+ function validateBNF(bnf, ruleName) {
33
+ var content = bnf, tokens = _grammar.customGrammarBNFLexer.tokenise(content), node = _grammar.customGrammarBNFParser.parse(tokens);
34
+ if (node === null) {
35
+ return;
36
+ }
37
+ var ruleNameTerminalNode = ruleNameTerminalNodeQuery(node);
38
+ if (ruleNameTerminalNode !== null) {
39
+ var name = nameFromRuleNameTerminalNode(ruleNameTerminalNode);
40
+ if (name !== ruleName) {
41
+ throw new Error("The '".concat(name, "' rule should be named '").concat(ruleName, "'."));
42
+ }
43
+ }
44
+ var types = _typesMap.default[ruleName], significantTokenTypeTerminalNodes = significantTokenTypeTerminalNodesQuery(node);
45
+ significantTokenTypeTerminalNodes.forEach(function(significantTokenTypeTerminalNode) {
46
+ var type = typeFromSignificantTokenTypeTerminalNode(significantTokenTypeTerminalNode), typesIncludeType = types.includes(type);
47
+ if (!typesIncludeType) {
48
+ throw new Error("The '".concat(type, "' type is not included in the '").concat(ruleName, "' rule's types."));
49
+ }
50
+ });
51
+ var stringLiteralTerminalNodes = stringLiteralTerminalNodesQuery(node);
52
+ stringLiteralTerminalNodes.forEach(function(stringLiteralTerminalNode) {
53
+ var content = contentFromStringLiteralTerminalNode(stringLiteralTerminalNode);
54
+ if (content === _constants.UNDERSCORE_CHARACTER) {
55
+ throw new Error('The "'.concat(content, '" string literal cannot be an underscore.'));
56
+ }
57
+ var tokens = _nominal.nominalLexer.tokenise(content), tokensLength = tokens.length;
58
+ if (tokensLength !== 1) {
59
+ throw new Error('Tokenising the "'.concat(content, '" string literal does not result in a single token.'));
60
+ }
61
+ var firstToken = first(tokens), token = firstToken, type = token.getType(), typesIncludeType = types.includes(type);
62
+ if (!typesIncludeType) {
63
+ throw new Error('The "'.concat(content, "\" string literal's token's '").concat(type, "' type is not included in the '").concat(ruleName, "' rule's types."));
64
+ }
65
+ });
66
+ }
67
+ function validateVocabulary(vocabulary) {
68
+ var content = vocabulary, tokens = _grammar.customGrammarVocabularyLexer.tokenise(content), node = _grammar.customGrammarVocabularyParser.parse(tokens);
69
+ if (node === null) {
70
+ return;
71
+ }
72
+ var expressionNodes = expressionNodesQuery(node);
73
+ expressionNodes.forEach(function(expressionNode) {
74
+ var content = contentFromExpressionNode(expressionNode), tokens = _nominal.nominalLexer.tokenise(content), tokensLength = tokens.length;
75
+ if (tokensLength > 1) {
76
+ throw new Error("Tokenising the '".concat(content, "' content results in more than one token."));
77
+ }
78
+ var firstToken = first(tokens), token = firstToken, type = token.getType();
79
+ if (type !== UNASSIGNED_TYPE) {
80
+ throw new Error("The '".concat(type, "' type of the '").concat(content, "' token is not 'unassigned'."));
81
+ }
82
+ if (content === _constants.UNDERSCORE_CHARACTER) {
83
+ throw new Error("The '".concat(content, "' token cannot be an underscore."));
84
+ }
85
+ });
86
+ }
87
+ function nameFromRuleNameTerminalNode(ruleNameTerminalNode) {
88
+ var name;
89
+ var content = ruleNameTerminalNode.getContent();
90
+ name = content; ///
91
+ return name;
92
+ }
93
+ function contentFromStringLiteralTerminalNode(stringLiteralTerminalNode) {
94
+ var content;
95
+ content = stringLiteralTerminalNode.getContent();
96
+ var matches = content.match(/"([^"]*)"/), secondMatch = second(matches);
97
+ content = secondMatch; ///
98
+ return content;
99
+ }
100
+ function typeFromSignificantTokenTypeTerminalNode(significantTokenTypeTerminalNode) {
101
+ var type;
102
+ var content = significantTokenTypeTerminalNode.getContent(), matches = content.match(/\[([^\]]*)\]/), secondMatch = second(matches);
103
+ type = secondMatch; ///
104
+ return type;
105
+ }
106
+
107
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/validate.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\n\nimport typesMap from \"../typesMap\";\n\nimport { nominalLexer } from \"../utilities/nominal\";\nimport { UNDERSCORE_CHARACTER } from \"../constants\";\nimport { nodeQuery, nodesQuery } from \"../utilities/query\";\nimport { customGrammarBNFLexer, customGrammarBNFParser, customGrammarVocabularyLexer, customGrammarVocabularyParser } from \"../utilities/grammar\";\n\nconst { first, second } = arrayUtilities;\n\nconst expressionNodesQuery = nodesQuery(\"//expression\"),\n      ruleNameTerminalNodeQuery = nodeQuery(\"/document/rule/name/@*!\"),\n      stringLiteralTerminalNodesQuery = nodesQuery(\"//stringLiteral/@*!\"),\n      significantTokenTypeTerminalNodesQuery = nodesQuery(\"//significantTokenType/@*!\");\n\nexport function validateBNF(bnf, ruleName) {\n  const content = bnf,\n        tokens = customGrammarBNFLexer.tokenise(content),\n        node = customGrammarBNFParser.parse(tokens);\n\n  if (node === null) {\n    return;\n  }\n\n  const ruleNameTerminalNode = ruleNameTerminalNodeQuery(node);\n\n  if (ruleNameTerminalNode !== null) {\n    const name = nameFromRuleNameTerminalNode(ruleNameTerminalNode);\n\n    if (name !== ruleName) {\n      throw new Error(`The '${name}' rule should be named '${ruleName}'.`);\n    }\n  }\n\n  const types = typesMap[ruleName],\n        significantTokenTypeTerminalNodes = significantTokenTypeTerminalNodesQuery(node);\n\n  significantTokenTypeTerminalNodes.forEach((significantTokenTypeTerminalNode) => {\n    const type = typeFromSignificantTokenTypeTerminalNode(significantTokenTypeTerminalNode),\n          typesIncludeType = types.includes(type);\n\n    if (!typesIncludeType) {\n      throw new Error(`The '${type}' type is not included in the '${ruleName}' rule's types.`)\n    }\n  });\n\n  const stringLiteralTerminalNodes = stringLiteralTerminalNodesQuery(node);\n\n  stringLiteralTerminalNodes.forEach((stringLiteralTerminalNode) => {\n    const content = contentFromStringLiteralTerminalNode(stringLiteralTerminalNode);\n\n    if (content === UNDERSCORE_CHARACTER) {\n      throw new Error(`The \"${content}\" string literal cannot be an underscore.`);\n    }\n\n    const tokens = nominalLexer.tokenise(content),\n          tokensLength = tokens.length;\n\n    if (tokensLength !== 1) {\n      throw new Error(`Tokenising the \"${content}\" string literal does not result in a single token.`);\n    }\n\n    const firstToken = first(tokens),\n          token = firstToken, ///\n          type = token.getType(),\n          typesIncludeType = types.includes(type);\n\n    if (!typesIncludeType) {\n      throw new Error(`The \"${content}\" string literal's token's '${type}' type is not included in the '${ruleName}' rule's types.`)\n    }\n  });\n}\n\nexport function validateVocabulary(vocabulary) {\n  const content = vocabulary, ///\n        tokens = customGrammarVocabularyLexer.tokenise(content),\n        node = customGrammarVocabularyParser.parse(tokens);\n\n  if (node === null) {\n    return;\n  }\n\n  const expressionNodes = expressionNodesQuery(node);\n\n  expressionNodes.forEach((expressionNode) => {\n    const content = contentFromExpressionNode(expressionNode),\n          tokens = nominalLexer.tokenise(content),\n          tokensLength = tokens.length;\n\n    if (tokensLength > 1) {\n      throw new Error(`Tokenising the '${content}' content results in more than one token.`);\n    }\n\n    const firstToken = first(tokens),\n          token = firstToken,\n          type = token.getType();\n\n    if (type !== UNASSIGNED_TYPE) {\n      throw new Error(`The '${type}' type of the '${content}' token is not 'unassigned'.`);\n    }\n\n    if (content === UNDERSCORE_CHARACTER) {\n      throw new Error(`The '${content}' token cannot be an underscore.`);\n    }\n  });\n}\n\nfunction nameFromRuleNameTerminalNode(ruleNameTerminalNode) {\n  let name;\n\n  const content = ruleNameTerminalNode.getContent();\n\n  name = content; ///\n\n  return name;\n}\n\nfunction contentFromStringLiteralTerminalNode(stringLiteralTerminalNode) {\n  let content;\n\n  content = stringLiteralTerminalNode.getContent();\n\n  const matches = content.match(/\"([^\"]*)\"/),\n        secondMatch = second(matches);\n\n  content = secondMatch; ///\n\n  return content;\n}\n\nfunction typeFromSignificantTokenTypeTerminalNode(significantTokenTypeTerminalNode) {\n  let type;\n\n  const content = significantTokenTypeTerminalNode.getContent(),\n        matches = content.match(/\\[([^\\]]*)\\]/),\n        secondMatch = second(matches);\n\n  type = secondMatch; ///\n\n  return type;\n}\n"],"names":["validateBNF","validateVocabulary","first","arrayUtilities","second","expressionNodesQuery","nodesQuery","ruleNameTerminalNodeQuery","nodeQuery","stringLiteralTerminalNodesQuery","significantTokenTypeTerminalNodesQuery","bnf","ruleName","content","tokens","customGrammarBNFLexer","tokenise","node","customGrammarBNFParser","parse","ruleNameTerminalNode","name","nameFromRuleNameTerminalNode","Error","types","typesMap","significantTokenTypeTerminalNodes","forEach","significantTokenTypeTerminalNode","type","typeFromSignificantTokenTypeTerminalNode","typesIncludeType","includes","stringLiteralTerminalNodes","stringLiteralTerminalNode","contentFromStringLiteralTerminalNode","UNDERSCORE_CHARACTER","nominalLexer","tokensLength","length","firstToken","token","getType","vocabulary","customGrammarVocabularyLexer","customGrammarVocabularyParser","expressionNodes","expressionNode","contentFromExpressionNode","UNASSIGNED_TYPE","getContent","matches","match","secondMatch"],"mappings":"AAAA;;;;;;;;;;;QAkBgBA;eAAAA;;QA0DAC;eAAAA;;;yBA1Ee;+DAEV;uBAEQ;yBACQ;qBACC;uBACqF;;;;;;AAE3H,IAAQC,QAAkBC,yBAAc,CAAhCD,OAAOE,SAAWD,yBAAc,CAAzBC;AAEf,IAAMC,uBAAuBC,IAAAA,iBAAU,EAAC,iBAClCC,4BAA4BC,IAAAA,gBAAS,EAAC,4BACtCC,kCAAkCH,IAAAA,iBAAU,EAAC,wBAC7CI,yCAAyCJ,IAAAA,iBAAU,EAAC;AAEnD,SAASN,YAAYW,GAAG,EAAEC,QAAQ;IACvC,IAAMC,UAAUF,KACVG,SAASC,8BAAqB,CAACC,QAAQ,CAACH,UACxCI,OAAOC,+BAAsB,CAACC,KAAK,CAACL;IAE1C,IAAIG,SAAS,MAAM;QACjB;IACF;IAEA,IAAMG,uBAAuBb,0BAA0BU;IAEvD,IAAIG,yBAAyB,MAAM;QACjC,IAAMC,OAAOC,6BAA6BF;QAE1C,IAAIC,SAAST,UAAU;YACrB,MAAM,IAAIW,MAAM,AAAC,QAAsCX,OAA/BS,MAAK,4BAAmC,OAATT,UAAS;QAClE;IACF;IAEA,IAAMY,QAAQC,iBAAQ,CAACb,SAAS,EAC1Bc,oCAAoChB,uCAAuCO;IAEjFS,kCAAkCC,OAAO,CAAC,SAACC;QACzC,IAAMC,OAAOC,yCAAyCF,mCAChDG,mBAAmBP,MAAMQ,QAAQ,CAACH;QAExC,IAAI,CAACE,kBAAkB;YACrB,MAAM,IAAIR,MAAM,AAAC,QAA6CX,OAAtCiB,MAAK,mCAA0C,OAATjB,UAAS;QACzE;IACF;IAEA,IAAMqB,6BAA6BxB,gCAAgCQ;IAEnEgB,2BAA2BN,OAAO,CAAC,SAACO;QAClC,IAAMrB,UAAUsB,qCAAqCD;QAErD,IAAIrB,YAAYuB,+BAAoB,EAAE;YACpC,MAAM,IAAIb,MAAM,AAAC,QAAe,OAARV,SAAQ;QAClC;QAEA,IAAMC,SAASuB,qBAAY,CAACrB,QAAQ,CAACH,UAC/ByB,eAAexB,OAAOyB,MAAM;QAElC,IAAID,iBAAiB,GAAG;YACtB,MAAM,IAAIf,MAAM,AAAC,mBAA0B,OAARV,SAAQ;QAC7C;QAEA,IAAM2B,aAAatC,MAAMY,SACnB2B,QAAQD,YACRX,OAAOY,MAAMC,OAAO,IACpBX,mBAAmBP,MAAMQ,QAAQ,CAACH;QAExC,IAAI,CAACE,kBAAkB;YACrB,MAAM,IAAIR,MAAM,AAAC,QAA6CM,OAAtChB,SAAQ,iCAAoED,OAAtCiB,MAAK,mCAA0C,OAATjB,UAAS;QAC/G;IACF;AACF;AAEO,SAASX,mBAAmB0C,UAAU;IAC3C,IAAM9B,UAAU8B,YACV7B,SAAS8B,qCAA4B,CAAC5B,QAAQ,CAACH,UAC/CI,OAAO4B,sCAA6B,CAAC1B,KAAK,CAACL;IAEjD,IAAIG,SAAS,MAAM;QACjB;IACF;IAEA,IAAM6B,kBAAkBzC,qBAAqBY;IAE7C6B,gBAAgBnB,OAAO,CAAC,SAACoB;QACvB,IAAMlC,UAAUmC,0BAA0BD,iBACpCjC,SAASuB,qBAAY,CAACrB,QAAQ,CAACH,UAC/ByB,eAAexB,OAAOyB,MAAM;QAElC,IAAID,eAAe,GAAG;YACpB,MAAM,IAAIf,MAAM,AAAC,mBAA0B,OAARV,SAAQ;QAC7C;QAEA,IAAM2B,aAAatC,MAAMY,SACnB2B,QAAQD,YACRX,OAAOY,MAAMC,OAAO;QAE1B,IAAIb,SAASoB,iBAAiB;YAC5B,MAAM,IAAI1B,MAAM,AAAC,QAA6BV,OAAtBgB,MAAK,mBAAyB,OAARhB,SAAQ;QACxD;QAEA,IAAIA,YAAYuB,+BAAoB,EAAE;YACpC,MAAM,IAAIb,MAAM,AAAC,QAAe,OAARV,SAAQ;QAClC;IACF;AACF;AAEA,SAASS,6BAA6BF,oBAAoB;IACxD,IAAIC;IAEJ,IAAMR,UAAUO,qBAAqB8B,UAAU;IAE/C7B,OAAOR,SAAS,GAAG;IAEnB,OAAOQ;AACT;AAEA,SAASc,qCAAqCD,yBAAyB;IACrE,IAAIrB;IAEJA,UAAUqB,0BAA0BgB,UAAU;IAE9C,IAAMC,UAAUtC,QAAQuC,KAAK,CAAC,cACxBC,cAAcjD,OAAO+C;IAE3BtC,UAAUwC,aAAa,GAAG;IAE1B,OAAOxC;AACT;AAEA,SAASiB,yCAAyCF,gCAAgC;IAChF,IAAIC;IAEJ,IAAMhB,UAAUe,iCAAiCsB,UAAU,IACrDC,UAAUtC,QAAQuC,KAAK,CAAC,iBACxBC,cAAcjD,OAAO+C;IAE3BtB,OAAOwB,aAAa,GAAG;IAEvB,OAAOxB;AACT"}
@@ -2,60 +2,23 @@
2
2
  Object.defineProperty(exports, "__esModule", {
3
3
  value: true
4
4
  });
5
- function _export(target, all) {
6
- for(var name in all)Object.defineProperty(target, name, {
7
- enumerable: true,
8
- get: Object.getOwnPropertyDescriptor(all, name).get
9
- });
10
- }
11
- _export(exports, {
12
- get expressionsFromVocabulary () {
5
+ Object.defineProperty(exports, "expressionsFromVocabulary", {
6
+ enumerable: true,
7
+ get: function() {
13
8
  return expressionsFromVocabulary;
14
- },
15
- get validateVocabulary () {
16
- return validateVocabulary;
17
9
  }
18
10
  });
19
- var _occamlexers = require("occam-lexers");
20
- var _occamgrammars = require("occam-grammars");
21
11
  var _necessary = require("necessary");
22
12
  var _query = require("../utilities/query");
23
- var _constants = require("../constants");
24
- var errorNodesQuery = (0, _query.nodesQuery)("//error"), expressionNodesQuery = (0, _query.nodesQuery)("//expression");
25
- var nominalLexer = _occamlexers.CommonLexer.fromNothing(_occamgrammars.NominalLexer), customGrammarVocabularyLexer = _occamgrammars.CustomGrammarVocabularyLexer.fromNothing(), customGrammarVocabularyParser = _occamgrammars.CustomGrammarVocabularyParser.fromNothing();
26
- var first = _necessary.arrayUtilities.first, second = _necessary.arrayUtilities.second;
27
- function validateVocabulary(vocabulary) {
28
- if (vocabulary === null || vocabulary === _constants.EMPTY_STRING) {
29
- return;
30
- }
31
- var content = vocabulary, tokens = customGrammarVocabularyLexer.tokenise(content), node = customGrammarVocabularyParser.parse(tokens);
32
- if (node === null) {
33
- throw new Error("The vocabulary cannot be parsed.");
34
- }
35
- var errorNodes = errorNodesQuery(node), errorNodesLength = errorNodes.length;
36
- if (errorNodesLength > 0) {
37
- throw new Error("The vocabulary contains errors.");
38
- }
39
- var expressionNodes = expressionNodesQuery(node);
40
- expressionNodes.forEach(function(expressionNode) {
41
- var content = contentFromExpressionNode(expressionNode), tokens = nominalLexer.tokenise(content), tokensLength = tokens.length;
42
- if (tokensLength > 1) {
43
- throw new Error("Tokenising '".concat(content, "' results in more than one token."));
44
- }
45
- var firstToken = first(tokens), token = firstToken, type = token.getType();
46
- if (type !== _constants.UNASSIGNED_TYPE) {
47
- throw new Error("The '".concat(type, "' type of the '").concat(content, "' token is not 'unassigned'."));
48
- }
49
- if (content === _constants.UNDERSCORE_CHARACTER) {
50
- throw new Error("The '".concat(content, "' token cannot be an underscore."));
51
- }
52
- });
53
- }
13
+ var _grammar = require("../utilities/grammar");
14
+ var second = _necessary.arrayUtilities.second;
15
+ var expressionNodesQuery = (0, _query.nodesQuery)("//expression");
54
16
  function expressionsFromVocabulary(vocabulary, expressions) {
55
- if (vocabulary === null || vocabulary === _constants.EMPTY_STRING) {
17
+ var content = vocabulary, tokens = _grammar.customGrammarVocabularyLexer.tokenise(content), node = _grammar.customGrammarVocabularyParser.parse(tokens);
18
+ if (node === null) {
56
19
  return;
57
20
  }
58
- var content = vocabulary, tokens = customGrammarVocabularyLexer.tokenise(content), node = customGrammarVocabularyParser.parse(tokens), expressionNodes = expressionNodesQuery(node);
21
+ var expressionNodes = expressionNodesQuery(node);
59
22
  expressionNodes.forEach(function(expressionNode) {
60
23
  var content = contentFromExpressionNode(expressionNode), expression = content; ///
61
24
  expressions.push(expression);
@@ -66,4 +29,4 @@ function contentFromExpressionNode(expressionNode) {
66
29
  return content;
67
30
  }
68
31
 
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsaXRpZXMvdm9jYWJ1bGFyeS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IHsgQ29tbW9uTGV4ZXIgfSBmcm9tIFwib2NjYW0tbGV4ZXJzXCI7XG5pbXBvcnQgeyBOb21pbmFsTGV4ZXIgfSBmcm9tIFwib2NjYW0tZ3JhbW1hcnNcIjtcbmltcG9ydCB7IGFycmF5VXRpbGl0aWVzIH0gZnJvbSBcIm5lY2Vzc2FyeVwiO1xuaW1wb3J0IHsgQ3VzdG9tR3JhbW1hclZvY2FidWxhcnlMZXhlciwgQ3VzdG9tR3JhbW1hclZvY2FidWxhcnlQYXJzZXIgfSBmcm9tIFwib2NjYW0tZ3JhbW1hcnNcIjtcblxuaW1wb3J0IHsgbm9kZXNRdWVyeSB9IGZyb20gXCIuLi91dGlsaXRpZXMvcXVlcnlcIjtcbmltcG9ydCB7IEVNUFRZX1NUUklORywgVU5BU1NJR05FRF9UWVBFLCBVTkRFUlNDT1JFX0NIQVJBQ1RFUiB9IGZyb20gXCIuLi9jb25zdGFudHNcIjtcblxuY29uc3QgZXJyb3JOb2Rlc1F1ZXJ5ID0gbm9kZXNRdWVyeShcIi8vZXJyb3JcIiksXG4gICAgICBleHByZXNzaW9uTm9kZXNRdWVyeSA9IG5vZGVzUXVlcnkoXCIvL2V4cHJlc3Npb25cIilcblxuY29uc3Qgbm9taW5hbExleGVyID0gQ29tbW9uTGV4ZXIuZnJvbU5vdGhpbmcoTm9taW5hbExleGVyKSxcbiAgICAgIGN1c3RvbUdyYW1tYXJWb2NhYnVsYXJ5TGV4ZXIgPSBDdXN0b21HcmFtbWFyVm9jYWJ1bGFyeUxleGVyLmZyb21Ob3RoaW5nKCksXG4gICAgICBjdXN0b21HcmFtbWFyVm9jYWJ1bGFyeVBhcnNlciA9IEN1c3RvbUdyYW1tYXJWb2NhYnVsYXJ5UGFyc2VyLmZyb21Ob3RoaW5nKCk7XG5cbmNvbnN0IHsgZmlyc3QsIHNlY29uZCB9ID0gYXJyYXlVdGlsaXRpZXM7XG5cbmV4cG9ydCBmdW5jdGlvbiB2YWxpZGF0ZVZvY2FidWxhcnkodm9jYWJ1bGFyeSkge1xuICBpZiAoKHZvY2FidWxhcnkgPT09IG51bGwpIHx8ICh2b2NhYnVsYXJ5ID09PSBFTVBUWV9TVFJJTkcpKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgY29uc3QgY29udGVudCA9IHZvY2FidWxhcnksIC8vL1xuICAgICAgICB0b2tlbnMgPSBjdXN0b21HcmFtbWFyVm9jYWJ1bGFyeUxleGVyLnRva2VuaXNlKGNvbnRlbnQpLFxuICAgICAgICBub2RlID0gY3VzdG9tR3JhbW1hclZvY2FidWxhcnlQYXJzZXIucGFyc2UodG9rZW5zKTtcblxuICBpZiAobm9kZSA9PT0gbnVsbCkge1xuICAgIHRocm93IG5ldyBFcnJvcihcIlRoZSB2b2NhYnVsYXJ5IGNhbm5vdCBiZSBwYXJzZWQuXCIpO1xuICB9XG5cbiAgY29uc3QgZXJyb3JOb2RlcyA9IGVycm9yTm9kZXNRdWVyeShub2RlKSxcbiAgICAgICAgZXJyb3JOb2Rlc0xlbmd0aCA9IGVycm9yTm9kZXMubGVuZ3RoO1xuXG4gIGlmIChlcnJvck5vZGVzTGVuZ3RoID4gMCkge1xuICAgIHRocm93IG5ldyBFcnJvcihcIlRoZSB2b2NhYnVsYXJ5IGNvbnRhaW5zIGVycm9ycy5cIik7XG4gIH1cblxuICBjb25zdCBleHByZXNzaW9uTm9kZXMgPSBleHByZXNzaW9uTm9kZXNRdWVyeShub2RlKTtcblxuICBleHByZXNzaW9uTm9kZXMuZm9yRWFjaCgoZXhwcmVzc2lvbk5vZGUpID0+IHtcbiAgICBjb25zdCBjb250ZW50ID0gY29udGVudEZyb21FeHByZXNzaW9uTm9kZShleHByZXNzaW9uTm9kZSksXG4gICAgICAgICAgdG9rZW5zID0gbm9taW5hbExleGVyLnRva2VuaXNlKGNvbnRlbnQpLFxuICAgICAgICAgIHRva2Vuc0xlbmd0aCA9IHRva2Vucy5sZW5ndGg7XG5cbiAgICBpZiAodG9rZW5zTGVuZ3RoID4gMSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBUb2tlbmlzaW5nICcke2NvbnRlbnR9JyByZXN1bHRzIGluIG1vcmUgdGhhbiBvbmUgdG9rZW4uYCk7XG4gICAgfVxuXG4gICAgY29uc3QgZmlyc3RUb2tlbiA9IGZpcnN0KHRva2VucyksXG4gICAgICAgICAgdG9rZW4gPSBmaXJzdFRva2VuLFxuICAgICAgICAgIHR5cGUgPSB0b2tlbi5nZXRUeXBlKCk7XG5cbiAgICBpZiAodHlwZSAhPT0gVU5BU1NJR05FRF9UWVBFKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYFRoZSAnJHt0eXBlfScgdHlwZSBvZiB0aGUgJyR7Y29udGVudH0nIHRva2VuIGlzIG5vdCAndW5hc3NpZ25lZCcuYCk7XG4gICAgfVxuXG4gICAgaWYgKGNvbnRlbnQgPT09IFVOREVSU0NPUkVfQ0hBUkFDVEVSKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYFRoZSAnJHtjb250ZW50fScgdG9rZW4gY2Fubm90IGJlIGFuIHVuZGVyc2NvcmUuYCk7XG4gICAgfVxuICB9KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGV4cHJlc3Npb25zRnJvbVZvY2FidWxhcnkodm9jYWJ1bGFyeSwgZXhwcmVzc2lvbnMpIHtcbiAgaWYgKCh2b2NhYnVsYXJ5ID09PSBudWxsKSB8fCAodm9jYWJ1bGFyeSA9PT0gRU1QVFlfU1RSSU5HKSkge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IGNvbnRlbnQgPSB2b2NhYnVsYXJ5LCAvLy9cbiAgICAgICAgdG9rZW5zID0gY3VzdG9tR3JhbW1hclZvY2FidWxhcnlMZXhlci50b2tlbmlzZShjb250ZW50KSxcbiAgICAgICAgbm9kZSA9IGN1c3RvbUdyYW1tYXJWb2NhYnVsYXJ5UGFyc2VyLnBhcnNlKHRva2VucyksXG4gICAgICAgIGV4cHJlc3Npb25Ob2RlcyA9IGV4cHJlc3Npb25Ob2Rlc1F1ZXJ5KG5vZGUpO1xuXG4gIGV4cHJlc3Npb25Ob2Rlcy5mb3JFYWNoKChleHByZXNzaW9uTm9kZSkgPT4ge1xuICAgIGNvbnN0IGNvbnRlbnQgPSBjb250ZW50RnJvbUV4cHJlc3Npb25Ob2RlKGV4cHJlc3Npb25Ob2RlKSxcbiAgICAgICAgICBleHByZXNzaW9uID0gY29udGVudDsgLy8vXG5cbiAgICBleHByZXNzaW9ucy5wdXNoKGV4cHJlc3Npb24pO1xuICB9KTtcbn1cblxuZnVuY3Rpb24gY29udGVudEZyb21FeHByZXNzaW9uTm9kZShleHByZXNzaW9uTm9kZSkge1xuICBjb25zdCBub25UZXJtaW5hbE5vZGUgPSBleHByZXNzaW9uTm9kZSwgLy8vXG4gICAgICAgIGNoaWxkTm9kZXMgPSBub25UZXJtaW5hbE5vZGUuZ2V0Q2hpbGROb2RlcygpLFxuICAgICAgICBzZWNvbmRDaGlsZE5vZGUgPSBzZWNvbmQoY2hpbGROb2RlcyksXG4gICAgICAgIHVuYXNzaWduZWRUZXJtaW5hbE5vZGUgPSBzZWNvbmRDaGlsZE5vZGUsICAvLy9cbiAgICAgICAgY29udGVudCA9IHVuYXNzaWduZWRUZXJtaW5hbE5vZGUuZ2V0Q29udGVudCgpO1xuXG4gIHJldHVybiBjb250ZW50O1xufVxuIl0sIm5hbWVzIjpbImV4cHJlc3Npb25zRnJvbVZvY2FidWxhcnkiLCJ2YWxpZGF0ZVZvY2FidWxhcnkiLCJlcnJvck5vZGVzUXVlcnkiLCJub2Rlc1F1ZXJ5IiwiZXhwcmVzc2lvbk5vZGVzUXVlcnkiLCJub21pbmFsTGV4ZXIiLCJDb21tb25MZXhlciIsImZyb21Ob3RoaW5nIiwiTm9taW5hbExleGVyIiwiY3VzdG9tR3JhbW1hclZvY2FidWxhcnlMZXhlciIsIkN1c3RvbUdyYW1tYXJWb2NhYnVsYXJ5TGV4ZXIiLCJjdXN0b21HcmFtbWFyVm9jYWJ1bGFyeVBhcnNlciIsIkN1c3RvbUdyYW1tYXJWb2NhYnVsYXJ5UGFyc2VyIiwiZmlyc3QiLCJhcnJheVV0aWxpdGllcyIsInNlY29uZCIsInZvY2FidWxhcnkiLCJFTVBUWV9TVFJJTkciLCJjb250ZW50IiwidG9rZW5zIiwidG9rZW5pc2UiLCJub2RlIiwicGFyc2UiLCJFcnJvciIsImVycm9yTm9kZXMiLCJlcnJvck5vZGVzTGVuZ3RoIiwibGVuZ3RoIiwiZXhwcmVzc2lvbk5vZGVzIiwiZm9yRWFjaCIsImV4cHJlc3Npb25Ob2RlIiwiY29udGVudEZyb21FeHByZXNzaW9uTm9kZSIsInRva2Vuc0xlbmd0aCIsImZpcnN0VG9rZW4iLCJ0b2tlbiIsInR5cGUiLCJnZXRUeXBlIiwiVU5BU1NJR05FRF9UWVBFIiwiVU5ERVJTQ09SRV9DSEFSQUNURVIiLCJleHByZXNzaW9ucyIsImV4cHJlc3Npb24iLCJwdXNoIiwibm9uVGVybWluYWxOb2RlIiwiY2hpbGROb2RlcyIsImdldENoaWxkTm9kZXMiLCJzZWNvbmRDaGlsZE5vZGUiLCJ1bmFzc2lnbmVkVGVybWluYWxOb2RlIiwiZ2V0Q29udGVudCJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7O1FBZ0VnQkE7ZUFBQUE7O1FBN0NBQztlQUFBQTs7OzJCQWpCWTs2QkFDQzt5QkFDRTtxQkFHSjt5QkFDeUM7QUFFcEUsSUFBTUMsa0JBQWtCQyxJQUFBQSxpQkFBVSxFQUFDLFlBQzdCQyx1QkFBdUJELElBQUFBLGlCQUFVLEVBQUM7QUFFeEMsSUFBTUUsZUFBZUMsd0JBQVcsQ0FBQ0MsV0FBVyxDQUFDQywyQkFBWSxHQUNuREMsK0JBQStCQywyQ0FBNEIsQ0FBQ0gsV0FBVyxJQUN2RUksZ0NBQWdDQyw0Q0FBNkIsQ0FBQ0wsV0FBVztBQUUvRSxJQUFRTSxRQUFrQkMseUJBQWMsQ0FBaENELE9BQU9FLFNBQVdELHlCQUFjLENBQXpCQztBQUVSLFNBQVNkLG1CQUFtQmUsVUFBVTtJQUMzQyxJQUFJLEFBQUNBLGVBQWUsUUFBVUEsZUFBZUMsdUJBQVksRUFBRztRQUMxRDtJQUNGO0lBRUEsSUFBTUMsVUFBVUYsWUFDVkcsU0FBU1YsNkJBQTZCVyxRQUFRLENBQUNGLFVBQy9DRyxPQUFPViw4QkFBOEJXLEtBQUssQ0FBQ0g7SUFFakQsSUFBSUUsU0FBUyxNQUFNO1FBQ2pCLE1BQU0sSUFBSUUsTUFBTTtJQUNsQjtJQUVBLElBQU1DLGFBQWF0QixnQkFBZ0JtQixPQUM3QkksbUJBQW1CRCxXQUFXRSxNQUFNO0lBRTFDLElBQUlELG1CQUFtQixHQUFHO1FBQ3hCLE1BQU0sSUFBSUYsTUFBTTtJQUNsQjtJQUVBLElBQU1JLGtCQUFrQnZCLHFCQUFxQmlCO0lBRTdDTSxnQkFBZ0JDLE9BQU8sQ0FBQyxTQUFDQztRQUN2QixJQUFNWCxVQUFVWSwwQkFBMEJELGlCQUNwQ1YsU0FBU2QsYUFBYWUsUUFBUSxDQUFDRixVQUMvQmEsZUFBZVosT0FBT08sTUFBTTtRQUVsQyxJQUFJSyxlQUFlLEdBQUc7WUFDcEIsTUFBTSxJQUFJUixNQUFNLEFBQUMsZUFBc0IsT0FBUkwsU0FBUTtRQUN6QztRQUVBLElBQU1jLGFBQWFuQixNQUFNTSxTQUNuQmMsUUFBUUQsWUFDUkUsT0FBT0QsTUFBTUUsT0FBTztRQUUxQixJQUFJRCxTQUFTRSwwQkFBZSxFQUFFO1lBQzVCLE1BQU0sSUFBSWIsTUFBTSxBQUFDLFFBQTZCTCxPQUF0QmdCLE1BQUssbUJBQXlCLE9BQVJoQixTQUFRO1FBQ3hEO1FBRUEsSUFBSUEsWUFBWW1CLCtCQUFvQixFQUFFO1lBQ3BDLE1BQU0sSUFBSWQsTUFBTSxBQUFDLFFBQWUsT0FBUkwsU0FBUTtRQUNsQztJQUNGO0FBQ0Y7QUFFTyxTQUFTbEIsMEJBQTBCZ0IsVUFBVSxFQUFFc0IsV0FBVztJQUMvRCxJQUFJLEFBQUN0QixlQUFlLFFBQVVBLGVBQWVDLHVCQUFZLEVBQUc7UUFDMUQ7SUFDRjtJQUVBLElBQU1DLFVBQVVGLFlBQ1ZHLFNBQVNWLDZCQUE2QlcsUUFBUSxDQUFDRixVQUMvQ0csT0FBT1YsOEJBQThCVyxLQUFLLENBQUNILFNBQzNDUSxrQkFBa0J2QixxQkFBcUJpQjtJQUU3Q00sZ0JBQWdCQyxPQUFPLENBQUMsU0FBQ0M7UUFDdkIsSUFBTVgsVUFBVVksMEJBQTBCRCxpQkFDcENVLGFBQWFyQixTQUFTLEdBQUc7UUFFL0JvQixZQUFZRSxJQUFJLENBQUNEO0lBQ25CO0FBQ0Y7QUFFQSxTQUFTVCwwQkFBMEJELGNBQWM7SUFDL0MsSUFBTVksa0JBQWtCWixnQkFDbEJhLGFBQWFELGdCQUFnQkUsYUFBYSxJQUMxQ0Msa0JBQWtCN0IsT0FBTzJCLGFBQ3pCRyx5QkFBeUJELGlCQUN6QjFCLFVBQVUyQix1QkFBdUJDLFVBQVU7SUFFakQsT0FBTzVCO0FBQ1QifQ==
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsaXRpZXMvdm9jYWJ1bGFyeS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IHsgYXJyYXlVdGlsaXRpZXMgfSBmcm9tIFwibmVjZXNzYXJ5XCI7XG5cbmltcG9ydCB7IG5vZGVzUXVlcnkgfSBmcm9tIFwiLi4vdXRpbGl0aWVzL3F1ZXJ5XCI7XG5pbXBvcnQgeyBjdXN0b21HcmFtbWFyVm9jYWJ1bGFyeUxleGVyLCBjdXN0b21HcmFtbWFyVm9jYWJ1bGFyeVBhcnNlciB9IGZyb20gXCIuLi91dGlsaXRpZXMvZ3JhbW1hclwiXG5cbmNvbnN0IHsgc2Vjb25kIH0gPSBhcnJheVV0aWxpdGllcztcblxuY29uc3QgZXhwcmVzc2lvbk5vZGVzUXVlcnkgPSBub2Rlc1F1ZXJ5KFwiLy9leHByZXNzaW9uXCIpO1xuXG5leHBvcnQgZnVuY3Rpb24gZXhwcmVzc2lvbnNGcm9tVm9jYWJ1bGFyeSh2b2NhYnVsYXJ5LCBleHByZXNzaW9ucykge1xuICBjb25zdCBjb250ZW50ID0gdm9jYWJ1bGFyeSwgLy8vXG4gICAgICAgIHRva2VucyA9IGN1c3RvbUdyYW1tYXJWb2NhYnVsYXJ5TGV4ZXIudG9rZW5pc2UoY29udGVudCksXG4gICAgICAgIG5vZGUgPSBjdXN0b21HcmFtbWFyVm9jYWJ1bGFyeVBhcnNlci5wYXJzZSh0b2tlbnMpO1xuXG4gIGlmIChub2RlID09PSBudWxsKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgY29uc3QgZXhwcmVzc2lvbk5vZGVzID0gZXhwcmVzc2lvbk5vZGVzUXVlcnkobm9kZSk7XG5cbiAgZXhwcmVzc2lvbk5vZGVzLmZvckVhY2goKGV4cHJlc3Npb25Ob2RlKSA9PiB7XG4gICAgY29uc3QgY29udGVudCA9IGNvbnRlbnRGcm9tRXhwcmVzc2lvbk5vZGUoZXhwcmVzc2lvbk5vZGUpLFxuICAgICAgICAgIGV4cHJlc3Npb24gPSBjb250ZW50OyAvLy9cblxuICAgIGV4cHJlc3Npb25zLnB1c2goZXhwcmVzc2lvbik7XG4gIH0pO1xufVxuXG5mdW5jdGlvbiBjb250ZW50RnJvbUV4cHJlc3Npb25Ob2RlKGV4cHJlc3Npb25Ob2RlKSB7XG4gIGNvbnN0IG5vblRlcm1pbmFsTm9kZSA9IGV4cHJlc3Npb25Ob2RlLCAvLy9cbiAgICAgICAgY2hpbGROb2RlcyA9IG5vblRlcm1pbmFsTm9kZS5nZXRDaGlsZE5vZGVzKCksXG4gICAgICAgIHNlY29uZENoaWxkTm9kZSA9IHNlY29uZChjaGlsZE5vZGVzKSxcbiAgICAgICAgdW5hc3NpZ25lZFRlcm1pbmFsTm9kZSA9IHNlY29uZENoaWxkTm9kZSwgIC8vL1xuICAgICAgICBjb250ZW50ID0gdW5hc3NpZ25lZFRlcm1pbmFsTm9kZS5nZXRDb250ZW50KCk7XG5cbiAgcmV0dXJuIGNvbnRlbnQ7XG59XG4iXSwibmFtZXMiOlsiZXhwcmVzc2lvbnNGcm9tVm9jYWJ1bGFyeSIsInNlY29uZCIsImFycmF5VXRpbGl0aWVzIiwiZXhwcmVzc2lvbk5vZGVzUXVlcnkiLCJub2Rlc1F1ZXJ5Iiwidm9jYWJ1bGFyeSIsImV4cHJlc3Npb25zIiwiY29udGVudCIsInRva2VucyIsImN1c3RvbUdyYW1tYXJWb2NhYnVsYXJ5TGV4ZXIiLCJ0b2tlbmlzZSIsIm5vZGUiLCJjdXN0b21HcmFtbWFyVm9jYWJ1bGFyeVBhcnNlciIsInBhcnNlIiwiZXhwcmVzc2lvbk5vZGVzIiwiZm9yRWFjaCIsImV4cHJlc3Npb25Ob2RlIiwiY29udGVudEZyb21FeHByZXNzaW9uTm9kZSIsImV4cHJlc3Npb24iLCJwdXNoIiwibm9uVGVybWluYWxOb2RlIiwiY2hpbGROb2RlcyIsImdldENoaWxkTm9kZXMiLCJzZWNvbmRDaGlsZE5vZGUiLCJ1bmFzc2lnbmVkVGVybWluYWxOb2RlIiwiZ2V0Q29udGVudCJdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7K0JBV2dCQTs7O2VBQUFBOzs7eUJBVGU7cUJBRUo7dUJBQ2lEO0FBRTVFLElBQU0sQUFBRUMsU0FBV0MseUJBQWMsQ0FBekJEO0FBRVIsSUFBTUUsdUJBQXVCQyxJQUFBQSxpQkFBVSxFQUFDO0FBRWpDLFNBQVNKLDBCQUEwQkssVUFBVSxFQUFFQyxXQUFXO0lBQy9ELElBQU1DLFVBQVVGLFlBQ1ZHLFNBQVNDLHFDQUE0QixDQUFDQyxRQUFRLENBQUNILFVBQy9DSSxPQUFPQyxzQ0FBNkIsQ0FBQ0MsS0FBSyxDQUFDTDtJQUVqRCxJQUFJRyxTQUFTLE1BQU07UUFDakI7SUFDRjtJQUVBLElBQU1HLGtCQUFrQlgscUJBQXFCUTtJQUU3Q0csZ0JBQWdCQyxPQUFPLENBQUMsU0FBQ0M7UUFDdkIsSUFBTVQsVUFBVVUsMEJBQTBCRCxpQkFDcENFLGFBQWFYLFNBQVMsR0FBRztRQUUvQkQsWUFBWWEsSUFBSSxDQUFDRDtJQUNuQjtBQUNGO0FBRUEsU0FBU0QsMEJBQTBCRCxjQUFjO0lBQy9DLElBQU1JLGtCQUFrQkosZ0JBQ2xCSyxhQUFhRCxnQkFBZ0JFLGFBQWEsSUFDMUNDLGtCQUFrQnRCLE9BQU9vQixhQUN6QkcseUJBQXlCRCxpQkFDekJoQixVQUFVaUIsdUJBQXVCQyxVQUFVO0lBRWpELE9BQU9sQjtBQUNUIn0=
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "occam-custom-grammars",
3
3
  "author": "James Smith",
4
- "version": "5.0.1228",
4
+ "version": "5.0.1230",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/occam-custom-grammars",
7
7
  "description": "Occam's custom grammars.",
@@ -14,7 +14,7 @@
14
14
  "occam-grammar-utilities": "^8.0.345",
15
15
  "occam-grammars": "^1.3.311",
16
16
  "occam-lexers": "^23.1.1",
17
- "occam-parsers": "^23.1.1",
17
+ "occam-parsers": "^23.1.3",
18
18
  "occam-query": "^4.1.109"
19
19
  },
20
20
  "devDependencies": {
package/src/constants.js CHANGED
@@ -2,5 +2,10 @@
2
2
 
3
3
  export const EMPTY_STRING = "";
4
4
  export const VERTICAL_BAR = "|";
5
+ export const VERTICAL_SPACE = `
6
+
7
+ `
5
8
  export const UNASSIGNED_TYPE = "unassigned";
9
+ export const STUFF_RULE_NAME = "stuff";
10
+ export const NONSENSE_RULE_NAME = "nonsense";
6
11
  export const UNDERSCORE_CHARACTER = "_";
@@ -1,17 +1,21 @@
1
1
  "use strict";
2
2
 
3
3
  import { arrayUtilities } from "necessary";
4
+ import { specialSymbols } from "occam-lexers";
4
5
  import { parserUtilities } from "occam-parsers";
5
6
  import { eliminateLeftRecursion } from "occam-grammar-utilities";
6
7
 
7
8
  import defaultCustomGrammar from "../customGrammar/default";
8
9
 
9
- import { EMPTY_STRING, VERTICAL_BAR } from "../constants";
10
- import { validateVocabulary, expressionsFromVocabulary } from "../utilities/vocabulary";
10
+ import { expressionsFromVocabulary } from "../utilities/vocabulary";
11
+ import { VERTICAL_BAR, VERTICAL_SPACE } from "../constants";
12
+ import { validateBNF, validateVocabulary } from "../utilities/validate";
13
+ import { TERM_RULE_NAME, STATEMENT_RULE_NAME } from "../ruleNames";
11
14
  import { TYPE_VOCABULARY_NAME, SYMBOL_VOCABULARY_NAME } from "../vocabularyNames";
12
15
 
13
- const { rulesFromBNF } = parserUtilities,
14
- { unshift, backwardsForEach } = arrayUtilities;
16
+ const { opaque } = specialSymbols,
17
+ { rulesFromBNF } = parserUtilities,
18
+ { unshift, forwardsForEach, backwardsForEach } = arrayUtilities;
15
19
 
16
20
  export default class CombinedCustomGrammar {
17
21
  constructor(rules, entries) {
@@ -45,7 +49,7 @@ export default class CombinedCustomGrammar {
45
49
  customGrammars = [ defaultCustomGrammar, ...customGrammars ]; ///
46
50
  }
47
51
 
48
- const rules = rulesFromCustomGrammarsAndDefaultBNF(customGrammars),
52
+ const rules = rulesFromCustomGrammars(customGrammars),
49
53
  entries = entriesFromCustomGrammars(customGrammars),
50
54
  combinedCustomGrammar = new CombinedCustomGrammar(rules, entries);
51
55
 
@@ -57,7 +61,7 @@ export default class CombinedCustomGrammar {
57
61
  customGrammars = [ defaultCustomGrammar, ...customGrammars ]; ///
58
62
  }
59
63
 
60
- const rules = rulesFromCustomGrammarsAndDefaultBNF(customGrammars),
64
+ const rules = rulesFromCustomGrammars(customGrammars),
61
65
  entries = entriesFromCustomGrammars(customGrammars),
62
66
  combinedCustomGrammar = new CombinedCustomGrammar(rules, entries);
63
67
 
@@ -65,16 +69,34 @@ export default class CombinedCustomGrammar {
65
69
  }
66
70
  }
67
71
 
68
- function rulesFromCustomGrammarsAndDefaultBNF(customGrammars) {
69
- const bnfs = customGrammars.map((customGrammar) => {
70
- const bnf = customGrammar.getBNF();
72
+ function rulesFromCustomGrammars(customGrammars) {
73
+ const ruleNames = [
74
+ TERM_RULE_NAME,
75
+ STATEMENT_RULE_NAME,
76
+ ],
77
+ bnfs = ruleNames.map((ruleName) => {
78
+ const bnf = bnfFromCustomGrammars(customGrammars, ruleName);
71
79
 
72
80
  return bnf;
73
81
  }),
74
- bnf = bnfs.join(EMPTY_STRING),
82
+ bnf = bnfs.join(VERTICAL_SPACE),
75
83
  rules = rulesFromBNF(bnf);
76
84
 
77
- combineRules(rules)
85
+ combineRules(rules);
86
+
87
+ const opacity = opaque; ///
88
+
89
+ ruleNames.forEach((ruleName) => {
90
+ const rule = rules.find((rule) => {
91
+ const name = rule.getName();
92
+
93
+ if (name === ruleName) {
94
+ return true;
95
+ }
96
+ });
97
+
98
+ rule.setOpacity(opacity);
99
+ });
78
100
 
79
101
  return rules;
80
102
  }
@@ -117,6 +139,25 @@ function entryFromCustomGrammars(customGrammars, vocabularyName) {
117
139
  return entry;
118
140
  }
119
141
 
142
+ function bnfFromCustomGrammars(customGrammars, ruleName) {
143
+ const bnfs = [];
144
+
145
+ forwardsForEach(customGrammars, (customGrammar) => {
146
+ const bnf = customGrammar.getBNF(ruleName),
147
+ customGrammarDefaultCustomGrammar = customGrammar.isDefaultCustomGrammar();
148
+
149
+ if (!customGrammarDefaultCustomGrammar) {
150
+ validateBNF(bnf, ruleName);
151
+ }
152
+
153
+ bnfs.push(bnf);
154
+ });
155
+
156
+ const bnf = bnfs.join(VERTICAL_SPACE);
157
+
158
+ return bnf;
159
+ }
160
+
120
161
  function combineRules(rules) {
121
162
  let outerIndex = 0,
122
163
  length = rules.length;
@@ -4,13 +4,13 @@ import CustomGrammar from "../customGrammar";
4
4
 
5
5
  import { DEFAULT_CUSTOM_GRAMMAR_NAME } from "../grammarNames";
6
6
 
7
- export const termBNF = `term. ::= "(" argument ")"
7
+ export const termBNF = `term ::= "(" argument ")"
8
8
 
9
9
  | variable
10
10
 
11
11
  ;`;
12
12
 
13
- export const statementBNF = `statement. ::= "(" metaArgument ")"
13
+ export const statementBNF = `statement ::= "(" metaArgument ")"
14
14
 
15
15
  | equality
16
16
 
@@ -34,34 +34,12 @@ export default class CustomGrammar {
34
34
  return this.symbolVocabulary;
35
35
  }
36
36
 
37
- getBNF(ruleName = null) {
37
+ getBNF(ruleName) {
38
38
  let bnf;
39
39
 
40
40
  switch (ruleName) {
41
41
  case TERM_RULE_NAME: bnf = this.termBNF; break;
42
42
  case STATEMENT_RULE_NAME: bnf = this.statementBNF; break;
43
-
44
- default: {
45
- const ruleNames = [
46
- TERM_RULE_NAME,
47
- STATEMENT_RULE_NAME
48
- ],
49
- combinedBNF = ruleNames.reduce((combinedBNF, ruleName) => {
50
- const bnf = this.getBNF(ruleName);
51
-
52
- if (bnf !== EMPTY_STRING) {
53
- combinedBNF = `${combinedBNF}
54
-
55
- ${bnf}`;
56
- }
57
-
58
- return combinedBNF;
59
- }, EMPTY_STRING);
60
-
61
- bnf = combinedBNF; ///
62
-
63
- break;
64
- }
65
43
  }
66
44
 
67
45
  return bnf;
@@ -30,7 +30,7 @@ const { rulesAsString } = rulesUtilities,
30
30
 
31
31
  class View extends Element {
32
32
  keyUpHandler = (event, element) => {
33
- try {
33
+ // try {
34
34
  const bnf = this.getBNF(),
35
35
  name = this.getName(),
36
36
  ruleName = this.getRuleName(),
@@ -78,13 +78,13 @@ class View extends Element {
78
78
  nominalBNF = rulesString; ///
79
79
 
80
80
  this.setNominalBNF(nominalBNF);
81
- } catch (error) {
82
- console.log(error);
83
-
84
- this.clearParseTree();
85
-
86
- this.clearNominalBNF();
87
- }
81
+ // } catch (error) {
82
+ // console.log(error);
83
+ //
84
+ // this.clearParseTree();
85
+ //
86
+ // this.clearNominalBNF();
87
+ // }
88
88
  }
89
89
 
90
90
  changeHandler = (event, element) => {
@@ -132,16 +132,16 @@ class View extends Element {
132
132
  Custom grammar
133
133
  </SubHeading>
134
134
  <NameSelect onChange={changeHandler} />
135
- <SubHeading>
136
- BNF
137
- </SubHeading>
138
- <RuleNameSelect onChange={changeHandler} />
139
- <BNFTextarea onKeyUp={keyUpHandler} />
140
135
  <SubHeading>
141
136
  Vocabulary
142
137
  </SubHeading>
143
138
  <VocabularyNameSelect onChange={changeHandler} />
144
139
  <VocabularyTextarea onKeyUp={keyUpHandler} />
140
+ <SubHeading>
141
+ BNF
142
+ </SubHeading>
143
+ <RuleNameSelect onChange={changeHandler} />
144
+ <BNFTextarea onKeyUp={keyUpHandler} />
145
145
  <SubHeading>
146
146
  Start rule
147
147
  </SubHeading>
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+
3
+ import { arrayUtilities } from "necessary";
4
+
5
+ import { nominalParser } from "./utilities/nominal";
6
+ import { TERM_RULE_NAME, STATEMENT_RULE_NAME } from "./ruleNames";
7
+ import { STUFF_RULE_NAME, NONSENSE_RULE_NAME } from "./constants";
8
+
9
+ const { first } = arrayUtilities;
10
+
11
+ const ruleMap = nominalParser.getRuleMap(),
12
+ stuffRule = ruleMap[STUFF_RULE_NAME],
13
+ nonsenseRule = ruleMap[NONSENSE_RULE_NAME],
14
+ stuffTypes = typesFromRule(stuffRule),
15
+ nonsenseTypes = typesFromRule(nonsenseRule),
16
+ termTypes = stuffTypes, ///
17
+ statementTypes = nonsenseTypes,
18
+ typesMap = {
19
+ [TERM_RULE_NAME]: termTypes,
20
+ [STATEMENT_RULE_NAME]: statementTypes
21
+ };
22
+
23
+ export default typesMap;
24
+
25
+ function typesFromRule(rule) {
26
+ let parts;
27
+
28
+ const definitions = rule.getDefinitions(),
29
+ firstDDefinition = first(definitions),
30
+ definition = firstDDefinition; ///
31
+
32
+ parts = definition.getParts();
33
+
34
+ const firstPart = first(parts),
35
+ oneOrMorePartsPart = firstPart, ///
36
+ part = oneOrMorePartsPart.getPart(),
37
+ choiceOrPartsPart = part; ///
38
+
39
+ parts = choiceOrPartsPart.getParts();
40
+
41
+ const types = parts.map((part) => {
42
+ const significantTokenTypePart = part, ///
43
+ significantTokenType = significantTokenTypePart.getSignificantTokenType(),
44
+ type = significantTokenType; ///
45
+
46
+ return type;
47
+ });
48
+
49
+ return types;
50
+ }
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+
3
+ import { CustomGrammarBNFLexer, CustomGrammarBNFParser } from "occam-grammars";
4
+ import { CustomGrammarVocabularyLexer, CustomGrammarVocabularyParser } from "occam-grammars";
5
+
6
+ export const customGrammarBNFLexer = CustomGrammarBNFLexer.fromNothing();
7
+
8
+ export const customGrammarBNFParser = CustomGrammarBNFParser.fromNothing();
9
+
10
+ export const customGrammarVocabularyLexer = CustomGrammarVocabularyLexer.fromNothing();
11
+
12
+ export const customGrammarVocabularyParser = CustomGrammarVocabularyParser.fromNothing();
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+
3
+ import { CommonLexer } from "occam-lexers";
4
+ import { CommonParser } from "occam-parsers";
5
+ import { NominalLexer, NominalParser } from "occam-grammars";
6
+
7
+ export const nominalLexer = CommonLexer.fromNothing(NominalLexer);
8
+
9
+ export const nominalParser = CommonParser.fromNothing(NominalParser);