|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import {factorySpace} from 'micromark-factory-space' |
|
import {markdownLineEnding, markdownSpace} from 'micromark-util-character' |
|
import {codes} from 'micromark-util-symbol/codes.js' |
|
import {constants} from 'micromark-util-symbol/constants.js' |
|
import {types} from 'micromark-util-symbol/types.js' |
|
import {ok as assert} from 'uvu/assert' |
|
|
|
|
|
export const thematicBreak = { |
|
name: 'thematicBreak', |
|
tokenize: tokenizeThematicBreak |
|
} |
|
|
|
|
|
|
|
|
|
|
|
function tokenizeThematicBreak(effects, ok, nok) { |
|
let size = 0 |
|
|
|
let marker |
|
|
|
return start |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function start(code) { |
|
effects.enter(types.thematicBreak) |
|
|
|
return before(code) |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function before(code) { |
|
assert( |
|
code === codes.asterisk || |
|
code === codes.dash || |
|
code === codes.underscore, |
|
'expected `*`, `-`, or `_`' |
|
) |
|
marker = code |
|
return atBreak(code) |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function atBreak(code) { |
|
if (code === marker) { |
|
effects.enter(types.thematicBreakSequence) |
|
return sequence(code) |
|
} |
|
|
|
if ( |
|
size >= constants.thematicBreakMarkerCountMin && |
|
(code === codes.eof || markdownLineEnding(code)) |
|
) { |
|
effects.exit(types.thematicBreak) |
|
return ok(code) |
|
} |
|
|
|
return nok(code) |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function sequence(code) { |
|
if (code === marker) { |
|
effects.consume(code) |
|
size++ |
|
return sequence |
|
} |
|
|
|
effects.exit(types.thematicBreakSequence) |
|
return markdownSpace(code) |
|
? factorySpace(effects, atBreak, types.whitespace)(code) |
|
: atBreak(code) |
|
} |
|
} |
|
|