@waline/client 1.3.11 → 1.5.2
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/dist/Waline.min.d.ts +26 -8
- package/dist/Waline.min.js +1 -1
- package/dist/Waline.min.js.map +1 -1
- package/dist/Waline.noStyle.d.ts +26 -8
- package/dist/Waline.noStyle.js +1 -1
- package/dist/Waline.noStyle.js.map +1 -1
- package/dist/index.html +2 -1
- package/package.json +6 -6
- package/dist/Waline.commonjs.min.js +0 -13676
- package/dist/Waline.commonjs.min.js.LICENSE.txt +0 -5
- package/dist/Waline.commonjs.min.js.map +0 -1
- package/dist/Waline.min.js.LICENSE.txt +0 -5
- package/dist/Waline.noStyle.js.LICENSE.txt +0 -5
- package/dist/markdown.commonjs.min.js +0 -2870
- package/dist/markdown.commonjs.min.js.map +0 -1
- package/dist/markdown.min.js +0 -2870
- package/dist/markdown.min.js.map +0 -1
- package/dist/markdown.noStyle.js +0 -2870
- package/dist/markdown.noStyle.js.map +0 -1
- package/test/dist/main.js +0 -0
- package/test/dist/main.js.LICENSE.txt +0 -355
- package/test/node_modules/.package-lock.json +0 -36
- package/test/node_modules/comment-regex/index.js +0 -13
- package/test/node_modules/comment-regex/license +0 -21
- package/test/node_modules/comment-regex/package.json +0 -41
- package/test/node_modules/comment-regex/readme.md +0 -52
- package/test/node_modules/hanabi/LICENSE +0 -21
- package/test/node_modules/hanabi/README.md +0 -43
- package/test/node_modules/hanabi/dist/hanabi.js +0 -68
- package/test/node_modules/hanabi/dist/hanabi.min.js +0 -2
- package/test/node_modules/hanabi/dist/hanabi.min.js.map +0 -1
- package/test/node_modules/hanabi/package.json +0 -57
- package/test/node_modules/marked/LICENSE.md +0 -44
- package/test/node_modules/marked/README.md +0 -74
- package/test/node_modules/marked/bin/marked +0 -215
- package/test/node_modules/marked/lib/marked.esm.js +0 -2637
- package/test/node_modules/marked/lib/marked.js +0 -2787
- package/test/node_modules/marked/man/marked.1 +0 -111
- package/test/node_modules/marked/man/marked.1.txt +0 -96
- package/test/node_modules/marked/marked.min.js +0 -6
- package/test/node_modules/marked/package.json +0 -88
- package/test/node_modules/marked/src/Lexer.js +0 -491
- package/test/node_modules/marked/src/Parser.js +0 -263
- package/test/node_modules/marked/src/Renderer.js +0 -166
- package/test/node_modules/marked/src/Slugger.js +0 -49
- package/test/node_modules/marked/src/TextRenderer.js +0 -42
- package/test/node_modules/marked/src/Tokenizer.js +0 -730
- package/test/node_modules/marked/src/defaults.js +0 -32
- package/test/node_modules/marked/src/helpers.js +0 -260
- package/test/node_modules/marked/src/marked.js +0 -270
- package/test/node_modules/marked/src/rules.js +0 -310
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
function getDefaults() {
|
|
2
|
-
return {
|
|
3
|
-
baseUrl: null,
|
|
4
|
-
breaks: false,
|
|
5
|
-
gfm: true,
|
|
6
|
-
headerIds: true,
|
|
7
|
-
headerPrefix: '',
|
|
8
|
-
highlight: null,
|
|
9
|
-
langPrefix: 'language-',
|
|
10
|
-
mangle: true,
|
|
11
|
-
pedantic: false,
|
|
12
|
-
renderer: null,
|
|
13
|
-
sanitize: false,
|
|
14
|
-
sanitizer: null,
|
|
15
|
-
silent: false,
|
|
16
|
-
smartLists: false,
|
|
17
|
-
smartypants: false,
|
|
18
|
-
tokenizer: null,
|
|
19
|
-
walkTokens: null,
|
|
20
|
-
xhtml: false
|
|
21
|
-
};
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
function changeDefaults(newDefaults) {
|
|
25
|
-
module.exports.defaults = newDefaults;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
module.exports = {
|
|
29
|
-
defaults: getDefaults(),
|
|
30
|
-
getDefaults,
|
|
31
|
-
changeDefaults
|
|
32
|
-
};
|
|
@@ -1,260 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Helpers
|
|
3
|
-
*/
|
|
4
|
-
const escapeTest = /[&<>"']/;
|
|
5
|
-
const escapeReplace = /[&<>"']/g;
|
|
6
|
-
const escapeTestNoEncode = /[<>"']|&(?!#?\w+;)/;
|
|
7
|
-
const escapeReplaceNoEncode = /[<>"']|&(?!#?\w+;)/g;
|
|
8
|
-
const escapeReplacements = {
|
|
9
|
-
'&': '&',
|
|
10
|
-
'<': '<',
|
|
11
|
-
'>': '>',
|
|
12
|
-
'"': '"',
|
|
13
|
-
"'": '''
|
|
14
|
-
};
|
|
15
|
-
const getEscapeReplacement = (ch) => escapeReplacements[ch];
|
|
16
|
-
function escape(html, encode) {
|
|
17
|
-
if (encode) {
|
|
18
|
-
if (escapeTest.test(html)) {
|
|
19
|
-
return html.replace(escapeReplace, getEscapeReplacement);
|
|
20
|
-
}
|
|
21
|
-
} else {
|
|
22
|
-
if (escapeTestNoEncode.test(html)) {
|
|
23
|
-
return html.replace(escapeReplaceNoEncode, getEscapeReplacement);
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
return html;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
const unescapeTest = /&(#(?:\d+)|(?:#x[0-9A-Fa-f]+)|(?:\w+));?/ig;
|
|
31
|
-
|
|
32
|
-
function unescape(html) {
|
|
33
|
-
// explicitly match decimal, hex, and named HTML entities
|
|
34
|
-
return html.replace(unescapeTest, (_, n) => {
|
|
35
|
-
n = n.toLowerCase();
|
|
36
|
-
if (n === 'colon') return ':';
|
|
37
|
-
if (n.charAt(0) === '#') {
|
|
38
|
-
return n.charAt(1) === 'x'
|
|
39
|
-
? String.fromCharCode(parseInt(n.substring(2), 16))
|
|
40
|
-
: String.fromCharCode(+n.substring(1));
|
|
41
|
-
}
|
|
42
|
-
return '';
|
|
43
|
-
});
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
const caret = /(^|[^\[])\^/g;
|
|
47
|
-
function edit(regex, opt) {
|
|
48
|
-
regex = regex.source || regex;
|
|
49
|
-
opt = opt || '';
|
|
50
|
-
const obj = {
|
|
51
|
-
replace: (name, val) => {
|
|
52
|
-
val = val.source || val;
|
|
53
|
-
val = val.replace(caret, '$1');
|
|
54
|
-
regex = regex.replace(name, val);
|
|
55
|
-
return obj;
|
|
56
|
-
},
|
|
57
|
-
getRegex: () => {
|
|
58
|
-
return new RegExp(regex, opt);
|
|
59
|
-
}
|
|
60
|
-
};
|
|
61
|
-
return obj;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
const nonWordAndColonTest = /[^\w:]/g;
|
|
65
|
-
const originIndependentUrl = /^$|^[a-z][a-z0-9+.-]*:|^[?#]/i;
|
|
66
|
-
function cleanUrl(sanitize, base, href) {
|
|
67
|
-
if (sanitize) {
|
|
68
|
-
let prot;
|
|
69
|
-
try {
|
|
70
|
-
prot = decodeURIComponent(unescape(href))
|
|
71
|
-
.replace(nonWordAndColonTest, '')
|
|
72
|
-
.toLowerCase();
|
|
73
|
-
} catch (e) {
|
|
74
|
-
return null;
|
|
75
|
-
}
|
|
76
|
-
if (prot.indexOf('javascript:') === 0 || prot.indexOf('vbscript:') === 0 || prot.indexOf('data:') === 0) {
|
|
77
|
-
return null;
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
if (base && !originIndependentUrl.test(href)) {
|
|
81
|
-
href = resolveUrl(base, href);
|
|
82
|
-
}
|
|
83
|
-
try {
|
|
84
|
-
href = encodeURI(href).replace(/%25/g, '%');
|
|
85
|
-
} catch (e) {
|
|
86
|
-
return null;
|
|
87
|
-
}
|
|
88
|
-
return href;
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
const baseUrls = {};
|
|
92
|
-
const justDomain = /^[^:]+:\/*[^/]*$/;
|
|
93
|
-
const protocol = /^([^:]+:)[\s\S]*$/;
|
|
94
|
-
const domain = /^([^:]+:\/*[^/]*)[\s\S]*$/;
|
|
95
|
-
|
|
96
|
-
function resolveUrl(base, href) {
|
|
97
|
-
if (!baseUrls[' ' + base]) {
|
|
98
|
-
// we can ignore everything in base after the last slash of its path component,
|
|
99
|
-
// but we might need to add _that_
|
|
100
|
-
// https://tools.ietf.org/html/rfc3986#section-3
|
|
101
|
-
if (justDomain.test(base)) {
|
|
102
|
-
baseUrls[' ' + base] = base + '/';
|
|
103
|
-
} else {
|
|
104
|
-
baseUrls[' ' + base] = rtrim(base, '/', true);
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
base = baseUrls[' ' + base];
|
|
108
|
-
const relativeBase = base.indexOf(':') === -1;
|
|
109
|
-
|
|
110
|
-
if (href.substring(0, 2) === '//') {
|
|
111
|
-
if (relativeBase) {
|
|
112
|
-
return href;
|
|
113
|
-
}
|
|
114
|
-
return base.replace(protocol, '$1') + href;
|
|
115
|
-
} else if (href.charAt(0) === '/') {
|
|
116
|
-
if (relativeBase) {
|
|
117
|
-
return href;
|
|
118
|
-
}
|
|
119
|
-
return base.replace(domain, '$1') + href;
|
|
120
|
-
} else {
|
|
121
|
-
return base + href;
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
const noopTest = { exec: function noopTest() {} };
|
|
126
|
-
|
|
127
|
-
function merge(obj) {
|
|
128
|
-
let i = 1,
|
|
129
|
-
target,
|
|
130
|
-
key;
|
|
131
|
-
|
|
132
|
-
for (; i < arguments.length; i++) {
|
|
133
|
-
target = arguments[i];
|
|
134
|
-
for (key in target) {
|
|
135
|
-
if (Object.prototype.hasOwnProperty.call(target, key)) {
|
|
136
|
-
obj[key] = target[key];
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
return obj;
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
function splitCells(tableRow, count) {
|
|
145
|
-
// ensure that every cell-delimiting pipe has a space
|
|
146
|
-
// before it to distinguish it from an escaped pipe
|
|
147
|
-
const row = tableRow.replace(/\|/g, (match, offset, str) => {
|
|
148
|
-
let escaped = false,
|
|
149
|
-
curr = offset;
|
|
150
|
-
while (--curr >= 0 && str[curr] === '\\') escaped = !escaped;
|
|
151
|
-
if (escaped) {
|
|
152
|
-
// odd number of slashes means | is escaped
|
|
153
|
-
// so we leave it alone
|
|
154
|
-
return '|';
|
|
155
|
-
} else {
|
|
156
|
-
// add space before unescaped |
|
|
157
|
-
return ' |';
|
|
158
|
-
}
|
|
159
|
-
}),
|
|
160
|
-
cells = row.split(/ \|/);
|
|
161
|
-
let i = 0;
|
|
162
|
-
|
|
163
|
-
if (cells.length > count) {
|
|
164
|
-
cells.splice(count);
|
|
165
|
-
} else {
|
|
166
|
-
while (cells.length < count) cells.push('');
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
for (; i < cells.length; i++) {
|
|
170
|
-
// leading or trailing whitespace is ignored per the gfm spec
|
|
171
|
-
cells[i] = cells[i].trim().replace(/\\\|/g, '|');
|
|
172
|
-
}
|
|
173
|
-
return cells;
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
// Remove trailing 'c's. Equivalent to str.replace(/c*$/, '').
|
|
177
|
-
// /c*$/ is vulnerable to REDOS.
|
|
178
|
-
// invert: Remove suffix of non-c chars instead. Default falsey.
|
|
179
|
-
function rtrim(str, c, invert) {
|
|
180
|
-
const l = str.length;
|
|
181
|
-
if (l === 0) {
|
|
182
|
-
return '';
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
// Length of suffix matching the invert condition.
|
|
186
|
-
let suffLen = 0;
|
|
187
|
-
|
|
188
|
-
// Step left until we fail to match the invert condition.
|
|
189
|
-
while (suffLen < l) {
|
|
190
|
-
const currChar = str.charAt(l - suffLen - 1);
|
|
191
|
-
if (currChar === c && !invert) {
|
|
192
|
-
suffLen++;
|
|
193
|
-
} else if (currChar !== c && invert) {
|
|
194
|
-
suffLen++;
|
|
195
|
-
} else {
|
|
196
|
-
break;
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
return str.substr(0, l - suffLen);
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
function findClosingBracket(str, b) {
|
|
204
|
-
if (str.indexOf(b[1]) === -1) {
|
|
205
|
-
return -1;
|
|
206
|
-
}
|
|
207
|
-
const l = str.length;
|
|
208
|
-
let level = 0,
|
|
209
|
-
i = 0;
|
|
210
|
-
for (; i < l; i++) {
|
|
211
|
-
if (str[i] === '\\') {
|
|
212
|
-
i++;
|
|
213
|
-
} else if (str[i] === b[0]) {
|
|
214
|
-
level++;
|
|
215
|
-
} else if (str[i] === b[1]) {
|
|
216
|
-
level--;
|
|
217
|
-
if (level < 0) {
|
|
218
|
-
return i;
|
|
219
|
-
}
|
|
220
|
-
}
|
|
221
|
-
}
|
|
222
|
-
return -1;
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
function checkSanitizeDeprecation(opt) {
|
|
226
|
-
if (opt && opt.sanitize && !opt.silent) {
|
|
227
|
-
console.warn('marked(): sanitize and sanitizer parameters are deprecated since version 0.7.0, should not be used and will be removed in the future. Read more here: https://marked.js.org/#/USING_ADVANCED.md#options');
|
|
228
|
-
}
|
|
229
|
-
}
|
|
230
|
-
|
|
231
|
-
// copied from https://stackoverflow.com/a/5450113/806777
|
|
232
|
-
function repeatString(pattern, count) {
|
|
233
|
-
if (count < 1) {
|
|
234
|
-
return '';
|
|
235
|
-
}
|
|
236
|
-
let result = '';
|
|
237
|
-
while (count > 1) {
|
|
238
|
-
if (count & 1) {
|
|
239
|
-
result += pattern;
|
|
240
|
-
}
|
|
241
|
-
count >>= 1;
|
|
242
|
-
pattern += pattern;
|
|
243
|
-
}
|
|
244
|
-
return result + pattern;
|
|
245
|
-
}
|
|
246
|
-
|
|
247
|
-
module.exports = {
|
|
248
|
-
escape,
|
|
249
|
-
unescape,
|
|
250
|
-
edit,
|
|
251
|
-
cleanUrl,
|
|
252
|
-
resolveUrl,
|
|
253
|
-
noopTest,
|
|
254
|
-
merge,
|
|
255
|
-
splitCells,
|
|
256
|
-
rtrim,
|
|
257
|
-
findClosingBracket,
|
|
258
|
-
checkSanitizeDeprecation,
|
|
259
|
-
repeatString
|
|
260
|
-
};
|
|
@@ -1,270 +0,0 @@
|
|
|
1
|
-
const Lexer = require('./Lexer.js');
|
|
2
|
-
const Parser = require('./Parser.js');
|
|
3
|
-
const Tokenizer = require('./Tokenizer.js');
|
|
4
|
-
const Renderer = require('./Renderer.js');
|
|
5
|
-
const TextRenderer = require('./TextRenderer.js');
|
|
6
|
-
const Slugger = require('./Slugger.js');
|
|
7
|
-
const {
|
|
8
|
-
merge,
|
|
9
|
-
checkSanitizeDeprecation,
|
|
10
|
-
escape
|
|
11
|
-
} = require('./helpers.js');
|
|
12
|
-
const {
|
|
13
|
-
getDefaults,
|
|
14
|
-
changeDefaults,
|
|
15
|
-
defaults
|
|
16
|
-
} = require('./defaults.js');
|
|
17
|
-
|
|
18
|
-
/**
|
|
19
|
-
* Marked
|
|
20
|
-
*/
|
|
21
|
-
function marked(src, opt, callback) {
|
|
22
|
-
// throw error in case of non string input
|
|
23
|
-
if (typeof src === 'undefined' || src === null) {
|
|
24
|
-
throw new Error('marked(): input parameter is undefined or null');
|
|
25
|
-
}
|
|
26
|
-
if (typeof src !== 'string') {
|
|
27
|
-
throw new Error('marked(): input parameter is of type '
|
|
28
|
-
+ Object.prototype.toString.call(src) + ', string expected');
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
if (typeof opt === 'function') {
|
|
32
|
-
callback = opt;
|
|
33
|
-
opt = null;
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
opt = merge({}, marked.defaults, opt || {});
|
|
37
|
-
checkSanitizeDeprecation(opt);
|
|
38
|
-
|
|
39
|
-
if (callback) {
|
|
40
|
-
const highlight = opt.highlight;
|
|
41
|
-
let tokens;
|
|
42
|
-
|
|
43
|
-
try {
|
|
44
|
-
tokens = Lexer.lex(src, opt);
|
|
45
|
-
} catch (e) {
|
|
46
|
-
return callback(e);
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
const done = function(err) {
|
|
50
|
-
let out;
|
|
51
|
-
|
|
52
|
-
if (!err) {
|
|
53
|
-
try {
|
|
54
|
-
if (opt.walkTokens) {
|
|
55
|
-
marked.walkTokens(tokens, opt.walkTokens);
|
|
56
|
-
}
|
|
57
|
-
out = Parser.parse(tokens, opt);
|
|
58
|
-
} catch (e) {
|
|
59
|
-
err = e;
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
opt.highlight = highlight;
|
|
64
|
-
|
|
65
|
-
return err
|
|
66
|
-
? callback(err)
|
|
67
|
-
: callback(null, out);
|
|
68
|
-
};
|
|
69
|
-
|
|
70
|
-
if (!highlight || highlight.length < 3) {
|
|
71
|
-
return done();
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
delete opt.highlight;
|
|
75
|
-
|
|
76
|
-
if (!tokens.length) return done();
|
|
77
|
-
|
|
78
|
-
let pending = 0;
|
|
79
|
-
marked.walkTokens(tokens, function(token) {
|
|
80
|
-
if (token.type === 'code') {
|
|
81
|
-
pending++;
|
|
82
|
-
setTimeout(() => {
|
|
83
|
-
highlight(token.text, token.lang, function(err, code) {
|
|
84
|
-
if (err) {
|
|
85
|
-
return done(err);
|
|
86
|
-
}
|
|
87
|
-
if (code != null && code !== token.text) {
|
|
88
|
-
token.text = code;
|
|
89
|
-
token.escaped = true;
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
pending--;
|
|
93
|
-
if (pending === 0) {
|
|
94
|
-
done();
|
|
95
|
-
}
|
|
96
|
-
});
|
|
97
|
-
}, 0);
|
|
98
|
-
}
|
|
99
|
-
});
|
|
100
|
-
|
|
101
|
-
if (pending === 0) {
|
|
102
|
-
done();
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
return;
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
try {
|
|
109
|
-
const tokens = Lexer.lex(src, opt);
|
|
110
|
-
if (opt.walkTokens) {
|
|
111
|
-
marked.walkTokens(tokens, opt.walkTokens);
|
|
112
|
-
}
|
|
113
|
-
return Parser.parse(tokens, opt);
|
|
114
|
-
} catch (e) {
|
|
115
|
-
e.message += '\nPlease report this to https://github.com/markedjs/marked.';
|
|
116
|
-
if (opt.silent) {
|
|
117
|
-
return '<p>An error occurred:</p><pre>'
|
|
118
|
-
+ escape(e.message + '', true)
|
|
119
|
-
+ '</pre>';
|
|
120
|
-
}
|
|
121
|
-
throw e;
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
/**
|
|
126
|
-
* Options
|
|
127
|
-
*/
|
|
128
|
-
|
|
129
|
-
marked.options =
|
|
130
|
-
marked.setOptions = function(opt) {
|
|
131
|
-
merge(marked.defaults, opt);
|
|
132
|
-
changeDefaults(marked.defaults);
|
|
133
|
-
return marked;
|
|
134
|
-
};
|
|
135
|
-
|
|
136
|
-
marked.getDefaults = getDefaults;
|
|
137
|
-
|
|
138
|
-
marked.defaults = defaults;
|
|
139
|
-
|
|
140
|
-
/**
|
|
141
|
-
* Use Extension
|
|
142
|
-
*/
|
|
143
|
-
|
|
144
|
-
marked.use = function(extension) {
|
|
145
|
-
const opts = merge({}, extension);
|
|
146
|
-
if (extension.renderer) {
|
|
147
|
-
const renderer = marked.defaults.renderer || new Renderer();
|
|
148
|
-
for (const prop in extension.renderer) {
|
|
149
|
-
const prevRenderer = renderer[prop];
|
|
150
|
-
renderer[prop] = (...args) => {
|
|
151
|
-
let ret = extension.renderer[prop].apply(renderer, args);
|
|
152
|
-
if (ret === false) {
|
|
153
|
-
ret = prevRenderer.apply(renderer, args);
|
|
154
|
-
}
|
|
155
|
-
return ret;
|
|
156
|
-
};
|
|
157
|
-
}
|
|
158
|
-
opts.renderer = renderer;
|
|
159
|
-
}
|
|
160
|
-
if (extension.tokenizer) {
|
|
161
|
-
const tokenizer = marked.defaults.tokenizer || new Tokenizer();
|
|
162
|
-
for (const prop in extension.tokenizer) {
|
|
163
|
-
const prevTokenizer = tokenizer[prop];
|
|
164
|
-
tokenizer[prop] = (...args) => {
|
|
165
|
-
let ret = extension.tokenizer[prop].apply(tokenizer, args);
|
|
166
|
-
if (ret === false) {
|
|
167
|
-
ret = prevTokenizer.apply(tokenizer, args);
|
|
168
|
-
}
|
|
169
|
-
return ret;
|
|
170
|
-
};
|
|
171
|
-
}
|
|
172
|
-
opts.tokenizer = tokenizer;
|
|
173
|
-
}
|
|
174
|
-
if (extension.walkTokens) {
|
|
175
|
-
const walkTokens = marked.defaults.walkTokens;
|
|
176
|
-
opts.walkTokens = (token) => {
|
|
177
|
-
extension.walkTokens(token);
|
|
178
|
-
if (walkTokens) {
|
|
179
|
-
walkTokens(token);
|
|
180
|
-
}
|
|
181
|
-
};
|
|
182
|
-
}
|
|
183
|
-
marked.setOptions(opts);
|
|
184
|
-
};
|
|
185
|
-
|
|
186
|
-
/**
|
|
187
|
-
* Run callback for every token
|
|
188
|
-
*/
|
|
189
|
-
|
|
190
|
-
marked.walkTokens = function(tokens, callback) {
|
|
191
|
-
for (const token of tokens) {
|
|
192
|
-
callback(token);
|
|
193
|
-
switch (token.type) {
|
|
194
|
-
case 'table': {
|
|
195
|
-
for (const cell of token.tokens.header) {
|
|
196
|
-
marked.walkTokens(cell, callback);
|
|
197
|
-
}
|
|
198
|
-
for (const row of token.tokens.cells) {
|
|
199
|
-
for (const cell of row) {
|
|
200
|
-
marked.walkTokens(cell, callback);
|
|
201
|
-
}
|
|
202
|
-
}
|
|
203
|
-
break;
|
|
204
|
-
}
|
|
205
|
-
case 'list': {
|
|
206
|
-
marked.walkTokens(token.items, callback);
|
|
207
|
-
break;
|
|
208
|
-
}
|
|
209
|
-
default: {
|
|
210
|
-
if (token.tokens) {
|
|
211
|
-
marked.walkTokens(token.tokens, callback);
|
|
212
|
-
}
|
|
213
|
-
}
|
|
214
|
-
}
|
|
215
|
-
}
|
|
216
|
-
};
|
|
217
|
-
|
|
218
|
-
/**
|
|
219
|
-
* Parse Inline
|
|
220
|
-
*/
|
|
221
|
-
marked.parseInline = function(src, opt) {
|
|
222
|
-
// throw error in case of non string input
|
|
223
|
-
if (typeof src === 'undefined' || src === null) {
|
|
224
|
-
throw new Error('marked.parseInline(): input parameter is undefined or null');
|
|
225
|
-
}
|
|
226
|
-
if (typeof src !== 'string') {
|
|
227
|
-
throw new Error('marked.parseInline(): input parameter is of type '
|
|
228
|
-
+ Object.prototype.toString.call(src) + ', string expected');
|
|
229
|
-
}
|
|
230
|
-
|
|
231
|
-
opt = merge({}, marked.defaults, opt || {});
|
|
232
|
-
checkSanitizeDeprecation(opt);
|
|
233
|
-
|
|
234
|
-
try {
|
|
235
|
-
const tokens = Lexer.lexInline(src, opt);
|
|
236
|
-
if (opt.walkTokens) {
|
|
237
|
-
marked.walkTokens(tokens, opt.walkTokens);
|
|
238
|
-
}
|
|
239
|
-
return Parser.parseInline(tokens, opt);
|
|
240
|
-
} catch (e) {
|
|
241
|
-
e.message += '\nPlease report this to https://github.com/markedjs/marked.';
|
|
242
|
-
if (opt.silent) {
|
|
243
|
-
return '<p>An error occurred:</p><pre>'
|
|
244
|
-
+ escape(e.message + '', true)
|
|
245
|
-
+ '</pre>';
|
|
246
|
-
}
|
|
247
|
-
throw e;
|
|
248
|
-
}
|
|
249
|
-
};
|
|
250
|
-
|
|
251
|
-
/**
|
|
252
|
-
* Expose
|
|
253
|
-
*/
|
|
254
|
-
|
|
255
|
-
marked.Parser = Parser;
|
|
256
|
-
marked.parser = Parser.parse;
|
|
257
|
-
|
|
258
|
-
marked.Renderer = Renderer;
|
|
259
|
-
marked.TextRenderer = TextRenderer;
|
|
260
|
-
|
|
261
|
-
marked.Lexer = Lexer;
|
|
262
|
-
marked.lexer = Lexer.lex;
|
|
263
|
-
|
|
264
|
-
marked.Tokenizer = Tokenizer;
|
|
265
|
-
|
|
266
|
-
marked.Slugger = Slugger;
|
|
267
|
-
|
|
268
|
-
marked.parse = marked;
|
|
269
|
-
|
|
270
|
-
module.exports = marked;
|