highmark-markdown 0.0.412 → 0.0.414
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 +21 -40
- package/lib/example/importer.js +2 -6
- package/lib/node/markdown/blockLine.js +2 -3
- package/lib/replacement/footnote.js +5 -6
- package/lib/replacement/subDivision/embedDirectives.js +2 -2
- package/lib/replacement/subDivision/includeDirectives.js +2 -2
- package/lib/replacement/subDivision.js +4 -21
- package/lib/replacement.js +13 -11
- package/lib/utilities/content.js +8 -7
- package/lib/utilities/replacement.js +5 -6
- package/package.json +3 -3
- package/src/example/importer.js +1 -8
- package/src/node/markdown/blockLine.js +2 -3
- package/src/replacement/footnote.js +1 -1
- package/src/replacement/subDivision/embedDirectives.js +1 -1
- package/src/replacement/subDivision/includeDirectives.js +1 -1
- package/src/replacement/subDivision.js +2 -9
- package/src/replacement.js +12 -11
- package/src/utilities/content.js +14 -12
- package/src/utilities/replacement.js +12 -14
- package/lib/utilities/node.js +0 -99
- package/src/utilities/node.js +0 -114
|
@@ -43,7 +43,6 @@ _export(exports, {
|
|
|
43
43
|
return replaceTokens;
|
|
44
44
|
}
|
|
45
45
|
});
|
|
46
|
-
var _node = require("../utilities/node");
|
|
47
46
|
function _array_like_to_array(arr, len) {
|
|
48
47
|
if (len == null || len > arr.length) len = arr.length;
|
|
49
48
|
for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
|
|
@@ -95,19 +94,19 @@ function addNodesAfter(existingNode, addedNodes, parentNode) {
|
|
|
95
94
|
}
|
|
96
95
|
function appendTokens(appendedTokens, parentNode, tokens) {
|
|
97
96
|
var _tokens;
|
|
98
|
-
var node = parentNode,
|
|
97
|
+
var node = parentNode, lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens), start = lastSignificantTokenIndex + 1, deleteCount = 0;
|
|
99
98
|
(_tokens = tokens).splice.apply(_tokens, [
|
|
100
99
|
start,
|
|
101
100
|
deleteCount
|
|
102
101
|
].concat(_to_consumable_array(appendedTokens)));
|
|
103
102
|
}
|
|
104
103
|
function removeTokens(removedNode, tokens) {
|
|
105
|
-
var node = removedNode,
|
|
104
|
+
var node = removedNode, firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens), lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens), start = firstSignificantTokenIndex, end = lastSignificantTokenIndex + 1, deleteCount = end - start;
|
|
106
105
|
tokens.splice(start, deleteCount);
|
|
107
106
|
}
|
|
108
107
|
function replaceTokens(replacementTokens, replacedNode, tokens) {
|
|
109
108
|
var _tokens;
|
|
110
|
-
var node = replacedNode,
|
|
109
|
+
var node = replacedNode, firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens), lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens), start = firstSignificantTokenIndex, end = lastSignificantTokenIndex + 1, deleteCount = end - start;
|
|
111
110
|
(_tokens = tokens).splice.apply(_tokens, [
|
|
112
111
|
start,
|
|
113
112
|
deleteCount
|
|
@@ -119,11 +118,11 @@ function addNodeAfter(existingNode, addedNode, parentNode) {
|
|
|
119
118
|
}
|
|
120
119
|
function addTokensAfter(existingNode, addedTokens, tokens) {
|
|
121
120
|
var _tokens;
|
|
122
|
-
var node = existingNode,
|
|
121
|
+
var node = existingNode, lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens), start = lastSignificantTokenIndex + 1, deleteCount = 0;
|
|
123
122
|
(_tokens = tokens).splice.apply(_tokens, [
|
|
124
123
|
start,
|
|
125
124
|
deleteCount
|
|
126
125
|
].concat(_to_consumable_array(addedTokens)));
|
|
127
126
|
}
|
|
128
127
|
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/replacement.js"],"sourcesContent":["\"use strict\";\n\nexport function appendNode(appendedNode, parentNode) {\n  const appendedChildNode = appendedNode;  ///\n\n  parentNode.appendChildNode(appendedChildNode);\n}\n\nexport function removeNode(removedNode, parentNode) {\n  const removedChildNode = removedNode; ///\n\n  parentNode.removeChildNode(removedChildNode);\n}\n\nexport function removeNodes(removedNodes, parentNode) {\n  const removedChildNodes = removedNodes; ///\n\n  parentNode.removeChildNodes(removedChildNodes);\n}\n\nexport function replaceNode(replacementNode, replacedNode, parentNode) {\n  const replacedChildNode = replacedNode,  ///\n        replacementChildNode = replacementNode; ///\n\n  parentNode.replaceChildNode(replacedChildNode, replacementChildNode);\n}\n\nexport function replaceNodes(replacementNodes, replacedNode, parentNode) {\n  const replacedChildNode = replacedNode,  ///\n        replacementChildNodes = replacementNodes; ///\n\n  parentNode.replaceChildNodes(replacedChildNode, replacementChildNodes);\n}\n\nexport function addNodesAfter(existingNode, addedNodes, parentNode) {\n  const existingChildNode = existingNode, ///\n        addedChildNodes = addedNodes; ///\n\n  parentNode.addChildNodesAfter(existingChildNode, addedChildNodes);\n}\n\nexport function appendTokens(appendedTokens, parentNode, tokens) {\n  const node = parentNode, ///\n        lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens),\n        start = lastSignificantTokenIndex + 1,\n        deleteCount = 0;\n\n  tokens.splice(start, deleteCount, ...appendedTokens);\n}\n\nexport function removeTokens(removedNode, tokens) {\n  const node = removedNode,  ///\n        firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens),\n        lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens),\n        start = firstSignificantTokenIndex, ///\n        end = lastSignificantTokenIndex + 1,\n        deleteCount = end - start;\n\n  tokens.splice(start, deleteCount);\n}\n\nexport function replaceTokens(replacementTokens, replacedNode, tokens) {\n  const node = replacedNode,  ///\n        firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens),\n        lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens),\n        start = firstSignificantTokenIndex, ///\n        end = lastSignificantTokenIndex + 1,\n        deleteCount = end - start;\n\n  tokens.splice(start, deleteCount, ...replacementTokens);\n}\n\nexport function addNodeAfter(existingNode, addedNode, parentNode) {\n  const existingChildNode = existingNode, ///\n        addedChildNode = addedNode; ///\n\n  parentNode.appendChildNodeAfter(existingChildNode, addedChildNode);\n}\n\nexport function addTokensAfter(existingNode, addedTokens, tokens) {\n  const node = existingNode,  ///\n        lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens),\n        start = lastSignificantTokenIndex + 1,\n        deleteCount = 0;\n\n  tokens.splice(start, deleteCount, ...addedTokens);\n}\n"],"names":["addNodeAfter","addNodesAfter","addTokensAfter","appendNode","appendTokens","removeNode","removeNodes","removeTokens","replaceNode","replaceNodes","replaceTokens","appendedNode","parentNode","appendedChildNode","appendChildNode","removedNode","removedChildNode","removeChildNode","removedNodes","removedChildNodes","removeChildNodes","replacementNode","replacedNode","replacedChildNode","replacementChildNode","replaceChildNode","replacementNodes","replacementChildNodes","replaceChildNodes","existingNode","addedNodes","existingChildNode","addedChildNodes","addChildNodesAfter","appendedTokens","tokens","node","lastSignificantTokenIndex","getLastSignificantTokenIndex","start","deleteCount","splice","firstSignificantTokenIndex","getFirstSignificantTokenIndex","end","replacementTokens","addedNode","addedChildNode","appendChildNodeAfter","addedTokens"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA;;;;;;;;;;;IAwEgBA,YAAY;eAAZA;;IAtCAC,aAAa;eAAbA;;IA6CAC,cAAc;eAAdA;;IA7EAC,UAAU;eAAVA;;IAuCAC,YAAY;eAAZA;;IAjCAC,UAAU;eAAVA;;IAMAC,WAAW;eAAXA;;IAoCAC,YAAY;eAAZA;;IA9BAC,WAAW;eAAXA;;IAOAC,YAAY;eAAZA;;IAkCAC,aAAa;eAAbA;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA3DT,SAASP,WAAWQ,YAAY,EAAEC,UAAU;IACjD,IAAMC,oBAAoBF,cAAe,GAAG;IAE5CC,WAAWE,eAAe,CAACD;AAC7B;AAEO,SAASR,WAAWU,WAAW,EAAEH,UAAU;IAChD,IAAMI,mBAAmBD,aAAa,GAAG;IAEzCH,WAAWK,eAAe,CAACD;AAC7B;AAEO,SAASV,YAAYY,YAAY,EAAEN,UAAU;IAClD,IAAMO,oBAAoBD,cAAc,GAAG;IAE3CN,WAAWQ,gBAAgB,CAACD;AAC9B;AAEO,SAASX,YAAYa,eAAe,EAAEC,YAAY,EAAEV,UAAU;IACnE,IAAMW,oBAAoBD,cACpBE,uBAAuBH,iBAAiB,GAAG;IAEjDT,WAAWa,gBAAgB,CAACF,mBAAmBC;AACjD;AAEO,SAASf,aAAaiB,gBAAgB,EAAEJ,YAAY,EAAEV,UAAU;IACrE,IAAMW,oBAAoBD,cACpBK,wBAAwBD,kBAAkB,GAAG;IAEnDd,WAAWgB,iBAAiB,CAACL,mBAAmBI;AAClD;AAEO,SAAS1B,cAAc4B,YAAY,EAAEC,UAAU,EAAElB,UAAU;IAChE,IAAMmB,oBAAoBF,cACpBG,kBAAkBF,YAAY,GAAG;IAEvClB,WAAWqB,kBAAkB,CAACF,mBAAmBC;AACnD;AAEO,SAAS5B,aAAa8B,cAAc,EAAEtB,UAAU,EAAEuB,MAAM;QAM7DA;IALA,IAAMC,OAAOxB,YACPyB,4BAA4BD,KAAKE,4BAA4B,CAACH,SAC9DI,QAAQF,4BAA4B,GACpCG,cAAc;IAEpBL,CAAAA,UAAAA,QAAOM,MAAM,CAAbN,MAAAA,SAAAA;QAAcI;QAAOC;KAA+B,CAApDL,OAAkC,qBAAGD;AACvC;AAEO,SAAS3B,aAAaQ,WAAW,EAAEoB,MAAM;IAC9C,IAAMC,OAAOrB,aACP2B,6BAA6BN,KAAKO,6BAA6B,CAACR,SAChEE,4BAA4BD,KAAKE,4BAA4B,CAACH,SAC9DI,QAAQG,4BACRE,MAAMP,4BAA4B,GAClCG,cAAcI,MAAML;IAE1BJ,OAAOM,MAAM,CAACF,OAAOC;AACvB;AAEO,SAAS9B,cAAcmC,iBAAiB,EAAEvB,YAAY,EAAEa,MAAM;QAQnEA;IAPA,IAAMC,OAAOd,cACPoB,6BAA6BN,KAAKO,6BAA6B,CAACR,SAChEE,4BAA4BD,KAAKE,4BAA4B,CAACH,SAC9DI,QAAQG,4BACRE,MAAMP,4BAA4B,GAClCG,cAAcI,MAAML;IAE1BJ,CAAAA,UAAAA,QAAOM,MAAM,CAAbN,MAAAA,SAAAA;QAAcI;QAAOC;KAAkC,CAAvDL,OAAkC,qBAAGU;AACvC;AAEO,SAAS7C,aAAa6B,YAAY,EAAEiB,SAAS,EAAElC,UAAU;IAC9D,IAAMmB,oBAAoBF,cACpBkB,iBAAiBD,WAAW,GAAG;IAErClC,WAAWoC,oBAAoB,CAACjB,mBAAmBgB;AACrD;AAEO,SAAS7C,eAAe2B,YAAY,EAAEoB,WAAW,EAAEd,MAAM;QAM9DA;IALA,IAAMC,OAAOP,cACPQ,4BAA4BD,KAAKE,4BAA4B,CAACH,SAC9DI,QAAQF,4BAA4B,GACpCG,cAAc;IAEpBL,CAAAA,UAAAA,QAAOM,MAAM,CAAbN,MAAAA,SAAAA;QAAcI;QAAOC;KAA4B,CAAjDL,OAAkC,qBAAGc;AACvC"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "highmark-markdown",
|
|
3
3
|
"author": "James Smith",
|
|
4
|
-
"version": "0.0.
|
|
4
|
+
"version": "0.0.414",
|
|
5
5
|
"license": "MIT, Anti-996",
|
|
6
6
|
"homepage": "https://github.com/djalbat/highmark-markdown",
|
|
7
7
|
"description": "Highmark's Markdown and Markdown Style languages.",
|
|
@@ -11,9 +11,9 @@
|
|
|
11
11
|
},
|
|
12
12
|
"dependencies": {
|
|
13
13
|
"necessary": "^14.0.1",
|
|
14
|
-
"occam-grammars": "^1.0.
|
|
14
|
+
"occam-grammars": "^1.0.651",
|
|
15
15
|
"occam-lexers": "^22.0.44",
|
|
16
|
-
"occam-parsers": "^22.0.
|
|
16
|
+
"occam-parsers": "^22.0.63",
|
|
17
17
|
"occam-query": "^3.1.174"
|
|
18
18
|
},
|
|
19
19
|
"devDependencies": {
|
package/src/example/importer.js
CHANGED
|
@@ -42,14 +42,7 @@ const CONTENT_PATH = "content.md",
|
|
|
42
42
|
INSTALLING_THE_CLI_PATH = "installing-the-cli.md",
|
|
43
43
|
GETTING_TO_GRIPS_WITH_THE_IDE_PATH = "getting-to-grips-with-the-ide.md";
|
|
44
44
|
|
|
45
|
-
export const defaultContent =
|
|
46
|
-
\`\`\`
|
|
47
|
-
git clone
|
|
48
|
-
npm install
|
|
49
|
-
\`\`\`
|
|
50
|
-
`;
|
|
51
|
-
|
|
52
|
-
export const _defaultContent = `@ignore
|
|
45
|
+
export const defaultContent = `@ignore
|
|
53
46
|
|
|
54
47
|
@include ${FRONT_MATTER_PATH}
|
|
55
48
|
@include ${CONTENT_PATH}`;
|
|
@@ -3,7 +3,6 @@
|
|
|
3
3
|
import MarkdownNode from "../../node/markdown";
|
|
4
4
|
|
|
5
5
|
import { contentFromNode } from "../../utilities/content";
|
|
6
|
-
import { leadingIndexFromNodeAndTokens } from "../../utilities/node";
|
|
7
6
|
|
|
8
7
|
export default class BlockLineMarkdownNode extends MarkdownNode {
|
|
9
8
|
content(context) {
|
|
@@ -14,8 +13,8 @@ export default class BlockLineMarkdownNode extends MarkdownNode {
|
|
|
14
13
|
|
|
15
14
|
content = contentFromNode(node, context);
|
|
16
15
|
|
|
17
|
-
const
|
|
18
|
-
previousTokenIndex =
|
|
16
|
+
const firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens),
|
|
17
|
+
previousTokenIndex = firstSignificantTokenIndex - 1,
|
|
19
18
|
previousToken = tokens[previousTokenIndex],
|
|
20
19
|
previousTokenWhitespaceToken = previousToken.isWhitespaceToken();
|
|
21
20
|
|
|
@@ -39,7 +39,7 @@ export default class FootnoteReplacement extends Replacement {
|
|
|
39
39
|
return footnoteMarkdownNode;
|
|
40
40
|
}
|
|
41
41
|
|
|
42
|
-
static fromNode(node,
|
|
42
|
+
static fromNode(node, ...remainingArguments) { return Replacement.fromNode(FootnoteReplacement, node, ...remainingArguments); }
|
|
43
43
|
|
|
44
44
|
static fromFootnoteSubDivisionReplacement(footnoteSubDivisionReplacement) {
|
|
45
45
|
const node = footnoteSubDivisionReplacement.getNode(),
|
|
@@ -44,7 +44,7 @@ export default class EmbedDirectivesSubDivisionReplacement extends SubDivisionRe
|
|
|
44
44
|
embedDirectiveMarkdownNodesLength = embedDirectiveMarkdownNodes.length;
|
|
45
45
|
|
|
46
46
|
if (embedDirectiveMarkdownNodesLength > 0) {
|
|
47
|
-
embedDirectivesSubDivisionReplacement = SubDivisionReplacement.fromSubDivisionMarkdownNode(EmbedDirectivesSubDivisionReplacement, subDivisionMarkdownNode,
|
|
47
|
+
embedDirectivesSubDivisionReplacement = SubDivisionReplacement.fromSubDivisionMarkdownNode(EmbedDirectivesSubDivisionReplacement, subDivisionMarkdownNode, embedDirectiveMarkdownNodes, context);
|
|
48
48
|
}
|
|
49
49
|
|
|
50
50
|
return embedDirectivesSubDivisionReplacement;
|
|
@@ -50,7 +50,7 @@ export default class IncludeDirectivesSubDivisionReplacement extends SubDivision
|
|
|
50
50
|
includeDirectiveMarkdownNodesLength = includeDirectiveMarkdownNodes.length;
|
|
51
51
|
|
|
52
52
|
if (includeDirectiveMarkdownNodesLength > 0) {
|
|
53
|
-
includeDirectivesSubDivisionReplacement = SubDivisionReplacement.fromSubDivisionMarkdownNode(IncludeDirectivesSubDivisionReplacement, subDivisionMarkdownNode,
|
|
53
|
+
includeDirectivesSubDivisionReplacement = SubDivisionReplacement.fromSubDivisionMarkdownNode(IncludeDirectivesSubDivisionReplacement, subDivisionMarkdownNode, includeDirectiveMarkdownNodes, context);
|
|
54
54
|
}
|
|
55
55
|
|
|
56
56
|
return includeDirectivesSubDivisionReplacement;
|
|
@@ -20,16 +20,9 @@ export default class SubDivisionReplacement extends Replacement {
|
|
|
20
20
|
super.removeFrom(removedNode, parentNode, context);
|
|
21
21
|
}
|
|
22
22
|
|
|
23
|
-
static
|
|
24
|
-
const subDivisionMarkdownNode = null,
|
|
25
|
-
subDivisionReplacement = Replacement.fromNodeAndTokens(Class, node, tokens, subDivisionMarkdownNode, ...remainingArguments);
|
|
26
|
-
|
|
27
|
-
return subDivisionReplacement;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
static fromSubDivisionMarkdownNode(Class, subDivisionMarkdownNode, context, ...remainingArguments) {
|
|
23
|
+
static fromSubDivisionMarkdownNode(Class, subDivisionMarkdownNode, ...remainingArguments) {
|
|
31
24
|
const node = subDivisionMarkdownNode, ///
|
|
32
|
-
subDivisionReplacement = Replacement.fromNode(Class, node,
|
|
25
|
+
subDivisionReplacement = Replacement.fromNode(Class, node, subDivisionMarkdownNode, ...remainingArguments);
|
|
33
26
|
|
|
34
27
|
return subDivisionReplacement;
|
|
35
28
|
}
|
package/src/replacement.js
CHANGED
|
@@ -2,7 +2,6 @@
|
|
|
2
2
|
|
|
3
3
|
import { arrayUtilities } from "necessary";
|
|
4
4
|
|
|
5
|
-
import { leadingIndexFromNodeAndTokens, trailingIndexFromNodeAndTokens } from "./utilities/node";
|
|
6
5
|
import { removeNode, appendNode, removeTokens, appendTokens, replaceNode, replaceNodes, replaceTokens, addNodesAfter, addTokensAfter } from "./utilities/replacement";
|
|
7
6
|
|
|
8
7
|
const { push } = arrayUtilities;
|
|
@@ -37,7 +36,7 @@ export default class Replacement {
|
|
|
37
36
|
context = { ///
|
|
38
37
|
tokens
|
|
39
38
|
},
|
|
40
|
-
replacement = Class.fromNode(node,
|
|
39
|
+
replacement = Class.fromNode(node, ...remainingArguments, context);
|
|
41
40
|
|
|
42
41
|
return replacement;
|
|
43
42
|
}
|
|
@@ -54,7 +53,7 @@ export default class Replacement {
|
|
|
54
53
|
context = {
|
|
55
54
|
tokens
|
|
56
55
|
},
|
|
57
|
-
replacement = Class.fromNode(node,
|
|
56
|
+
replacement = Class.fromNode(node, ...remainingArguments, context);
|
|
58
57
|
|
|
59
58
|
return replacement;
|
|
60
59
|
}
|
|
@@ -114,14 +113,16 @@ export default class Replacement {
|
|
|
114
113
|
|
|
115
114
|
overwriteNodeTokens(node, clonedTokens, this.tokens);
|
|
116
115
|
|
|
117
|
-
const Class = this.constructor,
|
|
116
|
+
const Class = this.constructor, ///
|
|
118
117
|
tokens = clonedTokens, ///
|
|
119
118
|
replacement = new Class(node, tokens, ...remainingArguments);
|
|
120
119
|
|
|
121
120
|
return replacement
|
|
122
121
|
}
|
|
123
122
|
|
|
124
|
-
static fromNode(Class, node,
|
|
123
|
+
static fromNode(Class, node, ...remainingArguments) {
|
|
124
|
+
let context = remainingArguments.pop();
|
|
125
|
+
|
|
125
126
|
if (context === undefined) {
|
|
126
127
|
context = node; ///
|
|
127
128
|
|
|
@@ -133,8 +134,8 @@ export default class Replacement {
|
|
|
133
134
|
let { tokens } = context;
|
|
134
135
|
|
|
135
136
|
const clonedTokens = clonedTokensFromNodeAndTokens(node, tokens),
|
|
136
|
-
|
|
137
|
-
offset =
|
|
137
|
+
firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens),
|
|
138
|
+
offset = firstSignificantTokenIndex; ///
|
|
138
139
|
|
|
139
140
|
node = node.clone(); ///
|
|
140
141
|
|
|
@@ -206,10 +207,10 @@ function overwriteNonTerminalNodeTokens(nonTerminalNode, clonedTokens, tokens, o
|
|
|
206
207
|
}
|
|
207
208
|
|
|
208
209
|
function clonedTokensFromNodeAndTokens(node, tokens) {
|
|
209
|
-
const
|
|
210
|
-
|
|
211
|
-
start =
|
|
212
|
-
end =
|
|
210
|
+
const firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens),
|
|
211
|
+
lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens),
|
|
212
|
+
start = firstSignificantTokenIndex, ///
|
|
213
|
+
end = lastSignificantTokenIndex + 1;
|
|
213
214
|
|
|
214
215
|
tokens = tokens.slice(start, end); ///
|
|
215
216
|
|
package/src/utilities/content.js
CHANGED
|
@@ -4,7 +4,6 @@ import { arrayUtilities } from "necessary";
|
|
|
4
4
|
|
|
5
5
|
import { EMPTY_STRING } from "../constants";
|
|
6
6
|
import { ESCAPED_TOKEN_TYPE } from "../tokenTypes";
|
|
7
|
-
import { leadingIndexFromNodeAndTokens, trailingIndexFromNodeAndTokens } from "../utilities/node";
|
|
8
7
|
|
|
9
8
|
const { first, last } = arrayUtilities;
|
|
10
9
|
|
|
@@ -13,10 +12,10 @@ export function contentFromNode(node, context) {
|
|
|
13
12
|
|
|
14
13
|
let { tokens } = context;
|
|
15
14
|
|
|
16
|
-
const
|
|
17
|
-
|
|
18
|
-
start =
|
|
19
|
-
end =
|
|
15
|
+
const firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens),
|
|
16
|
+
lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens),
|
|
17
|
+
start = firstSignificantTokenIndex, ///
|
|
18
|
+
end = lastSignificantTokenIndex + 1;
|
|
20
19
|
|
|
21
20
|
tokens = tokens.slice(start, end);
|
|
22
21
|
|
|
@@ -36,11 +35,11 @@ export function contentFromNodes(nodes, augmentLeft, augmentRight, context) {
|
|
|
36
35
|
|
|
37
36
|
const lastNode = last(nodes),
|
|
38
37
|
firstNode = first(nodes),
|
|
39
|
-
|
|
40
|
-
|
|
38
|
+
firstSignificantTokenIndex = firstNode.getFirstSignificantTokenIndex(tokens),
|
|
39
|
+
lastSignificantTokenIndex = lastNode.getLastSignificantTokenIndex(tokens);
|
|
41
40
|
|
|
42
|
-
let firstTokenIndex =
|
|
43
|
-
lastTokenIndex =
|
|
41
|
+
let firstTokenIndex = firstSignificantTokenIndex, ///
|
|
42
|
+
lastTokenIndex = lastSignificantTokenIndex; ///
|
|
44
43
|
|
|
45
44
|
if (augmentLeft) {
|
|
46
45
|
const previousTokenIndex = firstTokenIndex - 1;
|
|
@@ -87,10 +86,13 @@ export function contentFromNodes(nodes, augmentLeft, augmentRight, context) {
|
|
|
87
86
|
export function contentFromNodeAndTokens(node, tokens, offset = 0) {
|
|
88
87
|
let content = EMPTY_STRING;
|
|
89
88
|
|
|
90
|
-
|
|
91
|
-
trailingIndex = trailingIndexFromNodeAndTokens(node, tokens);
|
|
89
|
+
let firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens);
|
|
92
90
|
|
|
93
|
-
|
|
91
|
+
const lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens);
|
|
92
|
+
|
|
93
|
+
firstSignificantTokenIndex += offset;
|
|
94
|
+
|
|
95
|
+
for (let index = firstSignificantTokenIndex; index <= lastSignificantTokenIndex; index++) {
|
|
94
96
|
const token = tokens[index],
|
|
95
97
|
tokenContent = token.getContent();
|
|
96
98
|
|
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
import { leadingIndexFromNodeAndTokens, trailingIndexFromNodeAndTokens } from "../utilities/node";
|
|
4
|
-
|
|
5
3
|
export function appendNode(appendedNode, parentNode) {
|
|
6
4
|
const appendedChildNode = appendedNode; ///
|
|
7
5
|
|
|
@@ -43,8 +41,8 @@ export function addNodesAfter(existingNode, addedNodes, parentNode) {
|
|
|
43
41
|
|
|
44
42
|
export function appendTokens(appendedTokens, parentNode, tokens) {
|
|
45
43
|
const node = parentNode, ///
|
|
46
|
-
|
|
47
|
-
start =
|
|
44
|
+
lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens),
|
|
45
|
+
start = lastSignificantTokenIndex + 1,
|
|
48
46
|
deleteCount = 0;
|
|
49
47
|
|
|
50
48
|
tokens.splice(start, deleteCount, ...appendedTokens);
|
|
@@ -52,10 +50,10 @@ export function appendTokens(appendedTokens, parentNode, tokens) {
|
|
|
52
50
|
|
|
53
51
|
export function removeTokens(removedNode, tokens) {
|
|
54
52
|
const node = removedNode, ///
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
start =
|
|
58
|
-
end =
|
|
53
|
+
firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens),
|
|
54
|
+
lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens),
|
|
55
|
+
start = firstSignificantTokenIndex, ///
|
|
56
|
+
end = lastSignificantTokenIndex + 1,
|
|
59
57
|
deleteCount = end - start;
|
|
60
58
|
|
|
61
59
|
tokens.splice(start, deleteCount);
|
|
@@ -63,10 +61,10 @@ export function removeTokens(removedNode, tokens) {
|
|
|
63
61
|
|
|
64
62
|
export function replaceTokens(replacementTokens, replacedNode, tokens) {
|
|
65
63
|
const node = replacedNode, ///
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
start =
|
|
69
|
-
end =
|
|
64
|
+
firstSignificantTokenIndex = node.getFirstSignificantTokenIndex(tokens),
|
|
65
|
+
lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens),
|
|
66
|
+
start = firstSignificantTokenIndex, ///
|
|
67
|
+
end = lastSignificantTokenIndex + 1,
|
|
70
68
|
deleteCount = end - start;
|
|
71
69
|
|
|
72
70
|
tokens.splice(start, deleteCount, ...replacementTokens);
|
|
@@ -81,8 +79,8 @@ export function addNodeAfter(existingNode, addedNode, parentNode) {
|
|
|
81
79
|
|
|
82
80
|
export function addTokensAfter(existingNode, addedTokens, tokens) {
|
|
83
81
|
const node = existingNode, ///
|
|
84
|
-
|
|
85
|
-
start =
|
|
82
|
+
lastSignificantTokenIndex = node.getLastSignificantTokenIndex(tokens),
|
|
83
|
+
start = lastSignificantTokenIndex + 1,
|
|
86
84
|
deleteCount = 0;
|
|
87
85
|
|
|
88
86
|
tokens.splice(start, deleteCount, ...addedTokens);
|
package/lib/utilities/node.js
DELETED
|
@@ -1,99 +0,0 @@
|
|
|
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: all[name]
|
|
9
|
-
});
|
|
10
|
-
}
|
|
11
|
-
_export(exports, {
|
|
12
|
-
default: function() {
|
|
13
|
-
return _default;
|
|
14
|
-
},
|
|
15
|
-
leadingIndexFromNodeAndTokens: function() {
|
|
16
|
-
return leadingIndexFromNodeAndTokens;
|
|
17
|
-
},
|
|
18
|
-
trailingIndexFromNodeAndTokens: function() {
|
|
19
|
-
return trailingIndexFromNodeAndTokens;
|
|
20
|
-
}
|
|
21
|
-
});
|
|
22
|
-
var _necessary = require("necessary");
|
|
23
|
-
var forwardsSome = _necessary.arrayUtilities.forwardsSome, backwardsSome = _necessary.arrayUtilities.backwardsSome;
|
|
24
|
-
function leadingIndexFromNodeAndTokens(node, tokens) {
|
|
25
|
-
var leadingIndex;
|
|
26
|
-
var nodeTerminalNode = node.isTerminalNode();
|
|
27
|
-
if (nodeTerminalNode) {
|
|
28
|
-
var terminalNode = node; ///
|
|
29
|
-
leadingIndex = leadingIndexFromTerminalNodeAndTokens(terminalNode, tokens);
|
|
30
|
-
} else {
|
|
31
|
-
var nonTerminalNode = node; ///
|
|
32
|
-
leadingIndex = leadingIndexFromNonTerminalNodeAndTokens(nonTerminalNode, tokens);
|
|
33
|
-
}
|
|
34
|
-
return leadingIndex;
|
|
35
|
-
}
|
|
36
|
-
function trailingIndexFromNodeAndTokens(node, tokens) {
|
|
37
|
-
var trailingIndex;
|
|
38
|
-
var nodeTerminalNode = node.isTerminalNode();
|
|
39
|
-
if (nodeTerminalNode) {
|
|
40
|
-
var terminalNode = node; ///
|
|
41
|
-
trailingIndex = trailingIndexFromTerminalNodeAndTokens(terminalNode, tokens);
|
|
42
|
-
} else {
|
|
43
|
-
var nonTerminalNode = node; ///
|
|
44
|
-
trailingIndex = trailingIndexFromNonTerminalNodeAndTokens(nonTerminalNode, tokens);
|
|
45
|
-
}
|
|
46
|
-
return trailingIndex;
|
|
47
|
-
}
|
|
48
|
-
var _default = {
|
|
49
|
-
leadingIndexFromNodeAndTokens: leadingIndexFromNodeAndTokens,
|
|
50
|
-
trailingIndexFromNodeAndTokens: trailingIndexFromNodeAndTokens
|
|
51
|
-
};
|
|
52
|
-
function leadingIndexFromTerminalNodeAndTokens(terminalNode, tokens) {
|
|
53
|
-
var leadingIndex;
|
|
54
|
-
var significantToken = terminalNode.getSignificantToken();
|
|
55
|
-
if (significantToken === null) {
|
|
56
|
-
leadingIndex = -1;
|
|
57
|
-
} else {
|
|
58
|
-
var significantTokenIndex = tokens.indexOf(significantToken);
|
|
59
|
-
leadingIndex = significantTokenIndex; ///
|
|
60
|
-
}
|
|
61
|
-
return leadingIndex;
|
|
62
|
-
}
|
|
63
|
-
function trailingIndexFromTerminalNodeAndTokens(terminalNode, tokens) {
|
|
64
|
-
var trailingIndex;
|
|
65
|
-
var significantToken = terminalNode.getSignificantToken();
|
|
66
|
-
if (significantToken === null) {
|
|
67
|
-
trailingIndex = -1;
|
|
68
|
-
} else {
|
|
69
|
-
var significantTokenIndex = tokens.indexOf(significantToken);
|
|
70
|
-
trailingIndex = significantTokenIndex; ///
|
|
71
|
-
}
|
|
72
|
-
return trailingIndex;
|
|
73
|
-
}
|
|
74
|
-
function leadingIndexFromNonTerminalNodeAndTokens(nonTerminalNode, tokens) {
|
|
75
|
-
var leadingIndex;
|
|
76
|
-
var childNodes = nonTerminalNode.getChildNodes();
|
|
77
|
-
forwardsSome(childNodes, function(childNode) {
|
|
78
|
-
var node = childNode;
|
|
79
|
-
leadingIndex = leadingIndexFromNodeAndTokens(node, tokens);
|
|
80
|
-
if (leadingIndex !== -1) {
|
|
81
|
-
return true;
|
|
82
|
-
}
|
|
83
|
-
});
|
|
84
|
-
return leadingIndex;
|
|
85
|
-
}
|
|
86
|
-
function trailingIndexFromNonTerminalNodeAndTokens(nonTerminalNode, tokens) {
|
|
87
|
-
var trailingIndex;
|
|
88
|
-
var childNodes = nonTerminalNode.getChildNodes();
|
|
89
|
-
backwardsSome(childNodes, function(childNode) {
|
|
90
|
-
var node = childNode;
|
|
91
|
-
trailingIndex = trailingIndexFromNodeAndTokens(node, tokens);
|
|
92
|
-
if (trailingIndex !== -1) {
|
|
93
|
-
return true;
|
|
94
|
-
}
|
|
95
|
-
});
|
|
96
|
-
return trailingIndex;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsaXRpZXMvbm9kZS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcblxuaW1wb3J0IHsgYXJyYXlVdGlsaXRpZXMgfSBmcm9tIFwibmVjZXNzYXJ5XCI7XG5cbmNvbnN0IHsgZm9yd2FyZHNTb21lLCBiYWNrd2FyZHNTb21lIH0gPSBhcnJheVV0aWxpdGllcztcblxuZXhwb3J0IGZ1bmN0aW9uIGxlYWRpbmdJbmRleEZyb21Ob2RlQW5kVG9rZW5zKG5vZGUsIHRva2Vucykge1xuICBsZXQgbGVhZGluZ0luZGV4O1xuXG4gIGNvbnN0IG5vZGVUZXJtaW5hbE5vZGUgPSBub2RlLmlzVGVybWluYWxOb2RlKCk7XG5cbiAgaWYgKG5vZGVUZXJtaW5hbE5vZGUpIHtcbiAgICBjb25zdCB0ZXJtaW5hbE5vZGUgPSBub2RlOyAgLy8vXG5cbiAgICBsZWFkaW5nSW5kZXggPSBsZWFkaW5nSW5kZXhGcm9tVGVybWluYWxOb2RlQW5kVG9rZW5zKHRlcm1pbmFsTm9kZSwgdG9rZW5zKTtcbiAgfSBlbHNlIHtcbiAgICBjb25zdCBub25UZXJtaW5hbE5vZGUgPSBub2RlOyAgLy8vXG5cbiAgICBsZWFkaW5nSW5kZXggPSBsZWFkaW5nSW5kZXhGcm9tTm9uVGVybWluYWxOb2RlQW5kVG9rZW5zKG5vblRlcm1pbmFsTm9kZSwgdG9rZW5zKTtcbiAgfVxuXG4gIHJldHVybiBsZWFkaW5nSW5kZXg7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0cmFpbGluZ0luZGV4RnJvbU5vZGVBbmRUb2tlbnMobm9kZSwgdG9rZW5zKSB7XG4gIGxldCB0cmFpbGluZ0luZGV4O1xuXG4gIGNvbnN0IG5vZGVUZXJtaW5hbE5vZGUgPSBub2RlLmlzVGVybWluYWxOb2RlKCk7XG5cbiAgaWYgKG5vZGVUZXJtaW5hbE5vZGUpIHtcbiAgICBjb25zdCB0ZXJtaW5hbE5vZGUgPSBub2RlOyAgLy8vXG5cbiAgICB0cmFpbGluZ0luZGV4ID0gdHJhaWxpbmdJbmRleEZyb21UZXJtaW5hbE5vZGVBbmRUb2tlbnModGVybWluYWxOb2RlLCB0b2tlbnMpO1xuICB9IGVsc2Uge1xuICAgIGNvbnN0IG5vblRlcm1pbmFsTm9kZSA9IG5vZGU7ICAvLy9cblxuICAgIHRyYWlsaW5nSW5kZXggPSB0cmFpbGluZ0luZGV4RnJvbU5vblRlcm1pbmFsTm9kZUFuZFRva2Vucyhub25UZXJtaW5hbE5vZGUsIHRva2Vucyk7XG4gIH1cblxuICByZXR1cm4gdHJhaWxpbmdJbmRleDtcbn1cblxuZXhwb3J0IGRlZmF1bHQge1xuICBsZWFkaW5nSW5kZXhGcm9tTm9kZUFuZFRva2VucyxcbiAgdHJhaWxpbmdJbmRleEZyb21Ob2RlQW5kVG9rZW5zXG59O1xuXG5mdW5jdGlvbiBsZWFkaW5nSW5kZXhGcm9tVGVybWluYWxOb2RlQW5kVG9rZW5zKHRlcm1pbmFsTm9kZSwgdG9rZW5zKSB7XG4gIGxldCBsZWFkaW5nSW5kZXg7XG5cbiAgY29uc3Qgc2lnbmlmaWNhbnRUb2tlbiA9IHRlcm1pbmFsTm9kZS5nZXRTaWduaWZpY2FudFRva2VuKCk7XG5cbiAgaWYgKHNpZ25pZmljYW50VG9rZW4gPT09IG51bGwpIHtcbiAgICBsZWFkaW5nSW5kZXggPSAtMTtcbiAgfSBlbHNlIHtcbiAgICBjb25zdCBzaWduaWZpY2FudFRva2VuSW5kZXggPSB0b2tlbnMuaW5kZXhPZihzaWduaWZpY2FudFRva2VuKTtcblxuICAgIGxlYWRpbmdJbmRleCA9IHNpZ25pZmljYW50VG9rZW5JbmRleDsgLy8vXG4gIH1cblxuICByZXR1cm4gbGVhZGluZ0luZGV4O1xufVxuXG5mdW5jdGlvbiB0cmFpbGluZ0luZGV4RnJvbVRlcm1pbmFsTm9kZUFuZFRva2Vucyh0ZXJtaW5hbE5vZGUsIHRva2Vucykge1xuICBsZXQgdHJhaWxpbmdJbmRleDtcblxuICBjb25zdCBzaWduaWZpY2FudFRva2VuID0gdGVybWluYWxOb2RlLmdldFNpZ25pZmljYW50VG9rZW4oKTtcblxuICBpZiAoc2lnbmlmaWNhbnRUb2tlbiA9PT0gbnVsbCkge1xuICAgIHRyYWlsaW5nSW5kZXggPSAtMTtcbiAgfSBlbHNlIHtcbiAgICBjb25zdCBzaWduaWZpY2FudFRva2VuSW5kZXggPSB0b2tlbnMuaW5kZXhPZihzaWduaWZpY2FudFRva2VuKTtcblxuICAgIHRyYWlsaW5nSW5kZXggPSBzaWduaWZpY2FudFRva2VuSW5kZXg7IC8vL1xuICB9XG5cbiAgcmV0dXJuIHRyYWlsaW5nSW5kZXg7XG59XG5cbmZ1bmN0aW9uIGxlYWRpbmdJbmRleEZyb21Ob25UZXJtaW5hbE5vZGVBbmRUb2tlbnMobm9uVGVybWluYWxOb2RlLCB0b2tlbnMpIHtcbiAgbGV0IGxlYWRpbmdJbmRleDtcblxuICBjb25zdCBjaGlsZE5vZGVzID0gbm9uVGVybWluYWxOb2RlLmdldENoaWxkTm9kZXMoKTtcblxuICBmb3J3YXJkc1NvbWUoY2hpbGROb2RlcywgKGNoaWxkTm9kZSkgPT4ge1xuICAgIGNvbnN0IG5vZGUgPSBjaGlsZE5vZGU7XG5cbiAgICBsZWFkaW5nSW5kZXggPSBsZWFkaW5nSW5kZXhGcm9tTm9kZUFuZFRva2Vucyhub2RlLCB0b2tlbnMpO1xuXG4gICAgaWYgKGxlYWRpbmdJbmRleCAhPT0gLTEpIHtcbiAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cbiAgfSk7XG5cbiAgcmV0dXJuIGxlYWRpbmdJbmRleDtcbn1cblxuZnVuY3Rpb24gdHJhaWxpbmdJbmRleEZyb21Ob25UZXJtaW5hbE5vZGVBbmRUb2tlbnMobm9uVGVybWluYWxOb2RlLCB0b2tlbnMpIHtcbiAgbGV0IHRyYWlsaW5nSW5kZXg7XG5cbiAgY29uc3QgY2hpbGROb2RlcyA9IG5vblRlcm1pbmFsTm9kZS5nZXRDaGlsZE5vZGVzKCk7XG5cbiAgYmFja3dhcmRzU29tZShjaGlsZE5vZGVzLCAoY2hpbGROb2RlKSA9PiB7XG4gICAgY29uc3Qgbm9kZSA9IGNoaWxkTm9kZTtcblxuICAgIHRyYWlsaW5nSW5kZXggPSB0cmFpbGluZ0luZGV4RnJvbU5vZGVBbmRUb2tlbnMobm9kZSwgdG9rZW5zKTtcblxuICAgIGlmICh0cmFpbGluZ0luZGV4ICE9PSAtMSkge1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuICB9KTtcblxuICByZXR1cm4gdHJhaWxpbmdJbmRleDtcbn1cbiJdLCJuYW1lcyI6WyJsZWFkaW5nSW5kZXhGcm9tTm9kZUFuZFRva2VucyIsInRyYWlsaW5nSW5kZXhGcm9tTm9kZUFuZFRva2VucyIsImZvcndhcmRzU29tZSIsImFycmF5VXRpbGl0aWVzIiwiYmFja3dhcmRzU29tZSIsIm5vZGUiLCJ0b2tlbnMiLCJsZWFkaW5nSW5kZXgiLCJub2RlVGVybWluYWxOb2RlIiwiaXNUZXJtaW5hbE5vZGUiLCJ0ZXJtaW5hbE5vZGUiLCJsZWFkaW5nSW5kZXhGcm9tVGVybWluYWxOb2RlQW5kVG9rZW5zIiwibm9uVGVybWluYWxOb2RlIiwibGVhZGluZ0luZGV4RnJvbU5vblRlcm1pbmFsTm9kZUFuZFRva2VucyIsInRyYWlsaW5nSW5kZXgiLCJ0cmFpbGluZ0luZGV4RnJvbVRlcm1pbmFsTm9kZUFuZFRva2VucyIsInRyYWlsaW5nSW5kZXhGcm9tTm9uVGVybWluYWxOb2RlQW5kVG9rZW5zIiwic2lnbmlmaWNhbnRUb2tlbiIsImdldFNpZ25pZmljYW50VG9rZW4iLCJzaWduaWZpY2FudFRva2VuSW5kZXgiLCJpbmRleE9mIiwiY2hpbGROb2RlcyIsImdldENoaWxkTm9kZXMiLCJjaGlsZE5vZGUiXSwicmFuZ2VNYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OyIsIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7SUEwQ0EsT0FHRTtlQUhGOztJQXBDZ0JBLDZCQUE2QjtlQUE3QkE7O0lBa0JBQyw4QkFBOEI7ZUFBOUJBOzs7eUJBdEJlO0FBRS9CLElBQVFDLGVBQWdDQyx5QkFBYyxDQUE5Q0QsY0FBY0UsZ0JBQWtCRCx5QkFBYyxDQUFoQ0M7QUFFZixTQUFTSiw4QkFBOEJLLElBQUksRUFBRUMsTUFBTTtJQUN4RCxJQUFJQztJQUVKLElBQU1DLG1CQUFtQkgsS0FBS0ksY0FBYztJQUU1QyxJQUFJRCxrQkFBa0I7UUFDcEIsSUFBTUUsZUFBZUwsTUFBTyxHQUFHO1FBRS9CRSxlQUFlSSxzQ0FBc0NELGNBQWNKO0lBQ3JFLE9BQU87UUFDTCxJQUFNTSxrQkFBa0JQLE1BQU8sR0FBRztRQUVsQ0UsZUFBZU0seUNBQXlDRCxpQkFBaUJOO0lBQzNFO0lBRUEsT0FBT0M7QUFDVDtBQUVPLFNBQVNOLCtCQUErQkksSUFBSSxFQUFFQyxNQUFNO0lBQ3pELElBQUlRO0lBRUosSUFBTU4sbUJBQW1CSCxLQUFLSSxjQUFjO0lBRTVDLElBQUlELGtCQUFrQjtRQUNwQixJQUFNRSxlQUFlTCxNQUFPLEdBQUc7UUFFL0JTLGdCQUFnQkMsdUNBQXVDTCxjQUFjSjtJQUN2RSxPQUFPO1FBQ0wsSUFBTU0sa0JBQWtCUCxNQUFPLEdBQUc7UUFFbENTLGdCQUFnQkUsMENBQTBDSixpQkFBaUJOO0lBQzdFO0lBRUEsT0FBT1E7QUFDVDtJQUVBLFdBQWU7SUFDYmQsK0JBQUFBO0lBQ0FDLGdDQUFBQTtBQUNGO0FBRUEsU0FBU1Usc0NBQXNDRCxZQUFZLEVBQUVKLE1BQU07SUFDakUsSUFBSUM7SUFFSixJQUFNVSxtQkFBbUJQLGFBQWFRLG1CQUFtQjtJQUV6RCxJQUFJRCxxQkFBcUIsTUFBTTtRQUM3QlYsZUFBZSxDQUFDO0lBQ2xCLE9BQU87UUFDTCxJQUFNWSx3QkFBd0JiLE9BQU9jLE9BQU8sQ0FBQ0g7UUFFN0NWLGVBQWVZLHVCQUF1QixHQUFHO0lBQzNDO0lBRUEsT0FBT1o7QUFDVDtBQUVBLFNBQVNRLHVDQUF1Q0wsWUFBWSxFQUFFSixNQUFNO0lBQ2xFLElBQUlRO0lBRUosSUFBTUcsbUJBQW1CUCxhQUFhUSxtQkFBbUI7SUFFekQsSUFBSUQscUJBQXFCLE1BQU07UUFDN0JILGdCQUFnQixDQUFDO0lBQ25CLE9BQU87UUFDTCxJQUFNSyx3QkFBd0JiLE9BQU9jLE9BQU8sQ0FBQ0g7UUFFN0NILGdCQUFnQkssdUJBQXVCLEdBQUc7SUFDNUM7SUFFQSxPQUFPTDtBQUNUO0FBRUEsU0FBU0QseUNBQXlDRCxlQUFlLEVBQUVOLE1BQU07SUFDdkUsSUFBSUM7SUFFSixJQUFNYyxhQUFhVCxnQkFBZ0JVLGFBQWE7SUFFaERwQixhQUFhbUIsWUFBWSxTQUFDRTtRQUN4QixJQUFNbEIsT0FBT2tCO1FBRWJoQixlQUFlUCw4QkFBOEJLLE1BQU1DO1FBRW5ELElBQUlDLGlCQUFpQixDQUFDLEdBQUc7WUFDdkIsT0FBTztRQUNUO0lBQ0Y7SUFFQSxPQUFPQTtBQUNUO0FBRUEsU0FBU1MsMENBQTBDSixlQUFlLEVBQUVOLE1BQU07SUFDeEUsSUFBSVE7SUFFSixJQUFNTyxhQUFhVCxnQkFBZ0JVLGFBQWE7SUFFaERsQixjQUFjaUIsWUFBWSxTQUFDRTtRQUN6QixJQUFNbEIsT0FBT2tCO1FBRWJULGdCQUFnQmIsK0JBQStCSSxNQUFNQztRQUVyRCxJQUFJUSxrQkFBa0IsQ0FBQyxHQUFHO1lBQ3hCLE9BQU87UUFDVDtJQUNGO0lBRUEsT0FBT0E7QUFDVCJ9
|
package/src/utilities/node.js
DELETED
|
@@ -1,114 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
import { arrayUtilities } from "necessary";
|
|
4
|
-
|
|
5
|
-
const { forwardsSome, backwardsSome } = arrayUtilities;
|
|
6
|
-
|
|
7
|
-
export function leadingIndexFromNodeAndTokens(node, tokens) {
|
|
8
|
-
let leadingIndex;
|
|
9
|
-
|
|
10
|
-
const nodeTerminalNode = node.isTerminalNode();
|
|
11
|
-
|
|
12
|
-
if (nodeTerminalNode) {
|
|
13
|
-
const terminalNode = node; ///
|
|
14
|
-
|
|
15
|
-
leadingIndex = leadingIndexFromTerminalNodeAndTokens(terminalNode, tokens);
|
|
16
|
-
} else {
|
|
17
|
-
const nonTerminalNode = node; ///
|
|
18
|
-
|
|
19
|
-
leadingIndex = leadingIndexFromNonTerminalNodeAndTokens(nonTerminalNode, tokens);
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
return leadingIndex;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
export function trailingIndexFromNodeAndTokens(node, tokens) {
|
|
26
|
-
let trailingIndex;
|
|
27
|
-
|
|
28
|
-
const nodeTerminalNode = node.isTerminalNode();
|
|
29
|
-
|
|
30
|
-
if (nodeTerminalNode) {
|
|
31
|
-
const terminalNode = node; ///
|
|
32
|
-
|
|
33
|
-
trailingIndex = trailingIndexFromTerminalNodeAndTokens(terminalNode, tokens);
|
|
34
|
-
} else {
|
|
35
|
-
const nonTerminalNode = node; ///
|
|
36
|
-
|
|
37
|
-
trailingIndex = trailingIndexFromNonTerminalNodeAndTokens(nonTerminalNode, tokens);
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
return trailingIndex;
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
export default {
|
|
44
|
-
leadingIndexFromNodeAndTokens,
|
|
45
|
-
trailingIndexFromNodeAndTokens
|
|
46
|
-
};
|
|
47
|
-
|
|
48
|
-
function leadingIndexFromTerminalNodeAndTokens(terminalNode, tokens) {
|
|
49
|
-
let leadingIndex;
|
|
50
|
-
|
|
51
|
-
const significantToken = terminalNode.getSignificantToken();
|
|
52
|
-
|
|
53
|
-
if (significantToken === null) {
|
|
54
|
-
leadingIndex = -1;
|
|
55
|
-
} else {
|
|
56
|
-
const significantTokenIndex = tokens.indexOf(significantToken);
|
|
57
|
-
|
|
58
|
-
leadingIndex = significantTokenIndex; ///
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
return leadingIndex;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
function trailingIndexFromTerminalNodeAndTokens(terminalNode, tokens) {
|
|
65
|
-
let trailingIndex;
|
|
66
|
-
|
|
67
|
-
const significantToken = terminalNode.getSignificantToken();
|
|
68
|
-
|
|
69
|
-
if (significantToken === null) {
|
|
70
|
-
trailingIndex = -1;
|
|
71
|
-
} else {
|
|
72
|
-
const significantTokenIndex = tokens.indexOf(significantToken);
|
|
73
|
-
|
|
74
|
-
trailingIndex = significantTokenIndex; ///
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
return trailingIndex;
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
function leadingIndexFromNonTerminalNodeAndTokens(nonTerminalNode, tokens) {
|
|
81
|
-
let leadingIndex;
|
|
82
|
-
|
|
83
|
-
const childNodes = nonTerminalNode.getChildNodes();
|
|
84
|
-
|
|
85
|
-
forwardsSome(childNodes, (childNode) => {
|
|
86
|
-
const node = childNode;
|
|
87
|
-
|
|
88
|
-
leadingIndex = leadingIndexFromNodeAndTokens(node, tokens);
|
|
89
|
-
|
|
90
|
-
if (leadingIndex !== -1) {
|
|
91
|
-
return true;
|
|
92
|
-
}
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
return leadingIndex;
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
function trailingIndexFromNonTerminalNodeAndTokens(nonTerminalNode, tokens) {
|
|
99
|
-
let trailingIndex;
|
|
100
|
-
|
|
101
|
-
const childNodes = nonTerminalNode.getChildNodes();
|
|
102
|
-
|
|
103
|
-
backwardsSome(childNodes, (childNode) => {
|
|
104
|
-
const node = childNode;
|
|
105
|
-
|
|
106
|
-
trailingIndex = trailingIndexFromNodeAndTokens(node, tokens);
|
|
107
|
-
|
|
108
|
-
if (trailingIndex !== -1) {
|
|
109
|
-
return true;
|
|
110
|
-
}
|
|
111
|
-
});
|
|
112
|
-
|
|
113
|
-
return trailingIndex;
|
|
114
|
-
}
|