fix: add compiler error for invalid <p> contents (#10201)

* fix: add compiler error for invalid <p> contents

* add test
pull/10207/head
Dominic Gannaway 1 year ago committed by GitHub
parent 73c5983e9a
commit c7a7725abd
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -0,0 +1,5 @@
---
"svelte": patch
---
fix: add compiler error for invalid <p> contents

@ -153,6 +153,36 @@ const disallowed_contents = {
th: new Set(['td', 'th', 'tr']) th: new Set(['td', 'th', 'tr'])
}; };
export const disallowed_parapgraph_contents = [
'address',
'article',
'aside',
'blockquote',
'details',
'div',
'dl',
'fieldset',
'figcapture',
'figure',
'footer',
'form',
'h1',
'h2',
'h3',
'h4',
'h5',
'h6',
'header',
'hr',
'menu',
'nav',
'ol',
'pre',
'section',
'table',
'ul'
];
for (const interactive_element of interactive_elements) { for (const interactive_element of interactive_elements) {
disallowed_contents[interactive_element] = interactive_elements; disallowed_contents[interactive_element] = interactive_elements;
} }

@ -7,7 +7,7 @@ import {
} from '../../utils/ast.js'; } from '../../utils/ast.js';
import { warn } from '../../warnings.js'; import { warn } from '../../warnings.js';
import fuzzymatch from '../1-parse/utils/fuzzymatch.js'; import fuzzymatch from '../1-parse/utils/fuzzymatch.js';
import { interactive_elements } from '../1-parse/utils/html.js'; import { disallowed_parapgraph_contents, interactive_elements } from '../1-parse/utils/html.js';
import { binding_properties } from '../bindings.js'; import { binding_properties } from '../bindings.js';
import { ContentEditableBindings, EventModifiers, SVGElements } from '../constants.js'; import { ContentEditableBindings, EventModifiers, SVGElements } from '../constants.js';
import { is_custom_element_node } from '../nodes.js'; import { is_custom_element_node } from '../nodes.js';
@ -544,6 +544,15 @@ export const validation = {
} }
} }
if (disallowed_parapgraph_contents.includes(node.name)) {
const path = context.path;
for (let parent of path) {
if (parent.type === 'RegularElement' && parent.name === 'p') {
error(node, 'invalid-node-placement', `<${node.name}>`, parent.name);
}
}
}
context.next({ context.next({
...context.state, ...context.state,
parent_element: node.name parent_element: node.name

@ -0,0 +1,14 @@
[
{
"code": "invalid-node-placement",
"message": "<div> is invalid inside <p>",
"start": {
"line": 4,
"column": 3
},
"end": {
"line": 4,
"column": 17
}
}
]

@ -0,0 +1,7 @@
<div>
<p>
<span>
<div>foo</div>
</span>
</p>
</div>
Loading…
Cancel
Save