Markdown parser, done right. 100% CommonMark support, extensions, syntax plugins & high speed
https://markdown-it.github.io/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
66 lines
1.5 KiB
66 lines
1.5 KiB
/** internal
|
|
* class Core
|
|
*
|
|
* Top-level rules executor. Glues block/inline parsers and does intermediate
|
|
* transformations.
|
|
**/
|
|
|
|
import Ruler from './ruler.mjs'
|
|
import StateCore from './rules_core/state_core.mjs'
|
|
|
|
import r_normalize from './rules_core/normalize.mjs'
|
|
import r_block from './rules_core/block.mjs'
|
|
import r_inline from './rules_core/inline.mjs'
|
|
import r_linkify from './rules_core/linkify.mjs'
|
|
import r_replacements from './rules_core/replacements.mjs'
|
|
import r_smartquotes from './rules_core/smartquotes.mjs'
|
|
import r_text_join from './rules_core/text_join.mjs'
|
|
|
|
|
|
const _rules = [
|
|
[ 'normalize', r_normalize ],
|
|
[ 'block', r_block ],
|
|
[ 'inline', r_inline ],
|
|
[ 'linkify', r_linkify ],
|
|
[ 'replacements', r_replacements ],
|
|
[ 'smartquotes', r_smartquotes ],
|
|
// `text_join` finds `text_special` tokens (for escape sequences)
|
|
// and joins them with the rest of the text
|
|
[ 'text_join', r_text_join ]
|
|
]
|
|
|
|
|
|
/**
|
|
* new Core()
|
|
**/
|
|
function Core() {
|
|
/**
|
|
* Core#ruler -> Ruler
|
|
*
|
|
* [[Ruler]] instance. Keep configuration of core rules.
|
|
**/
|
|
this.ruler = new Ruler()
|
|
|
|
for (let i = 0; i < _rules.length; i++) {
|
|
this.ruler.push(_rules[i][0], _rules[i][1])
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Core.process(state)
|
|
*
|
|
* Executes core chain rules.
|
|
**/
|
|
Core.prototype.process = function (state) {
|
|
const rules = this.ruler.getRules('')
|
|
|
|
for (let i = 0, l = rules.length; i < l; i++) {
|
|
rules[i](state)
|
|
}
|
|
}
|
|
|
|
Core.prototype.State = StateCore
|
|
|
|
|
|
export default Core
|
|
|