@alloy-js/core 0.23.0-dev.10 → 0.23.0-dev.12
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/dev/src/binder.js +488 -0
- package/dist/dev/src/binder.js.map +1 -0
- package/dist/dev/src/code.js +181 -0
- package/dist/dev/src/code.js.map +1 -0
- package/dist/dev/src/components/AccessExpression.js +230 -0
- package/dist/dev/src/components/AccessExpression.js.map +1 -0
- package/dist/dev/src/components/AccessExpression.test.js +237 -0
- package/dist/dev/src/components/AccessExpression.test.js.map +1 -0
- package/dist/dev/src/components/AppendFile.js +246 -0
- package/dist/dev/src/components/AppendFile.js.map +1 -0
- package/dist/dev/src/components/Block.js +66 -0
- package/dist/dev/src/components/Block.js.map +1 -0
- package/dist/dev/src/components/CopyFile.js +16 -0
- package/dist/dev/src/components/CopyFile.js.map +1 -0
- package/dist/dev/src/components/Declaration.js +70 -0
- package/dist/dev/src/components/Declaration.js.map +1 -0
- package/dist/dev/src/components/For.js +40 -0
- package/dist/dev/src/components/For.js.map +1 -0
- package/dist/dev/src/components/Indent.js +37 -0
- package/dist/dev/src/components/Indent.js.map +1 -0
- package/dist/dev/src/components/List.js +29 -0
- package/dist/dev/src/components/List.js.map +1 -0
- package/dist/dev/src/components/MemberDeclaration.js +70 -0
- package/dist/dev/src/components/MemberDeclaration.js.map +1 -0
- package/dist/dev/src/components/MemberName.js +11 -0
- package/dist/dev/src/components/MemberName.js.map +1 -0
- package/dist/dev/src/components/MemberScope.js +57 -0
- package/dist/dev/src/components/MemberScope.js.map +1 -0
- package/dist/dev/src/components/Name.js +11 -0
- package/dist/dev/src/components/Name.js.map +1 -0
- package/dist/dev/src/components/Output.js +72 -0
- package/dist/dev/src/components/Output.js.map +1 -0
- package/dist/dev/src/components/Prose.js +32 -0
- package/dist/dev/src/components/Prose.js.map +1 -0
- package/dist/dev/src/components/ReferenceOrContent.js +12 -0
- package/dist/dev/src/components/ReferenceOrContent.js.map +1 -0
- package/dist/dev/src/components/Scope.js +50 -0
- package/dist/dev/src/components/Scope.js.map +1 -0
- package/dist/dev/src/components/Show.js +4 -0
- package/dist/dev/src/components/Show.js.map +1 -0
- package/dist/dev/src/components/SourceDirectory.js +41 -0
- package/dist/dev/src/components/SourceDirectory.js.map +1 -0
- package/dist/dev/src/components/SourceFile.js +52 -0
- package/dist/dev/src/components/SourceFile.js.map +1 -0
- package/dist/dev/src/components/StatementList.js +20 -0
- package/dist/dev/src/components/StatementList.js.map +1 -0
- package/dist/dev/src/components/Switch.js +42 -0
- package/dist/dev/src/components/Switch.js.map +1 -0
- package/dist/dev/src/components/TemplateFile.js +153 -0
- package/dist/dev/src/components/TemplateFile.js.map +1 -0
- package/dist/dev/src/components/UpdateFile.js +71 -0
- package/dist/dev/src/components/UpdateFile.js.map +1 -0
- package/dist/dev/src/components/Wrap.js +18 -0
- package/dist/dev/src/components/Wrap.js.map +1 -0
- package/dist/dev/src/components/index.js +25 -0
- package/dist/dev/src/components/index.js.map +1 -0
- package/dist/dev/src/components/stc/index.js +27 -0
- package/dist/dev/src/components/stc/index.js.map +1 -0
- package/dist/dev/src/components/stc/sti.js +10 -0
- package/dist/dev/src/components/stc/sti.js.map +1 -0
- package/dist/dev/src/content-slot.js +78 -0
- package/dist/dev/src/content-slot.js.map +1 -0
- package/dist/dev/src/content-slot.test.js +89 -0
- package/dist/dev/src/content-slot.test.js.map +1 -0
- package/dist/dev/src/context/assignment.js +46 -0
- package/dist/dev/src/context/assignment.js.map +1 -0
- package/dist/dev/src/context/binder.js +12 -0
- package/dist/dev/src/context/binder.js.map +1 -0
- package/dist/dev/src/context/declaration.js +3 -0
- package/dist/dev/src/context/declaration.js.map +1 -0
- package/dist/dev/src/context/format-options.js +32 -0
- package/dist/dev/src/context/format-options.js.map +1 -0
- package/dist/dev/src/context/index.js +11 -0
- package/dist/dev/src/context/index.js.map +1 -0
- package/dist/dev/src/context/member-declaration.js +11 -0
- package/dist/dev/src/context/member-declaration.js.map +1 -0
- package/dist/dev/src/context/member-scope.js +12 -0
- package/dist/dev/src/context/member-scope.js.map +1 -0
- package/dist/dev/src/context/name-policy.js +13 -0
- package/dist/dev/src/context/name-policy.js.map +1 -0
- package/dist/dev/src/context/scope.js +13 -0
- package/dist/dev/src/context/scope.js.map +1 -0
- package/dist/dev/src/context/source-directory.js +3 -0
- package/dist/dev/src/context/source-directory.js.map +1 -0
- package/dist/dev/src/context/source-file.js +3 -0
- package/dist/dev/src/context/source-file.js.map +1 -0
- package/dist/dev/src/context.js +47 -0
- package/dist/dev/src/context.js.map +1 -0
- package/dist/dev/src/debug/cli.js +163 -0
- package/dist/dev/src/debug/cli.js.map +1 -0
- package/dist/dev/src/debug/diagnostics.test.js +50 -0
- package/dist/dev/src/debug/diagnostics.test.js.map +1 -0
- package/dist/dev/src/debug/effects.js +293 -0
- package/dist/dev/src/debug/effects.js.map +1 -0
- package/dist/dev/src/debug/effects.test.js +280 -0
- package/dist/dev/src/debug/effects.test.js.map +1 -0
- package/dist/dev/src/debug/files.js +29 -0
- package/dist/dev/src/debug/files.js.map +1 -0
- package/dist/dev/src/debug/files.test.js +78 -0
- package/dist/dev/src/debug/files.test.js.map +1 -0
- package/dist/dev/src/debug/index.js +71 -0
- package/dist/dev/src/debug/index.js.map +1 -0
- package/dist/dev/src/debug/message-format.test.js +836 -0
- package/dist/dev/src/debug/message-format.test.js.map +1 -0
- package/dist/dev/src/debug/render-tree-orphans.test.js +365 -0
- package/dist/dev/src/debug/render-tree-orphans.test.js.map +1 -0
- package/dist/dev/src/debug/render.js +479 -0
- package/dist/dev/src/debug/render.js.map +1 -0
- package/dist/dev/src/debug/render.test.js +363 -0
- package/dist/dev/src/debug/render.test.js.map +1 -0
- package/dist/dev/src/debug/serialize.js +70 -0
- package/dist/dev/src/debug/serialize.js.map +1 -0
- package/dist/dev/src/debug/source-map.js +111 -0
- package/dist/dev/src/debug/source-map.js.map +1 -0
- package/dist/dev/src/debug/symbols.js +196 -0
- package/dist/dev/src/debug/symbols.js.map +1 -0
- package/dist/dev/src/debug/symbols.test.js +93 -0
- package/dist/dev/src/debug/symbols.test.js.map +1 -0
- package/dist/dev/src/debug/trace-writer.js +658 -0
- package/dist/dev/src/debug/trace-writer.js.map +1 -0
- package/dist/dev/src/debug/trace.js +459 -0
- package/dist/dev/src/debug/trace.js.map +1 -0
- package/dist/dev/src/devtools/devtools-protocol.js +2 -0
- package/dist/dev/src/devtools/devtools-protocol.js.map +1 -0
- package/dist/dev/src/devtools/devtools-server.browser.js +33 -0
- package/dist/dev/src/devtools/devtools-server.browser.js.map +1 -0
- package/dist/dev/src/devtools/devtools-server.js +444 -0
- package/dist/dev/src/devtools/devtools-server.js.map +1 -0
- package/dist/dev/src/devtools/devtools-transport.js +114 -0
- package/dist/dev/src/devtools/devtools-transport.js.map +1 -0
- package/dist/dev/src/devtools-entry.browser.js +2 -0
- package/dist/dev/src/devtools-entry.browser.js.map +1 -0
- package/dist/dev/src/devtools-entry.js +2 -0
- package/dist/dev/src/devtools-entry.js.map +1 -0
- package/dist/dev/src/diagnostics.js +89 -0
- package/dist/dev/src/diagnostics.js.map +1 -0
- package/dist/dev/src/host/alloy-host.browser.js +32 -0
- package/dist/dev/src/host/alloy-host.browser.js.map +1 -0
- package/dist/dev/src/host/alloy-host.js +144 -0
- package/dist/dev/src/host/alloy-host.js.map +1 -0
- package/dist/dev/src/host/interface.js +2 -0
- package/dist/dev/src/host/interface.js.map +1 -0
- package/dist/dev/src/index.browser.js +3 -0
- package/dist/dev/src/index.browser.js.map +1 -0
- package/dist/dev/src/index.js +27 -0
- package/dist/dev/src/index.js.map +1 -0
- package/dist/dev/src/inspect.browser.js +6 -0
- package/dist/dev/src/inspect.browser.js.map +1 -0
- package/dist/dev/src/inspect.js +2 -0
- package/dist/dev/src/inspect.js.map +1 -0
- package/dist/dev/src/jsx-runtime.js +17 -0
- package/dist/dev/src/jsx-runtime.js.map +1 -0
- package/dist/dev/src/library-symbol-reference.js +5 -0
- package/dist/dev/src/library-symbol-reference.js.map +1 -0
- package/dist/dev/src/name-policy.js +24 -0
- package/dist/dev/src/name-policy.js.map +1 -0
- package/dist/dev/src/pretty-string/pretty-string.js +100 -0
- package/dist/dev/src/pretty-string/pretty-string.js.map +1 -0
- package/dist/dev/src/pretty-string/pretty-string.test.js +38 -0
- package/dist/dev/src/pretty-string/pretty-string.test.js.map +1 -0
- package/dist/dev/src/print-hook.js +10 -0
- package/dist/dev/src/print-hook.js.map +1 -0
- package/dist/dev/src/props-combinators.js +109 -0
- package/dist/dev/src/props-combinators.js.map +1 -0
- package/dist/dev/src/reactive-union-set.js +213 -0
- package/dist/dev/src/reactive-union-set.js.map +1 -0
- package/dist/dev/src/reactivity.js +426 -0
- package/dist/dev/src/reactivity.js.map +1 -0
- package/dist/dev/src/refkey.js +167 -0
- package/dist/dev/src/refkey.js.map +1 -0
- package/dist/dev/src/render-stack.js +251 -0
- package/dist/dev/src/render-stack.js.map +1 -0
- package/dist/dev/src/render.js +872 -0
- package/dist/dev/src/render.js.map +1 -0
- package/dist/dev/src/resource.js +124 -0
- package/dist/dev/src/resource.js.map +1 -0
- package/dist/dev/src/runtime/component.js +41 -0
- package/dist/dev/src/runtime/component.js.map +1 -0
- package/dist/dev/src/runtime/intrinsic.js +12 -0
- package/dist/dev/src/runtime/intrinsic.js.map +1 -0
- package/dist/dev/src/scheduler.js +217 -0
- package/dist/dev/src/scheduler.js.map +1 -0
- package/dist/dev/src/stc.js +40 -0
- package/dist/dev/src/stc.js.map +1 -0
- package/dist/dev/src/sti.js +31 -0
- package/dist/dev/src/sti.js.map +1 -0
- package/dist/dev/src/symbols/basic-scope.js +21 -0
- package/dist/dev/src/symbols/basic-scope.js.map +1 -0
- package/dist/dev/src/symbols/basic-symbol.js +34 -0
- package/dist/dev/src/symbols/basic-symbol.js.map +1 -0
- package/dist/dev/src/symbols/decl.js +26 -0
- package/dist/dev/src/symbols/decl.js.map +1 -0
- package/dist/dev/src/symbols/index.js +10 -0
- package/dist/dev/src/symbols/index.js.map +1 -0
- package/dist/dev/src/symbols/output-scope.js +202 -0
- package/dist/dev/src/symbols/output-scope.js.map +1 -0
- package/dist/dev/src/symbols/output-space.js +36 -0
- package/dist/dev/src/symbols/output-space.js.map +1 -0
- package/dist/dev/src/symbols/output-symbol.js +504 -0
- package/dist/dev/src/symbols/output-symbol.js.map +1 -0
- package/dist/dev/src/symbols/symbol-flow.js +106 -0
- package/dist/dev/src/symbols/symbol-flow.js.map +1 -0
- package/dist/dev/src/symbols/symbol-slot.js +68 -0
- package/dist/dev/src/symbols/symbol-slot.js.map +1 -0
- package/dist/dev/src/symbols/symbol-slot.test.js +43 -0
- package/dist/dev/src/symbols/symbol-slot.test.js.map +1 -0
- package/dist/dev/src/symbols/symbol-table.js +93 -0
- package/dist/dev/src/symbols/symbol-table.js.map +1 -0
- package/dist/dev/src/tap.js +109 -0
- package/dist/dev/src/tap.js.map +1 -0
- package/dist/dev/src/trace.js +2 -0
- package/dist/dev/src/trace.js.map +1 -0
- package/dist/dev/src/tracer.js +180 -0
- package/dist/dev/src/tracer.js.map +1 -0
- package/dist/dev/src/utils.js +487 -0
- package/dist/dev/src/utils.js.map +1 -0
- package/dist/dev/src/write-output.js +47 -0
- package/dist/dev/src/write-output.js.map +1 -0
- package/dist/dev/test/browser-build.test.js +86 -0
- package/dist/dev/test/browser-build.test.js.map +1 -0
- package/dist/dev/test/children.test.js +44 -0
- package/dist/dev/test/children.test.js.map +1 -0
- package/dist/dev/test/components/append-file.test.js +394 -0
- package/dist/dev/test/components/append-file.test.js.map +1 -0
- package/dist/dev/test/components/block.test.js +83 -0
- package/dist/dev/test/components/block.test.js.map +1 -0
- package/dist/dev/test/components/copy-file.test.js +119 -0
- package/dist/dev/test/components/copy-file.test.js.map +1 -0
- package/dist/dev/test/components/declaration.test.js +40 -0
- package/dist/dev/test/components/declaration.test.js.map +1 -0
- package/dist/dev/test/components/list.test.js +250 -0
- package/dist/dev/test/components/list.test.js.map +1 -0
- package/dist/dev/test/components/prose.test.js +42 -0
- package/dist/dev/test/components/prose.test.js.map +1 -0
- package/dist/dev/test/components/reference-or-content.test.js +246 -0
- package/dist/dev/test/components/reference-or-content.test.js.map +1 -0
- package/dist/dev/test/components/source-file.test.js +271 -0
- package/dist/dev/test/components/source-file.test.js.map +1 -0
- package/dist/dev/test/components/template-file.test.js +200 -0
- package/dist/dev/test/components/template-file.test.js.map +1 -0
- package/dist/dev/test/components/update-file.test.js +210 -0
- package/dist/dev/test/components/update-file.test.js.map +1 -0
- package/dist/dev/test/components/wrap.test.js +48 -0
- package/dist/dev/test/components/wrap.test.js.map +1 -0
- package/dist/dev/test/control-flow/for.test.js +318 -0
- package/dist/dev/test/control-flow/for.test.js.map +1 -0
- package/dist/dev/test/control-flow/match.test.js +112 -0
- package/dist/dev/test/control-flow/match.test.js.map +1 -0
- package/dist/dev/test/control-flow/show.test.js +38 -0
- package/dist/dev/test/control-flow/show.test.js.map +1 -0
- package/dist/dev/test/lazy-isempty.test.js +121 -0
- package/dist/dev/test/lazy-isempty.test.js.map +1 -0
- package/dist/dev/test/name-policy.test.js +28 -0
- package/dist/dev/test/name-policy.test.js.map +1 -0
- package/dist/dev/test/props-with-defaults.test.js +94 -0
- package/dist/dev/test/props-with-defaults.test.js.map +1 -0
- package/dist/dev/test/reactive-union-set-disposers.test.js +98 -0
- package/dist/dev/test/reactive-union-set-disposers.test.js.map +1 -0
- package/dist/dev/test/reactive-union-set.test.js +171 -0
- package/dist/dev/test/reactive-union-set.test.js.map +1 -0
- package/dist/dev/test/reactivity/circular-reactives.test.js +62 -0
- package/dist/dev/test/reactivity/circular-reactives.test.js.map +1 -0
- package/dist/dev/test/reactivity/cleanup.test.js +96 -0
- package/dist/dev/test/reactivity/cleanup.test.js.map +1 -0
- package/dist/dev/test/reactivity/memo.test.js +17 -0
- package/dist/dev/test/reactivity/memo.test.js.map +1 -0
- package/dist/dev/test/reactivity/ref-rendering.test.js +38 -0
- package/dist/dev/test/reactivity/ref-rendering.test.js.map +1 -0
- package/dist/dev/test/reactivity/shallow-reactive.test.js +52 -0
- package/dist/dev/test/reactivity/shallow-reactive.test.js.map +1 -0
- package/dist/dev/test/reactivity/test.test.js +74 -0
- package/dist/dev/test/reactivity/test.test.js.map +1 -0
- package/dist/dev/test/reactivity/untrack.test.js +27 -0
- package/dist/dev/test/reactivity/untrack.test.js.map +1 -0
- package/dist/dev/test/refkey.test.js +36 -0
- package/dist/dev/test/refkey.test.js.map +1 -0
- package/dist/dev/test/rendering/basic.test.js +194 -0
- package/dist/dev/test/rendering/basic.test.js.map +1 -0
- package/dist/dev/test/rendering/code.test.js +64 -0
- package/dist/dev/test/rendering/code.test.js.map +1 -0
- package/dist/dev/test/rendering/formatting.test.js +797 -0
- package/dist/dev/test/rendering/formatting.test.js.map +1 -0
- package/dist/dev/test/rendering/indent.test.js +183 -0
- package/dist/dev/test/rendering/indent.test.js.map +1 -0
- package/dist/dev/test/rendering/memoization.test.js +37 -0
- package/dist/dev/test/rendering/memoization.test.js.map +1 -0
- package/dist/dev/test/rendering/print-render-stack.test.js +287 -0
- package/dist/dev/test/rendering/print-render-stack.test.js.map +1 -0
- package/dist/dev/test/rendering/refkeys.test.js +37 -0
- package/dist/dev/test/rendering/refkeys.test.js.map +1 -0
- package/dist/dev/test/scheduler-extended.test.js +96 -0
- package/dist/dev/test/scheduler-extended.test.js.map +1 -0
- package/dist/dev/test/scheduler.test.js +46 -0
- package/dist/dev/test/scheduler.test.js.map +1 -0
- package/dist/dev/test/split-props.test.js +78 -0
- package/dist/dev/test/split-props.test.js.map +1 -0
- package/dist/dev/test/stc.test.js +35 -0
- package/dist/dev/test/stc.test.js.map +1 -0
- package/dist/dev/test/symbols/output-scope.test.js +180 -0
- package/dist/dev/test/symbols/output-scope.test.js.map +1 -0
- package/dist/dev/test/symbols/output-symbol.test.js +202 -0
- package/dist/dev/test/symbols/output-symbol.test.js.map +1 -0
- package/dist/dev/test/symbols/resolution.test.js +487 -0
- package/dist/dev/test/symbols/resolution.test.js.map +1 -0
- package/dist/dev/test/symbols/symbol-table.test.js +15 -0
- package/dist/dev/test/symbols/symbol-table.test.js.map +1 -0
- package/dist/dev/test/symbols/utils.js +26 -0
- package/dist/dev/test/symbols/utils.js.map +1 -0
- package/dist/dev/test/utils.test.js +317 -0
- package/dist/dev/test/utils.test.js.map +1 -0
- package/dist/dev/testing/create-test-wrapper.js +76 -0
- package/dist/dev/testing/create-test-wrapper.js.map +1 -0
- package/dist/dev/testing/devtools-utils.js +162 -0
- package/dist/dev/testing/devtools-utils.js.map +1 -0
- package/dist/dev/testing/extend-expect.js +167 -0
- package/dist/dev/testing/extend-expect.js.map +1 -0
- package/dist/dev/testing/extend-expect.test.js +234 -0
- package/dist/dev/testing/extend-expect.test.js.map +1 -0
- package/dist/dev/testing/index.js +4 -0
- package/dist/dev/testing/index.js.map +1 -0
- package/dist/dev/testing/render.js +23 -0
- package/dist/dev/testing/render.js.map +1 -0
- package/dist/dev/testing/vitest.d.js +2 -0
- package/dist/dev/testing/vitest.d.js.map +1 -0
- package/dist/devtools/index.html +29 -17
- package/dist/src/binder.d.ts.map +1 -1
- package/dist/src/binder.js +5 -0
- package/dist/src/binder.js.map +1 -1
- package/dist/src/components/For.d.ts.map +1 -1
- package/dist/src/components/For.js +1 -1
- package/dist/src/components/For.js.map +1 -1
- package/dist/src/components/List.d.ts.map +1 -1
- package/dist/src/components/List.js +1 -1
- package/dist/src/components/List.js.map +1 -1
- package/dist/src/components/Switch.d.ts.map +1 -1
- package/dist/src/components/Switch.js +1 -1
- package/dist/src/components/Switch.js.map +1 -1
- package/dist/src/debug/diagnostics.test.js +3 -2
- package/dist/src/debug/diagnostics.test.js.map +1 -1
- package/dist/src/debug/effects.d.ts +12 -4
- package/dist/src/debug/effects.d.ts.map +1 -1
- package/dist/src/debug/effects.js +119 -54
- package/dist/src/debug/effects.js.map +1 -1
- package/dist/src/debug/effects.test.js +213 -41
- package/dist/src/debug/effects.test.js.map +1 -1
- package/dist/src/debug/files.d.ts.map +1 -1
- package/dist/src/debug/files.js +7 -18
- package/dist/src/debug/files.js.map +1 -1
- package/dist/src/debug/files.test.js +13 -36
- package/dist/src/debug/files.test.js.map +1 -1
- package/dist/src/debug/index.d.ts +4 -2
- package/dist/src/debug/index.d.ts.map +1 -1
- package/dist/src/debug/index.js +4 -2
- package/dist/src/debug/index.js.map +1 -1
- package/dist/src/debug/message-format.test.d.ts +2 -0
- package/dist/src/debug/message-format.test.d.ts.map +1 -0
- package/dist/src/debug/message-format.test.js +700 -0
- package/dist/src/debug/message-format.test.js.map +1 -0
- package/dist/src/debug/render-tree-orphans.test.d.ts +2 -0
- package/dist/src/debug/render-tree-orphans.test.d.ts.map +1 -0
- package/dist/src/debug/render-tree-orphans.test.js +297 -0
- package/dist/src/debug/render-tree-orphans.test.js.map +1 -0
- package/dist/src/debug/render.d.ts.map +1 -1
- package/dist/src/debug/render.js +91 -131
- package/dist/src/debug/render.js.map +1 -1
- package/dist/src/debug/render.test.js +91 -128
- package/dist/src/debug/render.test.js.map +1 -1
- package/dist/src/debug/source-map.d.ts +22 -0
- package/dist/src/debug/source-map.d.ts.map +1 -0
- package/dist/src/debug/source-map.js +111 -0
- package/dist/src/debug/source-map.js.map +1 -0
- package/dist/src/debug/symbols.d.ts +6 -5
- package/dist/src/debug/symbols.d.ts.map +1 -1
- package/dist/src/debug/symbols.js +46 -23
- package/dist/src/debug/symbols.js.map +1 -1
- package/dist/src/debug/symbols.test.js +15 -26
- package/dist/src/debug/symbols.test.js.map +1 -1
- package/dist/src/debug/trace-writer.d.ts +55 -0
- package/dist/src/debug/trace-writer.d.ts.map +1 -0
- package/dist/src/debug/trace-writer.js +658 -0
- package/dist/src/debug/trace-writer.js.map +1 -0
- package/dist/src/debug/trace.d.ts +10 -10
- package/dist/src/debug/trace.d.ts.map +1 -1
- package/dist/src/debug/trace.js +36 -20
- package/dist/src/debug/trace.js.map +1 -1
- package/dist/src/devtools/devtools-protocol.d.ts +318 -161
- package/dist/src/devtools/devtools-protocol.d.ts.map +1 -1
- package/dist/src/devtools/devtools-server.browser.d.ts +0 -5
- package/dist/src/devtools/devtools-server.browser.d.ts.map +1 -1
- package/dist/src/devtools/devtools-server.browser.js +0 -3
- package/dist/src/devtools/devtools-server.browser.js.map +1 -1
- package/dist/src/devtools/devtools-server.d.ts +0 -6
- package/dist/src/devtools/devtools-server.d.ts.map +1 -1
- package/dist/src/devtools/devtools-server.js +212 -24
- package/dist/src/devtools/devtools-server.js.map +1 -1
- package/dist/src/devtools/devtools-transport.d.ts +2 -2
- package/dist/src/devtools/devtools-transport.d.ts.map +1 -1
- package/dist/src/devtools/devtools-transport.js +2 -2
- package/dist/src/devtools/devtools-transport.js.map +1 -1
- package/dist/src/devtools-entry.browser.d.ts +1 -1
- package/dist/src/devtools-entry.browser.d.ts.map +1 -1
- package/dist/src/devtools-entry.browser.js.map +1 -1
- package/dist/src/devtools-entry.d.ts +1 -1
- package/dist/src/devtools-entry.d.ts.map +1 -1
- package/dist/src/devtools-entry.js.map +1 -1
- package/dist/src/diagnostics.d.ts.map +1 -1
- package/dist/src/diagnostics.js +5 -5
- package/dist/src/diagnostics.js.map +1 -1
- package/dist/src/reactivity.d.ts +13 -2
- package/dist/src/reactivity.d.ts.map +1 -1
- package/dist/src/reactivity.js +96 -13
- package/dist/src/reactivity.js.map +1 -1
- package/dist/src/render.d.ts.map +1 -1
- package/dist/src/render.js +84 -30
- package/dist/src/render.js.map +1 -1
- package/dist/src/scheduler.d.ts +5 -0
- package/dist/src/scheduler.d.ts.map +1 -1
- package/dist/src/scheduler.js +94 -23
- package/dist/src/scheduler.js.map +1 -1
- package/dist/src/utils.d.ts.map +1 -1
- package/dist/src/utils.js +11 -5
- package/dist/src/utils.js.map +1 -1
- package/dist/test/browser-build.test.js +1 -1
- package/dist/test/browser-build.test.js.map +1 -1
- package/dist/testing/devtools-utils.d.ts +12 -3
- package/dist/testing/devtools-utils.d.ts.map +1 -1
- package/dist/testing/devtools-utils.js +26 -4
- package/dist/testing/devtools-utils.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +9 -3
- package/src/binder.ts +47 -38
- package/src/components/For.tsx +14 -10
- package/src/components/List.tsx +7 -4
- package/src/components/Switch.tsx +11 -7
- package/src/debug/diagnostics.test.tsx +3 -2
- package/src/debug/effects.test.tsx +248 -36
- package/src/debug/effects.ts +198 -64
- package/src/debug/files.test.tsx +15 -35
- package/src/debug/files.ts +11 -11
- package/src/debug/index.ts +4 -0
- package/src/debug/message-format.test.tsx +759 -0
- package/src/debug/render-tree-orphans.test.tsx +344 -0
- package/src/debug/render.test.tsx +96 -118
- package/src/debug/render.ts +196 -125
- package/src/debug/source-map.ts +135 -0
- package/src/debug/symbols.test.tsx +19 -20
- package/src/debug/symbols.ts +106 -23
- package/src/debug/trace-writer.ts +969 -0
- package/src/debug/trace.ts +41 -28
- package/src/devtools/devtools-protocol.ts +361 -176
- package/src/devtools/devtools-server.browser.ts +0 -9
- package/src/devtools/devtools-server.ts +210 -32
- package/src/devtools/devtools-transport.ts +4 -4
- package/src/devtools-entry.browser.ts +11 -15
- package/src/devtools-entry.ts +9 -15
- package/src/diagnostics.ts +14 -5
- package/src/reactivity.ts +113 -17
- package/src/render.ts +104 -30
- package/src/scheduler.ts +145 -26
- package/src/utils.tsx +7 -4
- package/temp/api.json +142 -20
- package/test/browser-build.test.ts +1 -1
- package/testing/devtools-utils.ts +46 -4
- package/vitest.config.ts +8 -0
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@alloy-js/core",
|
|
3
|
-
"version": "0.23.0-dev.
|
|
3
|
+
"version": "0.23.0-dev.12",
|
|
4
4
|
"description": "",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -10,27 +10,33 @@
|
|
|
10
10
|
"exports": {
|
|
11
11
|
".": {
|
|
12
12
|
"browser": "./dist/src/index.browser.js",
|
|
13
|
+
"development": "./dist/dev/src/index.js",
|
|
13
14
|
"import": "./dist/src/index.js"
|
|
14
15
|
},
|
|
15
16
|
"./jsx-runtime": {
|
|
16
17
|
"types": "./dist/src/jsx-runtime.d.ts",
|
|
18
|
+
"development": "./dist/dev/src/jsx-runtime.js",
|
|
17
19
|
"import": "./dist/src/jsx-runtime.js"
|
|
18
20
|
},
|
|
19
21
|
"./testing": {
|
|
22
|
+
"development": "./dist/dev/testing/index.js",
|
|
20
23
|
"import": "./dist/testing/index.js"
|
|
21
24
|
},
|
|
22
25
|
"./testing/matchers": {
|
|
23
26
|
"types": "./testing/vitest.d.ts"
|
|
24
27
|
},
|
|
25
28
|
"./stc": {
|
|
29
|
+
"development": "./dist/dev/src/components/stc/index.js",
|
|
26
30
|
"import": "./dist/src/components/stc/index.js"
|
|
27
31
|
},
|
|
28
32
|
"./components": {
|
|
33
|
+
"development": "./dist/dev/src/components/index.js",
|
|
29
34
|
"import": "./dist/src/components/index.js"
|
|
30
35
|
},
|
|
31
36
|
"./devtools": {
|
|
32
37
|
"types": "./dist/src/devtools-entry.d.ts",
|
|
33
38
|
"browser": "./dist/src/devtools-entry.browser.js",
|
|
39
|
+
"development": "./dist/dev/src/devtools-entry.js",
|
|
34
40
|
"import": "./dist/src/devtools-entry.js"
|
|
35
41
|
}
|
|
36
42
|
},
|
|
@@ -56,7 +62,7 @@
|
|
|
56
62
|
"ws": "^8.19.0"
|
|
57
63
|
},
|
|
58
64
|
"devDependencies": {
|
|
59
|
-
"@alloy-js/cli": "~0.22.0 || >= 0.23.0-dev.
|
|
65
|
+
"@alloy-js/cli": "~0.22.0 || >= 0.23.0-dev.4",
|
|
60
66
|
"@alloy-js/rollup-plugin": "~0.1.0 || >= 0.1.1-dev.1",
|
|
61
67
|
"@microsoft/api-extractor": "~7.52.8",
|
|
62
68
|
"@rollup/plugin-typescript": "^12.1.2",
|
|
@@ -68,7 +74,7 @@
|
|
|
68
74
|
"type": "module",
|
|
69
75
|
"scripts": {
|
|
70
76
|
"generate-docs": "api-extractor run",
|
|
71
|
-
"build": "alloy build && pnpm run generate-docs",
|
|
77
|
+
"build": "alloy build --with-dev && pnpm run generate-docs",
|
|
72
78
|
"clean": "rimraf dist/ .temp/",
|
|
73
79
|
"test": "vitest run",
|
|
74
80
|
"test:watch": "vitest -w",
|
package/src/binder.ts
CHANGED
|
@@ -643,54 +643,63 @@ export function createOutputBinder(options: BinderOptions = {}): Binder {
|
|
|
643
643
|
}
|
|
644
644
|
|
|
645
645
|
function notifySymbolCreated(symbol: OutputSymbol): void {
|
|
646
|
-
effect<Refkey[]>(
|
|
647
|
-
|
|
648
|
-
|
|
649
|
-
|
|
650
|
-
|
|
651
|
-
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
if (oldRefkeys) {
|
|
655
|
-
for (const refkey of oldRefkeys) {
|
|
656
|
-
if (!symbol.refkeys.includes(refkey)) {
|
|
657
|
-
// remove the old refkey from the known declarations
|
|
658
|
-
knownDeclarations.delete(refkey);
|
|
646
|
+
effect<Refkey[]>(
|
|
647
|
+
(oldRefkeys) => {
|
|
648
|
+
if (symbol.refkeys) {
|
|
649
|
+
debug.trace(
|
|
650
|
+
TracePhase.resolve.pending,
|
|
651
|
+
() => `Notifying resolutions for ${formatRefkeys(symbol.refkeys)}.`,
|
|
652
|
+
);
|
|
653
|
+
}
|
|
659
654
|
|
|
660
|
-
|
|
661
|
-
|
|
662
|
-
|
|
663
|
-
|
|
655
|
+
if (oldRefkeys) {
|
|
656
|
+
for (const refkey of oldRefkeys) {
|
|
657
|
+
if (!symbol.refkeys.includes(refkey)) {
|
|
658
|
+
// remove the old refkey from the known declarations
|
|
659
|
+
knownDeclarations.delete(refkey);
|
|
660
|
+
|
|
661
|
+
// reset any waiting declarations
|
|
662
|
+
if (waitingDeclarations.has(refkey)) {
|
|
663
|
+
const signal = waitingDeclarations.get(refkey)!;
|
|
664
|
+
signal.value = undefined;
|
|
665
|
+
}
|
|
664
666
|
}
|
|
665
667
|
}
|
|
666
668
|
}
|
|
667
|
-
}
|
|
668
669
|
|
|
669
|
-
|
|
670
|
-
|
|
671
|
-
|
|
672
|
-
|
|
673
|
-
|
|
674
|
-
|
|
675
|
-
|
|
670
|
+
for (const refkey of symbol.refkeys) {
|
|
671
|
+
// notify those waiting for this refkey
|
|
672
|
+
knownDeclarations.set(refkey, symbol);
|
|
673
|
+
if (waitingDeclarations.has(refkey)) {
|
|
674
|
+
const signal = waitingDeclarations.get(refkey)!;
|
|
675
|
+
signal.value = symbol;
|
|
676
|
+
}
|
|
676
677
|
|
|
677
|
-
|
|
678
|
-
|
|
679
|
-
|
|
680
|
-
|
|
678
|
+
const scope = symbol.scope;
|
|
679
|
+
if (!scope) {
|
|
680
|
+
continue;
|
|
681
|
+
}
|
|
681
682
|
|
|
682
|
-
|
|
683
|
-
|
|
684
|
-
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
|
|
683
|
+
// notify those waiting for this symbol name
|
|
684
|
+
const waitingScope = waitingSymbolNames.get(scope);
|
|
685
|
+
if (waitingScope) {
|
|
686
|
+
const waitingName = waitingScope.get(symbol.name);
|
|
687
|
+
if (waitingName) {
|
|
688
|
+
waitingName.value = symbol;
|
|
689
|
+
}
|
|
688
690
|
}
|
|
689
691
|
}
|
|
690
|
-
}
|
|
691
692
|
|
|
692
|
-
|
|
693
|
-
|
|
693
|
+
return [...symbol.refkeys];
|
|
694
|
+
},
|
|
695
|
+
undefined,
|
|
696
|
+
{
|
|
697
|
+
debug: {
|
|
698
|
+
name: "binder:notifySymbolCreated",
|
|
699
|
+
type: "binder",
|
|
700
|
+
},
|
|
701
|
+
},
|
|
702
|
+
);
|
|
694
703
|
}
|
|
695
704
|
}
|
|
696
705
|
|
package/src/components/For.tsx
CHANGED
|
@@ -80,15 +80,19 @@ export function For<
|
|
|
80
80
|
const cb = props.children;
|
|
81
81
|
const options = baseListPropsToMapJoinArgs(props);
|
|
82
82
|
options.skipFalsy = props.skipFalsy;
|
|
83
|
-
return memo(
|
|
84
|
-
|
|
83
|
+
return memo(
|
|
84
|
+
() => {
|
|
85
|
+
const maybeRef = props.each;
|
|
85
86
|
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
87
|
+
return (mapJoin as any)(
|
|
88
|
+
typeof maybeRef === "function" ? maybeRef : (
|
|
89
|
+
() => (isRef(maybeRef) ? maybeRef.value : maybeRef)
|
|
90
|
+
),
|
|
91
|
+
cb,
|
|
92
|
+
options,
|
|
93
|
+
);
|
|
94
|
+
},
|
|
95
|
+
undefined,
|
|
96
|
+
"For",
|
|
97
|
+
);
|
|
94
98
|
}
|
package/src/components/List.tsx
CHANGED
|
@@ -57,10 +57,13 @@ export interface ListProps extends BaseListProps {
|
|
|
57
57
|
*/
|
|
58
58
|
export function List(props: ListProps) {
|
|
59
59
|
const [rest, forProps] = splitProps(props, ["children"]);
|
|
60
|
-
const resolvedChildren = memo(
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
60
|
+
const resolvedChildren = memo(
|
|
61
|
+
() =>
|
|
62
|
+
childrenArray(() => rest.children, {
|
|
63
|
+
preserveFragments: true,
|
|
64
|
+
}),
|
|
65
|
+
undefined,
|
|
66
|
+
"List:children",
|
|
64
67
|
);
|
|
65
68
|
return (
|
|
66
69
|
<For each={resolvedChildren} {...forProps} skipFalsy>
|
|
@@ -27,15 +27,19 @@ export function Switch(props: SwitchProps) {
|
|
|
27
27
|
const children = childrenArray(() => props.children);
|
|
28
28
|
const matches = findKeyedChildren(children, matchTag);
|
|
29
29
|
|
|
30
|
-
return memo(
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
30
|
+
return memo(
|
|
31
|
+
() => {
|
|
32
|
+
for (const match of matches) {
|
|
33
|
+
if (match.props.when || match.props.else) {
|
|
34
|
+
return match.props.children;
|
|
35
|
+
}
|
|
34
36
|
}
|
|
35
|
-
}
|
|
36
37
|
|
|
37
|
-
|
|
38
|
-
|
|
38
|
+
return undefined;
|
|
39
|
+
},
|
|
40
|
+
undefined,
|
|
41
|
+
"Switch",
|
|
42
|
+
);
|
|
39
43
|
}
|
|
40
44
|
|
|
41
45
|
export interface MatchProps {
|
|
@@ -34,7 +34,7 @@ afterEach(async () => {
|
|
|
34
34
|
});
|
|
35
35
|
|
|
36
36
|
it("emits diagnostics:report messages", async () => {
|
|
37
|
-
const collector = createMessageCollector(socket!);
|
|
37
|
+
const collector = await createMessageCollector(socket!);
|
|
38
38
|
const diagnostics = new DiagnosticsCollector();
|
|
39
39
|
|
|
40
40
|
diagnostics.emit({ message: "Test diagnostic", severity: "warning" });
|
|
@@ -50,6 +50,7 @@ it("emits diagnostics:report messages", async () => {
|
|
|
50
50
|
|
|
51
51
|
expect(diagnosticsMessages[0]).toMatchObject({
|
|
52
52
|
type: "diagnostics:report",
|
|
53
|
-
|
|
53
|
+
message: "Test diagnostic",
|
|
54
|
+
severity: "warning",
|
|
54
55
|
});
|
|
55
56
|
});
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { shallowReactive } from "@vue/reactivity";
|
|
2
|
+
import { afterEach, beforeEach, describe, expect, it } from "vitest";
|
|
2
3
|
import WebSocket from "ws";
|
|
3
4
|
import {
|
|
4
5
|
createMessageCollector,
|
|
@@ -9,8 +10,9 @@ import {
|
|
|
9
10
|
enableDevtools,
|
|
10
11
|
resetDevtoolsServerForTests,
|
|
11
12
|
} from "../devtools/devtools-server.js";
|
|
12
|
-
import { effect, ref } from "../reactivity.js";
|
|
13
|
+
import { effect, memo, ref } from "../reactivity.js";
|
|
13
14
|
import { renderAsync } from "../render.js";
|
|
15
|
+
import { flushJobsAsync } from "../scheduler.js";
|
|
14
16
|
import { debug } from "./index.js";
|
|
15
17
|
|
|
16
18
|
let socket: WebSocket | undefined;
|
|
@@ -36,54 +38,264 @@ afterEach(async () => {
|
|
|
36
38
|
debug.effect.reset();
|
|
37
39
|
});
|
|
38
40
|
|
|
39
|
-
it("emits effect, ref,
|
|
40
|
-
const collector = createMessageCollector(socket!);
|
|
41
|
+
it("emits effect, ref, and track messages", async () => {
|
|
42
|
+
const collector = await createMessageCollector(socket!);
|
|
41
43
|
const r1 = ref(0);
|
|
44
|
+
const r2 = ref(1);
|
|
42
45
|
|
|
43
|
-
// Create an effect that reads r1.
|
|
44
|
-
let observed = 0;
|
|
45
46
|
effect(() => {
|
|
46
|
-
|
|
47
|
+
r1.value = r2.value + 1;
|
|
47
48
|
});
|
|
48
49
|
|
|
49
|
-
// Mutate r1 to trigger the effect.
|
|
50
|
-
r1.value = 42;
|
|
51
|
-
|
|
52
50
|
await renderAsync(<Output>{"ok"}</Output>);
|
|
53
51
|
|
|
54
52
|
const messages = await collector.waitForRender();
|
|
55
53
|
const effectsMessages = filterEffectsMessages(messages);
|
|
56
54
|
collector.stop();
|
|
57
55
|
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
expect(
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
expect(
|
|
69
|
-
|
|
56
|
+
expect(effectsMessages[0]).toMatchObject({
|
|
57
|
+
type: "ref:added",
|
|
58
|
+
id: expect.any(Number),
|
|
59
|
+
kind: "ref",
|
|
60
|
+
});
|
|
61
|
+
expect(effectsMessages[1]).toMatchObject({
|
|
62
|
+
type: "ref:added",
|
|
63
|
+
id: expect.any(Number),
|
|
64
|
+
kind: "ref",
|
|
65
|
+
});
|
|
66
|
+
expect(effectsMessages[2]).toMatchObject({
|
|
67
|
+
type: "effect:added",
|
|
68
|
+
id: expect.any(Number),
|
|
69
|
+
});
|
|
70
|
+
expect(effectsMessages[3]).toMatchObject({
|
|
71
|
+
type: "edge:track",
|
|
72
|
+
effect_id: expect.any(Number),
|
|
73
|
+
ref_id: expect.any(Number),
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
|
|
77
|
+
describe("unified trigger edges", () => {
|
|
78
|
+
it("ref trigger records consumer and producer (caused_by)", async () => {
|
|
79
|
+
const collector = await createMessageCollector(socket!);
|
|
80
|
+
const r = ref(0);
|
|
81
|
+
|
|
82
|
+
// Producer effect writes to the ref
|
|
83
|
+
const producerName = "test-producer";
|
|
84
|
+
effect(
|
|
85
|
+
() => {
|
|
86
|
+
r.value = 42;
|
|
87
|
+
},
|
|
88
|
+
undefined,
|
|
89
|
+
{ debug: { name: producerName } },
|
|
90
|
+
);
|
|
91
|
+
|
|
92
|
+
// Consumer effect reads the ref
|
|
93
|
+
const consumerName = "test-consumer";
|
|
94
|
+
effect(
|
|
95
|
+
() => {
|
|
96
|
+
void r.value;
|
|
97
|
+
},
|
|
98
|
+
undefined,
|
|
99
|
+
{ debug: { name: consumerName } },
|
|
100
|
+
);
|
|
101
|
+
|
|
102
|
+
await renderAsync(<Output>{"ok"}</Output>);
|
|
103
|
+
const renderMessages = await collector.waitForRender();
|
|
104
|
+
|
|
105
|
+
// Trigger the consumer by changing the ref
|
|
106
|
+
r.value = 99;
|
|
107
|
+
await flushJobsAsync();
|
|
108
|
+
const flushMessages = await collector.waitForFlush();
|
|
109
|
+
collector.stop();
|
|
110
|
+
|
|
111
|
+
// Find the trigger edge on the consumer
|
|
112
|
+
const triggerEdges = flushMessages.filter(
|
|
113
|
+
(m: any) => m.type === "edge:trigger" && m.ref_id !== undefined,
|
|
114
|
+
);
|
|
115
|
+
expect(triggerEdges.length).toBeGreaterThan(0);
|
|
116
|
+
|
|
117
|
+
// The trigger edge should be on the consumer effect
|
|
118
|
+
const effectsMessages = filterEffectsMessages(renderMessages);
|
|
119
|
+
const consumerEffect = effectsMessages.find(
|
|
120
|
+
(m: any) => m.type === "effect:added" && m.name === consumerName,
|
|
121
|
+
);
|
|
122
|
+
expect(consumerEffect).toBeDefined();
|
|
123
|
+
|
|
124
|
+
const consumerTrigger = triggerEdges.find(
|
|
125
|
+
(m: any) => m.effect_id === consumerEffect!.id,
|
|
126
|
+
);
|
|
127
|
+
expect(consumerTrigger).toBeDefined();
|
|
128
|
+
// caused_by is null since the mutation happens outside any effect (top-level r.value = 99)
|
|
129
|
+
expect(consumerTrigger!.caused_by).toBeNull();
|
|
70
130
|
});
|
|
71
|
-
|
|
72
|
-
|
|
131
|
+
|
|
132
|
+
it("reactive object trigger records consumer and producer", async () => {
|
|
133
|
+
const collector = await createMessageCollector(socket!);
|
|
134
|
+
const map = shallowReactive(new Map<string, number>());
|
|
135
|
+
|
|
136
|
+
// Consumer: memo reads the map
|
|
137
|
+
const sum = memo(() => {
|
|
138
|
+
let total = 0;
|
|
139
|
+
for (const v of map.values()) total += v;
|
|
140
|
+
return total;
|
|
141
|
+
});
|
|
142
|
+
|
|
143
|
+
// Producer: effect mutates the map
|
|
144
|
+
effect(
|
|
145
|
+
() => {
|
|
146
|
+
const _s = sum();
|
|
147
|
+
map.set("key", 42);
|
|
148
|
+
},
|
|
149
|
+
undefined,
|
|
150
|
+
{ debug: { name: "producer-effect" } },
|
|
151
|
+
);
|
|
152
|
+
|
|
153
|
+
await renderAsync(<Output>{"ok"}</Output>);
|
|
154
|
+
|
|
155
|
+
const messages = await collector.waitForRender();
|
|
156
|
+
const effectsMessages = filterEffectsMessages(messages);
|
|
157
|
+
collector.stop();
|
|
158
|
+
|
|
159
|
+
// Find trigger edges for the reactive map
|
|
160
|
+
const triggerEdges = effectsMessages.filter(
|
|
161
|
+
(m: any) => m.type === "edge:trigger" && m.target_id !== undefined,
|
|
162
|
+
);
|
|
163
|
+
expect(triggerEdges.length).toBeGreaterThan(0);
|
|
164
|
+
|
|
165
|
+
// The trigger should have caused_by (the producer effect)
|
|
166
|
+
const producerEffect = effectsMessages.find(
|
|
167
|
+
(m: any) => m.type === "effect:added" && m.name === "producer-effect",
|
|
168
|
+
);
|
|
169
|
+
expect(producerEffect).toBeDefined();
|
|
170
|
+
|
|
171
|
+
const withCause = triggerEdges.filter(
|
|
172
|
+
(m: any) => m.caused_by === producerEffect!.id,
|
|
173
|
+
);
|
|
174
|
+
expect(withCause.length).toBeGreaterThan(0);
|
|
175
|
+
expect(withCause[0]).toMatchObject({
|
|
176
|
+
type: "edge:trigger",
|
|
177
|
+
effect_id: expect.any(Number),
|
|
178
|
+
caused_by: producerEffect!.id,
|
|
179
|
+
target_id: expect.any(Number),
|
|
180
|
+
});
|
|
73
181
|
});
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
182
|
+
|
|
183
|
+
it("trigger outside any effect has no caused_by", async () => {
|
|
184
|
+
const collector = await createMessageCollector(socket!);
|
|
185
|
+
const r = ref(0);
|
|
186
|
+
|
|
187
|
+
// Consumer effect
|
|
188
|
+
effect(() => {
|
|
189
|
+
void r.value;
|
|
190
|
+
});
|
|
191
|
+
|
|
192
|
+
await renderAsync(<Output>{"ok"}</Output>);
|
|
193
|
+
await collector.waitForRender();
|
|
194
|
+
|
|
195
|
+
// Trigger from top-level (outside any effect)
|
|
196
|
+
r.value = 1;
|
|
197
|
+
await flushJobsAsync();
|
|
198
|
+
const flushMessages = await collector.waitForFlush();
|
|
199
|
+
collector.stop();
|
|
200
|
+
|
|
201
|
+
const triggerEdges = flushMessages.filter(
|
|
202
|
+
(m: any) => m.type === "edge:trigger",
|
|
203
|
+
);
|
|
204
|
+
expect(triggerEdges.length).toBeGreaterThan(0);
|
|
205
|
+
// caused_by should be null (no producer effect)
|
|
206
|
+
expect(triggerEdges[0].caused_by).toBeNull();
|
|
80
207
|
});
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
208
|
+
|
|
209
|
+
it("multiple consumers of same ref get separate trigger edges", async () => {
|
|
210
|
+
const collector = await createMessageCollector(socket!);
|
|
211
|
+
const r = ref(0);
|
|
212
|
+
|
|
213
|
+
// Two consumer effects
|
|
214
|
+
effect(
|
|
215
|
+
() => {
|
|
216
|
+
void r.value;
|
|
217
|
+
},
|
|
218
|
+
undefined,
|
|
219
|
+
{ debug: { name: "consumer-a" } },
|
|
220
|
+
);
|
|
221
|
+
effect(
|
|
222
|
+
() => {
|
|
223
|
+
void r.value;
|
|
224
|
+
},
|
|
225
|
+
undefined,
|
|
226
|
+
{ debug: { name: "consumer-b" } },
|
|
227
|
+
);
|
|
228
|
+
|
|
229
|
+
await renderAsync(<Output>{"ok"}</Output>);
|
|
230
|
+
const renderMessages = await collector.waitForRender();
|
|
231
|
+
|
|
232
|
+
// Find the effect IDs
|
|
233
|
+
const effectsMessages = filterEffectsMessages(renderMessages);
|
|
234
|
+
const consumerA = effectsMessages.find(
|
|
235
|
+
(m: any) => m.type === "effect:added" && m.name === "consumer-a",
|
|
236
|
+
);
|
|
237
|
+
const consumerB = effectsMessages.find(
|
|
238
|
+
(m: any) => m.type === "effect:added" && m.name === "consumer-b",
|
|
239
|
+
);
|
|
240
|
+
expect(consumerA).toBeDefined();
|
|
241
|
+
expect(consumerB).toBeDefined();
|
|
242
|
+
|
|
243
|
+
// Trigger both by changing the ref
|
|
244
|
+
r.value = 1;
|
|
245
|
+
await flushJobsAsync();
|
|
246
|
+
const flushMessages = await collector.waitForFlush();
|
|
247
|
+
collector.stop();
|
|
248
|
+
|
|
249
|
+
const triggerEdges = flushMessages.filter(
|
|
250
|
+
(m: any) => m.type === "edge:trigger",
|
|
251
|
+
);
|
|
252
|
+
|
|
253
|
+
// Each consumer gets its own trigger edge
|
|
254
|
+
const aTrigger = triggerEdges.find(
|
|
255
|
+
(m: any) => m.effect_id === consumerA!.id,
|
|
256
|
+
);
|
|
257
|
+
const bTrigger = triggerEdges.find(
|
|
258
|
+
(m: any) => m.effect_id === consumerB!.id,
|
|
259
|
+
);
|
|
260
|
+
expect(aTrigger).toBeDefined();
|
|
261
|
+
expect(bTrigger).toBeDefined();
|
|
262
|
+
// Both reference the same ref
|
|
263
|
+
expect(aTrigger!.ref_id).toBe(bTrigger!.ref_id);
|
|
86
264
|
});
|
|
87
265
|
|
|
88
|
-
|
|
266
|
+
it("no triggered-by or duplicate trigger edge types exist", async () => {
|
|
267
|
+
const collector = await createMessageCollector(socket!);
|
|
268
|
+
const r = ref(0);
|
|
269
|
+
const map = shallowReactive(new Map<string, number>());
|
|
270
|
+
|
|
271
|
+
effect(() => {
|
|
272
|
+
void r.value;
|
|
273
|
+
for (const _v of map.values()) {
|
|
274
|
+
/* track */
|
|
275
|
+
}
|
|
276
|
+
});
|
|
277
|
+
|
|
278
|
+
effect(() => {
|
|
279
|
+
r.value = 1;
|
|
280
|
+
map.set("x", 1);
|
|
281
|
+
});
|
|
282
|
+
|
|
283
|
+
await renderAsync(<Output>{"ok"}</Output>);
|
|
284
|
+
const messages = await collector.waitForRender();
|
|
285
|
+
collector.stop();
|
|
286
|
+
|
|
287
|
+
// No edge:triggered-by messages should exist
|
|
288
|
+
const triggeredBy = messages.filter(
|
|
289
|
+
(m: any) => m.type === "edge:triggered-by",
|
|
290
|
+
);
|
|
291
|
+
expect(triggeredBy.length).toBe(0);
|
|
292
|
+
|
|
293
|
+
// All edge types should be edge:track or edge:trigger only
|
|
294
|
+
const edges = messages.filter(
|
|
295
|
+
(m: any) => typeof m.type === "string" && m.type.startsWith("edge:"),
|
|
296
|
+
);
|
|
297
|
+
for (const edge of edges) {
|
|
298
|
+
expect(["edge:track", "edge:trigger"]).toContain(edge.type);
|
|
299
|
+
}
|
|
300
|
+
});
|
|
89
301
|
});
|