fix(parser): properly set initial inXML state based on root ns

This commit is contained in:
Evan You 2023-11-28 18:37:17 +08:00
parent ef97e8b07d
commit 47ea285be3
2 changed files with 19 additions and 0 deletions

View File

@ -978,6 +978,10 @@ export function baseParse(input: string, options?: ParserOptions): RootNode {
? ParseMode.SFC
: ParseMode.BASE
tokenizer.inXML =
currentOptions.ns === Namespaces.SVG ||
currentOptions.ns === Namespaces.MATH_ML
const delimiters = options?.delimiters
if (delimiters) {
tokenizer.delimiterOpen = toCharCodes(delimiters[0])

View File

@ -481,5 +481,20 @@ describe('DOM parser', () => {
expect(elementForieng.ns).toBe(Namespaces.SVG)
expect(element.ns).toBe(Namespaces.HTML)
})
test('correct XML handling with root ns', () => {
// when root ns is an XML namespace, there should be no special content
// treatment for <script>, <style>, <textarea> etc.
const ast = parse('<script><g/><g/></script>', {
...parserOptions,
ns: Namespaces.SVG
})
const elementSvg = ast.children[0] as ElementNode
// should parse as nodes instead of text
expect(elementSvg.children).toMatchObject([
{ type: NodeTypes.ELEMENT, tag: 'g' },
{ type: NodeTypes.ELEMENT, tag: 'g' }
])
})
})
})