feat: error on invalid component name (#12821)

* feat: treat tag with `[` as a component, even if lowercase

* chore: simpler regex

Co-authored-by: Conduitry <git@chor.date>

* feat: error on invalid component name

* fix: fully revert dot notation test

* tweak error message

---------

Co-authored-by: Conduitry <git@chor.date>
Co-authored-by: Rich Harris <rich.harris@vercel.com>
pull/12931/head
Paolo Ricciuti 3 months ago committed by GitHub
parent 9d9ed33d0c
commit 02c86b1973
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -0,0 +1,5 @@
---
'svelte': patch
---
feat: error on invalid component name

@ -100,6 +100,10 @@
> This type of directive is not valid on components
## component_invalid_name
> Component name must be a valid variable name or dot notation expression
## const_tag_cycle
> Cyclical dependency detected: %cycle%

@ -786,6 +786,15 @@ export function component_invalid_directive(node) {
e(node, "component_invalid_directive", "This type of directive is not valid on components");
}
/**
* Component name must be a valid variable name or dot notation expression
* @param {null | number | NodeLike} node
* @returns {never}
*/
export function component_invalid_name(node) {
e(node, "component_invalid_name", "Component name must be a valid variable name or dot notation expression");
}
/**
* Cyclical dependency detected: %cycle%
* @param {null | number | NodeLike} node

@ -75,6 +75,8 @@ function parent_is_shadowroot_template(stack) {
const regex_closing_textarea_tag = /^<\/textarea(\s[^>]*)?>/i;
const regex_closing_comment = /-->/;
const regex_component_name = /^(?:[A-Z]|[A-Za-z][A-Za-z0-9_$]*\.)/;
const regex_valid_component_name =
/^(?:[A-Z][A-Za-z0-9_$.]*|[a-z][A-Za-z0-9_$]*\.[A-Za-z0-9_$])[A-Za-z0-9_$.]*$/;
/** @param {Parser} parser */
export default function element(parser) {
@ -136,6 +138,10 @@ export default function element(parser) {
? 'SlotElement'
: 'RegularElement';
if (type === 'Component' && !regex_valid_component_name.test(name)) {
e.component_invalid_name({ start: start + 1, end: start + name.length + 1 });
}
/** @type {Compiler.ElementLike} */
const element =
type === 'RegularElement'

@ -0,0 +1,9 @@
import { test } from '../../test';
export default test({
error: {
code: 'component_invalid_name',
message: 'Component name must be a valid variable name or dot notation expression',
position: [1, 14]
}
});
Loading…
Cancel
Save