documentation/lib/inline_tokenizer.js
John Firebaugh 08d6dc21bd Replace markdown strings with parsed ASTs
This eliminates the need for formatInlineTags and jsdoc-inline-lex, and simplifies the implementation of HTML themes.
2016-03-28 13:19:30 -07:00

57 lines
1.6 KiB
JavaScript

'use strict';
function makeTokenizer(type, regex) {
var tokenizer = function (eat, value, silent) {
var match = regex.exec(value);
if (!match) {
return;
}
if (silent) {
return true;
}
return eat(match[0])({
'type': type,
'url': match[1],
'title': null,
'children': [{
'type': 'text',
'value': match[2] || match[1]
}]
});
};
tokenizer.notInLink = true;
tokenizer.locator = function (value, fromIndex) {
return value.indexOf('{@' + type, fromIndex);
};
return tokenizer;
}
var tokenizeLink = makeTokenizer('link', /^\{@link\s+(.+?)(?:[\s|](.*?))?\}/);
var tokenizeTutorial = makeTokenizer('tutorial', /^\{@tutorial\s+(.+?)(?:[\s|](.*?))?\}/);
/**
* A remark plugin that installs
* [tokenizers](https://github.com/wooorm/remark/blob/master/doc/remarkplugin.3.md#function-tokenizereat-value-silent)
* and [locators](https://github.com/wooorm/remark/blob/master/doc/remarkplugin.3.md#function-locatorvalue-fromindex)
* for JSDoc inline `{@link}` and `{@tutorial}` tags.
*
* This does not handle the `[text]({@link url})` and `[text]({@tutorial url})` forms of these tags.
* That's a JSDoc misfeature; just use regular markdown syntax instead: `[text](url)`.
*
* @param {Object} processor - remark instance
* @returns {undefined}
*/
module.exports = function (processor) {
var proto = processor.Parser.prototype;
proto.inlineTokenizers.tokenizeLink = tokenizeLink;
proto.inlineTokenizers.tokenizeTutorial = tokenizeTutorial;
var methods = proto.inlineMethods;
methods.splice(methods.indexOf('inlineText'), 0,
'tokenizeLink', 'tokenizeTutorial');
};