chore: handle option warnings the same as others (#11303)

pull/11307/head
Rich Harris 9 months ago committed by GitHub
parent f6dfac985c
commit eea5c8ff95
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -1,3 +1,23 @@
## missing_custom_element_compile_option ## options_deprecated_immutable
The 'customElement' option is used when generating a custom element. Did you forget the 'customElement: true' compile option? The `immutable` option has been deprecated. It will have no effect in runes mode
## options_missing_custom_element
The `customElement` option is used when generating a custom element. Did you forget the `customElement: true` compile option?
## options_renamed_ssr_dom
`generate: "dom"` and `generate: "ssr"` options have been renamed to "client" and "server" respectively
## options_removed_enable_sourcemap
The `enableSourcemap` option has been removed. Source maps are always generated now, and tooling can choose to ignore them
## options_removed_hydratable
The `hydratable` option has been removed. Svelte components are always hydratable now
## options_removed_loop_guard_timeout
The `loopGuardTimeout` option has been removed

@ -31,7 +31,7 @@ export function reset_warnings(options) {
*/ */
function w(node, code, message) { function w(node, code, message) {
// @ts-expect-error // @ts-expect-error
if (node.ignores?.has(code)) return; if (node?.ignores?.has(code)) return;
warnings.push({ warnings.push({
code, code,

@ -396,7 +396,7 @@ export function analyze_component(root, source, options) {
}; };
if (!options.customElement && root.options?.customElement) { if (!options.customElement && root.options?.customElement) {
w.missing_custom_element_compile_option(root.options); w.options_missing_custom_element(root.options);
} }
if (analysis.runes) { if (analysis.runes) {

@ -1,4 +1,5 @@
import * as e from './errors.js'; import * as e from './errors.js';
import * as w from './warnings.js';
/** /**
* @template [Input=any] * @template [Input=any]
@ -13,9 +14,7 @@ const common = {
generate: validator('client', (input, keypath) => { generate: validator('client', (input, keypath) => {
if (input === 'dom' || input === 'ssr') { if (input === 'dom' || input === 'ssr') {
warn( warn_once(w.options_renamed_ssr_dom);
'`generate: "dom"` and `generate: "ssr"` options have been renamed to "client" and "server" respectively'
);
return input === 'dom' ? 'client' : 'server'; return input === 'dom' ? 'client' : 'server';
} }
@ -72,16 +71,13 @@ export const validate_component_options =
discloseVersion: boolean(true), discloseVersion: boolean(true),
immutable: deprecate( immutable: deprecate(w.options_deprecated_immutable, boolean(false)),
'The immutable option has been deprecated. It has no effect in runes mode.',
boolean(false)
),
legacy: object({ legacy: object({
componentApi: boolean(false) componentApi: boolean(false)
}), }),
loopGuardTimeout: warn_removed('The loopGuardTimeout option has been removed.'), loopGuardTimeout: warn_removed(w.options_removed_loop_guard_timeout),
name: string(undefined), name: string(undefined),
@ -103,12 +99,8 @@ export const validate_component_options =
return input; return input;
}), }),
enableSourcemap: warn_removed( enableSourcemap: warn_removed(w.options_removed_enable_sourcemap),
'The enableSourcemap option has been removed. Source maps are always generated now, and tooling can choose to ignore them.' hydratable: warn_removed(w.options_removed_hydratable),
),
hydratable: warn_removed(
'The hydratable option has been removed. Svelte components are always hydratable now.'
),
format: removed( format: removed(
'The format option has been removed in Svelte 4, the compiler only outputs ESM now. Remove "format" from your compiler options. ' + 'The format option has been removed in Svelte 4, the compiler only outputs ESM now. Remove "format" from your compiler options. ' +
'If you did not set this yourself, bump the version of your bundler plugin (vite-plugin-svelte/rollup-plugin-svelte/svelte-loader)' 'If you did not set this yourself, bump the version of your bundler plugin (vite-plugin-svelte/rollup-plugin-svelte/svelte-loader)'
@ -149,34 +141,33 @@ function removed(msg) {
const warned = new Set(); const warned = new Set();
/** @param {string} message */ /** @param {(node: null) => void} fn */
function warn(message) { function warn_once(fn) {
if (!warned.has(message)) { if (!warned.has(fn)) {
warned.add(message); warned.add(fn);
// eslint-disable-next-line no-console fn(null);
console.warn(message);
} }
} }
/** /**
* @param {string} message * @param {(node: null) => void} fn
* @returns {Validator} * @returns {Validator}
*/ */
function warn_removed(message) { function warn_removed(fn) {
return (input) => { return (input) => {
if (input !== undefined) warn(message); if (input !== undefined) warn_once(fn);
return /** @type {any} */ (undefined); return /** @type {any} */ (undefined);
}; };
} }
/** /**
* @param {string} message * @param {(node: null) => void} fn
* @param {Validator} validator * @param {Validator} validator
* @returns {Validator} * @returns {Validator}
*/ */
function deprecate(message, validator) { function deprecate(fn, validator) {
return (input, keypath) => { return (input, keypath) => {
if (input !== undefined) warn(message); if (input !== undefined) warn_once(fn);
return validator(input, keypath); return validator(input, keypath);
}; };
} }

@ -29,7 +29,7 @@ export function reset_warnings(options) {
*/ */
function w(node, code, message) { function w(node, code, message) {
// @ts-expect-error // @ts-expect-error
if (node.ignores?.has(code)) return; if (node?.ignores?.has(code)) return;
warnings.push({ warnings.push({
code, code,
@ -545,11 +545,51 @@ export function invalid_self_closing_tag(node, name) {
} }
/** /**
* The 'customElement' option is used when generating a custom element. Did you forget the 'customElement: true' compile option? * The `immutable` option has been deprecated. It will have no effect in runes mode
* @param {null | NodeLike} node * @param {null | NodeLike} node
*/ */
export function missing_custom_element_compile_option(node) { export function options_deprecated_immutable(node) {
w(node, "missing_custom_element_compile_option", "The 'customElement' option is used when generating a custom element. Did you forget the 'customElement: true' compile option?"); w(node, "options_deprecated_immutable", "The `immutable` option has been deprecated. It will have no effect in runes mode");
}
/**
* The `customElement` option is used when generating a custom element. Did you forget the `customElement: true` compile option?
* @param {null | NodeLike} node
*/
export function options_missing_custom_element(node) {
w(node, "options_missing_custom_element", "The `customElement` option is used when generating a custom element. Did you forget the `customElement: true` compile option?");
}
/**
* `generate: "dom"` and `generate: "ssr"` options have been renamed to "client" and "server" respectively
* @param {null | NodeLike} node
*/
export function options_renamed_ssr_dom(node) {
w(node, "options_renamed_ssr_dom", "`generate: \"dom\"` and `generate: \"ssr\"` options have been renamed to \"client\" and \"server\" respectively");
}
/**
* The `enableSourcemap` option has been removed. Source maps are always generated now, and tooling can choose to ignore them
* @param {null | NodeLike} node
*/
export function options_removed_enable_sourcemap(node) {
w(node, "options_removed_enable_sourcemap", "The `enableSourcemap` option has been removed. Source maps are always generated now, and tooling can choose to ignore them");
}
/**
* The `hydratable` option has been removed. Svelte components are always hydratable now
* @param {null | NodeLike} node
*/
export function options_removed_hydratable(node) {
w(node, "options_removed_hydratable", "The `hydratable` option has been removed. Svelte components are always hydratable now");
}
/**
* The `loopGuardTimeout` option has been removed
* @param {null | NodeLike} node
*/
export function options_removed_loop_guard_timeout(node) {
w(node, "options_removed_loop_guard_timeout", "The `loopGuardTimeout` option has been removed");
} }
/** /**

@ -1,7 +1,7 @@
[ [
{ {
"code": "missing_custom_element_compile_option", "code": "options_missing_custom_element",
"message": "The 'customElement' option is used when generating a custom element. Did you forget the 'customElement: true' compile option?", "message": "The `customElement` option is used when generating a custom element. Did you forget the `customElement: true` compile option?",
"start": { "start": {
"line": 1, "line": 1,
"column": 0 "column": 0

Loading…
Cancel
Save