unreal-engine-mcp-server 0.4.7 → 0.5.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.
- package/.env.example +26 -0
- package/.env.production +38 -7
- package/.eslintrc.json +0 -54
- package/.eslintrc.override.json +8 -0
- package/.github/ISSUE_TEMPLATE/bug_report.yml +94 -0
- package/.github/ISSUE_TEMPLATE/config.yml +8 -0
- package/.github/ISSUE_TEMPLATE/feature_request.yml +56 -0
- package/.github/copilot-instructions.md +478 -45
- package/.github/dependabot.yml +19 -0
- package/.github/labeler.yml +24 -0
- package/.github/labels.yml +70 -0
- package/.github/pull_request_template.md +42 -0
- package/.github/release-drafter.yml +148 -0
- package/.github/workflows/auto-merge.yml +38 -0
- package/.github/workflows/ci.yml +38 -0
- package/.github/workflows/dependency-review.yml +17 -0
- package/.github/workflows/gemini-issue-triage.yml +172 -0
- package/.github/workflows/greetings.yml +23 -0
- package/.github/workflows/labeler.yml +16 -0
- package/.github/workflows/links.yml +80 -0
- package/.github/workflows/pr-size-labeler.yml +137 -0
- package/.github/workflows/publish-mcp.yml +12 -7
- package/.github/workflows/release-drafter.yml +23 -0
- package/.github/workflows/release.yml +112 -0
- package/.github/workflows/semantic-pull-request.yml +35 -0
- package/.github/workflows/smoke-test.yml +36 -0
- package/.github/workflows/stale.yml +28 -0
- package/CHANGELOG.md +267 -31
- package/CONTRIBUTING.md +140 -0
- package/README.md +166 -71
- package/claude_desktop_config_example.json +7 -6
- package/dist/automation/bridge.d.ts +50 -0
- package/dist/automation/bridge.js +452 -0
- package/dist/automation/connection-manager.d.ts +23 -0
- package/dist/automation/connection-manager.js +107 -0
- package/dist/automation/handshake.d.ts +11 -0
- package/dist/automation/handshake.js +89 -0
- package/dist/automation/index.d.ts +3 -0
- package/dist/automation/index.js +3 -0
- package/dist/automation/message-handler.d.ts +12 -0
- package/dist/automation/message-handler.js +149 -0
- package/dist/automation/request-tracker.d.ts +25 -0
- package/dist/automation/request-tracker.js +98 -0
- package/dist/automation/types.d.ts +130 -0
- package/dist/automation/types.js +2 -0
- package/dist/cli.js +32 -5
- package/dist/config.d.ts +27 -0
- package/dist/config.js +60 -0
- package/dist/constants.d.ts +12 -0
- package/dist/constants.js +12 -0
- package/dist/graphql/resolvers.d.ts +268 -0
- package/dist/graphql/resolvers.js +743 -0
- package/dist/graphql/schema.d.ts +5 -0
- package/dist/graphql/schema.js +437 -0
- package/dist/graphql/server.d.ts +26 -0
- package/dist/graphql/server.js +115 -0
- package/dist/graphql/types.d.ts +7 -0
- package/dist/graphql/types.js +2 -0
- package/dist/handlers/resource-handlers.d.ts +20 -0
- package/dist/handlers/resource-handlers.js +180 -0
- package/dist/index.d.ts +31 -18
- package/dist/index.js +119 -619
- package/dist/prompts/index.js +4 -4
- package/dist/resources/actors.d.ts +17 -12
- package/dist/resources/actors.js +56 -76
- package/dist/resources/assets.d.ts +6 -14
- package/dist/resources/assets.js +115 -147
- package/dist/resources/levels.d.ts +13 -13
- package/dist/resources/levels.js +25 -34
- package/dist/server/resource-registry.d.ts +20 -0
- package/dist/server/resource-registry.js +37 -0
- package/dist/server/tool-registry.d.ts +23 -0
- package/dist/server/tool-registry.js +322 -0
- package/dist/server-setup.d.ts +21 -0
- package/dist/server-setup.js +111 -0
- package/dist/services/health-monitor.d.ts +34 -0
- package/dist/services/health-monitor.js +105 -0
- package/dist/services/metrics-server.d.ts +11 -0
- package/dist/services/metrics-server.js +105 -0
- package/dist/tools/actors.d.ts +147 -9
- package/dist/tools/actors.js +350 -311
- package/dist/tools/animation.d.ts +135 -4
- package/dist/tools/animation.js +510 -411
- package/dist/tools/assets.d.ts +117 -19
- package/dist/tools/assets.js +259 -284
- package/dist/tools/audio.d.ts +102 -42
- package/dist/tools/audio.js +272 -685
- package/dist/tools/base-tool.d.ts +17 -0
- package/dist/tools/base-tool.js +46 -0
- package/dist/tools/behavior-tree.d.ts +94 -0
- package/dist/tools/behavior-tree.js +39 -0
- package/dist/tools/blueprint/helpers.d.ts +29 -0
- package/dist/tools/blueprint/helpers.js +182 -0
- package/dist/tools/blueprint.d.ts +228 -118
- package/dist/tools/blueprint.js +685 -832
- package/dist/tools/consolidated-tool-definitions.d.ts +5462 -1781
- package/dist/tools/consolidated-tool-definitions.js +829 -496
- package/dist/tools/consolidated-tool-handlers.d.ts +2 -1
- package/dist/tools/consolidated-tool-handlers.js +211 -1026
- package/dist/tools/debug.d.ts +143 -85
- package/dist/tools/debug.js +234 -180
- package/dist/tools/dynamic-handler-registry.d.ts +11 -0
- package/dist/tools/dynamic-handler-registry.js +101 -0
- package/dist/tools/editor.d.ts +139 -18
- package/dist/tools/editor.js +239 -244
- package/dist/tools/engine.d.ts +10 -4
- package/dist/tools/engine.js +13 -5
- package/dist/tools/environment.d.ts +36 -0
- package/dist/tools/environment.js +267 -0
- package/dist/tools/foliage.d.ts +105 -14
- package/dist/tools/foliage.js +219 -331
- package/dist/tools/handlers/actor-handlers.d.ts +3 -0
- package/dist/tools/handlers/actor-handlers.js +232 -0
- package/dist/tools/handlers/animation-handlers.d.ts +3 -0
- package/dist/tools/handlers/animation-handlers.js +185 -0
- package/dist/tools/handlers/argument-helper.d.ts +16 -0
- package/dist/tools/handlers/argument-helper.js +80 -0
- package/dist/tools/handlers/asset-handlers.d.ts +3 -0
- package/dist/tools/handlers/asset-handlers.js +496 -0
- package/dist/tools/handlers/audio-handlers.d.ts +3 -0
- package/dist/tools/handlers/audio-handlers.js +166 -0
- package/dist/tools/handlers/blueprint-handlers.d.ts +4 -0
- package/dist/tools/handlers/blueprint-handlers.js +358 -0
- package/dist/tools/handlers/common-handlers.d.ts +14 -0
- package/dist/tools/handlers/common-handlers.js +56 -0
- package/dist/tools/handlers/editor-handlers.d.ts +3 -0
- package/dist/tools/handlers/editor-handlers.js +119 -0
- package/dist/tools/handlers/effect-handlers.d.ts +3 -0
- package/dist/tools/handlers/effect-handlers.js +171 -0
- package/dist/tools/handlers/environment-handlers.d.ts +3 -0
- package/dist/tools/handlers/environment-handlers.js +170 -0
- package/dist/tools/handlers/graph-handlers.d.ts +3 -0
- package/dist/tools/handlers/graph-handlers.js +90 -0
- package/dist/tools/handlers/input-handlers.d.ts +3 -0
- package/dist/tools/handlers/input-handlers.js +21 -0
- package/dist/tools/handlers/inspect-handlers.d.ts +3 -0
- package/dist/tools/handlers/inspect-handlers.js +383 -0
- package/dist/tools/handlers/level-handlers.d.ts +3 -0
- package/dist/tools/handlers/level-handlers.js +237 -0
- package/dist/tools/handlers/lighting-handlers.d.ts +3 -0
- package/dist/tools/handlers/lighting-handlers.js +144 -0
- package/dist/tools/handlers/performance-handlers.d.ts +3 -0
- package/dist/tools/handlers/performance-handlers.js +130 -0
- package/dist/tools/handlers/pipeline-handlers.d.ts +3 -0
- package/dist/tools/handlers/pipeline-handlers.js +110 -0
- package/dist/tools/handlers/sequence-handlers.d.ts +3 -0
- package/dist/tools/handlers/sequence-handlers.js +376 -0
- package/dist/tools/handlers/system-handlers.d.ts +4 -0
- package/dist/tools/handlers/system-handlers.js +506 -0
- package/dist/tools/input.d.ts +19 -0
- package/dist/tools/input.js +89 -0
- package/dist/tools/introspection.d.ts +103 -40
- package/dist/tools/introspection.js +425 -568
- package/dist/tools/landscape.d.ts +97 -36
- package/dist/tools/landscape.js +280 -409
- package/dist/tools/level.d.ts +130 -10
- package/dist/tools/level.js +639 -675
- package/dist/tools/lighting.d.ts +77 -38
- package/dist/tools/lighting.js +441 -943
- package/dist/tools/logs.d.ts +3 -3
- package/dist/tools/logs.js +5 -57
- package/dist/tools/materials.d.ts +91 -24
- package/dist/tools/materials.js +190 -118
- package/dist/tools/niagara.d.ts +149 -39
- package/dist/tools/niagara.js +232 -182
- package/dist/tools/performance.d.ts +27 -12
- package/dist/tools/performance.js +204 -122
- package/dist/tools/physics.d.ts +32 -77
- package/dist/tools/physics.js +171 -582
- package/dist/tools/property-dictionary.d.ts +13 -0
- package/dist/tools/property-dictionary.js +82 -0
- package/dist/tools/sequence.d.ts +73 -48
- package/dist/tools/sequence.js +196 -748
- package/dist/tools/tool-definition-utils.d.ts +59 -0
- package/dist/tools/tool-definition-utils.js +35 -0
- package/dist/tools/ui.d.ts +66 -34
- package/dist/tools/ui.js +134 -214
- package/dist/types/env.d.ts +0 -3
- package/dist/types/env.js +0 -7
- package/dist/types/tool-interfaces.d.ts +898 -0
- package/dist/types/tool-interfaces.js +2 -0
- package/dist/types/tool-types.d.ts +183 -19
- package/dist/types/tool-types.js +0 -4
- package/dist/unreal-bridge.d.ts +24 -131
- package/dist/unreal-bridge.js +364 -1506
- package/dist/utils/command-validator.d.ts +9 -0
- package/dist/utils/command-validator.js +67 -0
- package/dist/utils/elicitation.d.ts +1 -1
- package/dist/utils/elicitation.js +12 -15
- package/dist/utils/error-handler.d.ts +2 -51
- package/dist/utils/error-handler.js +11 -87
- package/dist/utils/ini-reader.d.ts +3 -0
- package/dist/utils/ini-reader.js +69 -0
- package/dist/utils/logger.js +9 -6
- package/dist/utils/normalize.d.ts +3 -0
- package/dist/utils/normalize.js +56 -0
- package/dist/utils/response-factory.d.ts +7 -0
- package/dist/utils/response-factory.js +33 -0
- package/dist/utils/response-validator.d.ts +3 -24
- package/dist/utils/response-validator.js +130 -81
- package/dist/utils/result-helpers.d.ts +4 -5
- package/dist/utils/result-helpers.js +15 -16
- package/dist/utils/safe-json.js +5 -11
- package/dist/utils/unreal-command-queue.d.ts +24 -0
- package/dist/utils/unreal-command-queue.js +120 -0
- package/dist/utils/validation.d.ts +0 -40
- package/dist/utils/validation.js +1 -78
- package/dist/wasm/index.d.ts +70 -0
- package/dist/wasm/index.js +535 -0
- package/docs/GraphQL-API.md +888 -0
- package/docs/Migration-Guide-v0.5.0.md +692 -0
- package/docs/Roadmap.md +53 -0
- package/docs/WebAssembly-Integration.md +628 -0
- package/docs/editor-plugin-extension.md +370 -0
- package/docs/handler-mapping.md +242 -0
- package/docs/native-automation-progress.md +128 -0
- package/docs/testing-guide.md +423 -0
- package/mcp-config-example.json +6 -6
- package/package.json +60 -27
- package/plugins/McpAutomationBridge/Config/FilterPlugin.ini +8 -0
- package/plugins/McpAutomationBridge/McpAutomationBridge.uplugin +64 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/McpAutomationBridge.Build.cs +189 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeGlobals.cpp +22 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeGlobals.h +30 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeHelpers.h +1983 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeModule.cpp +72 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeSettings.cpp +46 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridgeSubsystem.cpp +581 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_AnimationHandlers.cpp +2394 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_AssetQueryHandlers.cpp +300 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_AssetWorkflowHandlers.cpp +2807 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_AudioHandlers.cpp +1087 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BehaviorTreeHandlers.cpp +488 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BlueprintCreationHandlers.cpp +643 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BlueprintCreationHandlers.h +31 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BlueprintGraphHandlers.cpp +1184 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BlueprintHandlers.cpp +5652 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_BlueprintHandlers_List.cpp +152 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_ControlHandlers.cpp +2614 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_DebugHandlers.cpp +42 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_EditorFunctionHandlers.cpp +1237 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_EffectHandlers.cpp +1701 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_EnvironmentHandlers.cpp +2145 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_FoliageHandlers.cpp +954 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_InputHandlers.cpp +209 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_InsightsHandlers.cpp +41 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_LandscapeHandlers.cpp +1164 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_LevelHandlers.cpp +762 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_LightingHandlers.cpp +634 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_LogHandlers.cpp +136 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_MaterialGraphHandlers.cpp +494 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_NiagaraGraphHandlers.cpp +278 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_NiagaraHandlers.cpp +625 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_PerformanceHandlers.cpp +401 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_PipelineHandlers.cpp +67 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_ProcessRequest.cpp +735 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_PropertyHandlers.cpp +2634 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_RenderHandlers.cpp +189 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_SCSHandlers.cpp +917 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_SCSHandlers.h +39 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_SequenceHandlers.cpp +2670 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_SequencerHandlers.cpp +519 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_TestHandlers.cpp +38 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_UiHandlers.cpp +668 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpAutomationBridge_WorldPartitionHandlers.cpp +346 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpBridgeWebSocket.cpp +1330 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpBridgeWebSocket.h +149 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Private/McpConnectionManager.cpp +783 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Public/McpAutomationBridgeSettings.h +115 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Public/McpAutomationBridgeSubsystem.h +796 -0
- package/plugins/McpAutomationBridge/Source/McpAutomationBridge/Public/McpConnectionManager.h +117 -0
- package/scripts/check-unreal-connection.mjs +19 -0
- package/scripts/clean-tmp.js +23 -0
- package/scripts/patch-wasm.js +26 -0
- package/scripts/run-all-tests.mjs +131 -0
- package/scripts/smoke-test.ts +94 -0
- package/scripts/sync-mcp-plugin.js +143 -0
- package/scripts/test-no-plugin-alternates.mjs +113 -0
- package/scripts/validate-server.js +46 -0
- package/scripts/verify-automation-bridge.js +200 -0
- package/server.json +57 -21
- package/src/automation/bridge.ts +558 -0
- package/src/automation/connection-manager.ts +130 -0
- package/src/automation/handshake.ts +99 -0
- package/src/automation/index.ts +2 -0
- package/src/automation/message-handler.ts +167 -0
- package/src/automation/request-tracker.ts +123 -0
- package/src/automation/types.ts +107 -0
- package/src/cli.ts +33 -6
- package/src/config.ts +73 -0
- package/src/constants.ts +12 -0
- package/src/graphql/resolvers.ts +1010 -0
- package/src/graphql/schema.ts +452 -0
- package/src/graphql/server.ts +154 -0
- package/src/graphql/types.ts +7 -0
- package/src/handlers/resource-handlers.ts +186 -0
- package/src/index.ts +152 -663
- package/src/prompts/index.ts +4 -4
- package/src/resources/actors.ts +58 -76
- package/src/resources/assets.ts +147 -134
- package/src/resources/levels.ts +28 -33
- package/src/server/resource-registry.ts +47 -0
- package/src/server/tool-registry.ts +354 -0
- package/src/server-setup.ts +148 -0
- package/src/services/health-monitor.ts +132 -0
- package/src/services/metrics-server.ts +142 -0
- package/src/tools/actors.ts +417 -322
- package/src/tools/animation.ts +671 -461
- package/src/tools/assets.ts +353 -289
- package/src/tools/audio.ts +323 -766
- package/src/tools/base-tool.ts +52 -0
- package/src/tools/behavior-tree.ts +45 -0
- package/src/tools/blueprint/helpers.ts +189 -0
- package/src/tools/blueprint.ts +787 -965
- package/src/tools/consolidated-tool-definitions.ts +993 -515
- package/src/tools/consolidated-tool-handlers.ts +272 -1139
- package/src/tools/debug.ts +292 -187
- package/src/tools/dynamic-handler-registry.ts +151 -0
- package/src/tools/editor.ts +309 -246
- package/src/tools/engine.ts +14 -3
- package/src/tools/environment.ts +287 -0
- package/src/tools/foliage.ts +314 -379
- package/src/tools/handlers/actor-handlers.ts +271 -0
- package/src/tools/handlers/animation-handlers.ts +237 -0
- package/src/tools/handlers/argument-helper.ts +142 -0
- package/src/tools/handlers/asset-handlers.ts +532 -0
- package/src/tools/handlers/audio-handlers.ts +194 -0
- package/src/tools/handlers/blueprint-handlers.ts +380 -0
- package/src/tools/handlers/common-handlers.ts +87 -0
- package/src/tools/handlers/editor-handlers.ts +123 -0
- package/src/tools/handlers/effect-handlers.ts +220 -0
- package/src/tools/handlers/environment-handlers.ts +183 -0
- package/src/tools/handlers/graph-handlers.ts +116 -0
- package/src/tools/handlers/input-handlers.ts +28 -0
- package/src/tools/handlers/inspect-handlers.ts +450 -0
- package/src/tools/handlers/level-handlers.ts +252 -0
- package/src/tools/handlers/lighting-handlers.ts +147 -0
- package/src/tools/handlers/performance-handlers.ts +132 -0
- package/src/tools/handlers/pipeline-handlers.ts +127 -0
- package/src/tools/handlers/sequence-handlers.ts +415 -0
- package/src/tools/handlers/system-handlers.ts +564 -0
- package/src/tools/input.ts +101 -0
- package/src/tools/introspection.ts +493 -584
- package/src/tools/landscape.ts +394 -489
- package/src/tools/level.ts +752 -694
- package/src/tools/lighting.ts +583 -984
- package/src/tools/logs.ts +9 -57
- package/src/tools/materials.ts +231 -121
- package/src/tools/niagara.ts +293 -168
- package/src/tools/performance.ts +320 -168
- package/src/tools/physics.ts +268 -613
- package/src/tools/property-dictionary.ts +98 -0
- package/src/tools/sequence.ts +255 -815
- package/src/tools/tool-definition-utils.ts +35 -0
- package/src/tools/ui.ts +207 -283
- package/src/types/env.ts +0 -10
- package/src/types/tool-interfaces.ts +250 -0
- package/src/types/tool-types.ts +243 -21
- package/src/unreal-bridge.ts +460 -1550
- package/src/utils/command-validator.ts +75 -0
- package/src/utils/elicitation.ts +10 -7
- package/src/utils/error-handler.ts +14 -90
- package/src/utils/ini-reader.ts +86 -0
- package/src/utils/logger.ts +8 -3
- package/src/utils/normalize.ts +60 -0
- package/src/utils/response-factory.ts +39 -0
- package/src/utils/response-validator.ts +176 -56
- package/src/utils/result-helpers.ts +21 -19
- package/src/utils/safe-json.ts +14 -11
- package/src/utils/unreal-command-queue.ts +152 -0
- package/src/utils/validation.ts +4 -1
- package/src/wasm/index.ts +838 -0
- package/test-server.mjs +100 -0
- package/tests/run-unreal-tool-tests.mjs +242 -14
- package/tests/test-animation.mjs +44 -0
- package/tests/test-asset-advanced.mjs +82 -0
- package/tests/test-asset-errors.mjs +35 -0
- package/tests/test-audio.mjs +219 -0
- package/tests/test-automation-timeouts.mjs +98 -0
- package/tests/test-behavior-tree.mjs +261 -0
- package/tests/test-blueprint-events.mjs +35 -0
- package/tests/test-blueprint-graph.mjs +79 -0
- package/tests/test-blueprint.mjs +577 -0
- package/tests/test-client-mode.mjs +86 -0
- package/tests/test-console-command.mjs +56 -0
- package/tests/test-control-actor.mjs +425 -0
- package/tests/test-control-editor.mjs +80 -0
- package/tests/test-extra-tools.mjs +38 -0
- package/tests/test-graphql.mjs +322 -0
- package/tests/test-inspect.mjs +72 -0
- package/tests/test-landscape.mjs +60 -0
- package/tests/test-manage-asset.mjs +438 -0
- package/tests/test-manage-level.mjs +70 -0
- package/tests/test-materials.mjs +356 -0
- package/tests/test-niagara.mjs +185 -0
- package/tests/test-no-inline-python.mjs +122 -0
- package/tests/test-plugin-handshake.mjs +82 -0
- package/tests/test-render.mjs +33 -0
- package/tests/test-runner.mjs +933 -0
- package/tests/test-search-assets.mjs +66 -0
- package/tests/test-sequence.mjs +68 -0
- package/tests/test-system.mjs +57 -0
- package/tests/test-wasm.mjs +193 -0
- package/tests/test-world-partition.mjs +215 -0
- package/tsconfig.json +3 -3
- package/wasm/Cargo.lock +363 -0
- package/wasm/Cargo.toml +42 -0
- package/wasm/LICENSE +21 -0
- package/wasm/README.md +253 -0
- package/wasm/src/dependency_resolver.rs +377 -0
- package/wasm/src/lib.rs +153 -0
- package/wasm/src/property_parser.rs +271 -0
- package/wasm/src/transform_math.rs +396 -0
- package/wasm/tests/integration.rs +109 -0
- package/.github/workflows/smithery-build.yml +0 -29
- package/dist/tools/build_environment_advanced.d.ts +0 -65
- package/dist/tools/build_environment_advanced.js +0 -633
- package/dist/tools/rc.d.ts +0 -110
- package/dist/tools/rc.js +0 -437
- package/dist/tools/visual.d.ts +0 -40
- package/dist/tools/visual.js +0 -282
- package/dist/utils/http.d.ts +0 -6
- package/dist/utils/http.js +0 -151
- package/dist/utils/python-output.d.ts +0 -18
- package/dist/utils/python-output.js +0 -290
- package/dist/utils/python.d.ts +0 -2
- package/dist/utils/python.js +0 -4
- package/dist/utils/stdio-redirect.d.ts +0 -2
- package/dist/utils/stdio-redirect.js +0 -20
- package/docs/unreal-tool-test-cases.md +0 -574
- package/smithery.yaml +0 -29
- package/src/tools/build_environment_advanced.ts +0 -732
- package/src/tools/rc.ts +0 -515
- package/src/tools/visual.ts +0 -281
- package/src/utils/http.ts +0 -187
- package/src/utils/python-output.ts +0 -351
- package/src/utils/python.ts +0 -3
- package/src/utils/stdio-redirect.ts +0 -18
|
@@ -0,0 +1,535 @@
|
|
|
1
|
+
import { Logger } from '../utils/logger.js';
|
|
2
|
+
const isNodeEnvironment = typeof process !== 'undefined' &&
|
|
3
|
+
process.versions != null &&
|
|
4
|
+
process.versions.node != null;
|
|
5
|
+
let nodeFileFetchPatched = false;
|
|
6
|
+
async function ensureNodeFileFetchForWasm() {
|
|
7
|
+
if (!isNodeEnvironment || nodeFileFetchPatched) {
|
|
8
|
+
return;
|
|
9
|
+
}
|
|
10
|
+
const originalFetch = globalThis.fetch;
|
|
11
|
+
if (typeof originalFetch !== 'function') {
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
try {
|
|
15
|
+
const fs = await import('node:fs/promises');
|
|
16
|
+
const url = await import('node:url');
|
|
17
|
+
const readFile = fs.readFile;
|
|
18
|
+
const fileURLToPath = url.fileURLToPath;
|
|
19
|
+
const toUrl = (input) => {
|
|
20
|
+
try {
|
|
21
|
+
if (input instanceof URL) {
|
|
22
|
+
return input;
|
|
23
|
+
}
|
|
24
|
+
if (typeof input === 'string') {
|
|
25
|
+
return new URL(input);
|
|
26
|
+
}
|
|
27
|
+
const RequestCtor = globalThis.Request;
|
|
28
|
+
if (RequestCtor && input instanceof RequestCtor && typeof input.url === 'string') {
|
|
29
|
+
return new URL(input.url);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
catch {
|
|
33
|
+
}
|
|
34
|
+
return null;
|
|
35
|
+
};
|
|
36
|
+
globalThis.fetch = (async (input, init) => {
|
|
37
|
+
try {
|
|
38
|
+
const target = toUrl(input);
|
|
39
|
+
if (target && target.protocol === 'file:') {
|
|
40
|
+
const filePath = fileURLToPath(target);
|
|
41
|
+
const data = await readFile(filePath);
|
|
42
|
+
const buffer = data.buffer.slice(data.byteOffset, data.byteOffset + data.byteLength);
|
|
43
|
+
return buffer;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
catch {
|
|
47
|
+
}
|
|
48
|
+
return originalFetch(input, init);
|
|
49
|
+
});
|
|
50
|
+
nodeFileFetchPatched = true;
|
|
51
|
+
}
|
|
52
|
+
catch {
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
export class WASMIntegration {
|
|
56
|
+
log = new Logger('WASMIntegration');
|
|
57
|
+
module = null;
|
|
58
|
+
config;
|
|
59
|
+
metrics = [];
|
|
60
|
+
maxMetrics = 1000;
|
|
61
|
+
initialized = false;
|
|
62
|
+
moduleUnavailable = false;
|
|
63
|
+
constructor(config = {}) {
|
|
64
|
+
const envFlag = process.env.WASM_ENABLED;
|
|
65
|
+
const envEnabled = envFlag === undefined ? true : envFlag === 'true';
|
|
66
|
+
const here = new URL('.', import.meta.url);
|
|
67
|
+
const herePath = here.pathname.replace(/\\/g, '/');
|
|
68
|
+
const defaultUrl = herePath.includes('/dist/')
|
|
69
|
+
? new URL('../../src/wasm/pkg/unreal_mcp_wasm.js', import.meta.url)
|
|
70
|
+
: new URL('./pkg/unreal_mcp_wasm.js', import.meta.url);
|
|
71
|
+
const defaultWasmPath = defaultUrl.href;
|
|
72
|
+
this.config = {
|
|
73
|
+
enabled: config.enabled ?? envEnabled,
|
|
74
|
+
wasmPath: config.wasmPath ?? process.env.WASM_PATH ?? defaultWasmPath,
|
|
75
|
+
fallbackEnabled: config.fallbackEnabled ?? true,
|
|
76
|
+
performanceMonitoring: config.performanceMonitoring ?? true
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
async initialize() {
|
|
80
|
+
if (this.initialized && this.module) {
|
|
81
|
+
this.log.debug('WASM module already initialized');
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
if (this.moduleUnavailable) {
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
if (!this.config.enabled) {
|
|
88
|
+
this.log.info('WASM integration is disabled');
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
91
|
+
try {
|
|
92
|
+
this.log.info(`Loading WASM module from ${this.config.wasmPath}...`);
|
|
93
|
+
await ensureNodeFileFetchForWasm();
|
|
94
|
+
const wasmModule = await import(this.config.wasmPath);
|
|
95
|
+
await wasmModule.default();
|
|
96
|
+
this.module = wasmModule;
|
|
97
|
+
this.initialized = true;
|
|
98
|
+
this.log.info('✅ WebAssembly module initialized successfully');
|
|
99
|
+
this.log.debug('WASM module functions:', {
|
|
100
|
+
hasPropertyParser: typeof wasmModule.PropertyParser === 'function',
|
|
101
|
+
hasTransformCalculator: typeof wasmModule.TransformCalculator === 'function',
|
|
102
|
+
hasVector: typeof wasmModule.Vector === 'function',
|
|
103
|
+
hasUtils: typeof wasmModule.Utils === 'function'
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
catch (error) {
|
|
107
|
+
this.log.error('Failed to initialize WebAssembly module:', error);
|
|
108
|
+
const code = error?.code;
|
|
109
|
+
if (code === 'ERR_MODULE_NOT_FOUND') {
|
|
110
|
+
this.log.warn('WebAssembly module not found. To enable WASM, run "npm run build:wasm". To silence this warning, set WASM_ENABLED=false.');
|
|
111
|
+
this.moduleUnavailable = true;
|
|
112
|
+
}
|
|
113
|
+
this.log.warn('Falling back to TypeScript implementations');
|
|
114
|
+
if (!this.config.fallbackEnabled) {
|
|
115
|
+
throw new Error('WASM initialization failed and fallbacks are disabled');
|
|
116
|
+
}
|
|
117
|
+
this.module = null;
|
|
118
|
+
this.initialized = false;
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
isReady() {
|
|
122
|
+
return this.initialized && this.module !== null;
|
|
123
|
+
}
|
|
124
|
+
static isSupported() {
|
|
125
|
+
return typeof WebAssembly === 'object' &&
|
|
126
|
+
typeof WebAssembly.instantiate === 'function';
|
|
127
|
+
}
|
|
128
|
+
async parseProperties(jsonStr, options) {
|
|
129
|
+
const start = performance.now();
|
|
130
|
+
if (!this.isReady()) {
|
|
131
|
+
await this.initialize();
|
|
132
|
+
}
|
|
133
|
+
if (this.module && typeof this.module.PropertyParser === 'function') {
|
|
134
|
+
try {
|
|
135
|
+
const parser = new this.module.PropertyParser();
|
|
136
|
+
const result = parser.parse_properties(jsonStr, options?.maxDepth ?? 100);
|
|
137
|
+
const duration = performance.now() - start;
|
|
138
|
+
this.recordMetrics('parse_properties', duration, true);
|
|
139
|
+
return result;
|
|
140
|
+
}
|
|
141
|
+
catch (error) {
|
|
142
|
+
this.log.warn('WASM property parsing failed, falling back to TypeScript:', error);
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
const duration = performance.now() - start;
|
|
146
|
+
this.recordMetrics('parse_properties', duration, false);
|
|
147
|
+
return this.fallbackParseProperties(jsonStr);
|
|
148
|
+
}
|
|
149
|
+
composeTransform(location, rotation, scale) {
|
|
150
|
+
const start = performance.now();
|
|
151
|
+
if (this.isReady() && this.module && typeof this.module.TransformCalculator === 'function') {
|
|
152
|
+
try {
|
|
153
|
+
const calculator = new this.module.TransformCalculator();
|
|
154
|
+
const result = calculator.composeTransform(new Float32Array(location), new Float32Array(rotation), new Float32Array(scale));
|
|
155
|
+
const duration = performance.now() - start;
|
|
156
|
+
this.recordMetrics('compose_transform', duration, true);
|
|
157
|
+
return new Float32Array(result);
|
|
158
|
+
}
|
|
159
|
+
catch (error) {
|
|
160
|
+
this.log.warn('WASM transform calculation failed, falling back to TypeScript:', error);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
const duration = performance.now() - start;
|
|
164
|
+
this.recordMetrics('compose_transform', duration, false);
|
|
165
|
+
return this.fallbackComposeTransform(location, rotation, scale);
|
|
166
|
+
}
|
|
167
|
+
decomposeMatrix(matrix) {
|
|
168
|
+
const start = performance.now();
|
|
169
|
+
if (this.isReady() && this.module && typeof this.module.TransformCalculator === 'function') {
|
|
170
|
+
try {
|
|
171
|
+
const calculator = new this.module.TransformCalculator();
|
|
172
|
+
const result = calculator.decomposeMatrix(matrix);
|
|
173
|
+
const duration = performance.now() - start;
|
|
174
|
+
this.recordMetrics('decompose_matrix', duration, true);
|
|
175
|
+
return Array.from(result);
|
|
176
|
+
}
|
|
177
|
+
catch (error) {
|
|
178
|
+
this.log.warn('WASM matrix decomposition failed, falling back to TypeScript:', error);
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
const duration = performance.now() - start;
|
|
182
|
+
this.recordMetrics('decompose_matrix', duration, false);
|
|
183
|
+
return this.fallbackDecomposeMatrix(matrix);
|
|
184
|
+
}
|
|
185
|
+
vectorAdd(v1, v2) {
|
|
186
|
+
const start = performance.now();
|
|
187
|
+
if (this.isReady() && this.module && typeof this.module.Vector === 'function') {
|
|
188
|
+
try {
|
|
189
|
+
const vec1 = new this.module.Vector(v1[0], v1[1], v1[2]);
|
|
190
|
+
const vec2 = new this.module.Vector(v2[0], v2[1], v2[2]);
|
|
191
|
+
const result = vec1.add(vec2);
|
|
192
|
+
const duration = performance.now() - start;
|
|
193
|
+
this.recordMetrics('vector_add', duration, true);
|
|
194
|
+
return [result.x, result.y, result.z];
|
|
195
|
+
}
|
|
196
|
+
catch (error) {
|
|
197
|
+
this.log.warn('WASM vector addition failed, falling back to TypeScript:', error);
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
const duration = performance.now() - start;
|
|
201
|
+
this.recordMetrics('vector_add', duration, false);
|
|
202
|
+
return this.fallbackVectorAdd(v1, v2);
|
|
203
|
+
}
|
|
204
|
+
async resolveDependencies(assetPath, dependencies, options) {
|
|
205
|
+
const start = performance.now();
|
|
206
|
+
if (!this.isReady()) {
|
|
207
|
+
await this.initialize();
|
|
208
|
+
}
|
|
209
|
+
if (this.module && typeof this.module.DependencyResolver === 'function') {
|
|
210
|
+
try {
|
|
211
|
+
const resolver = new this.module.DependencyResolver();
|
|
212
|
+
const dependenciesJson = JSON.stringify(dependencies);
|
|
213
|
+
const result = resolver.analyzeDependencies(assetPath, dependenciesJson, options?.maxDepth ?? 100);
|
|
214
|
+
const duration = performance.now() - start;
|
|
215
|
+
this.recordMetrics('resolve_dependencies', duration, true);
|
|
216
|
+
return result;
|
|
217
|
+
}
|
|
218
|
+
catch (error) {
|
|
219
|
+
this.log.warn('WASM dependency resolution failed, falling back to TypeScript:', error);
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
const duration = performance.now() - start;
|
|
223
|
+
this.recordMetrics('resolve_dependencies', duration, false);
|
|
224
|
+
return this.fallbackResolveDependencies(assetPath, dependencies, options);
|
|
225
|
+
}
|
|
226
|
+
async calculateDependencyDepth(assetPath, dependencies, options) {
|
|
227
|
+
const start = performance.now();
|
|
228
|
+
if (!this.isReady()) {
|
|
229
|
+
await this.initialize();
|
|
230
|
+
}
|
|
231
|
+
if (this.module && typeof this.module.DependencyResolver === 'function') {
|
|
232
|
+
try {
|
|
233
|
+
const resolver = new this.module.DependencyResolver();
|
|
234
|
+
const dependenciesJson = JSON.stringify(dependencies);
|
|
235
|
+
const result = resolver.calculateDepth(assetPath, dependenciesJson, options?.maxDepth ?? 100);
|
|
236
|
+
const duration = performance.now() - start;
|
|
237
|
+
this.recordMetrics('calculate_dependency_depth', duration, true);
|
|
238
|
+
return result;
|
|
239
|
+
}
|
|
240
|
+
catch (error) {
|
|
241
|
+
this.log.warn('WASM dependency depth calculation failed, falling back to TypeScript:', error);
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
const duration = performance.now() - start;
|
|
245
|
+
this.recordMetrics('calculate_dependency_depth', duration, false);
|
|
246
|
+
return this.fallbackCalculateDependencyDepth(assetPath, dependencies, options);
|
|
247
|
+
}
|
|
248
|
+
async findCircularDependencies(dependencies, options) {
|
|
249
|
+
const start = performance.now();
|
|
250
|
+
if (!this.isReady()) {
|
|
251
|
+
await this.initialize();
|
|
252
|
+
}
|
|
253
|
+
if (this.module && typeof this.module.DependencyResolver === 'function') {
|
|
254
|
+
try {
|
|
255
|
+
const resolver = new this.module.DependencyResolver();
|
|
256
|
+
const dependenciesJson = JSON.stringify(dependencies);
|
|
257
|
+
const result = resolver.findCircularDependencies(dependenciesJson, options?.maxDepth ?? 100);
|
|
258
|
+
const duration = performance.now() - start;
|
|
259
|
+
this.recordMetrics('find_circular_dependencies', duration, true);
|
|
260
|
+
return result;
|
|
261
|
+
}
|
|
262
|
+
catch (error) {
|
|
263
|
+
this.log.warn('WASM circular dependency detection failed, falling back to TypeScript:', error);
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
const duration = performance.now() - start;
|
|
267
|
+
this.recordMetrics('find_circular_dependencies', duration, false);
|
|
268
|
+
return this.fallbackFindCircularDependencies(dependencies, options);
|
|
269
|
+
}
|
|
270
|
+
async topologicalSort(dependencies) {
|
|
271
|
+
const start = performance.now();
|
|
272
|
+
if (!this.isReady()) {
|
|
273
|
+
await this.initialize();
|
|
274
|
+
}
|
|
275
|
+
if (this.module && typeof this.module.DependencyResolver === 'function') {
|
|
276
|
+
try {
|
|
277
|
+
const resolver = new this.module.DependencyResolver();
|
|
278
|
+
const dependenciesJson = JSON.stringify(dependencies);
|
|
279
|
+
const result = resolver.topologicalSort(dependenciesJson);
|
|
280
|
+
const duration = performance.now() - start;
|
|
281
|
+
this.recordMetrics('topological_sort', duration, true);
|
|
282
|
+
return result;
|
|
283
|
+
}
|
|
284
|
+
catch (error) {
|
|
285
|
+
this.log.warn('WASM topological sort failed, falling back to TypeScript:', error);
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
const duration = performance.now() - start;
|
|
289
|
+
this.recordMetrics('topological_sort', duration, false);
|
|
290
|
+
return this.fallbackTopologicalSort(dependencies);
|
|
291
|
+
}
|
|
292
|
+
getMetrics() {
|
|
293
|
+
const operations = this.metrics.slice(-this.maxMetrics);
|
|
294
|
+
const wasmOperations = operations.filter(m => m.useWASM).length;
|
|
295
|
+
const tsOperations = operations.filter(m => !m.useWASM).length;
|
|
296
|
+
const totalTime = operations.reduce((sum, m) => sum + m.duration, 0);
|
|
297
|
+
const averageTime = operations.length > 0 ? totalTime / operations.length : 0;
|
|
298
|
+
return {
|
|
299
|
+
totalOperations: operations.length,
|
|
300
|
+
wasmOperations,
|
|
301
|
+
tsOperations,
|
|
302
|
+
averageTime,
|
|
303
|
+
operations
|
|
304
|
+
};
|
|
305
|
+
}
|
|
306
|
+
getStatus() {
|
|
307
|
+
return {
|
|
308
|
+
enabled: this.config.enabled,
|
|
309
|
+
ready: this.isReady(),
|
|
310
|
+
moduleUnavailable: this.moduleUnavailable
|
|
311
|
+
};
|
|
312
|
+
}
|
|
313
|
+
clearMetrics() {
|
|
314
|
+
this.metrics = [];
|
|
315
|
+
}
|
|
316
|
+
reportPerformance() {
|
|
317
|
+
const metrics = this.getMetrics();
|
|
318
|
+
const wasmPercentage = metrics.totalOperations > 0
|
|
319
|
+
? ((metrics.wasmOperations / metrics.totalOperations) * 100).toFixed(1)
|
|
320
|
+
: '0';
|
|
321
|
+
const report = [
|
|
322
|
+
'=== WASM Performance Report ===',
|
|
323
|
+
`Total Operations: ${metrics.totalOperations}`,
|
|
324
|
+
`WASM Operations: ${metrics.wasmOperations} (${wasmPercentage}%)`,
|
|
325
|
+
`TypeScript Operations: ${metrics.tsOperations}`,
|
|
326
|
+
`Average Time: ${metrics.averageTime.toFixed(2)}ms`,
|
|
327
|
+
'=============================='
|
|
328
|
+
].join('\n');
|
|
329
|
+
return report;
|
|
330
|
+
}
|
|
331
|
+
recordMetrics(operation, duration, useWASM) {
|
|
332
|
+
if (!this.config.performanceMonitoring) {
|
|
333
|
+
return;
|
|
334
|
+
}
|
|
335
|
+
this.metrics.push({
|
|
336
|
+
operation,
|
|
337
|
+
duration,
|
|
338
|
+
timestamp: Date.now(),
|
|
339
|
+
useWASM
|
|
340
|
+
});
|
|
341
|
+
if (this.metrics.length > this.maxMetrics) {
|
|
342
|
+
this.metrics.shift();
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
fallbackParseProperties(jsonStr) {
|
|
346
|
+
try {
|
|
347
|
+
return JSON.parse(jsonStr);
|
|
348
|
+
}
|
|
349
|
+
catch (error) {
|
|
350
|
+
this.log.error('Failed to parse JSON:', error);
|
|
351
|
+
throw error;
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
fallbackComposeTransform(location, rotation, scale) {
|
|
355
|
+
const matrix = new Float32Array(16);
|
|
356
|
+
const [x, y, z] = location;
|
|
357
|
+
const [_pitch, _yaw, _roll] = rotation.map(angle => angle * Math.PI / 180);
|
|
358
|
+
const [sx, sy, sz] = scale;
|
|
359
|
+
matrix[0] = sx;
|
|
360
|
+
matrix[5] = sy;
|
|
361
|
+
matrix[10] = sz;
|
|
362
|
+
matrix[12] = x;
|
|
363
|
+
matrix[13] = y;
|
|
364
|
+
matrix[14] = z;
|
|
365
|
+
matrix[15] = 1;
|
|
366
|
+
return matrix;
|
|
367
|
+
}
|
|
368
|
+
fallbackDecomposeMatrix(matrix) {
|
|
369
|
+
const location = [matrix[12], matrix[13], matrix[14]];
|
|
370
|
+
const scale = [
|
|
371
|
+
Math.sqrt(matrix[0] * matrix[0] + matrix[1] * matrix[1] + matrix[2] * matrix[2]),
|
|
372
|
+
Math.sqrt(matrix[4] * matrix[4] + matrix[5] * matrix[5] + matrix[6] * matrix[6]),
|
|
373
|
+
Math.sqrt(matrix[8] * matrix[8] + matrix[9] * matrix[9] + matrix[10] * matrix[10])
|
|
374
|
+
];
|
|
375
|
+
const rotation = [0, 0, 0];
|
|
376
|
+
return [...location, ...rotation, ...scale];
|
|
377
|
+
}
|
|
378
|
+
fallbackVectorAdd(v1, v2) {
|
|
379
|
+
return [
|
|
380
|
+
v1[0] + v2[0],
|
|
381
|
+
v1[1] + v2[1],
|
|
382
|
+
v1[2] + v2[2]
|
|
383
|
+
];
|
|
384
|
+
}
|
|
385
|
+
fallbackResolveDependencies(assetPath, dependencies, options) {
|
|
386
|
+
const maxDepth = options?.maxDepth ?? 100;
|
|
387
|
+
const visited = new Set();
|
|
388
|
+
const result = [];
|
|
389
|
+
const queue = [
|
|
390
|
+
{ path: assetPath, depth: 0 }
|
|
391
|
+
];
|
|
392
|
+
while (queue.length > 0) {
|
|
393
|
+
const item = queue.shift();
|
|
394
|
+
if (!item)
|
|
395
|
+
continue;
|
|
396
|
+
const { path, depth } = item;
|
|
397
|
+
if (depth > maxDepth || visited.has(path)) {
|
|
398
|
+
continue;
|
|
399
|
+
}
|
|
400
|
+
visited.add(path);
|
|
401
|
+
if (dependencies[path]) {
|
|
402
|
+
result.push({
|
|
403
|
+
path,
|
|
404
|
+
dependencies: dependencies[path],
|
|
405
|
+
depth
|
|
406
|
+
});
|
|
407
|
+
for (const dep of dependencies[path]) {
|
|
408
|
+
queue.push({ path: dep, depth: depth + 1 });
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
}
|
|
412
|
+
const totalCount = result.length;
|
|
413
|
+
return {
|
|
414
|
+
asset: assetPath,
|
|
415
|
+
dependencies: result,
|
|
416
|
+
total_dependency_count: totalCount,
|
|
417
|
+
max_depth: maxDepth,
|
|
418
|
+
analysis_time_ms: 0,
|
|
419
|
+
totalDependencyCount: totalCount,
|
|
420
|
+
maxDepth,
|
|
421
|
+
analysisTimeMs: 0,
|
|
422
|
+
circular_dependencies: [],
|
|
423
|
+
circularDependencies: []
|
|
424
|
+
};
|
|
425
|
+
}
|
|
426
|
+
fallbackCalculateDependencyDepth(assetPath, dependencies, options) {
|
|
427
|
+
const maxDepth = options?.maxDepth ?? 100;
|
|
428
|
+
const visited = new Set();
|
|
429
|
+
const dfs = (path, depthRemaining) => {
|
|
430
|
+
if (visited.has(path) || depthRemaining === 0) {
|
|
431
|
+
return 0;
|
|
432
|
+
}
|
|
433
|
+
visited.add(path);
|
|
434
|
+
const deps = dependencies[path] || [];
|
|
435
|
+
if (!deps.length) {
|
|
436
|
+
visited.delete(path);
|
|
437
|
+
return 0;
|
|
438
|
+
}
|
|
439
|
+
let maxChildDepth = 0;
|
|
440
|
+
for (const dep of deps) {
|
|
441
|
+
const childDepth = dfs(dep, depthRemaining - 1);
|
|
442
|
+
if (childDepth > maxChildDepth) {
|
|
443
|
+
maxChildDepth = childDepth;
|
|
444
|
+
}
|
|
445
|
+
}
|
|
446
|
+
visited.delete(path);
|
|
447
|
+
return maxChildDepth + 1;
|
|
448
|
+
};
|
|
449
|
+
return dfs(assetPath, maxDepth);
|
|
450
|
+
}
|
|
451
|
+
fallbackFindCircularDependencies(dependencies, options) {
|
|
452
|
+
const maxDepth = options?.maxDepth ?? 100;
|
|
453
|
+
const cycles = [];
|
|
454
|
+
const visited = new Set();
|
|
455
|
+
const stack = new Set();
|
|
456
|
+
const dfs = (current, depth, path) => {
|
|
457
|
+
if (depth > maxDepth) {
|
|
458
|
+
return;
|
|
459
|
+
}
|
|
460
|
+
visited.add(current);
|
|
461
|
+
stack.add(current);
|
|
462
|
+
path.push(current);
|
|
463
|
+
const deps = dependencies[current] || [];
|
|
464
|
+
for (const dep of deps) {
|
|
465
|
+
if (!visited.has(dep)) {
|
|
466
|
+
dfs(dep, depth + 1, path);
|
|
467
|
+
}
|
|
468
|
+
else if (stack.has(dep)) {
|
|
469
|
+
const startIndex = path.indexOf(dep);
|
|
470
|
+
if (startIndex !== -1) {
|
|
471
|
+
cycles.push(path.slice(startIndex));
|
|
472
|
+
}
|
|
473
|
+
}
|
|
474
|
+
}
|
|
475
|
+
stack.delete(current);
|
|
476
|
+
path.pop();
|
|
477
|
+
};
|
|
478
|
+
for (const asset of Object.keys(dependencies)) {
|
|
479
|
+
if (!visited.has(asset)) {
|
|
480
|
+
dfs(asset, 0, []);
|
|
481
|
+
}
|
|
482
|
+
}
|
|
483
|
+
return cycles;
|
|
484
|
+
}
|
|
485
|
+
fallbackTopologicalSort(dependencies) {
|
|
486
|
+
const inDegree = new Map();
|
|
487
|
+
const graph = new Map();
|
|
488
|
+
for (const [asset, deps] of Object.entries(dependencies)) {
|
|
489
|
+
if (!inDegree.has(asset)) {
|
|
490
|
+
inDegree.set(asset, 0);
|
|
491
|
+
}
|
|
492
|
+
for (const dep of deps) {
|
|
493
|
+
if (!inDegree.has(dep)) {
|
|
494
|
+
inDegree.set(dep, 0);
|
|
495
|
+
}
|
|
496
|
+
const list = graph.get(dep) || [];
|
|
497
|
+
list.push(asset);
|
|
498
|
+
graph.set(dep, list);
|
|
499
|
+
}
|
|
500
|
+
}
|
|
501
|
+
const queue = [];
|
|
502
|
+
for (const [asset, degree] of inDegree.entries()) {
|
|
503
|
+
if (degree === 0) {
|
|
504
|
+
queue.push(asset);
|
|
505
|
+
}
|
|
506
|
+
}
|
|
507
|
+
const sorted = [];
|
|
508
|
+
while (queue.length > 0) {
|
|
509
|
+
const asset = queue.shift();
|
|
510
|
+
sorted.push(asset);
|
|
511
|
+
const dependents = graph.get(asset) || [];
|
|
512
|
+
for (const dependent of dependents) {
|
|
513
|
+
const current = inDegree.get(dependent) ?? 0;
|
|
514
|
+
const next = current - 1;
|
|
515
|
+
inDegree.set(dependent, next);
|
|
516
|
+
if (next === 0) {
|
|
517
|
+
queue.push(dependent);
|
|
518
|
+
}
|
|
519
|
+
}
|
|
520
|
+
}
|
|
521
|
+
return sorted;
|
|
522
|
+
}
|
|
523
|
+
}
|
|
524
|
+
export const wasmIntegration = new WASMIntegration();
|
|
525
|
+
export async function initializeWASM(config) {
|
|
526
|
+
const integration = config ? new WASMIntegration(config) : wasmIntegration;
|
|
527
|
+
await integration.initialize();
|
|
528
|
+
}
|
|
529
|
+
export function isWASMReady() {
|
|
530
|
+
return wasmIntegration.isReady();
|
|
531
|
+
}
|
|
532
|
+
export function getWASMPerformanceReport() {
|
|
533
|
+
return wasmIntegration.reportPerformance();
|
|
534
|
+
}
|
|
535
|
+
//# sourceMappingURL=index.js.map
|