@alloy-js/core 0.24.0-dev.2 → 0.24.0-dev.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +8 -0
- package/dist/dev/src/components/AccessExpression.test.js +1 -1
- package/dist/dev/src/components/AccessExpression.test.js.map +1 -1
- package/dist/dev/src/components/Output.js +3 -2
- package/dist/dev/src/components/Output.js.map +1 -1
- package/dist/dev/src/components/SourceFile.js.map +1 -1
- package/dist/dev/src/content-slot.test.js +1 -1
- package/dist/dev/src/content-slot.test.js.map +1 -1
- package/dist/dev/src/context.js +30 -3
- package/dist/dev/src/context.js.map +1 -1
- package/dist/dev/src/debug/diagnostics.test.js +1 -1
- package/dist/dev/src/debug/diagnostics.test.js.map +1 -1
- package/dist/dev/src/debug/effects.test.js +1 -1
- package/dist/dev/src/debug/effects.test.js.map +1 -1
- package/dist/dev/src/debug/file-streaming.js +103 -0
- package/dist/dev/src/debug/file-streaming.js.map +1 -0
- package/dist/dev/src/debug/files.test.js +4 -5
- package/dist/dev/src/debug/files.test.js.map +1 -1
- package/dist/dev/src/debug/index.js +4 -6
- package/dist/dev/src/debug/index.js.map +1 -1
- package/dist/dev/src/debug/message-format.test.js +50 -52
- package/dist/dev/src/debug/message-format.test.js.map +1 -1
- package/dist/dev/src/debug/render-tree-orphans.test.js +13 -23
- package/dist/dev/src/debug/render-tree-orphans.test.js.map +1 -1
- package/dist/dev/src/debug/render.js +529 -352
- package/dist/dev/src/debug/render.js.map +1 -1
- package/dist/dev/src/debug/render.test.js +171 -92
- package/dist/dev/src/debug/render.test.js.map +1 -1
- package/dist/dev/src/debug/trace-writer.js +127 -15
- package/dist/dev/src/debug/trace-writer.js.map +1 -1
- package/dist/dev/src/debug/trace.js +0 -36
- package/dist/dev/src/debug/trace.js.map +1 -1
- package/dist/dev/src/devtools/devtools-server.js +55 -32
- package/dist/dev/src/devtools/devtools-server.js.map +1 -1
- package/dist/dev/src/devtools-entry.browser.js.map +1 -1
- package/dist/dev/src/devtools-entry.js.map +1 -1
- package/dist/dev/src/diagnostics.js +19 -1
- package/dist/dev/src/diagnostics.js.map +1 -1
- package/dist/dev/src/index.js +5 -2
- package/dist/dev/src/index.js.map +1 -1
- package/dist/dev/src/jsx-runtime.js +14 -8
- package/dist/dev/src/jsx-runtime.js.map +1 -1
- package/dist/dev/src/output-types.js +2 -0
- package/dist/dev/src/output-types.js.map +1 -0
- package/dist/dev/src/reactivity.js +155 -13
- package/dist/dev/src/reactivity.js.map +1 -1
- package/dist/dev/src/render/get-string-width.js +61 -0
- package/dist/dev/src/render/get-string-width.js.map +1 -0
- package/dist/dev/src/render/index.js +2 -0
- package/dist/dev/src/render/index.js.map +1 -0
- package/dist/dev/src/render/node-context.js +7 -0
- package/dist/dev/src/render/node-context.js.map +1 -0
- package/dist/dev/src/render/node.js +386 -0
- package/dist/dev/src/render/node.js.map +1 -0
- package/dist/dev/src/render/printer-support.js +180 -0
- package/dist/dev/src/render/printer-support.js.map +1 -0
- package/dist/dev/src/render/printer.js +797 -0
- package/dist/dev/src/render/printer.js.map +1 -0
- package/dist/dev/src/render-error.js +79 -0
- package/dist/dev/src/render-error.js.map +1 -0
- package/dist/dev/src/render-output.js +209 -0
- package/dist/dev/src/render-output.js.map +1 -0
- package/dist/dev/src/runtime/create-intrinsic.js +53 -0
- package/dist/dev/src/runtime/create-intrinsic.js.map +1 -0
- package/dist/dev/src/runtime/fragment.js +21 -0
- package/dist/dev/src/runtime/fragment.js.map +1 -0
- package/dist/dev/src/runtime/index.js +13 -0
- package/dist/dev/src/runtime/index.js.map +1 -0
- package/dist/dev/src/runtime/insert.js +453 -0
- package/dist/dev/src/runtime/insert.js.map +1 -0
- package/dist/dev/src/runtime/intrinsic.js +1 -11
- package/dist/dev/src/runtime/intrinsic.js.map +1 -1
- package/dist/dev/src/scheduler.js +38 -14
- package/dist/dev/src/scheduler.js.map +1 -1
- package/dist/dev/src/stc.js +2 -0
- package/dist/dev/src/stc.js.map +1 -1
- package/dist/dev/src/sti.js +1 -1
- package/dist/dev/src/sti.js.map +1 -1
- package/dist/dev/src/symbols/symbol-slot.test.js +1 -1
- package/dist/dev/src/symbols/symbol-slot.test.js.map +1 -1
- package/dist/dev/src/test-render.js +78 -0
- package/dist/dev/src/test-render.js.map +1 -0
- package/dist/dev/src/utils.js +47 -35
- package/dist/dev/src/utils.js.map +1 -1
- package/dist/dev/test/babel-e2e.test.js +218 -0
- package/dist/dev/test/babel-e2e.test.js.map +1 -0
- package/dist/dev/test/components/block.test.js +1 -1
- package/dist/dev/test/components/block.test.js.map +1 -1
- package/dist/dev/test/components/copy-file.test.js +7 -7
- package/dist/dev/test/components/copy-file.test.js.map +1 -1
- package/dist/dev/test/components/update-file.test.js +1 -1
- package/dist/dev/test/components/update-file.test.js.map +1 -1
- package/dist/dev/test/components/wrap.test.js +1 -1
- package/dist/dev/test/components/wrap.test.js.map +1 -1
- package/dist/dev/test/control-flow/match.test.js +1 -1
- package/dist/dev/test/control-flow/match.test.js.map +1 -1
- package/dist/dev/test/control-flow/show.test.js +1 -1
- package/dist/dev/test/control-flow/show.test.js.map +1 -1
- package/dist/dev/test/lazy-isempty.test.js +6 -6
- package/dist/dev/test/lazy-isempty.test.js.map +1 -1
- package/dist/dev/test/node.test.js +80 -0
- package/dist/dev/test/node.test.js.map +1 -0
- package/dist/dev/test/output-e2e.test.js +194 -0
- package/dist/dev/test/output-e2e.test.js.map +1 -0
- package/dist/dev/test/reactivity/circular-reactives.test.js +1 -1
- package/dist/dev/test/reactivity/circular-reactives.test.js.map +1 -1
- package/dist/dev/test/reactivity/cleanup.test.js +1 -1
- package/dist/dev/test/reactivity/cleanup.test.js.map +1 -1
- package/dist/dev/test/rendering/memoization.test.js +6 -1
- package/dist/dev/test/rendering/memoization.test.js.map +1 -1
- package/dist/dev/test/rendering/render-output-diagnostics.test.js +102 -0
- package/dist/dev/test/rendering/render-output-diagnostics.test.js.map +1 -0
- package/dist/dev/test/runtime.test.js +385 -0
- package/dist/dev/test/runtime.test.js.map +1 -0
- package/dist/dev/test/tree-test-utils.js +16 -0
- package/dist/dev/test/tree-test-utils.js.map +1 -0
- package/dist/dev/test/utils.test.js +1 -1
- package/dist/dev/test/utils.test.js.map +1 -1
- package/dist/dev/testing/devtools-utils.js +1 -1
- package/dist/dev/testing/devtools-utils.js.map +1 -1
- package/dist/dev/testing/extend-expect.js +7 -33
- package/dist/dev/testing/extend-expect.js.map +1 -1
- package/dist/dev/testing/render.js +7 -17
- package/dist/dev/testing/render.js.map +1 -1
- package/dist/devtools/index.html +17 -17
- package/dist/src/components/AccessExpression.test.js +1 -1
- package/dist/src/components/AccessExpression.test.js.map +1 -1
- package/dist/src/components/Output.d.ts +1 -1
- package/dist/src/components/Output.d.ts.map +1 -1
- package/dist/src/components/Output.js +2 -1
- package/dist/src/components/Output.js.map +1 -1
- package/dist/src/components/ReferenceOrContent.d.ts +1 -1
- package/dist/src/components/ReferenceOrContent.d.ts.map +1 -1
- package/dist/src/components/SourceFile.d.ts +1 -1
- package/dist/src/components/SourceFile.d.ts.map +1 -1
- package/dist/src/components/SourceFile.js.map +1 -1
- package/dist/src/content-slot.test.js +1 -1
- package/dist/src/content-slot.test.js.map +1 -1
- package/dist/src/context/format-options.d.ts +1 -1
- package/dist/src/context/format-options.d.ts.map +1 -1
- package/dist/src/context.d.ts +9 -1
- package/dist/src/context.d.ts.map +1 -1
- package/dist/src/context.js +30 -3
- package/dist/src/context.js.map +1 -1
- package/dist/src/debug/diagnostics.test.js +1 -1
- package/dist/src/debug/diagnostics.test.js.map +1 -1
- package/dist/src/debug/effects.test.js +1 -1
- package/dist/src/debug/effects.test.js.map +1 -1
- package/dist/src/debug/file-streaming.d.ts +22 -0
- package/dist/src/debug/file-streaming.d.ts.map +1 -0
- package/dist/src/debug/file-streaming.js +103 -0
- package/dist/src/debug/file-streaming.js.map +1 -0
- package/dist/src/debug/files.test.js +4 -5
- package/dist/src/debug/files.test.js.map +1 -1
- package/dist/src/debug/index.d.ts +5 -7
- package/dist/src/debug/index.d.ts.map +1 -1
- package/dist/src/debug/index.js +4 -6
- package/dist/src/debug/index.js.map +1 -1
- package/dist/src/debug/message-format.test.js +16 -18
- package/dist/src/debug/message-format.test.js.map +1 -1
- package/dist/src/debug/render-tree-orphans.test.js +8 -18
- package/dist/src/debug/render-tree-orphans.test.js.map +1 -1
- package/dist/src/debug/render.d.ts +71 -21
- package/dist/src/debug/render.d.ts.map +1 -1
- package/dist/src/debug/render.js +529 -352
- package/dist/src/debug/render.js.map +1 -1
- package/dist/src/debug/render.test.js +137 -74
- package/dist/src/debug/render.test.js.map +1 -1
- package/dist/src/debug/trace-writer.d.ts +6 -1
- package/dist/src/debug/trace-writer.d.ts.map +1 -1
- package/dist/src/debug/trace-writer.js +127 -15
- package/dist/src/debug/trace-writer.js.map +1 -1
- package/dist/src/debug/trace.d.ts +0 -36
- package/dist/src/debug/trace.d.ts.map +1 -1
- package/dist/src/debug/trace.js +0 -36
- package/dist/src/debug/trace.js.map +1 -1
- package/dist/src/devtools/devtools-protocol.d.ts +34 -1
- package/dist/src/devtools/devtools-protocol.d.ts.map +1 -1
- package/dist/src/devtools/devtools-server.d.ts.map +1 -1
- package/dist/src/devtools/devtools-server.js +55 -32
- package/dist/src/devtools/devtools-server.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 +4 -0
- package/dist/src/diagnostics.d.ts.map +1 -1
- package/dist/src/diagnostics.js +19 -1
- package/dist/src/diagnostics.js.map +1 -1
- package/dist/src/index.d.ts +5 -2
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +5 -2
- package/dist/src/index.js.map +1 -1
- package/dist/src/jsx-runtime.d.ts +13 -4
- package/dist/src/jsx-runtime.d.ts.map +1 -1
- package/dist/src/jsx-runtime.js +14 -8
- package/dist/src/jsx-runtime.js.map +1 -1
- package/dist/src/output-types.d.ts +40 -0
- package/dist/src/output-types.d.ts.map +1 -0
- package/dist/src/output-types.js +2 -0
- package/dist/src/output-types.js.map +1 -0
- package/dist/src/reactivity.d.ts +49 -18
- package/dist/src/reactivity.d.ts.map +1 -1
- package/dist/src/reactivity.js +155 -13
- package/dist/src/reactivity.js.map +1 -1
- package/dist/src/render/get-string-width.d.ts +19 -0
- package/dist/src/render/get-string-width.d.ts.map +1 -0
- package/dist/src/render/get-string-width.js +61 -0
- package/dist/src/render/get-string-width.js.map +1 -0
- package/dist/src/render/index.d.ts +2 -0
- package/dist/src/render/index.d.ts.map +1 -0
- package/dist/src/render/index.js +2 -0
- package/dist/src/render/index.js.map +1 -0
- package/dist/src/render/node-context.d.ts +5 -0
- package/dist/src/render/node-context.d.ts.map +1 -0
- package/dist/src/render/node-context.js +7 -0
- package/dist/src/render/node-context.js.map +1 -0
- package/dist/src/render/node.d.ts +146 -0
- package/dist/src/render/node.d.ts.map +1 -0
- package/dist/src/render/node.js +386 -0
- package/dist/src/render/node.js.map +1 -0
- package/dist/src/render/printer-support.d.ts +50 -0
- package/dist/src/render/printer-support.d.ts.map +1 -0
- package/dist/src/render/printer-support.js +180 -0
- package/dist/src/render/printer-support.js.map +1 -0
- package/dist/src/render/printer.d.ts +35 -0
- package/dist/src/render/printer.d.ts.map +1 -0
- package/dist/src/render/printer.js +797 -0
- package/dist/src/render/printer.js.map +1 -0
- package/dist/src/render-error.d.ts +4 -0
- package/dist/src/render-error.d.ts.map +1 -0
- package/dist/src/render-error.js +79 -0
- package/dist/src/render-error.js.map +1 -0
- package/dist/src/render-output.d.ts +42 -0
- package/dist/src/render-output.d.ts.map +1 -0
- package/dist/src/render-output.js +209 -0
- package/dist/src/render-output.js.map +1 -0
- package/dist/src/runtime/component.d.ts +2 -2
- package/dist/src/runtime/component.d.ts.map +1 -1
- package/dist/src/runtime/create-intrinsic.d.ts +28 -0
- package/dist/src/runtime/create-intrinsic.d.ts.map +1 -0
- package/dist/src/runtime/create-intrinsic.js +53 -0
- package/dist/src/runtime/create-intrinsic.js.map +1 -0
- package/dist/src/runtime/fragment.d.ts +16 -0
- package/dist/src/runtime/fragment.d.ts.map +1 -0
- package/dist/src/runtime/fragment.js +21 -0
- package/dist/src/runtime/fragment.js.map +1 -0
- package/dist/src/runtime/index.d.ts +12 -0
- package/dist/src/runtime/index.d.ts.map +1 -0
- package/dist/src/runtime/index.js +13 -0
- package/dist/src/runtime/index.js.map +1 -0
- package/dist/src/runtime/insert.d.ts +29 -0
- package/dist/src/runtime/insert.d.ts.map +1 -0
- package/dist/src/runtime/insert.js +453 -0
- package/dist/src/runtime/insert.js.map +1 -0
- package/dist/src/runtime/intrinsic.d.ts +12 -29
- package/dist/src/runtime/intrinsic.d.ts.map +1 -1
- package/dist/src/runtime/intrinsic.js +1 -11
- package/dist/src/runtime/intrinsic.js.map +1 -1
- package/dist/src/scheduler.d.ts.map +1 -1
- package/dist/src/scheduler.js +38 -14
- package/dist/src/scheduler.js.map +1 -1
- package/dist/src/stc.d.ts.map +1 -1
- package/dist/src/stc.js +2 -0
- package/dist/src/stc.js.map +1 -1
- package/dist/src/sti.d.ts +7 -6
- package/dist/src/sti.d.ts.map +1 -1
- package/dist/src/sti.js +1 -1
- package/dist/src/sti.js.map +1 -1
- package/dist/src/symbols/symbol-slot.test.js +1 -1
- package/dist/src/symbols/symbol-slot.test.js.map +1 -1
- package/dist/src/test-render.d.ts +31 -0
- package/dist/src/test-render.d.ts.map +1 -0
- package/dist/src/test-render.js +78 -0
- package/dist/src/test-render.js.map +1 -0
- package/dist/src/utils.d.ts +1 -1
- package/dist/src/utils.d.ts.map +1 -1
- package/dist/src/utils.js +40 -28
- package/dist/src/utils.js.map +1 -1
- package/dist/src/write-output.d.ts +1 -1
- package/dist/src/write-output.d.ts.map +1 -1
- package/dist/test/babel-e2e.test.d.ts +13 -0
- package/dist/test/babel-e2e.test.d.ts.map +1 -0
- package/dist/test/babel-e2e.test.js +218 -0
- package/dist/test/babel-e2e.test.js.map +1 -0
- package/dist/test/components/block.test.js +1 -1
- package/dist/test/components/block.test.js.map +1 -1
- package/dist/test/components/copy-file.test.d.ts.map +1 -1
- package/dist/test/components/copy-file.test.js +1 -1
- package/dist/test/components/copy-file.test.js.map +1 -1
- package/dist/test/components/update-file.test.js +1 -1
- package/dist/test/components/update-file.test.js.map +1 -1
- package/dist/test/components/wrap.test.js +1 -1
- package/dist/test/components/wrap.test.js.map +1 -1
- package/dist/test/control-flow/match.test.js +1 -1
- package/dist/test/control-flow/match.test.js.map +1 -1
- package/dist/test/control-flow/show.test.js +1 -1
- package/dist/test/control-flow/show.test.js.map +1 -1
- package/dist/test/lazy-isempty.test.js +6 -6
- package/dist/test/lazy-isempty.test.js.map +1 -1
- package/dist/test/node.test.d.ts +2 -0
- package/dist/test/node.test.d.ts.map +1 -0
- package/dist/test/node.test.js +80 -0
- package/dist/test/node.test.js.map +1 -0
- package/dist/test/output-e2e.test.d.ts +13 -0
- package/dist/test/output-e2e.test.d.ts.map +1 -0
- package/dist/test/output-e2e.test.js +194 -0
- package/dist/test/output-e2e.test.js.map +1 -0
- package/dist/test/reactivity/circular-reactives.test.js +1 -1
- package/dist/test/reactivity/circular-reactives.test.js.map +1 -1
- package/dist/test/reactivity/cleanup.test.js +1 -1
- package/dist/test/reactivity/cleanup.test.js.map +1 -1
- package/dist/test/rendering/memoization.test.js +6 -1
- package/dist/test/rendering/memoization.test.js.map +1 -1
- package/dist/test/rendering/render-output-diagnostics.test.d.ts +2 -0
- package/dist/test/rendering/render-output-diagnostics.test.d.ts.map +1 -0
- package/dist/test/rendering/render-output-diagnostics.test.js +82 -0
- package/dist/test/rendering/render-output-diagnostics.test.js.map +1 -0
- package/dist/test/runtime.test.d.ts +11 -0
- package/dist/test/runtime.test.d.ts.map +1 -0
- package/dist/test/runtime.test.js +385 -0
- package/dist/test/runtime.test.js.map +1 -0
- package/dist/test/tree-test-utils.d.ts +3 -0
- package/dist/test/tree-test-utils.d.ts.map +1 -0
- package/dist/test/tree-test-utils.js +16 -0
- package/dist/test/tree-test-utils.js.map +1 -0
- package/dist/test/utils.test.js +1 -1
- package/dist/test/utils.test.js.map +1 -1
- package/dist/testing/devtools-utils.d.ts.map +1 -1
- package/dist/testing/devtools-utils.js +1 -1
- package/dist/testing/devtools-utils.js.map +1 -1
- package/dist/testing/extend-expect.d.ts.map +1 -1
- package/dist/testing/extend-expect.js +7 -33
- package/dist/testing/extend-expect.js.map +1 -1
- package/dist/testing/render.d.ts +7 -9
- package/dist/testing/render.d.ts.map +1 -1
- package/dist/testing/render.js +7 -17
- package/dist/testing/render.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/docs/api/components/Output.md +0 -3
- package/docs/api/components/SourceFile.md +0 -3
- package/docs/api/functions/createComment.md +18 -0
- package/docs/api/functions/createElement.md +19 -0
- package/docs/api/functions/createFragment.md +17 -0
- package/docs/api/functions/createTextNode.md +18 -0
- package/docs/api/functions/emitDiagnosticForTree.md +19 -0
- package/docs/api/functions/ensureIsEmpty.md +1 -1
- package/docs/api/functions/getContextForNode.md +18 -0
- package/docs/api/functions/getContextForRenderNode.md +4 -4
- package/docs/api/functions/getDiagnosticsForTree.md +7 -5
- package/docs/api/functions/getRegisteredDiagnosticsForTree.md +18 -0
- package/docs/api/functions/index.md +17 -12
- package/docs/api/functions/isCustomContext.md +4 -4
- package/docs/api/functions/notifyContentState.md +6 -0
- package/docs/api/functions/printTree.md +6 -16
- package/docs/api/functions/registerDiagnosticsForTree.md +19 -0
- package/docs/api/functions/render.md +1 -2
- package/docs/api/functions/renderAsync.md +1 -2
- package/docs/api/functions/renderTree.md +8 -5
- package/docs/api/functions/reportDiagnosticsForTree.md +18 -0
- package/docs/api/functions/runInContext.md +28 -0
- package/docs/api/functions/sourceFilesForTree.md +6 -16
- package/docs/api/index.md +3 -3
- package/docs/api/testing/functions/index.md +1 -1
- package/docs/api/testing/functions/renderToString.md +1 -1
- package/docs/api/types/AlloyNode.md +22 -0
- package/docs/api/types/Child.md +1 -1
- package/docs/api/types/CommentNode.md +15 -0
- package/docs/api/types/Context.md +13 -15
- package/docs/api/types/ElementNode.md +18 -0
- package/docs/api/types/FragmentNode.md +12 -0
- package/docs/api/types/Insertable.md +7 -0
- package/docs/api/types/NodeType.md +5 -0
- package/docs/api/types/OutputDirectory.md +0 -50
- package/docs/api/types/PrintTreeOptions.md +0 -1
- package/docs/api/types/RenderTreeOptions.md +7 -0
- package/docs/api/types/StiComponentCreator.md +4 -4
- package/docs/api/types/StiSignature.md +1 -1
- package/docs/api/types/TextNode.md +16 -0
- package/docs/api/types/index.md +10 -28
- package/docs/api/variables/COMMENT_NODE.md +5 -0
- package/docs/api/variables/ELEMENT_NODE.md +11 -0
- package/docs/api/variables/FRAGMENT_NODE.md +5 -0
- package/docs/api/variables/TEXT_NODE.md +5 -0
- package/docs/api/variables/index.md +4 -2
- package/docs/formatting.md +1 -1
- package/docs/rendering.md +4 -4
- package/package.json +6 -6
- package/src/components/AccessExpression.test.tsx +1 -1
- package/src/components/Output.tsx +2 -1
- package/src/components/SourceFile.tsx +1 -1
- package/src/content-slot.test.tsx +1 -1
- package/src/context/format-options.ts +1 -1
- package/src/context.ts +37 -4
- package/src/debug/diagnostics.test.tsx +1 -1
- package/src/debug/effects.test.tsx +1 -1
- package/src/debug/file-streaming.ts +115 -0
- package/src/debug/files.test.tsx +15 -11
- package/src/debug/index.ts +11 -11
- package/src/debug/message-format.test.tsx +32 -19
- package/src/debug/render-tree-orphans.test.tsx +10 -19
- package/src/debug/render.test.tsx +206 -78
- package/src/debug/render.ts +642 -495
- package/src/debug/trace-writer.ts +168 -14
- package/src/debug/trace.ts +0 -20
- package/src/devtools/devtools-protocol.ts +43 -0
- package/src/devtools/devtools-server.ts +57 -32
- package/src/devtools-entry.browser.ts +5 -0
- package/src/devtools-entry.ts +5 -0
- package/src/diagnostics.ts +31 -0
- package/src/index.ts +66 -2
- package/src/jsx-runtime.ts +16 -14
- package/src/output-types.ts +47 -0
- package/src/reactivity.ts +186 -40
- package/src/render/get-string-width.ts +201 -0
- package/src/render/index.ts +1 -0
- package/src/render/node-context.ts +14 -0
- package/src/render/node.ts +442 -0
- package/src/render/printer-support.ts +209 -0
- package/src/render/printer.ts +817 -0
- package/src/render-error.ts +98 -0
- package/src/render-output.ts +243 -0
- package/src/runtime/component.ts +2 -2
- package/src/runtime/create-intrinsic.ts +56 -0
- package/src/runtime/fragment.ts +22 -0
- package/src/runtime/index.ts +12 -0
- package/src/runtime/insert.ts +569 -0
- package/src/runtime/intrinsic.ts +14 -70
- package/src/scheduler.ts +40 -25
- package/src/stc.ts +3 -0
- package/src/sti.ts +17 -20
- package/src/symbols/symbol-slot.test.tsx +1 -1
- package/src/test-render.ts +103 -0
- package/src/utils.tsx +55 -37
- package/src/write-output.ts +1 -1
- package/temp/api-testing.json +390 -14
- package/temp/api.json +4320 -4144
- package/test/babel-e2e.test.ts +224 -0
- package/test/components/block.test.tsx +1 -1
- package/test/components/copy-file.test.tsx +2 -1
- package/test/components/update-file.test.tsx +1 -1
- package/test/components/wrap.test.tsx +1 -1
- package/test/control-flow/match.test.tsx +1 -1
- package/test/control-flow/show.test.tsx +1 -1
- package/test/lazy-isempty.test.tsx +6 -6
- package/test/node.test.ts +90 -0
- package/test/output-e2e.test.ts +198 -0
- package/test/reactivity/circular-reactives.test.tsx +1 -1
- package/test/reactivity/cleanup.test.tsx +1 -1
- package/test/rendering/memoization.test.tsx +6 -1
- package/test/rendering/render-output-diagnostics.test.tsx +120 -0
- package/test/runtime.test.ts +448 -0
- package/test/tree-test-utils.ts +23 -0
- package/test/utils.test.tsx +1 -1
- package/testing/devtools-utils.ts +2 -0
- package/testing/extend-expect.ts +8 -46
- package/testing/render.ts +17 -21
- package/dist/dev/src/print-hook.js +0 -10
- package/dist/dev/src/print-hook.js.map +0 -1
- package/dist/dev/src/render.js +0 -872
- package/dist/dev/src/render.js.map +0 -1
- package/dist/src/print-hook.d.ts +0 -14
- package/dist/src/print-hook.d.ts.map +0 -1
- package/dist/src/print-hook.js +0 -10
- package/dist/src/print-hook.js.map +0 -1
- package/dist/src/render.d.ts +0 -155
- package/dist/src/render.d.ts.map +0 -1
- package/dist/src/render.js +0 -872
- package/dist/src/render.js.map +0 -1
- package/docs/api/functions/createIntrinsic.md +0 -19
- package/docs/api/functions/createRenderTreeHook.md +0 -19
- package/docs/api/functions/getElementCache.md +0 -17
- package/docs/api/functions/isIntrinsicElement.md +0 -18
- package/docs/api/functions/isPrintHook.md +0 -18
- package/docs/api/types/AlignIntrinsicElement.md +0 -5
- package/docs/api/types/BrIntrinsicElement.md +0 -5
- package/docs/api/types/BreakParentIntrinsicElement.md +0 -5
- package/docs/api/types/DedentIntrinsicElement.md +0 -5
- package/docs/api/types/DedentToRootIntrinsicElement.md +0 -5
- package/docs/api/types/ElementCache.md +0 -5
- package/docs/api/types/ElementCacheKey.md +0 -5
- package/docs/api/types/FillIntrinsicElement.md +0 -5
- package/docs/api/types/GroupIntrinsicElement.md +0 -5
- package/docs/api/types/HardlineIntrinsicElement.md +0 -5
- package/docs/api/types/HbrIntrinsicElement.md +0 -5
- package/docs/api/types/IfBreakIntrinsicElement.md +0 -5
- package/docs/api/types/IndentIfBreakIntrinsicElement.md +0 -5
- package/docs/api/types/IndentIntrinsicElement.md +0 -5
- package/docs/api/types/IntrinsicElement.md +0 -5
- package/docs/api/types/IntrinsicElementBase.md +0 -9
- package/docs/api/types/LbrIntrinsicElement.md +0 -5
- package/docs/api/types/LineIntrinsicElement.md +0 -5
- package/docs/api/types/LineSuffixBoundaryIntrinsicElement.md +0 -5
- package/docs/api/types/LineSuffixIntrinsicElement.md +0 -5
- package/docs/api/types/LiterallineIntrinsicElement.md +0 -5
- package/docs/api/types/MarkAsRootIntrinsicElement.md +0 -5
- package/docs/api/types/PrintHook.md +0 -10
- package/docs/api/types/RenderedTextTree.md +0 -5
- package/docs/api/types/SbrIntrinsicElement.md +0 -5
- package/docs/api/types/SoftlineIntrinsicElement.md +0 -5
- package/docs/api/variables/intrinsicElementKey.md +0 -5
- package/docs/api/variables/printHookTag.md +0 -7
- package/src/print-hook.ts +0 -22
- package/src/render.ts +0 -1154
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import * as devalue from "devalue";
|
|
1
2
|
import { afterEach, beforeEach, expect, it } from "vitest";
|
|
2
3
|
import WebSocket from "ws";
|
|
3
4
|
import {
|
|
@@ -7,16 +8,21 @@ import {
|
|
|
7
8
|
} from "../../testing/devtools-utils.js";
|
|
8
9
|
import { For } from "../components/For.jsx";
|
|
9
10
|
import { Output } from "../components/Output.jsx";
|
|
11
|
+
import { Show } from "../components/Show.jsx";
|
|
10
12
|
import {
|
|
11
13
|
enableDevtools,
|
|
12
14
|
resetDevtoolsServerForTests,
|
|
13
15
|
} from "../devtools/devtools-server.js";
|
|
14
16
|
import { ref } from "../reactivity.js";
|
|
15
|
-
import { renderAsync } from "../render.js";
|
|
17
|
+
import { renderAsync } from "../render-output.js";
|
|
16
18
|
import { flushJobsAsync } from "../scheduler.js";
|
|
17
19
|
|
|
18
20
|
let socket: WebSocket | undefined;
|
|
19
21
|
|
|
22
|
+
function componentMessages(messages: DevtoolsMessage[]) {
|
|
23
|
+
return messages.filter((m) => m.type.startsWith("component:"));
|
|
24
|
+
}
|
|
25
|
+
|
|
20
26
|
beforeEach(async () => {
|
|
21
27
|
const server = await enableDevtools({ port: 0 });
|
|
22
28
|
socket = new WebSocket(`ws://127.0.0.1:${server.port}`);
|
|
@@ -106,89 +112,117 @@ it("sends render tree messages during render", async () => {
|
|
|
106
112
|
type: "render:node_added",
|
|
107
113
|
parent_id: null,
|
|
108
114
|
});
|
|
109
|
-
expect(nodeAdded
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
expect(
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
expect(
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
expect(
|
|
143
|
-
type: "render:node_added",
|
|
144
|
-
value: "Hello",
|
|
145
|
-
});
|
|
146
|
-
expect(nodeAdded[11]).toMatchObject({
|
|
147
|
-
type: "render:node_added",
|
|
148
|
-
name: "br",
|
|
149
|
-
});
|
|
150
|
-
expect(nodeAdded[12]).toMatchObject({
|
|
151
|
-
type: "render:node_added",
|
|
152
|
-
});
|
|
153
|
-
expect(nodeAdded[13]).toMatchObject({
|
|
154
|
-
type: "render:node_added",
|
|
155
|
-
value: "World",
|
|
156
|
-
});
|
|
115
|
+
expect(nodeAdded.map((m) => m.kind)).not.toContain("component");
|
|
116
|
+
expect(nodeAdded.map((m) => m.kind)).not.toContain("memo");
|
|
117
|
+
|
|
118
|
+
// Component invocations are canonical component messages, not
|
|
119
|
+
// render-node rows. Exact ordering is not contractual.
|
|
120
|
+
const components = componentMessages(messages);
|
|
121
|
+
const componentNames = components
|
|
122
|
+
.filter((m) => m.type === "component:added")
|
|
123
|
+
.map((m) => m.name);
|
|
124
|
+
expect(componentNames).toContain("Output");
|
|
125
|
+
expect(componentNames).toContain("Context Binder");
|
|
126
|
+
expect(
|
|
127
|
+
componentNames.some(
|
|
128
|
+
(n) => typeof n === "string" && n.startsWith("Context FormatOptions"),
|
|
129
|
+
),
|
|
130
|
+
).toBe(true);
|
|
131
|
+
expect(componentNames).toContain("SourceDirectory");
|
|
132
|
+
expect(componentNames).toContain("Context SourceDirectory");
|
|
133
|
+
expect(componentNames).toContain("Foo");
|
|
134
|
+
expect(nodeAdded.map((m) => m.name)).toContain("br");
|
|
135
|
+
|
|
136
|
+
const foo = components.find(
|
|
137
|
+
(m) => m.type === "component:added" && m.name === "Foo",
|
|
138
|
+
);
|
|
139
|
+
expect(foo).toBeDefined();
|
|
140
|
+
const fooRoots = components.filter(
|
|
141
|
+
(m) => m.type === "component:root_added" && m.component_id === foo!.id,
|
|
142
|
+
);
|
|
143
|
+
expect(fooRoots.length).toBeGreaterThan(1);
|
|
144
|
+
|
|
145
|
+
// Text content from Foo's body is also exposed as text nodes.
|
|
146
|
+
const values = nodeAdded.map((m) => m.value);
|
|
147
|
+
expect(values).toContain("Hello");
|
|
148
|
+
expect(values).toContain("World");
|
|
157
149
|
});
|
|
158
150
|
|
|
159
151
|
it("rerenders when devtools requests rerender", async () => {
|
|
160
|
-
let
|
|
152
|
+
let value = "before";
|
|
153
|
+
const collector = await createMessageCollector(socket!);
|
|
161
154
|
|
|
162
|
-
function
|
|
163
|
-
|
|
164
|
-
return "Hi";
|
|
155
|
+
function Rerendered() {
|
|
156
|
+
return value;
|
|
165
157
|
}
|
|
166
158
|
|
|
167
|
-
const collector = await createMessageCollector(socket!);
|
|
168
|
-
|
|
169
159
|
await renderAsync(
|
|
170
160
|
<Output>
|
|
171
|
-
<
|
|
161
|
+
<Rerendered />
|
|
172
162
|
</Output>,
|
|
173
163
|
);
|
|
174
164
|
|
|
175
|
-
const
|
|
176
|
-
const
|
|
177
|
-
|
|
178
|
-
(message: DevtoolsMessage) =>
|
|
179
|
-
message.type === "render:node_added" && message.name === "Display",
|
|
165
|
+
const initialMessages = await collector.waitForRender();
|
|
166
|
+
const component = componentMessages(initialMessages).find(
|
|
167
|
+
(m) => m.type === "component:added" && m.name === "Rerendered",
|
|
180
168
|
);
|
|
169
|
+
expect(component).toBeDefined();
|
|
170
|
+
const root = componentMessages(initialMessages).find(
|
|
171
|
+
(m) =>
|
|
172
|
+
m.type === "component:root_added" && m.component_id === component!.id,
|
|
173
|
+
);
|
|
174
|
+
expect(root).toBeDefined();
|
|
181
175
|
|
|
182
|
-
|
|
183
|
-
expect(displayNode?.id).toEqual(expect.any(Number));
|
|
184
|
-
|
|
176
|
+
value = "after";
|
|
185
177
|
socket!.send(
|
|
186
|
-
JSON.stringify({
|
|
178
|
+
JSON.stringify({
|
|
179
|
+
type: "render:rerender",
|
|
180
|
+
id: root!.render_node_id,
|
|
181
|
+
}),
|
|
187
182
|
);
|
|
188
183
|
|
|
189
|
-
await collector.waitForFlush();
|
|
190
|
-
|
|
191
|
-
expect(
|
|
184
|
+
const updateMessages = await collector.waitForFlush();
|
|
185
|
+
const renderMessages = filterRenderTreeMessages(updateMessages);
|
|
186
|
+
expect(renderMessages).toEqual(
|
|
187
|
+
expect.arrayContaining([
|
|
188
|
+
expect.objectContaining({
|
|
189
|
+
type: "render:node_removed",
|
|
190
|
+
id: root!.render_node_id,
|
|
191
|
+
}),
|
|
192
|
+
expect.objectContaining({
|
|
193
|
+
type: "render:node_added",
|
|
194
|
+
value: "after",
|
|
195
|
+
}),
|
|
196
|
+
]),
|
|
197
|
+
);
|
|
198
|
+
expect(renderMessages).not.toEqual(
|
|
199
|
+
expect.arrayContaining([
|
|
200
|
+
expect.objectContaining({
|
|
201
|
+
type: "render:node_added",
|
|
202
|
+
value: "before",
|
|
203
|
+
}),
|
|
204
|
+
]),
|
|
205
|
+
);
|
|
206
|
+
expect(componentMessages(updateMessages)).toEqual(
|
|
207
|
+
expect.arrayContaining([
|
|
208
|
+
expect.objectContaining({
|
|
209
|
+
type: "component:root_removed",
|
|
210
|
+
component_id: component!.id,
|
|
211
|
+
render_node_id: root!.render_node_id,
|
|
212
|
+
}),
|
|
213
|
+
expect.objectContaining({
|
|
214
|
+
type: "component:removed",
|
|
215
|
+
id: component!.id,
|
|
216
|
+
}),
|
|
217
|
+
expect.objectContaining({
|
|
218
|
+
type: "component:added",
|
|
219
|
+
name: "Rerendered",
|
|
220
|
+
}),
|
|
221
|
+
expect.objectContaining({
|
|
222
|
+
type: "component:root_added",
|
|
223
|
+
}),
|
|
224
|
+
]),
|
|
225
|
+
);
|
|
192
226
|
collector.stop();
|
|
193
227
|
});
|
|
194
228
|
|
|
@@ -208,12 +242,16 @@ it("sends render tree messages during render with For component", async () => {
|
|
|
208
242
|
collector.stop();
|
|
209
243
|
|
|
210
244
|
expect(renderMessages[0]).toMatchObject({ type: "render:reset" });
|
|
211
|
-
expect(
|
|
245
|
+
expect(componentMessages(messages)).toEqual(
|
|
212
246
|
expect.arrayContaining([
|
|
213
247
|
expect.objectContaining({
|
|
214
|
-
type: "
|
|
248
|
+
type: "component:added",
|
|
215
249
|
name: "For",
|
|
216
250
|
}),
|
|
251
|
+
]),
|
|
252
|
+
);
|
|
253
|
+
expect(renderMessages).toEqual(
|
|
254
|
+
expect.arrayContaining([
|
|
217
255
|
expect.objectContaining({
|
|
218
256
|
type: "render:node_added",
|
|
219
257
|
value: "a",
|
|
@@ -226,7 +264,7 @@ it("sends render tree messages during render with For component", async () => {
|
|
|
226
264
|
);
|
|
227
265
|
});
|
|
228
266
|
|
|
229
|
-
it("emits
|
|
267
|
+
it("emits component metadata separately from render nodes", async () => {
|
|
230
268
|
const collector = await createMessageCollector(socket!);
|
|
231
269
|
|
|
232
270
|
function Counter(props: { value: number }) {
|
|
@@ -241,17 +279,107 @@ it("emits nodeUpdated during render for context updates", async () => {
|
|
|
241
279
|
|
|
242
280
|
const messages = await collector.waitForRender();
|
|
243
281
|
const renderMessages = filterRenderTreeMessages(messages);
|
|
282
|
+
const components = componentMessages(messages);
|
|
283
|
+
|
|
284
|
+
expect(
|
|
285
|
+
renderMessages.some(
|
|
286
|
+
(m: DevtoolsMessage) =>
|
|
287
|
+
m.type === "render:node_added" &&
|
|
288
|
+
(m.kind === "component" || m.kind === "memo"),
|
|
289
|
+
),
|
|
290
|
+
).toBe(false);
|
|
291
|
+
expect(components).toEqual(
|
|
292
|
+
expect.arrayContaining([
|
|
293
|
+
expect.objectContaining({
|
|
294
|
+
type: "component:added",
|
|
295
|
+
name: "Counter",
|
|
296
|
+
}),
|
|
297
|
+
expect.objectContaining({
|
|
298
|
+
type: "component:root_added",
|
|
299
|
+
}),
|
|
300
|
+
]),
|
|
301
|
+
);
|
|
302
|
+
collector.stop();
|
|
303
|
+
});
|
|
304
|
+
|
|
305
|
+
it("removes component metadata when its render roots are removed", async () => {
|
|
306
|
+
const show = ref(true);
|
|
307
|
+
const collector = await createMessageCollector(socket!);
|
|
308
|
+
|
|
309
|
+
function Child() {
|
|
310
|
+
return "visible";
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
await renderAsync(<Output>{() => (show.value ? <Child /> : null)}</Output>);
|
|
314
|
+
|
|
315
|
+
const initialMessages = await collector.waitForRender();
|
|
316
|
+
const child = componentMessages(initialMessages).find(
|
|
317
|
+
(m) => m.type === "component:added" && m.name === "Child",
|
|
318
|
+
);
|
|
319
|
+
expect(child).toBeDefined();
|
|
320
|
+
expect(componentMessages(initialMessages)).toEqual(
|
|
321
|
+
expect.arrayContaining([
|
|
322
|
+
expect.objectContaining({
|
|
323
|
+
type: "component:root_added",
|
|
324
|
+
component_id: child!.id,
|
|
325
|
+
}),
|
|
326
|
+
]),
|
|
327
|
+
);
|
|
328
|
+
|
|
329
|
+
show.value = false;
|
|
330
|
+
await flushJobsAsync();
|
|
244
331
|
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
(
|
|
332
|
+
const updateMessages = await collector.waitForFlush();
|
|
333
|
+
expect(componentMessages(updateMessages)).toEqual(
|
|
334
|
+
expect.arrayContaining([
|
|
335
|
+
expect.objectContaining({
|
|
336
|
+
type: "component:root_removed",
|
|
337
|
+
component_id: child!.id,
|
|
338
|
+
}),
|
|
339
|
+
expect.objectContaining({
|
|
340
|
+
type: "component:removed",
|
|
341
|
+
id: child!.id,
|
|
342
|
+
}),
|
|
343
|
+
]),
|
|
248
344
|
);
|
|
345
|
+
collector.stop();
|
|
346
|
+
});
|
|
347
|
+
|
|
348
|
+
it("emits component prop updates while reactive children update", async () => {
|
|
349
|
+
const visible = ref(true);
|
|
350
|
+
const collector = await createMessageCollector(socket!);
|
|
249
351
|
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
352
|
+
await renderAsync(
|
|
353
|
+
<Output>
|
|
354
|
+
<Show when={visible.value}>visible</Show>
|
|
355
|
+
</Output>,
|
|
356
|
+
);
|
|
357
|
+
|
|
358
|
+
const initialMessages = await collector.waitForRender();
|
|
359
|
+
const show = componentMessages(initialMessages).find(
|
|
360
|
+
(m) => m.type === "component:added" && m.name === "Show",
|
|
361
|
+
);
|
|
362
|
+
expect(show).toBeDefined();
|
|
363
|
+
|
|
364
|
+
visible.value = false;
|
|
365
|
+
await flushJobsAsync();
|
|
366
|
+
|
|
367
|
+
const updateMessages = await collector.waitForFlush();
|
|
368
|
+
const showUpdate = componentMessages(updateMessages).find(
|
|
369
|
+
(m) => m.type === "component:updated" && m.id === show!.id,
|
|
370
|
+
);
|
|
371
|
+
expect(showUpdate).toBeDefined();
|
|
372
|
+
expect(devalue.parse(showUpdate!.props as string)).toMatchObject({
|
|
373
|
+
when: false,
|
|
254
374
|
});
|
|
375
|
+
expect(componentMessages(updateMessages)).toEqual(
|
|
376
|
+
expect.arrayContaining([
|
|
377
|
+
expect.objectContaining({
|
|
378
|
+
type: "component:root_removed",
|
|
379
|
+
component_id: show!.id,
|
|
380
|
+
}),
|
|
381
|
+
]),
|
|
382
|
+
);
|
|
255
383
|
collector.stop();
|
|
256
384
|
});
|
|
257
385
|
|