1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- /**
- * @typedef {import('micromark-util-types').Construct} Construct
- * @typedef {import('micromark-util-types').State} State
- * @typedef {import('micromark-util-types').TokenizeContext} TokenizeContext
- * @typedef {import('micromark-util-types').Tokenizer} Tokenizer
- */
- import {codes, types} from 'micromark-util-symbol'
- import {ok as assert} from 'devlop'
- import {labelEnd} from './label-end.js'
- /** @type {Construct} */
- export const labelStartLink = {
- name: 'labelStartLink',
- tokenize: tokenizeLabelStartLink,
- resolveAll: labelEnd.resolveAll
- }
- /**
- * @this {TokenizeContext}
- * @type {Tokenizer}
- */
- function tokenizeLabelStartLink(effects, ok, nok) {
- const self = this
- return start
- /**
- * Start of label (link) start.
- *
- * ```markdown
- * > | a [b] c
- * ^
- * ```
- *
- * @type {State}
- */
- function start(code) {
- assert(code === codes.leftSquareBracket, 'expected `[`')
- effects.enter(types.labelLink)
- effects.enter(types.labelMarker)
- effects.consume(code)
- effects.exit(types.labelMarker)
- effects.exit(types.labelLink)
- return after
- }
- /** @type {State} */
- function after(code) {
- // To do: this isn’t needed in `micromark-extension-gfm-footnote`,
- // remove.
- // Hidden footnotes hook.
- /* c8 ignore next 3 */
- return code === codes.caret &&
- '_hiddenFootnoteSupport' in self.parser.constructs
- ? nok(code)
- : ok(code)
- }
- }
|