UNPKG

svelte

Version:

Cybernetically enhanced web apps

1,285 lines (1,146 loc) 63.3 kB
/* This file is generated by scripts/process-messages/index.js. Do not edit! */ import { CompileDiagnostic } from './utils/compile_diagnostic.js'; /** @typedef {{ start?: number, end?: number }} NodeLike */ class InternalCompileError extends Error { message = ''; // ensure this property is enumerable #diagnostic; /** * @param {string} code * @param {string} message * @param {[number, number] | undefined} position */ constructor(code, message, position) { super(message); this.stack = ''; // avoid unnecessary noise; don't set it as a class property or it becomes enumerable // We want to extend from Error so that various bundler plugins properly handle it. // But we also want to share the same object shape with that of warnings, therefore // we create an instance of the shared class an copy over its properties. this.#diagnostic = new CompileDiagnostic(code, message, position); Object.assign(this, this.#diagnostic); this.name = 'CompileError'; } toString() { return this.#diagnostic.toString(); } toJSON() { return this.#diagnostic.toJSON(); } } /** * @param {null | number | NodeLike} node * @param {string} code * @param {string} message * @returns {never} */ function e(node, code, message) { const start = typeof node === 'number' ? node : node?.start; const end = typeof node === 'number' ? node : node?.end; throw new InternalCompileError(code, message, start !== undefined ? [start, end ?? start] : undefined); } /** * Invalid compiler option: %details% * @param {null | number | NodeLike} node * @param {string} details * @returns {never} */ export function options_invalid_value(node, details) { e(node, 'options_invalid_value', `Invalid compiler option: ${details}\nhttps://svelte.dev/e/options_invalid_value`); } /** * Invalid compiler option: %details% * @param {null | number | NodeLike} node * @param {string} details * @returns {never} */ export function options_removed(node, details) { e(node, 'options_removed', `Invalid compiler option: ${details}\nhttps://svelte.dev/e/options_removed`); } /** * Unrecognised compiler option %keypath% * @param {null | number | NodeLike} node * @param {string} keypath * @returns {never} */ export function options_unrecognised(node, keypath) { e(node, 'options_unrecognised', `Unrecognised compiler option ${keypath}\nhttps://svelte.dev/e/options_unrecognised`); } /** * `$bindable()` can only be used inside a `$props()` declaration * @param {null | number | NodeLike} node * @returns {never} */ export function bindable_invalid_location(node) { e(node, 'bindable_invalid_location', `\`$bindable()\` can only be used inside a \`$props()\` declaration\nhttps://svelte.dev/e/bindable_invalid_location`); } /** * Cannot assign to %thing% * @param {null | number | NodeLike} node * @param {string} thing * @returns {never} */ export function constant_assignment(node, thing) { e(node, 'constant_assignment', `Cannot assign to ${thing}\nhttps://svelte.dev/e/constant_assignment`); } /** * Cannot bind to %thing% * @param {null | number | NodeLike} node * @param {string} thing * @returns {never} */ export function constant_binding(node, thing) { e(node, 'constant_binding', `Cannot bind to ${thing}\nhttps://svelte.dev/e/constant_binding`); } /** * `%name%` has already been declared * @param {null | number | NodeLike} node * @param {string} name * @returns {never} */ export function declaration_duplicate(node, name) { e(node, 'declaration_duplicate', `\`${name}\` has already been declared\nhttps://svelte.dev/e/declaration_duplicate`); } /** * Cannot declare a variable with the same name as an import inside `<script module>` * @param {null | number | NodeLike} node * @returns {never} */ export function declaration_duplicate_module_import(node) { e(node, 'declaration_duplicate_module_import', `Cannot declare a variable with the same name as an import inside \`<script module>\`\nhttps://svelte.dev/e/declaration_duplicate_module_import`); } /** * Cannot export derived state from a module. To expose the current derived value, export a function returning its value * @param {null | number | NodeLike} node * @returns {never} */ export function derived_invalid_export(node) { e(node, 'derived_invalid_export', `Cannot export derived state from a module. To expose the current derived value, export a function returning its value\nhttps://svelte.dev/e/derived_invalid_export`); } /** * The $ name is reserved, and cannot be used for variables and imports * @param {null | number | NodeLike} node * @returns {never} */ export function dollar_binding_invalid(node) { e(node, 'dollar_binding_invalid', `The $ name is reserved, and cannot be used for variables and imports\nhttps://svelte.dev/e/dollar_binding_invalid`); } /** * The $ prefix is reserved, and cannot be used for variables and imports * @param {null | number | NodeLike} node * @returns {never} */ export function dollar_prefix_invalid(node) { e(node, 'dollar_prefix_invalid', `The $ prefix is reserved, and cannot be used for variables and imports\nhttps://svelte.dev/e/dollar_prefix_invalid`); } /** * Cannot reassign or bind to each block argument in runes mode. Use the array and index variables instead (e.g. `array[i] = value` instead of `entry = value`, or `bind:value={array[i]}` instead of `bind:value={entry}`) * @param {null | number | NodeLike} node * @returns {never} */ export function each_item_invalid_assignment(node) { e(node, 'each_item_invalid_assignment', `Cannot reassign or bind to each block argument in runes mode. Use the array and index variables instead (e.g. \`array[i] = value\` instead of \`entry = value\`, or \`bind:value={array[i]}\` instead of \`bind:value={entry}\`)\nhttps://svelte.dev/e/each_item_invalid_assignment`); } /** * `$effect()` can only be used as an expression statement * @param {null | number | NodeLike} node * @returns {never} */ export function effect_invalid_placement(node) { e(node, 'effect_invalid_placement', `\`$effect()\` can only be used as an expression statement\nhttps://svelte.dev/e/effect_invalid_placement`); } /** * `%name%` is not defined * @param {null | number | NodeLike} node * @param {string} name * @returns {never} */ export function export_undefined(node, name) { e(node, 'export_undefined', `\`${name}\` is not defined\nhttps://svelte.dev/e/export_undefined`); } /** * `%name%` is an illegal variable name. To reference a global variable called `%name%`, use `globalThis.%name%` * @param {null | number | NodeLike} node * @param {string} name * @returns {never} */ export function global_reference_invalid(node, name) { e(node, 'global_reference_invalid', `\`${name}\` is an illegal variable name. To reference a global variable called \`${name}\`, use \`globalThis.${name}\`\nhttps://svelte.dev/e/global_reference_invalid`); } /** * `$host()` can only be used inside custom element component instances * @param {null | number | NodeLike} node * @returns {never} */ export function host_invalid_placement(node) { e(node, 'host_invalid_placement', `\`$host()\` can only be used inside custom element component instances\nhttps://svelte.dev/e/host_invalid_placement`); } /** * Imports of `svelte/internal/*` are forbidden. It contains private runtime code which is subject to change without notice. If you're importing from `svelte/internal/*` to work around a limitation of Svelte, please open an issue at https://github.com/sveltejs/svelte and explain your use case * @param {null | number | NodeLike} node * @returns {never} */ export function import_svelte_internal_forbidden(node) { e(node, 'import_svelte_internal_forbidden', `Imports of \`svelte/internal/*\` are forbidden. It contains private runtime code which is subject to change without notice. If you're importing from \`svelte/internal/*\` to work around a limitation of Svelte, please open an issue at https://github.com/sveltejs/svelte and explain your use case\nhttps://svelte.dev/e/import_svelte_internal_forbidden`); } /** * `$inspect.trace(...)` cannot be used inside a generator function * @param {null | number | NodeLike} node * @returns {never} */ export function inspect_trace_generator(node) { e(node, 'inspect_trace_generator', `\`$inspect.trace(...)\` cannot be used inside a generator function\nhttps://svelte.dev/e/inspect_trace_generator`); } /** * `$inspect.trace(...)` must be the first statement of a function body * @param {null | number | NodeLike} node * @returns {never} */ export function inspect_trace_invalid_placement(node) { e(node, 'inspect_trace_invalid_placement', `\`$inspect.trace(...)\` must be the first statement of a function body\nhttps://svelte.dev/e/inspect_trace_invalid_placement`); } /** * The arguments keyword cannot be used within the template or at the top level of a component * @param {null | number | NodeLike} node * @returns {never} */ export function invalid_arguments_usage(node) { e(node, 'invalid_arguments_usage', `The arguments keyword cannot be used within the template or at the top level of a component\nhttps://svelte.dev/e/invalid_arguments_usage`); } /** * Cannot use `export let` in runes mode — use `$props()` instead * @param {null | number | NodeLike} node * @returns {never} */ export function legacy_export_invalid(node) { e(node, 'legacy_export_invalid', `Cannot use \`export let\` in runes mode — use \`$props()\` instead\nhttps://svelte.dev/e/legacy_export_invalid`); } /** * Cannot use `$$props` in runes mode * @param {null | number | NodeLike} node * @returns {never} */ export function legacy_props_invalid(node) { e(node, 'legacy_props_invalid', `Cannot use \`$$props\` in runes mode\nhttps://svelte.dev/e/legacy_props_invalid`); } /** * `$:` is not allowed in runes mode, use `$derived` or `$effect` instead * @param {null | number | NodeLike} node * @returns {never} */ export function legacy_reactive_statement_invalid(node) { e(node, 'legacy_reactive_statement_invalid', `\`$:\` is not allowed in runes mode, use \`$derived\` or \`$effect\` instead\nhttps://svelte.dev/e/legacy_reactive_statement_invalid`); } /** * Cannot use `$$restProps` in runes mode * @param {null | number | NodeLike} node * @returns {never} */ export function legacy_rest_props_invalid(node) { e(node, 'legacy_rest_props_invalid', `Cannot use \`$$restProps\` in runes mode\nhttps://svelte.dev/e/legacy_rest_props_invalid`); } /** * A component cannot have a default export * @param {null | number | NodeLike} node * @returns {never} */ export function module_illegal_default_export(node) { e(node, 'module_illegal_default_export', `A component cannot have a default export\nhttps://svelte.dev/e/module_illegal_default_export`); } /** * Cannot use `%rune%()` more than once * @param {null | number | NodeLike} node * @param {string} rune * @returns {never} */ export function props_duplicate(node, rune) { e(node, 'props_duplicate', `Cannot use \`${rune}()\` more than once\nhttps://svelte.dev/e/props_duplicate`); } /** * `$props.id()` can only be used at the top level of components as a variable declaration initializer * @param {null | number | NodeLike} node * @returns {never} */ export function props_id_invalid_placement(node) { e(node, 'props_id_invalid_placement', `\`$props.id()\` can only be used at the top level of components as a variable declaration initializer\nhttps://svelte.dev/e/props_id_invalid_placement`); } /** * Declaring or accessing a prop starting with `$$` is illegal (they are reserved for Svelte internals) * @param {null | number | NodeLike} node * @returns {never} */ export function props_illegal_name(node) { e(node, 'props_illegal_name', `Declaring or accessing a prop starting with \`$$\` is illegal (they are reserved for Svelte internals)\nhttps://svelte.dev/e/props_illegal_name`); } /** * `$props()` can only be used with an object destructuring pattern * @param {null | number | NodeLike} node * @returns {never} */ export function props_invalid_identifier(node) { e(node, 'props_invalid_identifier', `\`$props()\` can only be used with an object destructuring pattern\nhttps://svelte.dev/e/props_invalid_identifier`); } /** * `$props()` assignment must not contain nested properties or computed keys * @param {null | number | NodeLike} node * @returns {never} */ export function props_invalid_pattern(node) { e(node, 'props_invalid_pattern', `\`$props()\` assignment must not contain nested properties or computed keys\nhttps://svelte.dev/e/props_invalid_pattern`); } /** * `$props()` can only be used at the top level of components as a variable declaration initializer * @param {null | number | NodeLike} node * @returns {never} */ export function props_invalid_placement(node) { e(node, 'props_invalid_placement', `\`$props()\` can only be used at the top level of components as a variable declaration initializer\nhttps://svelte.dev/e/props_invalid_placement`); } /** * Cyclical dependency detected: %cycle% * @param {null | number | NodeLike} node * @param {string} cycle * @returns {never} */ export function reactive_declaration_cycle(node, cycle) { e(node, 'reactive_declaration_cycle', `Cyclical dependency detected: ${cycle}\nhttps://svelte.dev/e/reactive_declaration_cycle`); } /** * `%rune%` cannot be called with arguments * @param {null | number | NodeLike} node * @param {string} rune * @returns {never} */ export function rune_invalid_arguments(node, rune) { e(node, 'rune_invalid_arguments', `\`${rune}\` cannot be called with arguments\nhttps://svelte.dev/e/rune_invalid_arguments`); } /** * `%rune%` must be called with %args% * @param {null | number | NodeLike} node * @param {string} rune * @param {string} args * @returns {never} */ export function rune_invalid_arguments_length(node, rune, args) { e(node, 'rune_invalid_arguments_length', `\`${rune}\` must be called with ${args}\nhttps://svelte.dev/e/rune_invalid_arguments_length`); } /** * Cannot access a computed property of a rune * @param {null | number | NodeLike} node * @returns {never} */ export function rune_invalid_computed_property(node) { e(node, 'rune_invalid_computed_property', `Cannot access a computed property of a rune\nhttps://svelte.dev/e/rune_invalid_computed_property`); } /** * `%name%` is not a valid rune * @param {null | number | NodeLike} node * @param {string} name * @returns {never} */ export function rune_invalid_name(node, name) { e(node, 'rune_invalid_name', `\`${name}\` is not a valid rune\nhttps://svelte.dev/e/rune_invalid_name`); } /** * `%rune%` cannot be called with a spread argument * @param {null | number | NodeLike} node * @param {string} rune * @returns {never} */ export function rune_invalid_spread(node, rune) { e(node, 'rune_invalid_spread', `\`${rune}\` cannot be called with a spread argument\nhttps://svelte.dev/e/rune_invalid_spread`); } /** * Cannot use `%rune%` rune in non-runes mode * @param {null | number | NodeLike} node * @param {string} rune * @returns {never} */ export function rune_invalid_usage(node, rune) { e(node, 'rune_invalid_usage', `Cannot use \`${rune}\` rune in non-runes mode\nhttps://svelte.dev/e/rune_invalid_usage`); } /** * Cannot use rune without parentheses * @param {null | number | NodeLike} node * @returns {never} */ export function rune_missing_parentheses(node) { e(node, 'rune_missing_parentheses', `Cannot use rune without parentheses\nhttps://svelte.dev/e/rune_missing_parentheses`); } /** * The `%name%` rune has been removed * @param {null | number | NodeLike} node * @param {string} name * @returns {never} */ export function rune_removed(node, name) { e(node, 'rune_removed', `The \`${name}\` rune has been removed\nhttps://svelte.dev/e/rune_removed`); } /** * `%name%` is now `%replacement%` * @param {null | number | NodeLike} node * @param {string} name * @param {string} replacement * @returns {never} */ export function rune_renamed(node, name, replacement) { e(node, 'rune_renamed', `\`${name}\` is now \`${replacement}\`\nhttps://svelte.dev/e/rune_renamed`); } /** * %name% cannot be used in runes mode * @param {null | number | NodeLike} node * @param {string} name * @returns {never} */ export function runes_mode_invalid_import(node, name) { e(node, 'runes_mode_invalid_import', `${name} cannot be used in runes mode\nhttps://svelte.dev/e/runes_mode_invalid_import`); } /** * An exported snippet can only reference things declared in a `<script module>`, or other exportable snippets * @param {null | number | NodeLike} node * @returns {never} */ export function snippet_invalid_export(node) { e(node, 'snippet_invalid_export', `An exported snippet can only reference things declared in a \`<script module>\`, or other exportable snippets\nhttps://svelte.dev/e/snippet_invalid_export`); } /** * Cannot reassign or bind to snippet parameter * @param {null | number | NodeLike} node * @returns {never} */ export function snippet_parameter_assignment(node) { e(node, 'snippet_parameter_assignment', `Cannot reassign or bind to snippet parameter\nhttps://svelte.dev/e/snippet_parameter_assignment`); } /** * Cannot export state from a module if it is reassigned. Either export a function returning the state value or only mutate the state value's properties * @param {null | number | NodeLike} node * @returns {never} */ export function state_invalid_export(node) { e(node, 'state_invalid_export', `Cannot export state from a module if it is reassigned. Either export a function returning the state value or only mutate the state value's properties\nhttps://svelte.dev/e/state_invalid_export`); } /** * `%rune%(...)` can only be used as a variable declaration initializer or a class field * @param {null | number | NodeLike} node * @param {string} rune * @returns {never} */ export function state_invalid_placement(node, rune) { e(node, 'state_invalid_placement', `\`${rune}(...)\` can only be used as a variable declaration initializer or a class field\nhttps://svelte.dev/e/state_invalid_placement`); } /** * Cannot subscribe to stores that are not declared at the top level of the component * @param {null | number | NodeLike} node * @returns {never} */ export function store_invalid_scoped_subscription(node) { e(node, 'store_invalid_scoped_subscription', `Cannot subscribe to stores that are not declared at the top level of the component\nhttps://svelte.dev/e/store_invalid_scoped_subscription`); } /** * Cannot reference store value inside `<script module>` * @param {null | number | NodeLike} node * @returns {never} */ export function store_invalid_subscription(node) { e(node, 'store_invalid_subscription', `Cannot reference store value inside \`<script module>\`\nhttps://svelte.dev/e/store_invalid_subscription`); } /** * Cannot reference store value outside a `.svelte` file * @param {null | number | NodeLike} node * @returns {never} */ export function store_invalid_subscription_module(node) { e(node, 'store_invalid_subscription_module', `Cannot reference store value outside a \`.svelte\` file\nhttps://svelte.dev/e/store_invalid_subscription_module`); } /** * TypeScript language features like %feature% are not natively supported, and their use is generally discouraged. Outside of `<script>` tags, these features are not supported. For use within `<script>` tags, you will need to use a preprocessor to convert it to JavaScript before it gets passed to the Svelte compiler. If you are using `vitePreprocess`, make sure to specifically enable preprocessing script tags (`vitePreprocess({ script: true })`) * @param {null | number | NodeLike} node * @param {string} feature * @returns {never} */ export function typescript_invalid_feature(node, feature) { e(node, 'typescript_invalid_feature', `TypeScript language features like ${feature} are not natively supported, and their use is generally discouraged. Outside of \`<script>\` tags, these features are not supported. For use within \`<script>\` tags, you will need to use a preprocessor to convert it to JavaScript before it gets passed to the Svelte compiler. If you are using \`vitePreprocess\`, make sure to specifically enable preprocessing script tags (\`vitePreprocess({ script: true })\`)\nhttps://svelte.dev/e/typescript_invalid_feature`); } /** * Declaration cannot be empty * @param {null | number | NodeLike} node * @returns {never} */ export function css_empty_declaration(node) { e(node, 'css_empty_declaration', `Declaration cannot be empty\nhttps://svelte.dev/e/css_empty_declaration`); } /** * Expected a valid CSS identifier * @param {null | number | NodeLike} node * @returns {never} */ export function css_expected_identifier(node) { e(node, 'css_expected_identifier', `Expected a valid CSS identifier\nhttps://svelte.dev/e/css_expected_identifier`); } /** * A `:global` selector cannot follow a `%name%` combinator * @param {null | number | NodeLike} node * @param {string} name * @returns {never} */ export function css_global_block_invalid_combinator(node, name) { e(node, 'css_global_block_invalid_combinator', `A \`:global\` selector cannot follow a \`${name}\` combinator\nhttps://svelte.dev/e/css_global_block_invalid_combinator`); } /** * A top-level `:global {...}` block can only contain rules, not declarations * @param {null | number | NodeLike} node * @returns {never} */ export function css_global_block_invalid_declaration(node) { e(node, 'css_global_block_invalid_declaration', `A top-level \`:global {...}\` block can only contain rules, not declarations\nhttps://svelte.dev/e/css_global_block_invalid_declaration`); } /** * A `:global` selector cannot be part of a selector list with more than one item * @param {null | number | NodeLike} node * @returns {never} */ export function css_global_block_invalid_list(node) { e(node, 'css_global_block_invalid_list', `A \`:global\` selector cannot be part of a selector list with more than one item\nhttps://svelte.dev/e/css_global_block_invalid_list`); } /** * A `:global` selector cannot modify an existing selector * @param {null | number | NodeLike} node * @returns {never} */ export function css_global_block_invalid_modifier(node) { e(node, 'css_global_block_invalid_modifier', `A \`:global\` selector cannot modify an existing selector\nhttps://svelte.dev/e/css_global_block_invalid_modifier`); } /** * A `:global` selector can only be modified if it is a descendant of other selectors * @param {null | number | NodeLike} node * @returns {never} */ export function css_global_block_invalid_modifier_start(node) { e(node, 'css_global_block_invalid_modifier_start', `A \`:global\` selector can only be modified if it is a descendant of other selectors\nhttps://svelte.dev/e/css_global_block_invalid_modifier_start`); } /** * `:global(...)` can be at the start or end of a selector sequence, but not in the middle * @param {null | number | NodeLike} node * @returns {never} */ export function css_global_invalid_placement(node) { e(node, 'css_global_invalid_placement', `\`:global(...)\` can be at the start or end of a selector sequence, but not in the middle\nhttps://svelte.dev/e/css_global_invalid_placement`); } /** * `:global(...)` must contain exactly one selector * @param {null | number | NodeLike} node * @returns {never} */ export function css_global_invalid_selector(node) { e(node, 'css_global_invalid_selector', `\`:global(...)\` must contain exactly one selector\nhttps://svelte.dev/e/css_global_invalid_selector`); } /** * `:global(...)` must not contain type or universal selectors when used in a compound selector * @param {null | number | NodeLike} node * @returns {never} */ export function css_global_invalid_selector_list(node) { e(node, 'css_global_invalid_selector_list', `\`:global(...)\` must not contain type or universal selectors when used in a compound selector\nhttps://svelte.dev/e/css_global_invalid_selector_list`); } /** * Nesting selectors can only be used inside a rule or as the first selector inside a lone `:global(...)` * @param {null | number | NodeLike} node * @returns {never} */ export function css_nesting_selector_invalid_placement(node) { e(node, 'css_nesting_selector_invalid_placement', `Nesting selectors can only be used inside a rule or as the first selector inside a lone \`:global(...)\`\nhttps://svelte.dev/e/css_nesting_selector_invalid_placement`); } /** * Invalid selector * @param {null | number | NodeLike} node * @returns {never} */ export function css_selector_invalid(node) { e(node, 'css_selector_invalid', `Invalid selector\nhttps://svelte.dev/e/css_selector_invalid`); } /** * `:global(...)` must not be followed by a type selector * @param {null | number | NodeLike} node * @returns {never} */ export function css_type_selector_invalid_placement(node) { e(node, 'css_type_selector_invalid_placement', `\`:global(...)\` must not be followed by a type selector\nhttps://svelte.dev/e/css_type_selector_invalid_placement`); } /** * An element can only have one 'animate' directive * @param {null | number | NodeLike} node * @returns {never} */ export function animation_duplicate(node) { e(node, 'animation_duplicate', `An element can only have one 'animate' directive\nhttps://svelte.dev/e/animation_duplicate`); } /** * An element that uses the `animate:` directive must be the only child of a keyed `{#each ...}` block * @param {null | number | NodeLike} node * @returns {never} */ export function animation_invalid_placement(node) { e(node, 'animation_invalid_placement', `An element that uses the \`animate:\` directive must be the only child of a keyed \`{#each ...}\` block\nhttps://svelte.dev/e/animation_invalid_placement`); } /** * An element that uses the `animate:` directive must be the only child of a keyed `{#each ...}` block. Did you forget to add a key to your each block? * @param {null | number | NodeLike} node * @returns {never} */ export function animation_missing_key(node) { e(node, 'animation_missing_key', `An element that uses the \`animate:\` directive must be the only child of a keyed \`{#each ...}\` block. Did you forget to add a key to your each block?\nhttps://svelte.dev/e/animation_missing_key`); } /** * 'contenteditable' attribute cannot be dynamic if element uses two-way binding * @param {null | number | NodeLike} node * @returns {never} */ export function attribute_contenteditable_dynamic(node) { e(node, 'attribute_contenteditable_dynamic', `'contenteditable' attribute cannot be dynamic if element uses two-way binding\nhttps://svelte.dev/e/attribute_contenteditable_dynamic`); } /** * 'contenteditable' attribute is required for textContent, innerHTML and innerText two-way bindings * @param {null | number | NodeLike} node * @returns {never} */ export function attribute_contenteditable_missing(node) { e(node, 'attribute_contenteditable_missing', `'contenteditable' attribute is required for textContent, innerHTML and innerText two-way bindings\nhttps://svelte.dev/e/attribute_contenteditable_missing`); } /** * Attributes need to be unique * @param {null | number | NodeLike} node * @returns {never} */ export function attribute_duplicate(node) { e(node, 'attribute_duplicate', `Attributes need to be unique\nhttps://svelte.dev/e/attribute_duplicate`); } /** * Attribute shorthand cannot be empty * @param {null | number | NodeLike} node * @returns {never} */ export function attribute_empty_shorthand(node) { e(node, 'attribute_empty_shorthand', `Attribute shorthand cannot be empty\nhttps://svelte.dev/e/attribute_empty_shorthand`); } /** * Event attribute must be a JavaScript expression, not a string * @param {null | number | NodeLike} node * @returns {never} */ export function attribute_invalid_event_handler(node) { e(node, 'attribute_invalid_event_handler', `Event attribute must be a JavaScript expression, not a string\nhttps://svelte.dev/e/attribute_invalid_event_handler`); } /** * 'multiple' attribute must be static if select uses two-way binding * @param {null | number | NodeLike} node * @returns {never} */ export function attribute_invalid_multiple(node) { e(node, 'attribute_invalid_multiple', `'multiple' attribute must be static if select uses two-way binding\nhttps://svelte.dev/e/attribute_invalid_multiple`); } /** * '%name%' is not a valid attribute name * @param {null | number | NodeLike} node * @param {string} name * @returns {never} */ export function attribute_invalid_name(node, name) { e(node, 'attribute_invalid_name', `'${name}' is not a valid attribute name\nhttps://svelte.dev/e/attribute_invalid_name`); } /** * Sequence expressions are not allowed as attribute/directive values in runes mode, unless wrapped in parentheses * @param {null | number | NodeLike} node * @returns {never} */ export function attribute_invalid_sequence_expression(node) { e(node, 'attribute_invalid_sequence_expression', `Sequence expressions are not allowed as attribute/directive values in runes mode, unless wrapped in parentheses\nhttps://svelte.dev/e/attribute_invalid_sequence_expression`); } /** * 'type' attribute must be a static text value if input uses two-way binding * @param {null | number | NodeLike} node * @returns {never} */ export function attribute_invalid_type(node) { e(node, 'attribute_invalid_type', `'type' attribute must be a static text value if input uses two-way binding\nhttps://svelte.dev/e/attribute_invalid_type`); } /** * Attribute values containing `{...}` must be enclosed in quote marks, unless the value only contains the expression * @param {null | number | NodeLike} node * @returns {never} */ export function attribute_unquoted_sequence(node) { e(node, 'attribute_unquoted_sequence', `Attribute values containing \`{...}\` must be enclosed in quote marks, unless the value only contains the expression\nhttps://svelte.dev/e/attribute_unquoted_sequence`); } /** * `bind:group` can only bind to an Identifier or MemberExpression * @param {null | number | NodeLike} node * @returns {never} */ export function bind_group_invalid_expression(node) { e(node, 'bind_group_invalid_expression', `\`bind:group\` can only bind to an Identifier or MemberExpression\nhttps://svelte.dev/e/bind_group_invalid_expression`); } /** * Cannot `bind:group` to a snippet parameter * @param {null | number | NodeLike} node * @returns {never} */ export function bind_group_invalid_snippet_parameter(node) { e(node, 'bind_group_invalid_snippet_parameter', `Cannot \`bind:group\` to a snippet parameter\nhttps://svelte.dev/e/bind_group_invalid_snippet_parameter`); } /** * Can only bind to an Identifier or MemberExpression or a `{get, set}` pair * @param {null | number | NodeLike} node * @returns {never} */ export function bind_invalid_expression(node) { e(node, 'bind_invalid_expression', `Can only bind to an Identifier or MemberExpression or a \`{get, set}\` pair\nhttps://svelte.dev/e/bind_invalid_expression`); } /** * `bind:%name%` is not a valid binding. %explanation% * @param {null | number | NodeLike} node * @param {string} name * @param {string | undefined | null} [explanation] * @returns {never} */ export function bind_invalid_name(node, name, explanation) { e(node, 'bind_invalid_name', `${explanation ? `\`bind:${name}\` is not a valid binding. ${explanation}` : `\`bind:${name}\` is not a valid binding`}\nhttps://svelte.dev/e/bind_invalid_name`); } /** * `bind:%name%={get, set}` must not have surrounding parentheses * @param {null | number | NodeLike} node * @param {string} name * @returns {never} */ export function bind_invalid_parens(node, name) { e(node, 'bind_invalid_parens', `\`bind:${name}={get, set}\` must not have surrounding parentheses\nhttps://svelte.dev/e/bind_invalid_parens`); } /** * `bind:%name%` can only be used with %elements% * @param {null | number | NodeLike} node * @param {string} name * @param {string} elements * @returns {never} */ export function bind_invalid_target(node, name, elements) { e(node, 'bind_invalid_target', `\`bind:${name}\` can only be used with ${elements}\nhttps://svelte.dev/e/bind_invalid_target`); } /** * Can only bind to state or props * @param {null | number | NodeLike} node * @returns {never} */ export function bind_invalid_value(node) { e(node, 'bind_invalid_value', `Can only bind to state or props\nhttps://svelte.dev/e/bind_invalid_value`); } /** * %name% cannot appear more than once within a block * @param {null | number | NodeLike} node * @param {string} name * @returns {never} */ export function block_duplicate_clause(node, name) { e(node, 'block_duplicate_clause', `${name} cannot appear more than once within a block\nhttps://svelte.dev/e/block_duplicate_clause`); } /** * {:...} block is invalid at this position (did you forget to close the preceding element or block?) * @param {null | number | NodeLike} node * @returns {never} */ export function block_invalid_continuation_placement(node) { e(node, 'block_invalid_continuation_placement', `{:...} block is invalid at this position (did you forget to close the preceding element or block?)\nhttps://svelte.dev/e/block_invalid_continuation_placement`); } /** * 'elseif' should be 'else if' * @param {null | number | NodeLike} node * @returns {never} */ export function block_invalid_elseif(node) { e(node, 'block_invalid_elseif', `'elseif' should be 'else if'\nhttps://svelte.dev/e/block_invalid_elseif`); } /** * {#%name% ...} block cannot be %location% * @param {null | number | NodeLike} node * @param {string} name * @param {string} location * @returns {never} */ export function block_invalid_placement(node, name, location) { e(node, 'block_invalid_placement', `{#${name} ...} block cannot be ${location}\nhttps://svelte.dev/e/block_invalid_placement`); } /** * Block was left open * @param {null | number | NodeLike} node * @returns {never} */ export function block_unclosed(node) { e(node, 'block_unclosed', `Block was left open\nhttps://svelte.dev/e/block_unclosed`); } /** * Expected a `%character%` character immediately following the opening bracket * @param {null | number | NodeLike} node * @param {string} character * @returns {never} */ export function block_unexpected_character(node, character) { e(node, 'block_unexpected_character', `Expected a \`${character}\` character immediately following the opening bracket\nhttps://svelte.dev/e/block_unexpected_character`); } /** * Unexpected block closing tag * @param {null | number | NodeLike} node * @returns {never} */ export function block_unexpected_close(node) { e(node, 'block_unexpected_close', `Unexpected block closing tag\nhttps://svelte.dev/e/block_unexpected_close`); } /** * This type of directive is not valid on components * @param {null | number | NodeLike} node * @returns {never} */ export function component_invalid_directive(node) { e(node, 'component_invalid_directive', `This type of directive is not valid on components\nhttps://svelte.dev/e/component_invalid_directive`); } /** * Cyclical dependency detected: %cycle% * @param {null | number | NodeLike} node * @param {string} cycle * @returns {never} */ export function const_tag_cycle(node, cycle) { e(node, 'const_tag_cycle', `Cyclical dependency detected: ${cycle}\nhttps://svelte.dev/e/const_tag_cycle`); } /** * {@const ...} must consist of a single variable declaration * @param {null | number | NodeLike} node * @returns {never} */ export function const_tag_invalid_expression(node) { e(node, 'const_tag_invalid_expression', `{@const ...} must consist of a single variable declaration\nhttps://svelte.dev/e/const_tag_invalid_expression`); } /** * `{@const}` must be the immediate child of `{#snippet}`, `{#if}`, `{:else if}`, `{:else}`, `{#each}`, `{:then}`, `{:catch}`, `<svelte:fragment>`, `<svelte:boundary` or `<Component>` * @param {null | number | NodeLike} node * @returns {never} */ export function const_tag_invalid_placement(node) { e(node, 'const_tag_invalid_placement', `\`{@const}\` must be the immediate child of \`{#snippet}\`, \`{#if}\`, \`{:else if}\`, \`{:else}\`, \`{#each}\`, \`{:then}\`, \`{:catch}\`, \`<svelte:fragment>\`, \`<svelte:boundary\` or \`<Component>\`\nhttps://svelte.dev/e/const_tag_invalid_placement`); } /** * {@debug ...} arguments must be identifiers, not arbitrary expressions * @param {null | number | NodeLike} node * @returns {never} */ export function debug_tag_invalid_arguments(node) { e(node, 'debug_tag_invalid_arguments', `{@debug ...} arguments must be identifiers, not arbitrary expressions\nhttps://svelte.dev/e/debug_tag_invalid_arguments`); } /** * Directive value must be a JavaScript expression enclosed in curly braces * @param {null | number | NodeLike} node * @returns {never} */ export function directive_invalid_value(node) { e(node, 'directive_invalid_value', `Directive value must be a JavaScript expression enclosed in curly braces\nhttps://svelte.dev/e/directive_invalid_value`); } /** * `%type%` name cannot be empty * @param {null | number | NodeLike} node * @param {string} type * @returns {never} */ export function directive_missing_name(node, type) { e(node, 'directive_missing_name', `\`${type}\` name cannot be empty\nhttps://svelte.dev/e/directive_missing_name`); } /** * `</%name%>` attempted to close an element that was not open * @param {null | number | NodeLike} node * @param {string} name * @returns {never} */ export function element_invalid_closing_tag(node, name) { e(node, 'element_invalid_closing_tag', `\`</${name}>\` attempted to close an element that was not open\nhttps://svelte.dev/e/element_invalid_closing_tag`); } /** * `</%name%>` attempted to close element that was already automatically closed by `<%reason%>` (cannot nest `<%reason%>` inside `<%name%>`) * @param {null | number | NodeLike} node * @param {string} name * @param {string} reason * @returns {never} */ export function element_invalid_closing_tag_autoclosed(node, name, reason) { e(node, 'element_invalid_closing_tag_autoclosed', `\`</${name}>\` attempted to close element that was already automatically closed by \`<${reason}>\` (cannot nest \`<${reason}>\` inside \`<${name}>\`)\nhttps://svelte.dev/e/element_invalid_closing_tag_autoclosed`); } /** * `<%name%>` was left open * @param {null | number | NodeLike} node * @param {string} name * @returns {never} */ export function element_unclosed(node, name) { e(node, 'element_unclosed', `\`<${name}>\` was left open\nhttps://svelte.dev/e/element_unclosed`); } /** * Event modifiers other than 'once' can only be used on DOM elements * @param {null | number | NodeLike} node * @returns {never} */ export function event_handler_invalid_component_modifier(node) { e(node, 'event_handler_invalid_component_modifier', `Event modifiers other than 'once' can only be used on DOM elements\nhttps://svelte.dev/e/event_handler_invalid_component_modifier`); } /** * Valid event modifiers are %list% * @param {null | number | NodeLike} node * @param {string} list * @returns {never} */ export function event_handler_invalid_modifier(node, list) { e(node, 'event_handler_invalid_modifier', `Valid event modifiers are ${list}\nhttps://svelte.dev/e/event_handler_invalid_modifier`); } /** * The '%modifier1%' and '%modifier2%' modifiers cannot be used together * @param {null | number | NodeLike} node * @param {string} modifier1 * @param {string} modifier2 * @returns {never} */ export function event_handler_invalid_modifier_combination(node, modifier1, modifier2) { e(node, 'event_handler_invalid_modifier_combination', `The '${modifier1}' and '${modifier2}' modifiers cannot be used together\nhttps://svelte.dev/e/event_handler_invalid_modifier_combination`); } /** * Expected attribute value * @param {null | number | NodeLike} node * @returns {never} */ export function expected_attribute_value(node) { e(node, 'expected_attribute_value', `Expected attribute value\nhttps://svelte.dev/e/expected_attribute_value`); } /** * Expected 'if', 'each', 'await', 'key' or 'snippet' * @param {null | number | NodeLike} node * @returns {never} */ export function expected_block_type(node) { e(node, 'expected_block_type', `Expected 'if', 'each', 'await', 'key' or 'snippet'\nhttps://svelte.dev/e/expected_block_type`); } /** * Expected an identifier * @param {null | number | NodeLike} node * @returns {never} */ export function expected_identifier(node) { e(node, 'expected_identifier', `Expected an identifier\nhttps://svelte.dev/e/expected_identifier`); } /** * Expected identifier or destructure pattern * @param {null | number | NodeLike} node * @returns {never} */ export function expected_pattern(node) { e(node, 'expected_pattern', `Expected identifier or destructure pattern\nhttps://svelte.dev/e/expected_pattern`); } /** * Expected token %token% * @param {null | number | NodeLike} node * @param {string} token * @returns {never} */ export function expected_token(node, token) { e(node, 'expected_token', `Expected token ${token}\nhttps://svelte.dev/e/expected_token`); } /** * Expected whitespace * @param {null | number | NodeLike} node * @returns {never} */ export function expected_whitespace(node) { e(node, 'expected_whitespace', `Expected whitespace\nhttps://svelte.dev/e/expected_whitespace`); } /** * `<%name%>` does not support non-event attributes or spread attributes * @param {null | number | NodeLike} node * @param {string} name * @returns {never} */ export function illegal_element_attribute(node, name) { e(node, 'illegal_element_attribute', `\`<${name}>\` does not support non-event attributes or spread attributes\nhttps://svelte.dev/e/illegal_element_attribute`); } /** * %message% * @param {null | number | NodeLike} node * @param {string} message * @returns {never} */ export function js_parse_error(node, message) { e(node, 'js_parse_error', `${message}\nhttps://svelte.dev/e/js_parse_error`); } /** * `let:` directive at invalid position * @param {null | number | NodeLike} node * @returns {never} */ export function let_directive_invalid_placement(node) { e(node, 'let_directive_invalid_placement', `\`let:\` directive at invalid position\nhttps://svelte.dev/e/let_directive_invalid_placement`); } /** * Mixing old (on:%name%) and new syntaxes for event handling is not allowed. Use only the on%name% syntax * @param {null | number | NodeLike} node * @param {string} name * @returns {never} */ export function mixed_event_handler_syntaxes(node, name) { e(node, 'mixed_event_handler_syntaxes', `Mixing old (on:${name}) and new syntaxes for event handling is not allowed. Use only the on${name} syntax\nhttps://svelte.dev/e/mixed_event_handler_syntaxes`); } /** * %message%. The browser will 'repair' the HTML (by moving, removing, or inserting elements) which breaks Svelte's assumptions about the structure of your components. * @param {null | number | NodeLike} node * @param {string} message * @returns {never} */ export function node_invalid_placement(node, message) { e(node, 'node_invalid_placement', `${message}. The browser will 'repair' the HTML (by moving, removing, or inserting elements) which breaks Svelte's assumptions about the structure of your components.\nhttps://svelte.dev/e/node_invalid_placement`); } /** * Calling a snippet function using apply, bind or call is not allowed * @param {null | number | NodeLike} node * @returns {never} */ export function render_tag_invalid_call_expression(node) { e(node, 'render_tag_invalid_call_expression', `Calling a snippet function using apply, bind or call is not allowed\nhttps://svelte.dev/e/render_tag_invalid_call_expression`); } /** * `{@render ...}` tags can only contain call expressions * @param {null | number | NodeLike} node * @returns {never} */ export function render_tag_invalid_expression(node) { e(node, 'render_tag_invalid_expression', `\`{@render ...}\` tags can only contain call expressions\nhttps://svelte.dev/e/render_tag_invalid_expression`); } /** * cannot use spread arguments in `{@render ...}` tags * @param {null | number | NodeLike} node * @returns {never} */ export function render_tag_invalid_spread_argument(node) { e(node, 'render_tag_invalid_spread_argument', `cannot use spread arguments in \`{@render ...}\` tags\nhttps://svelte.dev/e/render_tag_invalid_spread_argument`); } /** * A component can have a single top-level `<script>` element and/or a single top-level `<script module>` element * @param {null | number | NodeLike} node * @returns {never} */ export function script_duplicate(node) { e(node, 'script_duplicate', `A component can have a single top-level \`<script>\` element and/or a single top-level \`<script module>\` element\nhttps://svelte.dev/e/script_duplicate`); } /** * If the `%name%` attribute is supplied, it must be a boolean attribute * @param {null | number | NodeLike} node * @param {string} name * @returns {never} */ export function script_invalid_attribute_value(node, name) { e(node, 'script_invalid_attribute_value', `If the \`${name}\` attribute is supplied, it must be a boolean attribute\nhttps://svelte.dev/e/script_invalid_attribute_value`); } /** * If the context attribute is supplied, its value must be "module" * @param {null | number | NodeLike} node * @returns {never} */ export function script_invalid_context(node) { e(node, 'script_invalid_context', `If the context attribute is supplied, its value must be "module"\nhttps://svelte.dev/e/script_invalid_context`); } /** * The `%name%` attribute is reserved and cannot be used * @param {null | number | NodeLike} node * @param {string} name * @returns {never} */ export function script_reserved_attribute(node, name) { e(node, 'script_reserved_attribute', `The \`${name}\` attribute is reserved and cannot be used\nhttps://svelte.dev/e/script_reserved_attribute`); } /** * Duplicate slot name '%name%' in <%component%> * @param {null | number | NodeLike} node * @param {string} name * @param {string} component * @returns {never} */ export function slot_attribute_duplicate(node, name, component) { e(node, 'slot_attribute_duplicate', `Duplicate slot name '${name}' in <${component}>\nhttps://svelte.dev/e/slot_attribute_duplicate`); } /** * slot attribute must be a static value * @param {null | number | NodeLike} node * @returns {never} */ export function slot_attribute_invalid(node) { e(node, 'slot_attribute_invalid', `slot attribute must be a static value\nhttps://svelte.dev/e/slot_attribute_invalid`); } /** * Element with a slot='...' attribute must be a child of a component or a descendant of a custom element * @param {null | number | NodeLike} node * @returns {never} */ export function slot_attribute_invalid_placement(node) { e(node, 'slot_attribute_invalid_placement', `Element with a slot='...' attribute must be a child of a component or a descendant of a custom element\nhttps://svelte.dev/e/slot_attribute_invalid_placement`); } /** * Found default slot content alongside an explicit slot="default" * @param {null | number | NodeLike} node * @returns {never} */ export function slot_default_duplicate(node) { e(node, 'slot_default_duplicate', `Found default slot content alongside an explicit slot="default"\nhttps://svelte.dev/e/slot_default_duplicate`); } /** * `<slot>` can only receive attributes and (optionally) let directives * @param {null | number | NodeLike} node * @returns {never} */ export function slot_element_invalid_attribute(node) { e(node, 'slot_element_invalid_attribute', `\`<slot>\` can only receive attributes and (optionally) let directives\nhttps://svelte.dev/e/slot_element_invalid_attribute`); } /** * slot attribute must be a static value * @param {null | number | NodeLike} node * @returns {never} */ export function slot_element_invalid_name(node) { e(node, 'slot_element_invalid_name', `slot attribute must be a static value\nhttps://svelte.dev/e/slot_element_invalid_name`); } /** * `default` is a reserved word — it cannot be used as a slot name * @param {null | number | NodeLike} node * @returns {never} */ export function slot_element_invalid_name_default(node) { e(node, 'slot_element_invalid_name_default', `\`default\` is a reserved word — it cannot be used as a slot name\nhttps://svelte.dev/e/slot_element_invalid_name_default`); } /** * Cannot use `<slot>` syntax and `{@render ...}` tags in the same component. Migrate towards `{@render ...}` tags completely * @param {null | number | NodeLike} node * @returns {never} */ export function slot_snippet_conflict(node) { e(node, 'slot_snippet_conflict', `Cannot use \`<slot>\` syntax and \`{@render ...}\` tags in the same component. Migrate towards \`{@render ...}\` tags completely\nhttps://svelte.dev/e/slot_snippet_conflict`); } /** * Cannot use explicit children snippet at the same time as implicit children content. Remove either the non-whitespace content or the children snippet block * @param {null | number | NodeLike} node * @returns {never} */ export function snippet_conflict(node) { e(node, 'snippet_conflict', `Cannot use explicit children snippet at the same time as implicit children content. Remove either the non-whitespace content or the children snippet block\nhttps://svelte.dev/e/snippet_conflict`); } /** * Snippets do not support rest parameters; use an array instead * @param {null | number | NodeLike} node * @returns {never} */ export function snippet_invalid_rest_parameter(node) { e(node, 'snippet_invalid_rest_parameter', `Snippets do not support rest parameters; use an array instead\nhttps://svelte.dev/e/snippet_invalid_rest_parameter`); } /** * This snippet is shadowing the prop `%prop%` with the same name * @param {null | number | NodeLike} node * @param {string} prop * @returns {never} */ export function snippet_shadowing_prop(node, prop) { e(node, 'snippet_shadowing_prop', `T