@depup/svelte 5.53.3-depup.0

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.
Files changed (386) hide show
  1. package/LICENSE.md +7 -0
  2. package/README.md +41 -0
  3. package/action.d.ts +1 -0
  4. package/animate.d.ts +1 -0
  5. package/compiler/index.js +1 -0
  6. package/compiler/package.json +3 -0
  7. package/compiler.d.ts +1 -0
  8. package/easing.d.ts +1 -0
  9. package/elements.d.ts +2078 -0
  10. package/index.d.ts +1 -0
  11. package/legacy.d.ts +1 -0
  12. package/motion.d.ts +1 -0
  13. package/package.json +185 -0
  14. package/src/animate/index.js +78 -0
  15. package/src/attachments/index.js +113 -0
  16. package/src/compiler/errors.js +1719 -0
  17. package/src/compiler/index.js +198 -0
  18. package/src/compiler/legacy.js +637 -0
  19. package/src/compiler/migrate/index.js +1996 -0
  20. package/src/compiler/phases/1-parse/acorn.js +198 -0
  21. package/src/compiler/phases/1-parse/index.js +326 -0
  22. package/src/compiler/phases/1-parse/read/context.js +116 -0
  23. package/src/compiler/phases/1-parse/read/expression.js +93 -0
  24. package/src/compiler/phases/1-parse/read/options.js +263 -0
  25. package/src/compiler/phases/1-parse/read/script.js +97 -0
  26. package/src/compiler/phases/1-parse/read/style.js +637 -0
  27. package/src/compiler/phases/1-parse/remove_typescript_nodes.js +180 -0
  28. package/src/compiler/phases/1-parse/state/element.js +937 -0
  29. package/src/compiler/phases/1-parse/state/fragment.js +17 -0
  30. package/src/compiler/phases/1-parse/state/tag.js +751 -0
  31. package/src/compiler/phases/1-parse/state/text.js +23 -0
  32. package/src/compiler/phases/1-parse/utils/bracket.js +213 -0
  33. package/src/compiler/phases/1-parse/utils/create.js +16 -0
  34. package/src/compiler/phases/1-parse/utils/entities.js +2234 -0
  35. package/src/compiler/phases/1-parse/utils/fuzzymatch.js +281 -0
  36. package/src/compiler/phases/1-parse/utils/html.js +127 -0
  37. package/src/compiler/phases/2-analyze/css/css-analyze.js +331 -0
  38. package/src/compiler/phases/2-analyze/css/css-prune.js +1206 -0
  39. package/src/compiler/phases/2-analyze/css/css-warn.js +47 -0
  40. package/src/compiler/phases/2-analyze/css/utils.js +177 -0
  41. package/src/compiler/phases/2-analyze/index.js +1300 -0
  42. package/src/compiler/phases/2-analyze/utils/check_graph_for_cycles.js +47 -0
  43. package/src/compiler/phases/2-analyze/visitors/AnimateDirective.js +15 -0
  44. package/src/compiler/phases/2-analyze/visitors/ArrowFunctionExpression.js +11 -0
  45. package/src/compiler/phases/2-analyze/visitors/AssignmentExpression.js +31 -0
  46. package/src/compiler/phases/2-analyze/visitors/AttachTag.js +17 -0
  47. package/src/compiler/phases/2-analyze/visitors/Attribute.js +66 -0
  48. package/src/compiler/phases/2-analyze/visitors/AwaitBlock.js +48 -0
  49. package/src/compiler/phases/2-analyze/visitors/AwaitExpression.js +150 -0
  50. package/src/compiler/phases/2-analyze/visitors/BindDirective.js +280 -0
  51. package/src/compiler/phases/2-analyze/visitors/CallExpression.js +339 -0
  52. package/src/compiler/phases/2-analyze/visitors/ClassBody.js +156 -0
  53. package/src/compiler/phases/2-analyze/visitors/ClassDeclaration.js +25 -0
  54. package/src/compiler/phases/2-analyze/visitors/ClassDirective.js +13 -0
  55. package/src/compiler/phases/2-analyze/visitors/Component.js +26 -0
  56. package/src/compiler/phases/2-analyze/visitors/ConstTag.js +45 -0
  57. package/src/compiler/phases/2-analyze/visitors/DebugTag.js +15 -0
  58. package/src/compiler/phases/2-analyze/visitors/EachBlock.js +97 -0
  59. package/src/compiler/phases/2-analyze/visitors/ExportDefaultDeclaration.js +20 -0
  60. package/src/compiler/phases/2-analyze/visitors/ExportNamedDeclaration.js +70 -0
  61. package/src/compiler/phases/2-analyze/visitors/ExportSpecifier.js +30 -0
  62. package/src/compiler/phases/2-analyze/visitors/ExpressionStatement.js +38 -0
  63. package/src/compiler/phases/2-analyze/visitors/ExpressionTag.js +26 -0
  64. package/src/compiler/phases/2-analyze/visitors/Fragment.js +10 -0
  65. package/src/compiler/phases/2-analyze/visitors/FunctionDeclaration.js +16 -0
  66. package/src/compiler/phases/2-analyze/visitors/FunctionExpression.js +11 -0
  67. package/src/compiler/phases/2-analyze/visitors/HtmlTag.js +19 -0
  68. package/src/compiler/phases/2-analyze/visitors/Identifier.js +194 -0
  69. package/src/compiler/phases/2-analyze/visitors/IfBlock.js +46 -0
  70. package/src/compiler/phases/2-analyze/visitors/ImportDeclaration.js +31 -0
  71. package/src/compiler/phases/2-analyze/visitors/KeyBlock.js +21 -0
  72. package/src/compiler/phases/2-analyze/visitors/LabeledStatement.js +95 -0
  73. package/src/compiler/phases/2-analyze/visitors/LetDirective.js +24 -0
  74. package/src/compiler/phases/2-analyze/visitors/Literal.js +14 -0
  75. package/src/compiler/phases/2-analyze/visitors/MemberExpression.js +28 -0
  76. package/src/compiler/phases/2-analyze/visitors/NewExpression.js +17 -0
  77. package/src/compiler/phases/2-analyze/visitors/OnDirective.js +28 -0
  78. package/src/compiler/phases/2-analyze/visitors/PropertyDefinition.js +21 -0
  79. package/src/compiler/phases/2-analyze/visitors/RegularElement.js +240 -0
  80. package/src/compiler/phases/2-analyze/visitors/RenderTag.js +68 -0
  81. package/src/compiler/phases/2-analyze/visitors/SlotElement.js +42 -0
  82. package/src/compiler/phases/2-analyze/visitors/SnippetBlock.js +113 -0
  83. package/src/compiler/phases/2-analyze/visitors/SpreadAttribute.js +13 -0
  84. package/src/compiler/phases/2-analyze/visitors/SpreadElement.js +16 -0
  85. package/src/compiler/phases/2-analyze/visitors/StyleDirective.js +39 -0
  86. package/src/compiler/phases/2-analyze/visitors/SvelteBody.js +22 -0
  87. package/src/compiler/phases/2-analyze/visitors/SvelteBoundary.js +30 -0
  88. package/src/compiler/phases/2-analyze/visitors/SvelteComponent.js +18 -0
  89. package/src/compiler/phases/2-analyze/visitors/SvelteDocument.js +24 -0
  90. package/src/compiler/phases/2-analyze/visitors/SvelteElement.js +78 -0
  91. package/src/compiler/phases/2-analyze/visitors/SvelteFragment.js +27 -0
  92. package/src/compiler/phases/2-analyze/visitors/SvelteHead.js +18 -0
  93. package/src/compiler/phases/2-analyze/visitors/SvelteSelf.js +36 -0
  94. package/src/compiler/phases/2-analyze/visitors/SvelteWindow.js +24 -0
  95. package/src/compiler/phases/2-analyze/visitors/TaggedTemplateExpression.js +16 -0
  96. package/src/compiler/phases/2-analyze/visitors/TemplateElement.js +12 -0
  97. package/src/compiler/phases/2-analyze/visitors/Text.js +52 -0
  98. package/src/compiler/phases/2-analyze/visitors/TitleElement.js +21 -0
  99. package/src/compiler/phases/2-analyze/visitors/TransitionDirective.js +19 -0
  100. package/src/compiler/phases/2-analyze/visitors/UpdateExpression.js +29 -0
  101. package/src/compiler/phases/2-analyze/visitors/UseDirective.js +18 -0
  102. package/src/compiler/phases/2-analyze/visitors/VariableDeclarator.js +160 -0
  103. package/src/compiler/phases/2-analyze/visitors/shared/a11y/constants.js +334 -0
  104. package/src/compiler/phases/2-analyze/visitors/shared/a11y/index.js +981 -0
  105. package/src/compiler/phases/2-analyze/visitors/shared/attribute.js +125 -0
  106. package/src/compiler/phases/2-analyze/visitors/shared/component.js +177 -0
  107. package/src/compiler/phases/2-analyze/visitors/shared/element.js +160 -0
  108. package/src/compiler/phases/2-analyze/visitors/shared/fragment.js +15 -0
  109. package/src/compiler/phases/2-analyze/visitors/shared/function.js +24 -0
  110. package/src/compiler/phases/2-analyze/visitors/shared/snippets.js +17 -0
  111. package/src/compiler/phases/2-analyze/visitors/shared/special-element.js +16 -0
  112. package/src/compiler/phases/2-analyze/visitors/shared/utils.js +301 -0
  113. package/src/compiler/phases/3-transform/client/transform-client.js +719 -0
  114. package/src/compiler/phases/3-transform/client/transform-template/fix-attribute-casing.js +18 -0
  115. package/src/compiler/phases/3-transform/client/transform-template/index.js +67 -0
  116. package/src/compiler/phases/3-transform/client/transform-template/template.js +164 -0
  117. package/src/compiler/phases/3-transform/client/utils.js +181 -0
  118. package/src/compiler/phases/3-transform/client/visitors/AnimateDirective.js +38 -0
  119. package/src/compiler/phases/3-transform/client/visitors/ArrowFunctionExpression.js +11 -0
  120. package/src/compiler/phases/3-transform/client/visitors/AssignmentExpression.js +247 -0
  121. package/src/compiler/phases/3-transform/client/visitors/AttachTag.js +26 -0
  122. package/src/compiler/phases/3-transform/client/visitors/Attribute.js +14 -0
  123. package/src/compiler/phases/3-transform/client/visitors/AwaitBlock.js +124 -0
  124. package/src/compiler/phases/3-transform/client/visitors/AwaitExpression.js +25 -0
  125. package/src/compiler/phases/3-transform/client/visitors/BinaryExpression.js +34 -0
  126. package/src/compiler/phases/3-transform/client/visitors/BindDirective.js +290 -0
  127. package/src/compiler/phases/3-transform/client/visitors/BlockStatement.js +32 -0
  128. package/src/compiler/phases/3-transform/client/visitors/BreakStatement.js +20 -0
  129. package/src/compiler/phases/3-transform/client/visitors/CallExpression.js +136 -0
  130. package/src/compiler/phases/3-transform/client/visitors/ClassBody.js +111 -0
  131. package/src/compiler/phases/3-transform/client/visitors/Comment.js +11 -0
  132. package/src/compiler/phases/3-transform/client/visitors/Component.js +12 -0
  133. package/src/compiler/phases/3-transform/client/visitors/ConstTag.js +134 -0
  134. package/src/compiler/phases/3-transform/client/visitors/DebugTag.js +28 -0
  135. package/src/compiler/phases/3-transform/client/visitors/EachBlock.js +362 -0
  136. package/src/compiler/phases/3-transform/client/visitors/ExportNamedDeclaration.js +19 -0
  137. package/src/compiler/phases/3-transform/client/visitors/ExpressionStatement.js +20 -0
  138. package/src/compiler/phases/3-transform/client/visitors/ForOfStatement.js +25 -0
  139. package/src/compiler/phases/3-transform/client/visitors/Fragment.js +186 -0
  140. package/src/compiler/phases/3-transform/client/visitors/FunctionDeclaration.js +12 -0
  141. package/src/compiler/phases/3-transform/client/visitors/FunctionExpression.js +11 -0
  142. package/src/compiler/phases/3-transform/client/visitors/HtmlTag.js +53 -0
  143. package/src/compiler/phases/3-transform/client/visitors/Identifier.js +45 -0
  144. package/src/compiler/phases/3-transform/client/visitors/IfBlock.js +131 -0
  145. package/src/compiler/phases/3-transform/client/visitors/KeyBlock.js +45 -0
  146. package/src/compiler/phases/3-transform/client/visitors/LabeledStatement.js +64 -0
  147. package/src/compiler/phases/3-transform/client/visitors/LetDirective.js +55 -0
  148. package/src/compiler/phases/3-transform/client/visitors/MemberExpression.js +23 -0
  149. package/src/compiler/phases/3-transform/client/visitors/OnDirective.js +38 -0
  150. package/src/compiler/phases/3-transform/client/visitors/Program.js +153 -0
  151. package/src/compiler/phases/3-transform/client/visitors/RegularElement.js +725 -0
  152. package/src/compiler/phases/3-transform/client/visitors/RenderTag.js +95 -0
  153. package/src/compiler/phases/3-transform/client/visitors/SlotElement.js +94 -0
  154. package/src/compiler/phases/3-transform/client/visitors/SnippetBlock.js +94 -0
  155. package/src/compiler/phases/3-transform/client/visitors/SpreadAttribute.js +10 -0
  156. package/src/compiler/phases/3-transform/client/visitors/SvelteBody.js +11 -0
  157. package/src/compiler/phases/3-transform/client/visitors/SvelteBoundary.js +126 -0
  158. package/src/compiler/phases/3-transform/client/visitors/SvelteComponent.js +13 -0
  159. package/src/compiler/phases/3-transform/client/visitors/SvelteDocument.js +11 -0
  160. package/src/compiler/phases/3-transform/client/visitors/SvelteElement.js +161 -0
  161. package/src/compiler/phases/3-transform/client/visitors/SvelteFragment.js +17 -0
  162. package/src/compiler/phases/3-transform/client/visitors/SvelteHead.js +23 -0
  163. package/src/compiler/phases/3-transform/client/visitors/SvelteSelf.js +13 -0
  164. package/src/compiler/phases/3-transform/client/visitors/SvelteWindow.js +11 -0
  165. package/src/compiler/phases/3-transform/client/visitors/TitleElement.js +48 -0
  166. package/src/compiler/phases/3-transform/client/visitors/TransitionDirective.js +41 -0
  167. package/src/compiler/phases/3-transform/client/visitors/UpdateExpression.js +55 -0
  168. package/src/compiler/phases/3-transform/client/visitors/UseDirective.js +49 -0
  169. package/src/compiler/phases/3-transform/client/visitors/VariableDeclaration.js +422 -0
  170. package/src/compiler/phases/3-transform/client/visitors/shared/component.js +536 -0
  171. package/src/compiler/phases/3-transform/client/visitors/shared/declarations.js +53 -0
  172. package/src/compiler/phases/3-transform/client/visitors/shared/element.js +263 -0
  173. package/src/compiler/phases/3-transform/client/visitors/shared/events.js +180 -0
  174. package/src/compiler/phases/3-transform/client/visitors/shared/fragment.js +185 -0
  175. package/src/compiler/phases/3-transform/client/visitors/shared/function.js +17 -0
  176. package/src/compiler/phases/3-transform/client/visitors/shared/special_element.js +22 -0
  177. package/src/compiler/phases/3-transform/client/visitors/shared/utils.js +513 -0
  178. package/src/compiler/phases/3-transform/css/index.js +479 -0
  179. package/src/compiler/phases/3-transform/index.js +118 -0
  180. package/src/compiler/phases/3-transform/server/transform-server.js +428 -0
  181. package/src/compiler/phases/3-transform/server/visitors/AssignmentExpression.js +124 -0
  182. package/src/compiler/phases/3-transform/server/visitors/AwaitBlock.js +36 -0
  183. package/src/compiler/phases/3-transform/server/visitors/AwaitExpression.js +40 -0
  184. package/src/compiler/phases/3-transform/server/visitors/CallExpression.js +71 -0
  185. package/src/compiler/phases/3-transform/server/visitors/ClassBody.js +81 -0
  186. package/src/compiler/phases/3-transform/server/visitors/Component.js +13 -0
  187. package/src/compiler/phases/3-transform/server/visitors/ConstTag.js +49 -0
  188. package/src/compiler/phases/3-transform/server/visitors/DebugTag.js +24 -0
  189. package/src/compiler/phases/3-transform/server/visitors/EachBlock.js +76 -0
  190. package/src/compiler/phases/3-transform/server/visitors/ExpressionStatement.js +23 -0
  191. package/src/compiler/phases/3-transform/server/visitors/Fragment.js +53 -0
  192. package/src/compiler/phases/3-transform/server/visitors/HtmlTag.js +25 -0
  193. package/src/compiler/phases/3-transform/server/visitors/Identifier.js +24 -0
  194. package/src/compiler/phases/3-transform/server/visitors/IfBlock.js +48 -0
  195. package/src/compiler/phases/3-transform/server/visitors/KeyBlock.js +22 -0
  196. package/src/compiler/phases/3-transform/server/visitors/LabeledStatement.js +24 -0
  197. package/src/compiler/phases/3-transform/server/visitors/MemberExpression.js +19 -0
  198. package/src/compiler/phases/3-transform/server/visitors/Program.js +25 -0
  199. package/src/compiler/phases/3-transform/server/visitors/PropertyDefinition.js +37 -0
  200. package/src/compiler/phases/3-transform/server/visitors/RegularElement.js +216 -0
  201. package/src/compiler/phases/3-transform/server/visitors/RenderTag.js +45 -0
  202. package/src/compiler/phases/3-transform/server/visitors/SlotElement.js +68 -0
  203. package/src/compiler/phases/3-transform/server/visitors/SnippetBlock.js +29 -0
  204. package/src/compiler/phases/3-transform/server/visitors/SpreadAttribute.js +10 -0
  205. package/src/compiler/phases/3-transform/server/visitors/SvelteBoundary.js +139 -0
  206. package/src/compiler/phases/3-transform/server/visitors/SvelteComponent.js +12 -0
  207. package/src/compiler/phases/3-transform/server/visitors/SvelteElement.js +89 -0
  208. package/src/compiler/phases/3-transform/server/visitors/SvelteFragment.js +11 -0
  209. package/src/compiler/phases/3-transform/server/visitors/SvelteHead.js +25 -0
  210. package/src/compiler/phases/3-transform/server/visitors/SvelteSelf.js +12 -0
  211. package/src/compiler/phases/3-transform/server/visitors/TitleElement.js +21 -0
  212. package/src/compiler/phases/3-transform/server/visitors/UpdateExpression.js +35 -0
  213. package/src/compiler/phases/3-transform/server/visitors/VariableDeclaration.js +247 -0
  214. package/src/compiler/phases/3-transform/server/visitors/shared/component.js +359 -0
  215. package/src/compiler/phases/3-transform/server/visitors/shared/element.js +557 -0
  216. package/src/compiler/phases/3-transform/server/visitors/shared/utils.js +408 -0
  217. package/src/compiler/phases/3-transform/shared/assignments.js +92 -0
  218. package/src/compiler/phases/3-transform/shared/transform-async.js +114 -0
  219. package/src/compiler/phases/3-transform/utils.js +451 -0
  220. package/src/compiler/phases/bindings.js +227 -0
  221. package/src/compiler/phases/css.js +14 -0
  222. package/src/compiler/phases/nodes.js +258 -0
  223. package/src/compiler/phases/patterns.js +27 -0
  224. package/src/compiler/phases/scope.js +1432 -0
  225. package/src/compiler/preprocess/decode_sourcemap.js +96 -0
  226. package/src/compiler/preprocess/index.js +368 -0
  227. package/src/compiler/preprocess/replace_in_code.js +72 -0
  228. package/src/compiler/print/index.js +911 -0
  229. package/src/compiler/state.js +144 -0
  230. package/src/compiler/utils/assert.js +9 -0
  231. package/src/compiler/utils/ast.js +639 -0
  232. package/src/compiler/utils/builders.js +698 -0
  233. package/src/compiler/utils/compile_diagnostic.js +107 -0
  234. package/src/compiler/utils/extract_svelte_ignore.js +104 -0
  235. package/src/compiler/utils/mapped_code.js +454 -0
  236. package/src/compiler/utils/push_array.js +13 -0
  237. package/src/compiler/utils/sanitize_template_string.js +7 -0
  238. package/src/compiler/utils/slot.js +20 -0
  239. package/src/compiler/utils/string.js +9 -0
  240. package/src/compiler/validate-options.js +324 -0
  241. package/src/compiler/warnings.js +845 -0
  242. package/src/constants.js +66 -0
  243. package/src/easing/index.js +286 -0
  244. package/src/escaping.js +26 -0
  245. package/src/events/index.js +1 -0
  246. package/src/html-tree-validation.js +238 -0
  247. package/src/index-client.js +255 -0
  248. package/src/index-server.js +56 -0
  249. package/src/internal/client/constants.js +77 -0
  250. package/src/internal/client/context.js +258 -0
  251. package/src/internal/client/dev/assign.js +79 -0
  252. package/src/internal/client/dev/console-log.js +37 -0
  253. package/src/internal/client/dev/css.js +31 -0
  254. package/src/internal/client/dev/debug.js +500 -0
  255. package/src/internal/client/dev/elements.js +63 -0
  256. package/src/internal/client/dev/equality.js +101 -0
  257. package/src/internal/client/dev/hmr.js +89 -0
  258. package/src/internal/client/dev/inspect.js +72 -0
  259. package/src/internal/client/dev/legacy.js +25 -0
  260. package/src/internal/client/dev/ownership.js +81 -0
  261. package/src/internal/client/dev/tracing.js +162 -0
  262. package/src/internal/client/dev/validation.js +16 -0
  263. package/src/internal/client/dom/blocks/async.js +71 -0
  264. package/src/internal/client/dom/blocks/await.js +142 -0
  265. package/src/internal/client/dom/blocks/boundary.js +534 -0
  266. package/src/internal/client/dom/blocks/branches.js +227 -0
  267. package/src/internal/client/dom/blocks/css-props.js +28 -0
  268. package/src/internal/client/dom/blocks/each.js +723 -0
  269. package/src/internal/client/dom/blocks/html.js +128 -0
  270. package/src/internal/client/dom/blocks/if.js +82 -0
  271. package/src/internal/client/dom/blocks/key.js +40 -0
  272. package/src/internal/client/dom/blocks/slot.js +44 -0
  273. package/src/internal/client/dom/blocks/snippet.js +103 -0
  274. package/src/internal/client/dom/blocks/svelte-component.js +61 -0
  275. package/src/internal/client/dom/blocks/svelte-element.js +152 -0
  276. package/src/internal/client/dom/blocks/svelte-head.js +61 -0
  277. package/src/internal/client/dom/css.js +33 -0
  278. package/src/internal/client/dom/elements/actions.js +43 -0
  279. package/src/internal/client/dom/elements/attachments.js +33 -0
  280. package/src/internal/client/dom/elements/attributes.js +657 -0
  281. package/src/internal/client/dom/elements/bindings/document.js +17 -0
  282. package/src/internal/client/dom/elements/bindings/input.js +312 -0
  283. package/src/internal/client/dom/elements/bindings/media.js +233 -0
  284. package/src/internal/client/dom/elements/bindings/navigator.js +11 -0
  285. package/src/internal/client/dom/elements/bindings/props.js +22 -0
  286. package/src/internal/client/dom/elements/bindings/select.js +159 -0
  287. package/src/internal/client/dom/elements/bindings/shared.js +76 -0
  288. package/src/internal/client/dom/elements/bindings/size.js +107 -0
  289. package/src/internal/client/dom/elements/bindings/this.js +61 -0
  290. package/src/internal/client/dom/elements/bindings/universal.js +75 -0
  291. package/src/internal/client/dom/elements/bindings/window.js +66 -0
  292. package/src/internal/client/dom/elements/class.js +51 -0
  293. package/src/internal/client/dom/elements/custom-element.js +344 -0
  294. package/src/internal/client/dom/elements/customizable-select.js +99 -0
  295. package/src/internal/client/dom/elements/events.js +355 -0
  296. package/src/internal/client/dom/elements/misc.js +58 -0
  297. package/src/internal/client/dom/elements/style.js +57 -0
  298. package/src/internal/client/dom/elements/transitions.js +471 -0
  299. package/src/internal/client/dom/hydration.js +125 -0
  300. package/src/internal/client/dom/legacy/event-modifiers.js +127 -0
  301. package/src/internal/client/dom/legacy/lifecycle.js +82 -0
  302. package/src/internal/client/dom/legacy/misc.js +68 -0
  303. package/src/internal/client/dom/operations.js +293 -0
  304. package/src/internal/client/dom/reconciler.js +25 -0
  305. package/src/internal/client/dom/task.js +42 -0
  306. package/src/internal/client/dom/template.js +401 -0
  307. package/src/internal/client/error-handling.js +118 -0
  308. package/src/internal/client/errors.js +510 -0
  309. package/src/internal/client/hydratable.js +33 -0
  310. package/src/internal/client/index.js +183 -0
  311. package/src/internal/client/legacy.js +46 -0
  312. package/src/internal/client/loop.js +48 -0
  313. package/src/internal/client/proxy.js +432 -0
  314. package/src/internal/client/reactivity/async.js +306 -0
  315. package/src/internal/client/reactivity/batch.js +1057 -0
  316. package/src/internal/client/reactivity/deriveds.js +426 -0
  317. package/src/internal/client/reactivity/effects.js +718 -0
  318. package/src/internal/client/reactivity/equality.js +31 -0
  319. package/src/internal/client/reactivity/props.js +430 -0
  320. package/src/internal/client/reactivity/sources.js +370 -0
  321. package/src/internal/client/reactivity/status.js +25 -0
  322. package/src/internal/client/reactivity/store.js +203 -0
  323. package/src/internal/client/reactivity/utils.js +40 -0
  324. package/src/internal/client/render.js +335 -0
  325. package/src/internal/client/runtime.js +827 -0
  326. package/src/internal/client/timing.js +16 -0
  327. package/src/internal/client/validate.js +54 -0
  328. package/src/internal/client/warnings.js +271 -0
  329. package/src/internal/disclose-version.js +6 -0
  330. package/src/internal/flags/async.js +3 -0
  331. package/src/internal/flags/index.js +23 -0
  332. package/src/internal/flags/legacy.js +3 -0
  333. package/src/internal/flags/tracing.js +3 -0
  334. package/src/internal/index.js +5 -0
  335. package/src/internal/server/abort-signal.js +13 -0
  336. package/src/internal/server/blocks/html.js +11 -0
  337. package/src/internal/server/blocks/snippet.js +24 -0
  338. package/src/internal/server/context.js +132 -0
  339. package/src/internal/server/crypto.js +45 -0
  340. package/src/internal/server/dev.js +115 -0
  341. package/src/internal/server/errors.js +131 -0
  342. package/src/internal/server/hydratable.js +142 -0
  343. package/src/internal/server/hydration.js +6 -0
  344. package/src/internal/server/index.js +544 -0
  345. package/src/internal/server/render-context.js +86 -0
  346. package/src/internal/server/renderer.js +923 -0
  347. package/src/internal/server/warnings.js +29 -0
  348. package/src/internal/shared/attributes.js +225 -0
  349. package/src/internal/shared/clone.js +137 -0
  350. package/src/internal/shared/dev.js +65 -0
  351. package/src/internal/shared/errors.js +134 -0
  352. package/src/internal/shared/utils.js +144 -0
  353. package/src/internal/shared/validate.js +47 -0
  354. package/src/internal/shared/warnings.js +40 -0
  355. package/src/legacy/legacy-client.js +281 -0
  356. package/src/legacy/legacy-server.js +112 -0
  357. package/src/motion/index.js +32 -0
  358. package/src/motion/spring.js +369 -0
  359. package/src/motion/tweened.js +306 -0
  360. package/src/motion/utils.js +7 -0
  361. package/src/reactivity/create-subscriber.js +95 -0
  362. package/src/reactivity/date.js +118 -0
  363. package/src/reactivity/index-client.js +7 -0
  364. package/src/reactivity/index-server.js +23 -0
  365. package/src/reactivity/map.js +273 -0
  366. package/src/reactivity/media-query.js +55 -0
  367. package/src/reactivity/reactive-value.js +24 -0
  368. package/src/reactivity/set.js +213 -0
  369. package/src/reactivity/url-search-params.js +174 -0
  370. package/src/reactivity/url.js +205 -0
  371. package/src/reactivity/window/index.js +161 -0
  372. package/src/server/index.js +1 -0
  373. package/src/store/index-client.js +169 -0
  374. package/src/store/index-server.js +101 -0
  375. package/src/store/shared/index.js +209 -0
  376. package/src/store/utils.js +36 -0
  377. package/src/transition/index.js +300 -0
  378. package/src/utils.js +504 -0
  379. package/src/version.js +8 -0
  380. package/store.d.ts +1 -0
  381. package/svelte-html.d.ts +245 -0
  382. package/transition.d.ts +1 -0
  383. package/types/compiler/interfaces.d.ts +1 -0
  384. package/types/compiler/preprocess.d.ts +1 -0
  385. package/types/index.d.ts +3744 -0
  386. package/types/index.d.ts.map +280 -0
@@ -0,0 +1,428 @@
1
+ /** @import * as ESTree from 'estree' */
2
+ /** @import { AST, ValidatedCompileOptions, ValidatedModuleCompileOptions } from '#compiler' */
3
+ /** @import { ComponentServerTransformState, ComponentVisitors, ServerTransformState, Visitors } from './types.js' */
4
+ /** @import { Analysis, ComponentAnalysis } from '../../types.js' */
5
+ import { walk } from 'zimmerframe';
6
+ import { set_scope } from '../../scope.js';
7
+ import { extract_identifiers } from '../../../utils/ast.js';
8
+ import * as b from '#compiler/builders';
9
+ import { component_name, dev, filename } from '../../../state.js';
10
+ import { render_stylesheet } from '../css/index.js';
11
+ import { AssignmentExpression } from './visitors/AssignmentExpression.js';
12
+ import { AwaitBlock } from './visitors/AwaitBlock.js';
13
+ import { AwaitExpression } from './visitors/AwaitExpression.js';
14
+ import { CallExpression } from './visitors/CallExpression.js';
15
+ import { ClassBody } from './visitors/ClassBody.js';
16
+ import { Component } from './visitors/Component.js';
17
+ import { ConstTag } from './visitors/ConstTag.js';
18
+ import { DebugTag } from './visitors/DebugTag.js';
19
+ import { EachBlock } from './visitors/EachBlock.js';
20
+ import { ExpressionStatement } from './visitors/ExpressionStatement.js';
21
+ import { Fragment } from './visitors/Fragment.js';
22
+ import { HtmlTag } from './visitors/HtmlTag.js';
23
+ import { Identifier } from './visitors/Identifier.js';
24
+ import { IfBlock } from './visitors/IfBlock.js';
25
+ import { KeyBlock } from './visitors/KeyBlock.js';
26
+ import { LabeledStatement } from './visitors/LabeledStatement.js';
27
+ import { MemberExpression } from './visitors/MemberExpression.js';
28
+ import { Program } from './visitors/Program.js';
29
+ import { PropertyDefinition } from './visitors/PropertyDefinition.js';
30
+ import { RegularElement } from './visitors/RegularElement.js';
31
+ import { RenderTag } from './visitors/RenderTag.js';
32
+ import { SlotElement } from './visitors/SlotElement.js';
33
+ import { SnippetBlock } from './visitors/SnippetBlock.js';
34
+ import { SpreadAttribute } from './visitors/SpreadAttribute.js';
35
+ import { SvelteComponent } from './visitors/SvelteComponent.js';
36
+ import { SvelteElement } from './visitors/SvelteElement.js';
37
+ import { SvelteFragment } from './visitors/SvelteFragment.js';
38
+ import { SvelteHead } from './visitors/SvelteHead.js';
39
+ import { SvelteSelf } from './visitors/SvelteSelf.js';
40
+ import { TitleElement } from './visitors/TitleElement.js';
41
+ import { UpdateExpression } from './visitors/UpdateExpression.js';
42
+ import { VariableDeclaration } from './visitors/VariableDeclaration.js';
43
+ import { SvelteBoundary } from './visitors/SvelteBoundary.js';
44
+
45
+ /** @type {Visitors} */
46
+ const global_visitors = {
47
+ _: set_scope,
48
+ AssignmentExpression,
49
+ AwaitExpression,
50
+ CallExpression,
51
+ ClassBody,
52
+ ExpressionStatement,
53
+ Identifier,
54
+ LabeledStatement,
55
+ MemberExpression,
56
+ Program,
57
+ PropertyDefinition,
58
+ UpdateExpression,
59
+ VariableDeclaration
60
+ };
61
+
62
+ /** @type {ComponentVisitors} */
63
+ const template_visitors = {
64
+ AwaitBlock,
65
+ Component,
66
+ ConstTag,
67
+ DebugTag,
68
+ EachBlock,
69
+ Fragment,
70
+ HtmlTag,
71
+ IfBlock,
72
+ KeyBlock,
73
+ RegularElement,
74
+ RenderTag,
75
+ SlotElement,
76
+ SnippetBlock,
77
+ SpreadAttribute,
78
+ SvelteComponent,
79
+ SvelteElement,
80
+ SvelteFragment,
81
+ SvelteHead,
82
+ SvelteSelf,
83
+ TitleElement,
84
+ SvelteBoundary
85
+ };
86
+
87
+ /**
88
+ * @param {ComponentAnalysis} analysis
89
+ * @param {ValidatedCompileOptions} options
90
+ * @returns {ESTree.Program}
91
+ */
92
+ export function server_component(analysis, options) {
93
+ /** @type {ComponentServerTransformState} */
94
+ const state = {
95
+ analysis,
96
+ options,
97
+ scope: analysis.module.scope,
98
+ scopes: analysis.module.scopes,
99
+ hoisted: [b.import_all('$', 'svelte/internal/server'), ...analysis.instance_body.hoisted],
100
+ legacy_reactive_statements: new Map(),
101
+ // these are set inside the `Fragment` visitor, and cannot be used until then
102
+ init: /** @type {any} */ (null),
103
+ template: /** @type {any} */ (null),
104
+ namespace: options.namespace,
105
+ preserve_whitespace: options.preserveWhitespace,
106
+ state_fields: new Map(),
107
+ is_standalone: false,
108
+ is_instance: false
109
+ };
110
+
111
+ const module = /** @type {ESTree.Program} */ (
112
+ walk(/** @type {AST.SvelteNode} */ (analysis.module.ast), state, global_visitors)
113
+ );
114
+
115
+ const instance = /** @type {ESTree.Program} */ (
116
+ walk(
117
+ /** @type {AST.SvelteNode} */ (analysis.instance.ast),
118
+ { ...state, scopes: analysis.instance.scopes, is_instance: true },
119
+ {
120
+ ...global_visitors,
121
+ ImportDeclaration(node) {
122
+ state.hoisted.push(node);
123
+ return b.empty;
124
+ },
125
+ ExportNamedDeclaration(node, context) {
126
+ if (node.declaration) {
127
+ return context.visit(node.declaration);
128
+ }
129
+
130
+ return b.empty;
131
+ }
132
+ }
133
+ )
134
+ );
135
+
136
+ const template = /** @type {ESTree.Program} */ (
137
+ walk(
138
+ /** @type {AST.SvelteNode} */ (analysis.template.ast),
139
+ { ...state, scopes: analysis.template.scopes },
140
+ // @ts-expect-error don't know, don't care
141
+ { ...global_visitors, ...template_visitors }
142
+ )
143
+ );
144
+
145
+ /** @type {ESTree.VariableDeclarator[]} */
146
+ const legacy_reactive_declarations = [];
147
+
148
+ for (const [node] of analysis.reactive_statements) {
149
+ const statement = [...state.legacy_reactive_statements].find(([n]) => n === node);
150
+ if (statement === undefined) {
151
+ throw new Error('Could not find reactive statement');
152
+ }
153
+
154
+ if (
155
+ node.body.type === 'ExpressionStatement' &&
156
+ node.body.expression.type === 'AssignmentExpression'
157
+ ) {
158
+ for (const id of extract_identifiers(node.body.expression.left)) {
159
+ const binding = analysis.instance.scope.get(id.name);
160
+ if (binding?.kind === 'legacy_reactive') {
161
+ legacy_reactive_declarations.push(b.declarator(id));
162
+ }
163
+ }
164
+ }
165
+
166
+ instance.body.push(statement[1]);
167
+ }
168
+
169
+ if (legacy_reactive_declarations.length > 0) {
170
+ instance.body.unshift({
171
+ type: 'VariableDeclaration',
172
+ kind: 'let',
173
+ declarations: legacy_reactive_declarations
174
+ });
175
+ }
176
+
177
+ // If the component binds to a child, we need to put the template in a loop and repeat until legacy bindings are stable.
178
+ // We can remove this once the legacy syntax is gone.
179
+ if (analysis.uses_component_bindings) {
180
+ const snippets = template.body.filter(
181
+ // @ts-expect-error
182
+ (node) => node.type === 'FunctionDeclaration' && node.___snippet
183
+ );
184
+
185
+ const rest = template.body.filter(
186
+ // @ts-expect-error
187
+ (node) => node.type !== 'FunctionDeclaration' || !node.___snippet
188
+ );
189
+
190
+ template.body = [
191
+ ...snippets,
192
+ b.let('$$settled', b.true),
193
+ b.let('$$inner_renderer'),
194
+ b.function_declaration(
195
+ b.id('$$render_inner'),
196
+ [b.id('$$renderer')],
197
+ b.block(/** @type {ESTree.Statement[]} */ (rest))
198
+ ),
199
+ b.do_while(
200
+ b.unary('!', b.id('$$settled')),
201
+ b.block([
202
+ b.stmt(b.assignment('=', b.id('$$settled'), b.true)),
203
+ b.stmt(b.assignment('=', b.id('$$inner_renderer'), b.call('$$renderer.copy'))),
204
+ b.stmt(b.call('$$render_inner', b.id('$$inner_renderer')))
205
+ ])
206
+ ),
207
+ b.stmt(b.call('$$renderer.subsume', b.id('$$inner_renderer')))
208
+ ];
209
+ }
210
+
211
+ if (
212
+ [...analysis.instance.scope.declarations.values()].some(
213
+ (binding) => binding.kind === 'store_sub'
214
+ )
215
+ ) {
216
+ instance.body.unshift(b.var('$$store_subs'));
217
+ template.body.push(
218
+ b.if(b.id('$$store_subs'), b.stmt(b.call('$.unsubscribe_stores', b.id('$$store_subs'))))
219
+ );
220
+ }
221
+
222
+ // Propagate values of bound props upwards if they're undefined in the parent and have a value.
223
+ // Don't do this as part of the props retrieval because people could eagerly mutate the prop in the instance script.
224
+ /** @type {ESTree.Property[]} */
225
+ const props = [];
226
+
227
+ for (const [name, binding] of analysis.instance.scope.declarations) {
228
+ if (binding.kind === 'bindable_prop' && !name.startsWith('$$')) {
229
+ props.push(b.init(binding.prop_alias ?? name, b.id(name)));
230
+ }
231
+ }
232
+
233
+ for (const { name, alias } of analysis.exports) {
234
+ props.push(b.init(alias ?? name, b.id(name)));
235
+ }
236
+
237
+ if (props.length > 0) {
238
+ // This has no effect in runes mode other than throwing an error when someone passes
239
+ // undefined to a binding that has a default value.
240
+ template.body.push(b.stmt(b.call('$.bind_props', b.id('$$props'), b.object(props))));
241
+ }
242
+
243
+ let component_block = b.block([
244
+ .../** @type {ESTree.Statement[]} */ (instance.body),
245
+ .../** @type {ESTree.Statement[]} */ (template.body)
246
+ ]);
247
+
248
+ // trick esrap into including comments
249
+ component_block.loc = instance.loc;
250
+
251
+ if (analysis.props_id) {
252
+ // need to be placed on first line of the component for hydration
253
+ component_block.body.unshift(
254
+ b.const(analysis.props_id, b.call('$.props_id', b.id('$$renderer')))
255
+ );
256
+ }
257
+
258
+ let should_inject_context = dev || analysis.needs_context;
259
+
260
+ if (should_inject_context) {
261
+ component_block = b.block([
262
+ b.stmt(
263
+ b.call(
264
+ '$$renderer.component',
265
+ b.arrow([b.id('$$renderer')], component_block, false),
266
+ dev && b.id(component_name)
267
+ )
268
+ )
269
+ ]);
270
+ }
271
+
272
+ if (analysis.uses_rest_props) {
273
+ /** @type {string[]} */
274
+ const named_props = analysis.exports.map(({ name, alias }) => alias ?? name);
275
+ for (const [name, binding] of analysis.instance.scope.declarations) {
276
+ if (binding.kind === 'bindable_prop') named_props.push(binding.prop_alias ?? name);
277
+ }
278
+
279
+ component_block.body.unshift(
280
+ b.const(
281
+ '$$restProps',
282
+ b.call(
283
+ '$.rest_props',
284
+ b.id('$$sanitized_props'),
285
+ b.array(named_props.map((name) => b.literal(name)))
286
+ )
287
+ )
288
+ );
289
+ }
290
+
291
+ if (analysis.uses_props || analysis.uses_rest_props) {
292
+ component_block.body.unshift(
293
+ b.const('$$sanitized_props', b.call('$.sanitize_props', b.id('$$props')))
294
+ );
295
+ }
296
+
297
+ if (analysis.uses_slots) {
298
+ component_block.body.unshift(b.const('$$slots', b.call('$.sanitize_slots', b.id('$$props'))));
299
+ }
300
+
301
+ const body = [...state.hoisted, ...module.body];
302
+
303
+ if (analysis.css.ast !== null && options.css === 'injected' && !options.customElement) {
304
+ const hash = b.literal(analysis.css.hash);
305
+ const code = b.literal(render_stylesheet(analysis.source, analysis, options).code);
306
+
307
+ body.push(b.const('$$css', b.object([b.init('hash', hash), b.init('code', code)])));
308
+ component_block.body.unshift(b.stmt(b.call('$$renderer.global.css.add', b.id('$$css'))));
309
+ }
310
+
311
+ let should_inject_props =
312
+ should_inject_context ||
313
+ props.length > 0 ||
314
+ analysis.needs_props ||
315
+ analysis.uses_props ||
316
+ analysis.uses_rest_props ||
317
+ analysis.uses_slots ||
318
+ analysis.slot_names.size > 0;
319
+
320
+ const component_function = b.function_declaration(
321
+ b.id(analysis.name),
322
+ should_inject_props ? [b.id('$$renderer'), b.id('$$props')] : [b.id('$$renderer')],
323
+ component_block
324
+ );
325
+
326
+ if (options.compatibility.componentApi === 4) {
327
+ body.unshift(b.imports([['render', '$$_render']], 'svelte/server'));
328
+ body.push(
329
+ component_function,
330
+ b.stmt(
331
+ b.assignment(
332
+ '=',
333
+ b.member_id(`${analysis.name}.render`),
334
+ b.function(
335
+ null,
336
+ [b.id('$$props'), b.id('$$opts')],
337
+ b.block([
338
+ b.return(
339
+ b.call(
340
+ '$$_render',
341
+ b.id(analysis.name),
342
+ b.object([
343
+ b.init('props', b.id('$$props')),
344
+ b.init('context', b.member(b.id('$$opts'), 'context', false, true))
345
+ ])
346
+ )
347
+ )
348
+ ])
349
+ )
350
+ )
351
+ ),
352
+ b.export_default(b.id(analysis.name))
353
+ );
354
+ } else if (dev) {
355
+ body.push(
356
+ component_function,
357
+ b.stmt(
358
+ b.assignment(
359
+ '=',
360
+ b.member_id(`${analysis.name}.render`),
361
+ b.function(
362
+ null,
363
+ [],
364
+ b.block([
365
+ b.throw_error(
366
+ `Component.render(...) is no longer valid in Svelte 5. ` +
367
+ 'See https://svelte.dev/docs/svelte/v5-migration-guide#Components-are-no-longer-classes for more information'
368
+ )
369
+ ])
370
+ )
371
+ )
372
+ ),
373
+ b.export_default(b.id(analysis.name))
374
+ );
375
+ } else {
376
+ body.push(b.export_default(component_function));
377
+ }
378
+
379
+ if (dev) {
380
+ // add `App[$.FILENAME] = 'App.svelte'` so that we can print useful messages later
381
+ body.unshift(
382
+ b.stmt(
383
+ b.assignment('=', b.member(b.id(analysis.name), '$.FILENAME', true), b.literal(filename))
384
+ )
385
+ );
386
+ }
387
+
388
+ if (options.experimental.async) {
389
+ body.unshift(b.imports([], 'svelte/internal/flags/async'));
390
+ }
391
+
392
+ return {
393
+ type: 'Program',
394
+ sourceType: 'module',
395
+ body
396
+ };
397
+ }
398
+
399
+ /**
400
+ * @param {Analysis} analysis
401
+ * @param {ValidatedModuleCompileOptions} options
402
+ * @returns {ESTree.Program}
403
+ */
404
+ export function server_module(analysis, options) {
405
+ /** @type {ServerTransformState} */
406
+ const state = {
407
+ analysis,
408
+ options,
409
+ scope: analysis.module.scope,
410
+ scopes: analysis.module.scopes,
411
+ // this is an anomaly — it can only be used in components, but it needs
412
+ // to be present for `javascript_visitors_legacy` and so is included in module
413
+ // transform state as well as component transform state
414
+ legacy_reactive_statements: new Map(),
415
+ state_fields: new Map(),
416
+ is_instance: false
417
+ };
418
+
419
+ const module = /** @type {ESTree.Program} */ (
420
+ walk(/** @type {AST.SvelteNode} */ (analysis.module.ast), state, global_visitors)
421
+ );
422
+
423
+ return {
424
+ type: 'Program',
425
+ sourceType: 'module',
426
+ body: [b.import_all('$', 'svelte/internal/server'), ...module.body]
427
+ };
428
+ }
@@ -0,0 +1,124 @@
1
+ /** @import { AssignmentExpression, AssignmentOperator, Expression, Pattern } from 'estree' */
2
+ /** @import { AST } from '#compiler' */
3
+ /** @import { Context, ServerTransformState } from '../types.js' */
4
+ import * as b from '#compiler/builders';
5
+ import { build_assignment_value } from '../../../../utils/ast.js';
6
+ import { get_name } from '../../../nodes.js';
7
+ import { get_rune } from '../../../scope.js';
8
+ import { visit_assignment_expression } from '../../shared/assignments.js';
9
+
10
+ /**
11
+ * @param {AssignmentExpression} node
12
+ * @param {Context} context
13
+ */
14
+ export function AssignmentExpression(node, context) {
15
+ return visit_assignment_expression(node, context, build_assignment) ?? context.next();
16
+ }
17
+
18
+ /**
19
+ * Only returns an expression if this is not a `$store` assignment, as others can be kept as-is
20
+ * @param {AssignmentOperator} operator
21
+ * @param {Pattern} left
22
+ * @param {Expression} right
23
+ * @param {import('zimmerframe').Context<AST.SvelteNode, ServerTransformState>} context
24
+ * @returns {Expression | null}
25
+ */
26
+ function build_assignment(operator, left, right, context) {
27
+ if (
28
+ context.state.analysis.runes &&
29
+ left.type === 'MemberExpression' &&
30
+ left.object.type === 'ThisExpression' &&
31
+ !left.computed
32
+ ) {
33
+ const name = get_name(left.property);
34
+ const field = name && context.state.state_fields.get(name);
35
+
36
+ // special case — state declaration in class constructor
37
+ if (field && field.node.type === 'AssignmentExpression' && left === field.node.left) {
38
+ const rune = get_rune(right, context.state.scope);
39
+
40
+ if (rune) {
41
+ const key =
42
+ left.property.type === 'PrivateIdentifier' || rune === '$state' || rune === '$state.raw'
43
+ ? left.property
44
+ : field.key;
45
+
46
+ return b.assignment(
47
+ operator,
48
+ b.member(b.this, key, key.type === 'Literal'),
49
+ /** @type {Expression} */ (context.visit(right))
50
+ );
51
+ }
52
+ } else if (
53
+ field &&
54
+ (field.type === '$derived' || field.type === '$derived.by') &&
55
+ left.property.type === 'PrivateIdentifier'
56
+ ) {
57
+ let value = /** @type {Expression} */ (
58
+ context.visit(build_assignment_value(operator, left, right))
59
+ );
60
+ return b.call(b.member(b.this, name), value);
61
+ }
62
+ }
63
+
64
+ let object = left;
65
+
66
+ while (object.type === 'MemberExpression') {
67
+ // @ts-expect-error
68
+ object = object.object;
69
+ }
70
+
71
+ if (object.type !== 'Identifier') {
72
+ return null;
73
+ }
74
+
75
+ if (is_store_name(object.name)) {
76
+ const name = object.name.slice(1);
77
+
78
+ if (!context.state.scope.get(name)) {
79
+ return null;
80
+ }
81
+
82
+ if (object === left) {
83
+ let value = /** @type {Expression} */ (
84
+ context.visit(build_assignment_value(operator, left, right))
85
+ );
86
+
87
+ return b.call('$.store_set', b.id(name), value);
88
+ }
89
+
90
+ return b.call(
91
+ '$.store_mutate',
92
+ b.assignment('??=', b.id('$$store_subs'), b.object([])),
93
+ b.literal(object.name),
94
+ b.id(name),
95
+ b.assignment(
96
+ operator,
97
+ /** @type {Pattern} */ (context.visit(left)),
98
+ /** @type {Expression} */ (context.visit(right))
99
+ )
100
+ );
101
+ }
102
+
103
+ const binding = context.state.scope.get(object.name);
104
+
105
+ // TODO 6.0 this won't work perfectly: once a derived is written to, it will
106
+ // no longer recompute. It might be better to disallow writing to deriveds
107
+ // on the server, to prevent this bug occurring
108
+ if (binding?.kind === 'derived' && object === left) {
109
+ let value = /** @type {Expression} */ (
110
+ context.visit(build_assignment_value(operator, left, right))
111
+ );
112
+
113
+ return b.call(binding.node, value);
114
+ }
115
+
116
+ return null;
117
+ }
118
+
119
+ /**
120
+ * @param {string} name
121
+ */
122
+ function is_store_name(name) {
123
+ return name[0] === '$' && /[A-Za-z_]/.test(name[1]);
124
+ }
@@ -0,0 +1,36 @@
1
+ /** @import { BlockStatement, Expression, Pattern, Statement } from 'estree' */
2
+ /** @import { AST } from '#compiler' */
3
+ /** @import { ComponentContext } from '../types.js' */
4
+ import * as b from '#compiler/builders';
5
+ import { block_close, create_child_block } from './shared/utils.js';
6
+
7
+ /**
8
+ * @param {AST.AwaitBlock} node
9
+ * @param {ComponentContext} context
10
+ */
11
+ export function AwaitBlock(node, context) {
12
+ /** @type {Statement} */
13
+ let statement = b.stmt(
14
+ b.call(
15
+ '$.await',
16
+ b.id('$$renderer'),
17
+ /** @type {Expression} */ (context.visit(node.expression)),
18
+ b.thunk(
19
+ node.pending ? /** @type {BlockStatement} */ (context.visit(node.pending)) : b.block([])
20
+ ),
21
+ b.arrow(
22
+ node.value ? [/** @type {Pattern} */ (context.visit(node.value))] : [],
23
+ node.then ? /** @type {BlockStatement} */ (context.visit(node.then)) : b.block([])
24
+ )
25
+ )
26
+ );
27
+
28
+ context.state.template.push(
29
+ ...create_child_block(
30
+ [statement],
31
+ node.metadata.expression.blockers(),
32
+ node.metadata.expression.has_await
33
+ ),
34
+ block_close
35
+ );
36
+ }
@@ -0,0 +1,40 @@
1
+ /** @import { AwaitExpression, Expression } from 'estree' */
2
+ /** @import { Context } from '../types' */
3
+ import { save } from '../../../../utils/ast.js';
4
+
5
+ /**
6
+ * @param {AwaitExpression} node
7
+ * @param {Context} context
8
+ */
9
+ export function AwaitExpression(node, context) {
10
+ const argument = /** @type {Expression} */ (context.visit(node.argument));
11
+
12
+ if (context.state.analysis.pickled_awaits.has(node)) {
13
+ return save(argument);
14
+ }
15
+
16
+ // we also need to restore context after block expressions
17
+ let i = context.path.length;
18
+ while (i--) {
19
+ const parent = context.path[i];
20
+
21
+ if (
22
+ parent.type === 'ArrowFunctionExpression' ||
23
+ parent.type === 'FunctionExpression' ||
24
+ parent.type === 'FunctionDeclaration'
25
+ ) {
26
+ break;
27
+ }
28
+
29
+ // @ts-ignore
30
+ if (parent.metadata) {
31
+ if (parent.type !== 'ExpressionTag' && parent.type !== 'Fragment') {
32
+ return save(argument);
33
+ }
34
+
35
+ break;
36
+ }
37
+ }
38
+
39
+ return argument === node.argument ? node : { ...node, argument };
40
+ }
@@ -0,0 +1,71 @@
1
+ /** @import { CallExpression, Expression, MemberExpression } from 'estree' */
2
+ /** @import { Context } from '../types.js' */
3
+ import { dev, is_ignored } from '../../../../state.js';
4
+ import * as b from '#compiler/builders';
5
+ import { get_rune } from '../../../scope.js';
6
+ import { get_inspect_args } from '../../utils.js';
7
+
8
+ /**
9
+ * @param {CallExpression} node
10
+ * @param {Context} context
11
+ */
12
+ export function CallExpression(node, context) {
13
+ const rune = get_rune(node, context.state.scope);
14
+
15
+ if (
16
+ rune === '$host' ||
17
+ rune === '$effect' ||
18
+ rune === '$effect.pre' ||
19
+ rune === '$inspect.trace'
20
+ ) {
21
+ // we will only encounter `$effect` etc if they are top-level statements in the <script>
22
+ // following an `await`, otherwise they are removed by the ExpressionStatement visitor
23
+ return b.void0;
24
+ }
25
+
26
+ if (rune === '$effect.tracking') {
27
+ return b.false;
28
+ }
29
+
30
+ if (rune === '$effect.root') {
31
+ // ignore $effect.root() calls, just return a noop which mimics the cleanup function
32
+ return b.arrow([], b.block([]));
33
+ }
34
+
35
+ if (rune === '$effect.pending') {
36
+ return b.literal(0);
37
+ }
38
+
39
+ if (rune === '$state' || rune === '$state.raw') {
40
+ return node.arguments[0] ? context.visit(node.arguments[0]) : b.void0;
41
+ }
42
+
43
+ if (rune === '$derived' || rune === '$derived.by') {
44
+ const fn = /** @type {Expression} */ (context.visit(node.arguments[0]));
45
+ return b.call('$.derived', rune === '$derived' ? b.thunk(fn) : fn);
46
+ }
47
+
48
+ if (rune === '$state.eager') {
49
+ return node.arguments[0];
50
+ }
51
+
52
+ if (rune === '$state.snapshot') {
53
+ return b.call(
54
+ '$.snapshot',
55
+ /** @type {Expression} */ (context.visit(node.arguments[0])),
56
+ is_ignored(node, 'state_snapshot_uncloneable') && b.true
57
+ );
58
+ }
59
+
60
+ if (rune === '$inspect' || rune === '$inspect().with') {
61
+ if (!dev) return b.empty;
62
+
63
+ const { args, inspector } = get_inspect_args(rune, node, context.visit);
64
+
65
+ return rune === '$inspect'
66
+ ? b.call(inspector, b.literal('$inspect('), ...args, b.literal(')'))
67
+ : b.call(inspector, b.literal('init'), ...args);
68
+ }
69
+
70
+ context.next();
71
+ }