lumen-plus 0.0.5 → 0.0.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/Alert/Alert.svelte +1 -1
- package/dist/components/Autocomplete/Autocomplete.svelte +1 -1
- package/dist/components/Backtop/Backtop.svelte +1 -1
- package/dist/components/Breadcrumb/Breadcrumb.svelte +1 -1
- package/dist/components/Button/Button.svelte +1 -1
- package/dist/components/Calendar/Calendar.svelte +1 -1
- package/dist/components/Carousel/Carousel.svelte +1 -1
- package/dist/components/Cascader/Cascader.svelte +1 -1
- package/dist/components/Checkbox/Checkbox.svelte +1 -1
- package/dist/components/Collapse/CollapseItem.svelte +1 -1
- package/dist/components/ColorPicker/ColorPicker.svelte +1 -1
- package/dist/components/DatePicker/DatePicker.svelte +1 -1
- package/dist/components/DateTimePicker/DateTimePicker.svelte +1 -1
- package/dist/components/Dialog/Dialog.svelte +1 -1
- package/dist/components/Drawer/Drawer.svelte +1 -1
- package/dist/components/Dropdown/Dropdown.svelte +1 -1
- package/dist/components/Image/Image.svelte +1 -1
- package/dist/components/Input/Input.svelte +1 -1
- package/dist/components/InputNumber/InputNumber.svelte +1 -1
- package/dist/components/InputTag/InputTag.svelte +1 -1
- package/dist/components/Loading/Loading.svelte +1 -1
- package/dist/components/Menu/Menu.svelte +1 -1
- package/dist/components/Message/MessageBox.svelte +1 -1
- package/dist/components/MessageBox/MessageBox.svelte +2 -2
- package/dist/components/Notification/Notification.svelte +1 -1
- package/dist/components/Pagination/Pagination.svelte +4 -4
- package/dist/components/Popconfirm/Popconfirm.svelte +2 -2
- package/dist/components/Result/Result.svelte +1 -1
- package/dist/components/Select/Select.svelte +1 -1
- package/dist/components/Slider/Slider.svelte +1 -1
- package/dist/components/Steps/Step.svelte +1 -1
- package/dist/components/Switch/Switch.svelte +1 -1
- package/dist/components/Table/Table.svelte +5 -5
- package/dist/components/Tabs/Tabs.svelte +1 -1
- package/dist/components/Tag/Tag.svelte +1 -1
- package/dist/components/Textarea/Textarea.svelte +1 -1
- package/dist/components/TimePicker/TimePicker.svelte +1 -1
- package/dist/components/Transfer/Transfer.svelte +2 -2
- package/dist/components/Tree/TreeNode.svelte +2 -2
- package/dist/components/TreeSelect/TreeSelect.svelte +3 -3
- package/dist/components/Upload/Upload.svelte +1 -1
- package/dist/utils/node_modules/.bin/tsc +2 -0
- package/dist/utils/node_modules/.bin/tsserver +2 -0
- package/dist/utils/node_modules/svelte/LICENSE.md +7 -0
- package/dist/utils/node_modules/svelte/README.md +41 -0
- package/dist/utils/node_modules/svelte/compiler/index.js +1 -0
- package/dist/utils/node_modules/svelte/compiler/package.json +3 -0
- package/dist/utils/node_modules/svelte/package.json +184 -0
- package/dist/utils/node_modules/svelte/src/animate/index.js +78 -0
- package/dist/utils/node_modules/svelte/src/attachments/index.js +113 -0
- package/dist/utils/node_modules/svelte/src/compiler/errors.js +1719 -0
- package/dist/utils/node_modules/svelte/src/compiler/index.js +198 -0
- package/dist/utils/node_modules/svelte/src/compiler/legacy.js +632 -0
- package/dist/utils/node_modules/svelte/src/compiler/migrate/index.js +1996 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/acorn.js +198 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/index.js +326 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/read/context.js +116 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/read/expression.js +93 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/read/options.js +261 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/read/script.js +97 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/read/style.js +633 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/remove_typescript_nodes.js +180 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/state/element.js +877 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/state/fragment.js +17 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/state/tag.js +751 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/state/text.js +23 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/utils/bracket.js +213 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/utils/create.js +16 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/utils/entities.js +2234 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/utils/fuzzymatch.js +280 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/1-parse/utils/html.js +127 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/css/css-analyze.js +331 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/css/css-prune.js +1160 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/css/css-warn.js +47 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/css/utils.js +177 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/index.js +1283 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/utils/check_graph_for_cycles.js +47 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/AnimateDirective.js +15 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ArrowFunctionExpression.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/AssignmentExpression.js +31 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/AttachTag.js +17 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/Attribute.js +66 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/AwaitBlock.js +48 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/AwaitExpression.js +150 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/BindDirective.js +280 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/CallExpression.js +339 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ClassBody.js +156 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ClassDeclaration.js +25 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ClassDirective.js +13 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/Component.js +26 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ConstTag.js +45 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/DebugTag.js +15 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/EachBlock.js +97 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ExportDefaultDeclaration.js +20 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ExportNamedDeclaration.js +70 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ExportSpecifier.js +30 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ExpressionStatement.js +38 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ExpressionTag.js +26 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/Fragment.js +10 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/FunctionDeclaration.js +16 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/FunctionExpression.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/HtmlTag.js +19 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/Identifier.js +193 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/IfBlock.js +27 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ImportDeclaration.js +31 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/KeyBlock.js +21 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/LabeledStatement.js +95 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/LetDirective.js +24 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/Literal.js +14 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/MemberExpression.js +28 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/NewExpression.js +17 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/OnDirective.js +28 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/PropertyDefinition.js +21 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/RegularElement.js +210 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/RenderTag.js +68 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SlotElement.js +42 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SnippetBlock.js +113 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SpreadAttribute.js +13 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SpreadElement.js +16 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/StyleDirective.js +39 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteBody.js +22 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteBoundary.js +30 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteComponent.js +18 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteDocument.js +24 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteElement.js +78 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteFragment.js +27 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteHead.js +18 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteSelf.js +36 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/SvelteWindow.js +24 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/TaggedTemplateExpression.js +16 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/TemplateElement.js +12 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/Text.js +52 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/TitleElement.js +21 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/TransitionDirective.js +19 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/UpdateExpression.js +29 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/UseDirective.js +18 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/VariableDeclarator.js +160 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/a11y/constants.js +319 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/a11y/index.js +977 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/attribute.js +125 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/component.js +177 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/element.js +160 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/fragment.js +15 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/function.js +24 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/snippets.js +17 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/special-element.js +16 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/shared/utils.js +301 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/transform-client.js +709 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/transform-template/fix-attribute-casing.js +18 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/transform-template/index.js +67 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/transform-template/template.js +162 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/utils.js +181 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/AnimateDirective.js +38 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/ArrowFunctionExpression.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/AssignmentExpression.js +225 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/AttachTag.js +26 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/Attribute.js +14 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/AwaitBlock.js +124 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/AwaitExpression.js +25 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/BinaryExpression.js +34 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/BindDirective.js +290 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/BlockStatement.js +32 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/BreakStatement.js +20 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/CallExpression.js +136 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/ClassBody.js +111 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/Comment.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/Component.js +12 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/ConstTag.js +134 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/DebugTag.js +28 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/EachBlock.js +367 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/ExportNamedDeclaration.js +19 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/ExpressionStatement.js +20 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/ForOfStatement.js +25 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/Fragment.js +181 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/FunctionDeclaration.js +12 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/FunctionExpression.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/HtmlTag.js +49 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/Identifier.js +45 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/IfBlock.js +90 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/KeyBlock.js +39 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/LabeledStatement.js +64 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/LetDirective.js +55 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/MemberExpression.js +23 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/OnDirective.js +38 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/Program.js +153 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/RegularElement.js +791 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/RenderTag.js +91 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SlotElement.js +94 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SnippetBlock.js +94 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SpreadAttribute.js +10 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteBody.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteBoundary.js +126 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteComponent.js +13 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteDocument.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteElement.js +157 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteFragment.js +17 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteHead.js +23 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteSelf.js +13 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/SvelteWindow.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/TitleElement.js +48 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/TransitionDirective.js +41 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/UpdateExpression.js +55 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/UseDirective.js +49 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/VariableDeclaration.js +422 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/shared/component.js +530 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/shared/declarations.js +53 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/shared/element.js +263 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/shared/events.js +176 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/shared/fragment.js +185 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/shared/function.js +17 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/shared/special_element.js +22 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/client/visitors/shared/utils.js +513 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/css/index.js +479 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/index.js +118 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/transform-server.js +423 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/AssignmentExpression.js +107 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/AwaitBlock.js +37 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/AwaitExpression.js +40 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/CallExpression.js +71 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/ClassBody.js +81 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/Component.js +12 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/ConstTag.js +49 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/DebugTag.js +24 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/EachBlock.js +80 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/ExpressionStatement.js +23 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/Fragment.js +53 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/HtmlTag.js +26 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/Identifier.js +19 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/IfBlock.js +39 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/KeyBlock.js +22 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/LabeledStatement.js +24 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/MemberExpression.js +19 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/Program.js +25 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/PropertyDefinition.js +37 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/RegularElement.js +255 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/RenderTag.js +51 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SlotElement.js +77 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SnippetBlock.js +29 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SpreadAttribute.js +10 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SvelteBoundary.js +71 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SvelteComponent.js +12 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SvelteElement.js +102 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SvelteFragment.js +11 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SvelteHead.js +25 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/SvelteSelf.js +12 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/TitleElement.js +21 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/UpdateExpression.js +26 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/VariableDeclaration.js +212 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/shared/component.js +360 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/shared/element.js +563 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/server/visitors/shared/utils.js +407 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/shared/assignments.js +93 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/shared/transform-async.js +114 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/3-transform/utils.js +451 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/bindings.js +227 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/css.js +14 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/nodes.js +245 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/patterns.js +27 -0
- package/dist/utils/node_modules/svelte/src/compiler/phases/scope.js +1412 -0
- package/dist/utils/node_modules/svelte/src/compiler/preprocess/decode_sourcemap.js +96 -0
- package/dist/utils/node_modules/svelte/src/compiler/preprocess/index.js +368 -0
- package/dist/utils/node_modules/svelte/src/compiler/preprocess/replace_in_code.js +72 -0
- package/dist/utils/node_modules/svelte/src/compiler/print/index.js +890 -0
- package/dist/utils/node_modules/svelte/src/compiler/state.js +144 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/assert.js +9 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/ast.js +639 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/builders.js +698 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/compile_diagnostic.js +107 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/extract_svelte_ignore.js +104 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/mapped_code.js +454 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/push_array.js +13 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/sanitize_template_string.js +7 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/slot.js +20 -0
- package/dist/utils/node_modules/svelte/src/compiler/utils/string.js +9 -0
- package/dist/utils/node_modules/svelte/src/compiler/validate-options.js +324 -0
- package/dist/utils/node_modules/svelte/src/compiler/warnings.js +845 -0
- package/dist/utils/node_modules/svelte/src/constants.js +64 -0
- package/dist/utils/node_modules/svelte/src/easing/index.js +286 -0
- package/dist/utils/node_modules/svelte/src/escaping.js +26 -0
- package/dist/utils/node_modules/svelte/src/events/index.js +1 -0
- package/dist/utils/node_modules/svelte/src/html-tree-validation.js +238 -0
- package/dist/utils/node_modules/svelte/src/index-client.js +255 -0
- package/dist/utils/node_modules/svelte/src/index-server.js +56 -0
- package/dist/utils/node_modules/svelte/src/internal/client/constants.js +73 -0
- package/dist/utils/node_modules/svelte/src/internal/client/context.js +258 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/assign.js +78 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/console-log.js +35 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/css.js +31 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/debug.js +500 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/elements.js +63 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/equality.js +101 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/hmr.js +89 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/inspect.js +72 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/legacy.js +25 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/ownership.js +81 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/tracing.js +162 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dev/validation.js +16 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/async.js +64 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/await.js +142 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/boundary.js +507 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/branches.js +227 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/css-props.js +28 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/each.js +666 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/html.js +121 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/if.js +70 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/key.js +33 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/slot.js +44 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/snippet.js +103 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/svelte-component.js +26 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/svelte-element.js +152 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/blocks/svelte-head.js +59 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/css.js +32 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/actions.js +43 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/attachments.js +33 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/attributes.js +657 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/document.js +17 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/input.js +312 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/media.js +232 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/navigator.js +11 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/props.js +22 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/select.js +159 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/shared.js +76 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/size.js +108 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/this.js +61 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/universal.js +75 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/bindings/window.js +66 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/class.js +51 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/custom-element.js +338 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/customizable-select.js +98 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/events.js +338 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/misc.js +58 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/style.js +57 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/elements/transitions.js +472 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/hydration.js +120 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/legacy/event-modifiers.js +127 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/legacy/lifecycle.js +82 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/legacy/misc.js +68 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/operations.js +260 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/reconciler.js +6 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/task.js +42 -0
- package/dist/utils/node_modules/svelte/src/internal/client/dom/template.js +388 -0
- package/dist/utils/node_modules/svelte/src/internal/client/error-handling.js +116 -0
- package/dist/utils/node_modules/svelte/src/internal/client/errors.js +491 -0
- package/dist/utils/node_modules/svelte/src/internal/client/hydratable.js +33 -0
- package/dist/utils/node_modules/svelte/src/internal/client/index.js +184 -0
- package/dist/utils/node_modules/svelte/src/internal/client/legacy.js +46 -0
- package/dist/utils/node_modules/svelte/src/internal/client/loop.js +48 -0
- package/dist/utils/node_modules/svelte/src/internal/client/proxy.js +432 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/async.js +302 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/batch.js +988 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/deriveds.js +394 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/effects.js +717 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/equality.js +31 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/props.js +430 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/sources.js +368 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/status.js +25 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/store.js +203 -0
- package/dist/utils/node_modules/svelte/src/internal/client/reactivity/utils.js +40 -0
- package/dist/utils/node_modules/svelte/src/internal/client/render.js +319 -0
- package/dist/utils/node_modules/svelte/src/internal/client/runtime.js +831 -0
- package/dist/utils/node_modules/svelte/src/internal/client/timing.js +16 -0
- package/dist/utils/node_modules/svelte/src/internal/client/validate.js +88 -0
- package/dist/utils/node_modules/svelte/src/internal/client/warnings.js +271 -0
- package/dist/utils/node_modules/svelte/src/internal/disclose-version.js +6 -0
- package/dist/utils/node_modules/svelte/src/internal/flags/async.js +3 -0
- package/dist/utils/node_modules/svelte/src/internal/flags/index.js +23 -0
- package/dist/utils/node_modules/svelte/src/internal/flags/legacy.js +3 -0
- package/dist/utils/node_modules/svelte/src/internal/flags/tracing.js +3 -0
- package/dist/utils/node_modules/svelte/src/internal/index.js +5 -0
- package/dist/utils/node_modules/svelte/src/internal/server/abort-signal.js +13 -0
- package/dist/utils/node_modules/svelte/src/internal/server/blocks/html.js +11 -0
- package/dist/utils/node_modules/svelte/src/internal/server/blocks/snippet.js +24 -0
- package/dist/utils/node_modules/svelte/src/internal/server/context.js +122 -0
- package/dist/utils/node_modules/svelte/src/internal/server/crypto.js +41 -0
- package/dist/utils/node_modules/svelte/src/internal/server/dev.js +115 -0
- package/dist/utils/node_modules/svelte/src/internal/server/errors.js +118 -0
- package/dist/utils/node_modules/svelte/src/internal/server/hydratable.js +142 -0
- package/dist/utils/node_modules/svelte/src/internal/server/hydration.js +6 -0
- package/dist/utils/node_modules/svelte/src/internal/server/index.js +490 -0
- package/dist/utils/node_modules/svelte/src/internal/server/render-context.js +86 -0
- package/dist/utils/node_modules/svelte/src/internal/server/renderer.js +770 -0
- package/dist/utils/node_modules/svelte/src/internal/server/warnings.js +29 -0
- package/dist/utils/node_modules/svelte/src/internal/shared/attributes.js +223 -0
- package/dist/utils/node_modules/svelte/src/internal/shared/clone.js +137 -0
- package/dist/utils/node_modules/svelte/src/internal/shared/dev.js +65 -0
- package/dist/utils/node_modules/svelte/src/internal/shared/errors.js +134 -0
- package/dist/utils/node_modules/svelte/src/internal/shared/utils.js +118 -0
- package/dist/utils/node_modules/svelte/src/internal/shared/validate.js +47 -0
- package/dist/utils/node_modules/svelte/src/internal/shared/warnings.js +40 -0
- package/dist/utils/node_modules/svelte/src/legacy/legacy-client.js +280 -0
- package/dist/utils/node_modules/svelte/src/legacy/legacy-server.js +112 -0
- package/dist/utils/node_modules/svelte/src/motion/index.js +32 -0
- package/dist/utils/node_modules/svelte/src/motion/spring.js +369 -0
- package/dist/utils/node_modules/svelte/src/motion/tweened.js +306 -0
- package/dist/utils/node_modules/svelte/src/motion/utils.js +7 -0
- package/dist/utils/node_modules/svelte/src/reactivity/create-subscriber.js +95 -0
- package/dist/utils/node_modules/svelte/src/reactivity/date.js +118 -0
- package/dist/utils/node_modules/svelte/src/reactivity/index-client.js +7 -0
- package/dist/utils/node_modules/svelte/src/reactivity/index-server.js +23 -0
- package/dist/utils/node_modules/svelte/src/reactivity/map.js +273 -0
- package/dist/utils/node_modules/svelte/src/reactivity/media-query.js +55 -0
- package/dist/utils/node_modules/svelte/src/reactivity/reactive-value.js +24 -0
- package/dist/utils/node_modules/svelte/src/reactivity/set.js +213 -0
- package/dist/utils/node_modules/svelte/src/reactivity/url-search-params.js +174 -0
- package/dist/utils/node_modules/svelte/src/reactivity/url.js +205 -0
- package/dist/utils/node_modules/svelte/src/reactivity/window/index.js +161 -0
- package/dist/utils/node_modules/svelte/src/server/index.js +1 -0
- package/dist/utils/node_modules/svelte/src/store/index-client.js +169 -0
- package/dist/utils/node_modules/svelte/src/store/index-server.js +101 -0
- package/dist/utils/node_modules/svelte/src/store/shared/index.js +209 -0
- package/dist/utils/node_modules/svelte/src/store/utils.js +36 -0
- package/dist/utils/node_modules/svelte/src/transition/index.js +300 -0
- package/dist/utils/node_modules/svelte/src/utils.js +491 -0
- package/dist/utils/node_modules/svelte/src/version.js +8 -0
- package/dist/utils/node_modules/typescript/LICENSE.txt +55 -0
- package/dist/utils/node_modules/typescript/README.md +50 -0
- package/dist/utils/node_modules/typescript/SECURITY.md +41 -0
- package/dist/utils/node_modules/typescript/ThirdPartyNoticeText.txt +193 -0
- package/dist/utils/node_modules/typescript/bin/tsc +2 -0
- package/dist/utils/node_modules/typescript/bin/tsserver +2 -0
- package/dist/utils/node_modules/typescript/lib/_tsc.js +133818 -0
- package/dist/utils/node_modules/typescript/lib/_tsserver.js +659 -0
- package/dist/utils/node_modules/typescript/lib/_typingsInstaller.js +222 -0
- package/dist/utils/node_modules/typescript/lib/cs/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/de/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/es/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/fr/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/it/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/ja/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/ko/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/pl/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/pt-br/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/ru/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/tr/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/tsc.js +8 -0
- package/dist/utils/node_modules/typescript/lib/tsserver.js +8 -0
- package/dist/utils/node_modules/typescript/lib/tsserverlibrary.js +21 -0
- package/dist/utils/node_modules/typescript/lib/typesMap.json +497 -0
- package/dist/utils/node_modules/typescript/lib/typescript.js +200276 -0
- package/dist/utils/node_modules/typescript/lib/typingsInstaller.js +8 -0
- package/dist/utils/node_modules/typescript/lib/watchGuard.js +53 -0
- package/dist/utils/node_modules/typescript/lib/zh-cn/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/lib/zh-tw/diagnosticMessages.generated.json +2122 -0
- package/dist/utils/node_modules/typescript/package.json +120 -0
- package/dist/utils/package.json +27 -0
- package/package.json +1 -1
package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/CallExpression.js
ADDED
|
@@ -0,0 +1,339 @@
|
|
|
1
|
+
/** @import { ArrowFunctionExpression, CallExpression, Expression, FunctionDeclaration, FunctionExpression, Identifier, VariableDeclarator } from 'estree' */
|
|
2
|
+
/** @import { AST } from '#compiler' */
|
|
3
|
+
/** @import { Context } from '../types' */
|
|
4
|
+
import { get_rune } from '../../scope.js';
|
|
5
|
+
import * as e from '../../../errors.js';
|
|
6
|
+
import { get_parent } from '../../../utils/ast.js';
|
|
7
|
+
import { is_pure, is_safe_identifier } from './shared/utils.js';
|
|
8
|
+
import { dev, locate_node, source } from '../../../state.js';
|
|
9
|
+
import * as b from '#compiler/builders';
|
|
10
|
+
import { ExpressionMetadata } from '../../nodes.js';
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* @param {CallExpression} node
|
|
14
|
+
* @param {Context} context
|
|
15
|
+
*/
|
|
16
|
+
export function CallExpression(node, context) {
|
|
17
|
+
const parent = /** @type {AST.SvelteNode} */ (get_parent(context.path, -1));
|
|
18
|
+
|
|
19
|
+
const rune = get_rune(node, context.state.scope);
|
|
20
|
+
|
|
21
|
+
if (rune && rune !== '$inspect') {
|
|
22
|
+
for (const arg of node.arguments) {
|
|
23
|
+
if (arg.type === 'SpreadElement') {
|
|
24
|
+
e.rune_invalid_spread(node, rune);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
switch (rune) {
|
|
30
|
+
case null:
|
|
31
|
+
if (!is_safe_identifier(node.callee, context.state.scope)) {
|
|
32
|
+
context.state.analysis.needs_context = true;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
break;
|
|
36
|
+
|
|
37
|
+
case '$bindable':
|
|
38
|
+
if (node.arguments.length > 1) {
|
|
39
|
+
e.rune_invalid_arguments_length(node, '$bindable', 'zero or one arguments');
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
if (
|
|
43
|
+
parent.type !== 'AssignmentPattern' ||
|
|
44
|
+
context.path.at(-3)?.type !== 'ObjectPattern' ||
|
|
45
|
+
context.path.at(-4)?.type !== 'VariableDeclarator' ||
|
|
46
|
+
get_rune(
|
|
47
|
+
/** @type {VariableDeclarator} */ (context.path.at(-4)).init,
|
|
48
|
+
context.state.scope
|
|
49
|
+
) !== '$props'
|
|
50
|
+
) {
|
|
51
|
+
e.bindable_invalid_location(node);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
// We need context in case the bound prop is stale
|
|
55
|
+
context.state.analysis.needs_context = true;
|
|
56
|
+
|
|
57
|
+
break;
|
|
58
|
+
|
|
59
|
+
case '$host':
|
|
60
|
+
if (node.arguments.length > 0) {
|
|
61
|
+
e.rune_invalid_arguments(node, '$host');
|
|
62
|
+
} else if (context.state.ast_type === 'module' || !context.state.analysis.custom_element) {
|
|
63
|
+
e.host_invalid_placement(node);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
break;
|
|
67
|
+
|
|
68
|
+
case '$props':
|
|
69
|
+
if (context.state.has_props_rune) {
|
|
70
|
+
e.props_duplicate(node, rune);
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
context.state.has_props_rune = true;
|
|
74
|
+
|
|
75
|
+
if (
|
|
76
|
+
parent.type !== 'VariableDeclarator' ||
|
|
77
|
+
context.state.ast_type !== 'instance' ||
|
|
78
|
+
context.state.scope !== context.state.analysis.instance.scope
|
|
79
|
+
) {
|
|
80
|
+
e.props_invalid_placement(node);
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
if (node.arguments.length > 0) {
|
|
84
|
+
e.rune_invalid_arguments(node, rune);
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
break;
|
|
88
|
+
|
|
89
|
+
case '$props.id': {
|
|
90
|
+
const grand_parent = get_parent(context.path, -2);
|
|
91
|
+
|
|
92
|
+
if (context.state.analysis.props_id) {
|
|
93
|
+
e.props_duplicate(node, rune);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
if (
|
|
97
|
+
parent.type !== 'VariableDeclarator' ||
|
|
98
|
+
parent.id.type !== 'Identifier' ||
|
|
99
|
+
context.state.ast_type !== 'instance' ||
|
|
100
|
+
context.state.scope !== context.state.analysis.instance.scope ||
|
|
101
|
+
grand_parent.type !== 'VariableDeclaration'
|
|
102
|
+
) {
|
|
103
|
+
e.props_id_invalid_placement(node);
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
if (node.arguments.length > 0) {
|
|
107
|
+
e.rune_invalid_arguments(node, rune);
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
context.state.analysis.props_id = parent.id;
|
|
111
|
+
|
|
112
|
+
break;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
case '$state':
|
|
116
|
+
case '$state.raw':
|
|
117
|
+
case '$derived':
|
|
118
|
+
case '$derived.by': {
|
|
119
|
+
const valid =
|
|
120
|
+
is_variable_declaration(parent, context) ||
|
|
121
|
+
is_class_property_definition(parent) ||
|
|
122
|
+
is_class_property_assignment_at_constructor_root(parent, context);
|
|
123
|
+
|
|
124
|
+
if (!valid) {
|
|
125
|
+
e.state_invalid_placement(node, rune);
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
if ((rune === '$derived' || rune === '$derived.by') && node.arguments.length !== 1) {
|
|
129
|
+
e.rune_invalid_arguments_length(node, rune, 'exactly one argument');
|
|
130
|
+
} else if (node.arguments.length > 1) {
|
|
131
|
+
e.rune_invalid_arguments_length(node, rune, 'zero or one arguments');
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
break;
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
case '$effect':
|
|
138
|
+
case '$effect.pre':
|
|
139
|
+
if (parent.type !== 'ExpressionStatement') {
|
|
140
|
+
e.effect_invalid_placement(node);
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
if (node.arguments.length !== 1) {
|
|
144
|
+
e.rune_invalid_arguments_length(node, rune, 'exactly one argument');
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
// `$effect` needs context because Svelte needs to know whether it should re-run
|
|
148
|
+
// effects that invalidate themselves, and that's determined by whether we're in runes mode
|
|
149
|
+
context.state.analysis.needs_context = true;
|
|
150
|
+
|
|
151
|
+
break;
|
|
152
|
+
|
|
153
|
+
case '$effect.tracking':
|
|
154
|
+
if (node.arguments.length !== 0) {
|
|
155
|
+
e.rune_invalid_arguments(node, rune);
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
break;
|
|
159
|
+
|
|
160
|
+
case '$effect.root':
|
|
161
|
+
if (node.arguments.length !== 1) {
|
|
162
|
+
e.rune_invalid_arguments_length(node, rune, 'exactly one argument');
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
break;
|
|
166
|
+
|
|
167
|
+
case '$effect.pending':
|
|
168
|
+
if (context.state.expression) {
|
|
169
|
+
context.state.expression.has_state = true;
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
break;
|
|
173
|
+
|
|
174
|
+
case '$inspect':
|
|
175
|
+
if (node.arguments.length < 1) {
|
|
176
|
+
e.rune_invalid_arguments_length(node, rune, 'one or more arguments');
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
break;
|
|
180
|
+
|
|
181
|
+
case '$inspect().with':
|
|
182
|
+
if (node.arguments.length !== 1) {
|
|
183
|
+
e.rune_invalid_arguments_length(node, rune, 'exactly one argument');
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
break;
|
|
187
|
+
|
|
188
|
+
case '$inspect.trace': {
|
|
189
|
+
if (node.arguments.length > 1) {
|
|
190
|
+
e.rune_invalid_arguments_length(node, rune, 'zero or one arguments');
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
const grand_parent = context.path.at(-2);
|
|
194
|
+
const fn = context.path.at(-3);
|
|
195
|
+
|
|
196
|
+
if (
|
|
197
|
+
parent.type !== 'ExpressionStatement' ||
|
|
198
|
+
grand_parent?.type !== 'BlockStatement' ||
|
|
199
|
+
!(
|
|
200
|
+
fn?.type === 'FunctionDeclaration' ||
|
|
201
|
+
fn?.type === 'FunctionExpression' ||
|
|
202
|
+
fn?.type === 'ArrowFunctionExpression'
|
|
203
|
+
) ||
|
|
204
|
+
grand_parent.body[0] !== parent
|
|
205
|
+
) {
|
|
206
|
+
e.inspect_trace_invalid_placement(node);
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
if (fn.generator) {
|
|
210
|
+
e.inspect_trace_generator(node);
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
if (dev) {
|
|
214
|
+
if (node.arguments[0]) {
|
|
215
|
+
context.state.scope.tracing = b.thunk(/** @type {Expression} */ (node.arguments[0]));
|
|
216
|
+
} else {
|
|
217
|
+
const label = get_function_label(context.path.slice(0, -2)) ?? 'trace';
|
|
218
|
+
const loc = `(${locate_node(fn)})`;
|
|
219
|
+
|
|
220
|
+
context.state.scope.tracing = b.thunk(b.literal(label + ' ' + loc));
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
context.state.analysis.tracing = true;
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
break;
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
case '$state.eager':
|
|
230
|
+
if (node.arguments.length !== 1) {
|
|
231
|
+
e.rune_invalid_arguments_length(node, rune, 'exactly one argument');
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
break;
|
|
235
|
+
|
|
236
|
+
case '$state.snapshot':
|
|
237
|
+
if (node.arguments.length !== 1) {
|
|
238
|
+
e.rune_invalid_arguments_length(node, rune, 'exactly one argument');
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
break;
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
// `$inspect(foo)` or `$derived(foo) should not trigger the `static-state-reference` warning
|
|
245
|
+
if (rune === '$derived') {
|
|
246
|
+
const expression = new ExpressionMetadata();
|
|
247
|
+
|
|
248
|
+
context.next({
|
|
249
|
+
...context.state,
|
|
250
|
+
function_depth: context.state.function_depth + 1,
|
|
251
|
+
derived_function_depth: context.state.function_depth + 1,
|
|
252
|
+
expression
|
|
253
|
+
});
|
|
254
|
+
|
|
255
|
+
if (expression.has_await) {
|
|
256
|
+
context.state.analysis.async_deriveds.add(node);
|
|
257
|
+
}
|
|
258
|
+
} else if (rune === '$inspect') {
|
|
259
|
+
context.next({ ...context.state, function_depth: context.state.function_depth + 1 });
|
|
260
|
+
} else {
|
|
261
|
+
context.next();
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
if (context.state.expression) {
|
|
265
|
+
// TODO We assume that any dependencies are stateful, which isn't necessarily the case — see
|
|
266
|
+
// https://github.com/sveltejs/svelte/issues/13266. This check also includes dependencies
|
|
267
|
+
// outside the call expression itself (e.g. `{blah && pure()}`) resulting in additional
|
|
268
|
+
// false positives, but for now we accept that trade-off
|
|
269
|
+
if (!is_pure(node.callee, context) || context.state.expression.dependencies.size > 0) {
|
|
270
|
+
context.state.expression.has_call = true;
|
|
271
|
+
context.state.expression.has_state = true;
|
|
272
|
+
}
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
/**
|
|
277
|
+
* @param {AST.SvelteNode[]} nodes
|
|
278
|
+
*/
|
|
279
|
+
function get_function_label(nodes) {
|
|
280
|
+
const fn = /** @type {FunctionExpression | FunctionDeclaration | ArrowFunctionExpression} */ (
|
|
281
|
+
nodes.at(-1)
|
|
282
|
+
);
|
|
283
|
+
|
|
284
|
+
if ((fn.type === 'FunctionDeclaration' || fn.type === 'FunctionExpression') && fn.id != null) {
|
|
285
|
+
return fn.id.name;
|
|
286
|
+
}
|
|
287
|
+
|
|
288
|
+
const parent = nodes.at(-2);
|
|
289
|
+
if (!parent) return;
|
|
290
|
+
|
|
291
|
+
if (parent.type === 'CallExpression') {
|
|
292
|
+
return source.slice(parent.callee.start, parent.callee.end) + '(...)';
|
|
293
|
+
}
|
|
294
|
+
|
|
295
|
+
if (parent.type === 'Property' && !parent.computed) {
|
|
296
|
+
return /** @type {Identifier} */ (parent.key).name;
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
if (parent.type === 'VariableDeclarator' && parent.id.type === 'Identifier') {
|
|
300
|
+
return parent.id.name;
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
|
|
304
|
+
/**
|
|
305
|
+
* @param {AST.SvelteNode} parent
|
|
306
|
+
* @param {Context} context
|
|
307
|
+
*/
|
|
308
|
+
function is_variable_declaration(parent, context) {
|
|
309
|
+
return parent.type === 'VariableDeclarator' && get_parent(context.path, -3).type !== 'ConstTag';
|
|
310
|
+
}
|
|
311
|
+
|
|
312
|
+
/**
|
|
313
|
+
* @param {AST.SvelteNode} parent
|
|
314
|
+
*/
|
|
315
|
+
function is_class_property_definition(parent) {
|
|
316
|
+
return parent.type === 'PropertyDefinition' && !parent.static && !parent.computed;
|
|
317
|
+
}
|
|
318
|
+
|
|
319
|
+
/**
|
|
320
|
+
* @param {AST.SvelteNode} node
|
|
321
|
+
* @param {Context} context
|
|
322
|
+
*/
|
|
323
|
+
function is_class_property_assignment_at_constructor_root(node, context) {
|
|
324
|
+
if (
|
|
325
|
+
node.type === 'AssignmentExpression' &&
|
|
326
|
+
node.operator === '=' &&
|
|
327
|
+
node.left.type === 'MemberExpression' &&
|
|
328
|
+
node.left.object.type === 'ThisExpression' &&
|
|
329
|
+
((node.left.property.type === 'Identifier' && !node.left.computed) ||
|
|
330
|
+
node.left.property.type === 'PrivateIdentifier' ||
|
|
331
|
+
node.left.property.type === 'Literal')
|
|
332
|
+
) {
|
|
333
|
+
// MethodDefinition (-5) -> FunctionExpression (-4) -> BlockStatement (-3) -> ExpressionStatement (-2) -> AssignmentExpression (-1)
|
|
334
|
+
const parent = get_parent(context.path, -5);
|
|
335
|
+
return parent?.type === 'MethodDefinition' && parent.kind === 'constructor';
|
|
336
|
+
}
|
|
337
|
+
|
|
338
|
+
return false;
|
|
339
|
+
}
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
/** @import { AssignmentExpression, CallExpression, ClassBody, PropertyDefinition, Expression, PrivateIdentifier, MethodDefinition } from 'estree' */
|
|
2
|
+
/** @import { StateField } from '#compiler' */
|
|
3
|
+
/** @import { Context } from '../types' */
|
|
4
|
+
import * as b from '#compiler/builders';
|
|
5
|
+
import { get_rune } from '../../scope.js';
|
|
6
|
+
import * as e from '../../../errors.js';
|
|
7
|
+
import { is_state_creation_rune } from '../../../../utils.js';
|
|
8
|
+
import { get_name } from '../../nodes.js';
|
|
9
|
+
import { regex_invalid_identifier_chars } from '../../patterns.js';
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* @param {ClassBody} node
|
|
13
|
+
* @param {Context} context
|
|
14
|
+
*/
|
|
15
|
+
export function ClassBody(node, context) {
|
|
16
|
+
if (!context.state.analysis.runes) {
|
|
17
|
+
context.next();
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
/** @type {string[]} */
|
|
22
|
+
const private_ids = [];
|
|
23
|
+
|
|
24
|
+
for (const prop of node.body) {
|
|
25
|
+
if (
|
|
26
|
+
(prop.type === 'MethodDefinition' || prop.type === 'PropertyDefinition') &&
|
|
27
|
+
prop.key.type === 'PrivateIdentifier'
|
|
28
|
+
) {
|
|
29
|
+
private_ids.push(prop.key.name);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
/** @type {Map<string, StateField>} */
|
|
34
|
+
const state_fields = new Map();
|
|
35
|
+
|
|
36
|
+
/** @type {Map<string, Array<MethodDefinition['kind'] | 'prop' | 'assigned_prop'>>} */
|
|
37
|
+
const fields = new Map();
|
|
38
|
+
|
|
39
|
+
context.state.analysis.classes.set(node, state_fields);
|
|
40
|
+
|
|
41
|
+
/** @type {MethodDefinition | null} */
|
|
42
|
+
let constructor = null;
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* @param {PropertyDefinition | AssignmentExpression} node
|
|
46
|
+
* @param {Expression | PrivateIdentifier} key
|
|
47
|
+
* @param {Expression | null | undefined} value
|
|
48
|
+
*/
|
|
49
|
+
function handle(node, key, value) {
|
|
50
|
+
const name = get_name(key);
|
|
51
|
+
if (name === null) return;
|
|
52
|
+
|
|
53
|
+
const rune = get_rune(value, context.state.scope);
|
|
54
|
+
|
|
55
|
+
if (rune && is_state_creation_rune(rune)) {
|
|
56
|
+
if (state_fields.has(name)) {
|
|
57
|
+
e.state_field_duplicate(node, name);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
const _key = (node.type === 'AssignmentExpression' || !node.static ? '' : '@') + name;
|
|
61
|
+
const field = fields.get(_key);
|
|
62
|
+
|
|
63
|
+
// if there's already a method or assigned field, error
|
|
64
|
+
if (field && !(field.length === 1 && field[0] === 'prop')) {
|
|
65
|
+
e.duplicate_class_field(node, _key);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
state_fields.set(name, {
|
|
69
|
+
node,
|
|
70
|
+
type: rune,
|
|
71
|
+
// @ts-expect-error for public state this is filled out in a moment
|
|
72
|
+
key: key.type === 'PrivateIdentifier' ? key : null,
|
|
73
|
+
value: /** @type {CallExpression} */ (value)
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
for (const child of node.body) {
|
|
79
|
+
if (child.type === 'PropertyDefinition' && !child.computed && !child.static) {
|
|
80
|
+
handle(child, child.key, child.value);
|
|
81
|
+
const key = /** @type {string} */ (get_name(child.key));
|
|
82
|
+
const field = fields.get(key);
|
|
83
|
+
if (!field) {
|
|
84
|
+
fields.set(key, [child.value ? 'assigned_prop' : 'prop']);
|
|
85
|
+
continue;
|
|
86
|
+
}
|
|
87
|
+
e.duplicate_class_field(child, key);
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
if (child.type === 'MethodDefinition') {
|
|
91
|
+
if (child.kind === 'constructor') {
|
|
92
|
+
constructor = child;
|
|
93
|
+
} else if (!child.computed) {
|
|
94
|
+
const key = (child.static ? '@' : '') + get_name(child.key);
|
|
95
|
+
const field = fields.get(key);
|
|
96
|
+
if (!field) {
|
|
97
|
+
fields.set(key, [child.kind]);
|
|
98
|
+
continue;
|
|
99
|
+
}
|
|
100
|
+
if (
|
|
101
|
+
field.includes(child.kind) ||
|
|
102
|
+
field.includes('prop') ||
|
|
103
|
+
field.includes('assigned_prop')
|
|
104
|
+
) {
|
|
105
|
+
e.duplicate_class_field(child, key);
|
|
106
|
+
}
|
|
107
|
+
if (child.kind === 'get') {
|
|
108
|
+
if (field.length === 1 && field[0] === 'set') {
|
|
109
|
+
field.push('get');
|
|
110
|
+
continue;
|
|
111
|
+
}
|
|
112
|
+
} else if (child.kind === 'set') {
|
|
113
|
+
if (field.length === 1 && field[0] === 'get') {
|
|
114
|
+
field.push('set');
|
|
115
|
+
continue;
|
|
116
|
+
}
|
|
117
|
+
} else {
|
|
118
|
+
field.push(child.kind);
|
|
119
|
+
continue;
|
|
120
|
+
}
|
|
121
|
+
e.duplicate_class_field(child, key);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
if (constructor) {
|
|
127
|
+
for (const statement of constructor.value.body.body) {
|
|
128
|
+
if (statement.type !== 'ExpressionStatement') continue;
|
|
129
|
+
if (statement.expression.type !== 'AssignmentExpression') continue;
|
|
130
|
+
|
|
131
|
+
const { left, right } = statement.expression;
|
|
132
|
+
|
|
133
|
+
if (left.type !== 'MemberExpression') continue;
|
|
134
|
+
if (left.object.type !== 'ThisExpression') continue;
|
|
135
|
+
if (left.computed && left.property.type !== 'Literal') continue;
|
|
136
|
+
|
|
137
|
+
handle(statement.expression, left.property, right);
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
for (const [name, field] of state_fields) {
|
|
142
|
+
if (name[0] === '#') {
|
|
143
|
+
continue;
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
let deconflicted = name.replace(regex_invalid_identifier_chars, '_');
|
|
147
|
+
while (private_ids.includes(deconflicted)) {
|
|
148
|
+
deconflicted = '_' + deconflicted;
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
private_ids.push(deconflicted);
|
|
152
|
+
field.key = b.private_id(deconflicted);
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
context.next({ ...context.state, state_fields });
|
|
156
|
+
}
|
package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ClassDeclaration.js
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/** @import { ClassDeclaration } from 'estree' */
|
|
2
|
+
/** @import { Context } from '../types' */
|
|
3
|
+
import * as w from '../../../warnings.js';
|
|
4
|
+
import { validate_identifier_name } from './shared/utils.js';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* @param {ClassDeclaration} node
|
|
8
|
+
* @param {Context} context
|
|
9
|
+
*/
|
|
10
|
+
export function ClassDeclaration(node, context) {
|
|
11
|
+
if (context.state.analysis.runes && node.id !== null) {
|
|
12
|
+
validate_identifier_name(context.state.scope.get(node.id.name));
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
// In modules, we allow top-level module scope only, in components, we allow the component scope,
|
|
16
|
+
// which is function_depth of 1. With the exception of `new class` which is also not allowed at
|
|
17
|
+
// component scope level either.
|
|
18
|
+
const allowed_depth = context.state.ast_type === 'module' ? 0 : 1;
|
|
19
|
+
|
|
20
|
+
if (context.state.scope.function_depth > allowed_depth) {
|
|
21
|
+
w.perf_avoid_nested_class(node);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
context.next();
|
|
25
|
+
}
|
package/dist/utils/node_modules/svelte/src/compiler/phases/2-analyze/visitors/ClassDirective.js
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/** @import { AST } from '#compiler' */
|
|
2
|
+
/** @import { Context } from '../types' */
|
|
3
|
+
|
|
4
|
+
import { mark_subtree_dynamic } from './shared/fragment.js';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* @param {AST.ClassDirective} node
|
|
8
|
+
* @param {Context} context
|
|
9
|
+
*/
|
|
10
|
+
export function ClassDirective(node, context) {
|
|
11
|
+
mark_subtree_dynamic(context.path);
|
|
12
|
+
context.next({ ...context.state, expression: node.metadata.expression });
|
|
13
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/** @import { AST } from '#compiler' */
|
|
2
|
+
/** @import { Context } from '../types' */
|
|
3
|
+
import { visit_component } from './shared/component.js';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* @param {AST.Component} node
|
|
7
|
+
* @param {Context} context
|
|
8
|
+
*/
|
|
9
|
+
export function Component(node, context) {
|
|
10
|
+
const binding = context.state.scope.get(
|
|
11
|
+
node.name.includes('.') ? node.name.slice(0, node.name.indexOf('.')) : node.name
|
|
12
|
+
);
|
|
13
|
+
|
|
14
|
+
node.metadata.dynamic =
|
|
15
|
+
context.state.analysis.runes && // Svelte 4 required you to use svelte:component to switch components
|
|
16
|
+
binding !== null &&
|
|
17
|
+
(binding.kind !== 'normal' || node.name.includes('.'));
|
|
18
|
+
|
|
19
|
+
if (binding) {
|
|
20
|
+
node.metadata.expression.has_state = node.metadata.dynamic;
|
|
21
|
+
node.metadata.expression.dependencies.add(binding);
|
|
22
|
+
node.metadata.expression.references.add(binding);
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
visit_component(node, context);
|
|
26
|
+
}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
/** @import { AST } from '#compiler' */
|
|
2
|
+
/** @import { Context } from '../types' */
|
|
3
|
+
import * as e from '../../../errors.js';
|
|
4
|
+
import { validate_opening_tag } from './shared/utils.js';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* @param {AST.ConstTag} node
|
|
8
|
+
* @param {Context} context
|
|
9
|
+
*/
|
|
10
|
+
export function ConstTag(node, context) {
|
|
11
|
+
if (context.state.analysis.runes) {
|
|
12
|
+
validate_opening_tag(node, context.state, '@');
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
const parent = context.path.at(-1);
|
|
16
|
+
const grand_parent = context.path.at(-2);
|
|
17
|
+
|
|
18
|
+
if (
|
|
19
|
+
parent?.type !== 'Fragment' ||
|
|
20
|
+
(grand_parent?.type !== 'IfBlock' &&
|
|
21
|
+
grand_parent?.type !== 'SvelteFragment' &&
|
|
22
|
+
grand_parent?.type !== 'Component' &&
|
|
23
|
+
grand_parent?.type !== 'SvelteComponent' &&
|
|
24
|
+
grand_parent?.type !== 'EachBlock' &&
|
|
25
|
+
grand_parent?.type !== 'AwaitBlock' &&
|
|
26
|
+
grand_parent?.type !== 'SnippetBlock' &&
|
|
27
|
+
grand_parent?.type !== 'SvelteBoundary' &&
|
|
28
|
+
grand_parent?.type !== 'KeyBlock' &&
|
|
29
|
+
((grand_parent?.type !== 'RegularElement' && grand_parent?.type !== 'SvelteElement') ||
|
|
30
|
+
!grand_parent.attributes.some((a) => a.type === 'Attribute' && a.name === 'slot')))
|
|
31
|
+
) {
|
|
32
|
+
e.const_tag_invalid_placement(node);
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
const declaration = node.declaration.declarations[0];
|
|
36
|
+
|
|
37
|
+
context.visit(declaration.id);
|
|
38
|
+
context.visit(declaration.init, {
|
|
39
|
+
...context.state,
|
|
40
|
+
expression: node.metadata.expression,
|
|
41
|
+
// We're treating this like a $derived under the hood
|
|
42
|
+
function_depth: context.state.function_depth + 1,
|
|
43
|
+
derived_function_depth: context.state.function_depth + 1
|
|
44
|
+
});
|
|
45
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/** @import { AST } from '#compiler' */
|
|
2
|
+
/** @import { Context } from '../types' */
|
|
3
|
+
import { validate_opening_tag } from './shared/utils.js';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* @param {AST.DebugTag} node
|
|
7
|
+
* @param {Context} context
|
|
8
|
+
*/
|
|
9
|
+
export function DebugTag(node, context) {
|
|
10
|
+
if (context.state.analysis.runes) {
|
|
11
|
+
validate_opening_tag(node, context.state, '@');
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
context.next();
|
|
15
|
+
}
|