58 lines
1.5 KiB
JavaScript
58 lines
1.5 KiB
JavaScript
module.exports = phrasing
|
||
|
||
function phrasing(parent, context, safeOptions) {
|
||
var children = parent.children || []
|
||
var results = []
|
||
var index = -1
|
||
var before = safeOptions.before
|
||
var after
|
||
var handle
|
||
var child
|
||
|
||
while (++index < children.length) {
|
||
child = children[index]
|
||
|
||
if (index + 1 < children.length) {
|
||
handle = context.handle.handlers[children[index + 1].type]
|
||
if (handle && handle.peek) handle = handle.peek
|
||
after = handle
|
||
? handle(children[index + 1], parent, context, {
|
||
before: '',
|
||
after: ''
|
||
}).charAt(0)
|
||
: ''
|
||
} else {
|
||
after = safeOptions.after
|
||
}
|
||
|
||
// In some cases, html (text) can be found in phrasing right after an eol.
|
||
// When we’d serialize that, in most cases that would be seen as html
|
||
// (flow).
|
||
// As we can’t escape or so to prevent it from happening, we take a somewhat
|
||
// reasonable approach: replace that eol with a space.
|
||
// See: <https://github.com/syntax-tree/mdast-util-to-markdown/issues/15>
|
||
if (
|
||
results.length > 0 &&
|
||
(before === '\r' || before === '\n') &&
|
||
child.type === 'html'
|
||
) {
|
||
results[results.length - 1] = results[results.length - 1].replace(
|
||
/(\r?\n|\r)$/,
|
||
' '
|
||
)
|
||
before = ' '
|
||
}
|
||
|
||
results.push(
|
||
context.handle(child, parent, context, {
|
||
before: before,
|
||
after: after
|
||
})
|
||
)
|
||
|
||
before = results[results.length - 1].slice(-1)
|
||
}
|
||
|
||
return results.join('')
|
||
}
|