var Tokenizer_1 = function()

in src/sql/base/common/marked/marked.js [479:1107]


	var Tokenizer_1 = /*#__PURE__*/function () {
		function Tokenizer(options) {
			this.options = options || defaults$1;
		}

		var _proto = Tokenizer.prototype;

		_proto.space = function space(src) {
			var cap = this.rules.block.newline.exec(src);

			if (cap) {
				if (cap[0].length > 1) {
					return {
						type: 'space',
						raw: cap[0]
					};
				}

				return {
					raw: '\n'
				};
			}
		};

		_proto.code = function code(src, tokens) {
			var cap = this.rules.block.code.exec(src);

			if (cap) {
				var lastToken = tokens[tokens.length - 1]; // An indented code block cannot interrupt a paragraph.

				if (lastToken && lastToken.type === 'paragraph') {
					return {
						raw: cap[0],
						text: cap[0].trimRight()
					};
				}

				var text = cap[0].replace(/^ {4}/gm, '');
				return {
					type: 'code',
					raw: cap[0],
					codeBlockStyle: 'indented',
					text: !this.options.pedantic ? rtrim$1(text, '\n') : text
				};
			}
		};

		_proto.fences = function fences(src) {
			var cap = this.rules.block.fences.exec(src);

			if (cap) {
				var raw = cap[0];
				var text = indentCodeCompensation(raw, cap[3] || '');
				return {
					type: 'code',
					raw: raw,
					lang: cap[2] ? cap[2].trim() : cap[2],
					text: text
				};
			}
		};

		_proto.heading = function heading(src) {
			var cap = this.rules.block.heading.exec(src);

			if (cap) {
				return {
					type: 'heading',
					raw: cap[0],
					depth: cap[1].length,
					text: cap[2]
				};
			}
		};

		_proto.nptable = function nptable(src) {
			var cap = this.rules.block.nptable.exec(src);

			if (cap) {
				var item = {
					type: 'table',
					header: splitCells$1(cap[1].replace(/^ *| *\| *$/g, '')),
					align: cap[2].replace(/^ *|\| *$/g, '').split(/ *\| */),
					cells: cap[3] ? cap[3].replace(/\n$/, '').split('\n') : [],
					raw: cap[0]
				};

				if (item.header.length === item.align.length) {
					var l = item.align.length;
					var i;

					for (i = 0; i < l; i++) {
						if (/^ *-+: *$/.test(item.align[i])) {
							item.align[i] = 'right';
						} else if (/^ *:-+: *$/.test(item.align[i])) {
							item.align[i] = 'center';
						} else if (/^ *:-+ *$/.test(item.align[i])) {
							item.align[i] = 'left';
						} else {
							item.align[i] = null;
						}
					}

					l = item.cells.length;

					for (i = 0; i < l; i++) {
						item.cells[i] = splitCells$1(item.cells[i], item.header.length);
					}

					return item;
				}
			}
		};

		_proto.hr = function hr(src) {
			var cap = this.rules.block.hr.exec(src);

			if (cap) {
				return {
					type: 'hr',
					raw: cap[0]
				};
			}
		};

		_proto.blockquote = function blockquote(src) {
			var cap = this.rules.block.blockquote.exec(src);

			if (cap) {
				var text = cap[0].replace(/^ *> ?/gm, '');
				return {
					type: 'blockquote',
					raw: cap[0],
					text: text
				};
			}
		};

		_proto.list = function list(src) {
			var cap = this.rules.block.list.exec(src);

			if (cap) {
				var raw = cap[0];
				var bull = cap[2];
				var isordered = bull.length > 1;
				var isparen = bull[bull.length - 1] === ')';
				var list = {
					type: 'list',
					raw: raw,
					ordered: isordered,
					start: isordered ? +bull.slice(0, -1) : '',
					loose: false,
					items: []
				}; // Get each top-level item.

				var itemMatch = cap[0].match(this.rules.block.item);
				var next = false,
					item,
					space,
					b,
					addBack,
					loose,
					istask,
					ischecked;
				var l = itemMatch.length;

				for (var i = 0; i < l; i++) {
					item = itemMatch[i];
					raw = item; // Remove the list item's bullet
					// so it is seen as the next token.

					space = item.length;
					item = item.replace(/^ *([*+-]|\d+[.)]) ?/, ''); // Outdent whatever the
					// list item contains. Hacky.

					if (~item.indexOf('\n ')) {
						space -= item.length;
						item = !this.options.pedantic ? item.replace(new RegExp('^ {1,' + space + '}', 'gm'), '') : item.replace(/^ {1,4}/gm, '');
					} // Determine whether the next list item belongs here.
					// Backpedal if it does not belong in this list.


					if (i !== l - 1) {
						b = this.rules.block.bullet.exec(itemMatch[i + 1])[0];

						if (isordered ? b.length === 1 || !isparen && b[b.length - 1] === ')' : b.length > 1 || this.options.smartLists && b !== bull) {
							addBack = itemMatch.slice(i + 1).join('\n');
							list.raw = list.raw.substring(0, list.raw.length - addBack.length);
							i = l - 1;
						}
					} // Determine whether item is loose or not.
					// Use: /(^|\n)(?! )[^\n]+\n\n(?!\s*$)/
					// for discount behavior.


					loose = next || /\n\n(?!\s*$)/.test(item);

					if (i !== l - 1) {
						next = item.charAt(item.length - 1) === '\n';
						if (!loose) loose = next;
					}

					if (loose) {
						list.loose = true;
					} // Check for task list items


					istask = /^\[[ xX]\] /.test(item);
					ischecked = undefined;

					if (istask) {
						ischecked = item[1] !== ' ';
						item = item.replace(/^\[[ xX]\] +/, '');
					}

					list.items.push({
						type: 'list_item',
						raw: raw,
						task: istask,
						checked: ischecked,
						loose: loose,
						text: item
					});
				}

				return list;
			}
		};

		_proto.html = function html(src) {
			var cap = this.rules.block.html.exec(src);

			if (cap) {
				return {
					type: this.options.sanitize ? 'paragraph' : 'html',
					raw: cap[0],
					pre: !this.options.sanitizer && (cap[1] === 'pre' || cap[1] === 'script' || cap[1] === 'style'),
					text: this.options.sanitize ? this.options.sanitizer ? this.options.sanitizer(cap[0]) : _escape(cap[0]) : cap[0]
				};
			}
		};

		_proto.def = function def(src) {
			var cap = this.rules.block.def.exec(src);

			if (cap) {
				if (cap[3]) cap[3] = cap[3].substring(1, cap[3].length - 1);
				var tag = cap[1].toLowerCase().replace(/\s+/g, ' ');
				return {
					tag: tag,
					raw: cap[0],
					href: cap[2],
					title: cap[3]
				};
			}
		};

		_proto.table = function table(src) {
			var cap = this.rules.block.table.exec(src);

			if (cap) {
				var item = {
					type: 'table',
					header: splitCells$1(cap[1].replace(/^ *| *\| *$/g, '')),
					align: cap[2].replace(/^ *|\| *$/g, '').split(/ *\| */),
					cells: cap[3] ? cap[3].replace(/\n$/, '').split('\n') : []
				};

				if (item.header.length === item.align.length) {
					item.raw = cap[0];
					var l = item.align.length;
					var i;

					for (i = 0; i < l; i++) {
						if (/^ *-+: *$/.test(item.align[i])) {
							item.align[i] = 'right';
						} else if (/^ *:-+: *$/.test(item.align[i])) {
							item.align[i] = 'center';
						} else if (/^ *:-+ *$/.test(item.align[i])) {
							item.align[i] = 'left';
						} else {
							item.align[i] = null;
						}
					}

					l = item.cells.length;

					for (i = 0; i < l; i++) {
						item.cells[i] = splitCells$1(item.cells[i].replace(/^ *\| *| *\| *$/g, ''), item.header.length);
					}

					return item;
				}
			}
		};

		_proto.lheading = function lheading(src) {
			var cap = this.rules.block.lheading.exec(src);

			if (cap) {
				return {
					type: 'heading',
					raw: cap[0],
					depth: cap[2].charAt(0) === '=' ? 1 : 2,
					text: cap[1]
				};
			}
		};

		_proto.paragraph = function paragraph(src) {
			var cap = this.rules.block.paragraph.exec(src);

			if (cap) {
				return {
					type: 'paragraph',
					raw: cap[0],
					text: cap[1].charAt(cap[1].length - 1) === '\n' ? cap[1].slice(0, -1) : cap[1]
				};
			}
		};

		_proto.text = function text(src, tokens) {
			var cap = this.rules.block.text.exec(src);

			if (cap) {
				var lastToken = tokens[tokens.length - 1];

				if (lastToken && lastToken.type === 'text') {
					return {
						raw: cap[0],
						text: cap[0]
					};
				}

				return {
					type: 'text',
					raw: cap[0],
					text: cap[0]
				};
			}
		};

		_proto.escape = function escape(src) {
			var cap = this.rules.inline.escape.exec(src);

			if (cap) {
				return {
					type: 'escape',
					raw: cap[0],
					text: _escape(cap[1])
				};
			}
		};

		_proto.tag = function tag(src, inLink, inRawBlock) {
			var cap = this.rules.inline.tag.exec(src);

			if (cap) {
				if (!inLink && /^<a /i.test(cap[0])) {
					inLink = true;
				} else if (inLink && /^<\/a>/i.test(cap[0])) {
					inLink = false;
				}

				if (!inRawBlock && /^<(pre|code|kbd|script)(\s|>)/i.test(cap[0])) {
					inRawBlock = true;
				} else if (inRawBlock && /^<\/(pre|code|kbd|script)(\s|>)/i.test(cap[0])) {
					inRawBlock = false;
				}

				return {
					type: this.options.sanitize ? 'text' : 'html',
					raw: cap[0],
					inLink: inLink,
					inRawBlock: inRawBlock,
					text: this.options.sanitize ? this.options.sanitizer ? this.options.sanitizer(cap[0]) : _escape(cap[0]) : cap[0]
				};
			}
		};

		_proto.link = function link(src) {
			var cap = this.rules.inline.link.exec(src);

			if (cap) {
				var lastParenIndex = findClosingBracket$1(cap[2], '()');

				if (lastParenIndex > -1) {
					var start = cap[0].indexOf('!') === 0 ? 5 : 4;
					var linkLen = start + cap[1].length + lastParenIndex;
					cap[2] = cap[2].substring(0, lastParenIndex);
					cap[0] = cap[0].substring(0, linkLen).trim();
					cap[3] = '';
				}

				var href = cap[2];
				var title = '';

				if (this.options.pedantic) {
					var link = /^([^'"]*[^\s])\s+(['"])(.*)\2/.exec(href);

					if (link) {
						href = link[1];
						title = link[3];
					} else {
						title = '';
					}
				} else {
					title = cap[3] ? cap[3].slice(1, -1) : '';
				}

				href = href.trim().replace(/^<([\s\S]*)>$/, '$1');
				var token = outputLink(cap, {
					href: href ? href.replace(this.rules.inline._escapes, '$1') : href,
					title: title ? title.replace(this.rules.inline._escapes, '$1') : title
				}, cap[0]);
				return token;
			}
		};

		_proto.reflink = function reflink(src, links) {
			var cap;

			if ((cap = this.rules.inline.reflink.exec(src)) || (cap = this.rules.inline.nolink.exec(src))) {
				var link = (cap[2] || cap[1]).replace(/\s+/g, ' ');
				link = links[link.toLowerCase()];

				if (!link || !link.href) {
					var text = cap[0].charAt(0);
					return {
						type: 'text',
						raw: text,
						text: text
					};
				}

				var token = outputLink(cap, link, cap[0]);
				return token;
			}
		};

		_proto.strong = function strong(src, maskedSrc, prevChar) {
			if (prevChar === void 0) {
				prevChar = '';
			}

			var match = this.rules.inline.strong.start.exec(src);

			if (match && (!match[1] || match[1] && (prevChar === '' || this.rules.inline.punctuation.exec(prevChar)))) {
				maskedSrc = maskedSrc.slice(-1 * src.length);
				var endReg = match[0] === '**' ? this.rules.inline.strong.endAst : this.rules.inline.strong.endUnd;
				endReg.lastIndex = 0;
				var cap;

				while ((match = endReg.exec(maskedSrc)) != null) {
					cap = this.rules.inline.strong.middle.exec(maskedSrc.slice(0, match.index + 3));

					if (cap) {
						return {
							type: 'strong',
							raw: src.slice(0, cap[0].length),
							text: src.slice(2, cap[0].length - 2)
						};
					}
				}
			}
		};

		_proto.em = function em(src, maskedSrc, prevChar) {
			if (prevChar === void 0) {
				prevChar = '';
			}

			var match = this.rules.inline.em.start.exec(src);

			if (match && (!match[1] || match[1] && (prevChar === '' || this.rules.inline.punctuation.exec(prevChar)))) {
				maskedSrc = maskedSrc.slice(-1 * src.length);
				var endReg = match[0] === '*' ? this.rules.inline.em.endAst : this.rules.inline.em.endUnd;
				endReg.lastIndex = 0;
				var cap;

				while ((match = endReg.exec(maskedSrc)) != null) {
					cap = this.rules.inline.em.middle.exec(maskedSrc.slice(0, match.index + 2));

					if (cap) {
						return {
							type: 'em',
							raw: src.slice(0, cap[0].length),
							text: src.slice(1, cap[0].length - 1)
						};
					}
				}
			}
		};

		_proto.codespan = function codespan(src) {
			var cap = this.rules.inline.code.exec(src);

			if (cap) {
				var text = cap[2].replace(/\n/g, ' ');
				var hasNonSpaceChars = /[^ ]/.test(text);
				var hasSpaceCharsOnBothEnds = text.startsWith(' ') && text.endsWith(' ');

				if (hasNonSpaceChars && hasSpaceCharsOnBothEnds) {
					text = text.substring(1, text.length - 1);
				}

				text = _escape(text, true);
				return {
					type: 'codespan',
					raw: cap[0],
					text: text
				};
			}
		};

		_proto.br = function br(src) {
			var cap = this.rules.inline.br.exec(src);

			if (cap) {
				return {
					type: 'br',
					raw: cap[0]
				};
			}
		};

		_proto.del = function del(src) {
			var cap = this.rules.inline.del.exec(src);

			if (cap) {
				return {
					type: 'del',
					raw: cap[0],
					text: cap[1]
				};
			}
		};

		_proto.autolink = function autolink(src, mangle) {
			var cap = this.rules.inline.autolink.exec(src);

			if (cap) {
				var text, href;

				if (cap[2] === '@') {
					text = _escape(this.options.mangle ? mangle(cap[1]) : cap[1]);
					href = 'mailto:' + text;
				} else {
					text = _escape(cap[1]);
					href = text;
				}

				return {
					type: 'link',
					raw: cap[0],
					text: text,
					href: href,
					tokens: [{
						type: 'text',
						raw: text,
						text: text
					}]
				};
			}
		};

		_proto.url = function url(src, mangle) {
			var cap;

			if (cap = this.rules.inline.url.exec(src)) {
				var text, href;

				if (cap[2] === '@') {
					text = _escape(this.options.mangle ? mangle(cap[0]) : cap[0]);
					href = 'mailto:' + text;
				} else {
					// do extended autolink path validation
					var prevCapZero;

					do {
						prevCapZero = cap[0];
						cap[0] = this.rules.inline._backpedal.exec(cap[0])[0];
					} while (prevCapZero !== cap[0]);

					text = _escape(cap[0]);

					if (cap[1] === 'www.') {
						href = 'http://' + text;
					} else {
						href = text;
					}
				}

				return {
					type: 'link',
					raw: cap[0],
					text: text,
					href: href,
					tokens: [{
						type: 'text',
						raw: text,
						text: text
					}]
				};
			}
		};

		_proto.inlineText = function inlineText(src, inRawBlock, smartypants) {
			var cap = this.rules.inline.text.exec(src);

			if (cap) {
				var text;

				if (inRawBlock) {
					text = this.options.sanitize ? this.options.sanitizer ? this.options.sanitizer(cap[0]) : _escape(cap[0]) : cap[0];
				} else {
					text = _escape(this.options.smartypants ? smartypants(cap[0]) : cap[0]);
				}

				return {
					type: 'text',
					raw: cap[0],
					text: text
				};
			}
		};

		return Tokenizer;
	}();