@holoscript/core 2.0.1 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (137) hide show
  1. package/dist/chunk-2XXE34KS.js +344 -0
  2. package/dist/chunk-2XXE34KS.js.map +1 -0
  3. package/dist/chunk-3X2EGU7Z.cjs +52 -0
  4. package/dist/chunk-3X2EGU7Z.cjs.map +1 -0
  5. package/dist/chunk-AFFVFO4D.js +1689 -0
  6. package/dist/chunk-AFFVFO4D.js.map +1 -0
  7. package/dist/chunk-DGUM43GV.js +10 -0
  8. package/dist/chunk-DGUM43GV.js.map +1 -0
  9. package/{src/HoloScriptDebugger.ts → dist/chunk-DOY73HDH.js} +118 -257
  10. package/dist/chunk-DOY73HDH.js.map +1 -0
  11. package/dist/chunk-JEQ2X3Z6.cjs +12 -0
  12. package/dist/chunk-JEQ2X3Z6.cjs.map +1 -0
  13. package/dist/chunk-L6VLNVKP.cjs +1691 -0
  14. package/dist/chunk-L6VLNVKP.cjs.map +1 -0
  15. package/dist/chunk-MFNO57XL.cjs +347 -0
  16. package/dist/chunk-MFNO57XL.cjs.map +1 -0
  17. package/dist/chunk-R75MREOS.cjs +424 -0
  18. package/dist/chunk-R75MREOS.cjs.map +1 -0
  19. package/dist/chunk-SATNCODL.js +45 -0
  20. package/dist/chunk-SATNCODL.js.map +1 -0
  21. package/dist/chunk-T57ZL7KR.cjs +1281 -0
  22. package/dist/chunk-T57ZL7KR.cjs.map +1 -0
  23. package/dist/chunk-U72GEJZT.js +1279 -0
  24. package/dist/chunk-U72GEJZT.js.map +1 -0
  25. package/dist/debugger.cjs +20 -0
  26. package/dist/debugger.cjs.map +1 -0
  27. package/dist/debugger.d.cts +171 -0
  28. package/dist/debugger.d.ts +171 -0
  29. package/dist/debugger.js +7 -0
  30. package/dist/debugger.js.map +1 -0
  31. package/dist/index.cjs +6803 -0
  32. package/dist/index.cjs.map +1 -0
  33. package/dist/index.d.cts +4093 -0
  34. package/dist/index.d.ts +4093 -0
  35. package/dist/index.js +6715 -0
  36. package/dist/index.js.map +1 -0
  37. package/dist/parser.cjs +14 -0
  38. package/dist/parser.cjs.map +1 -0
  39. package/dist/parser.d.cts +172 -0
  40. package/dist/parser.d.ts +172 -0
  41. package/dist/parser.js +5 -0
  42. package/dist/parser.js.map +1 -0
  43. package/dist/runtime.cjs +14 -0
  44. package/dist/runtime.cjs.map +1 -0
  45. package/dist/runtime.d.cts +200 -0
  46. package/dist/runtime.d.ts +200 -0
  47. package/dist/runtime.js +5 -0
  48. package/dist/runtime.js.map +1 -0
  49. package/dist/type-checker.cjs +17 -0
  50. package/dist/type-checker.cjs.map +1 -0
  51. package/dist/type-checker.d.cts +105 -0
  52. package/dist/type-checker.d.ts +105 -0
  53. package/dist/type-checker.js +4 -0
  54. package/dist/type-checker.js.map +1 -0
  55. package/dist/types-4h8cbtF_.d.cts +329 -0
  56. package/dist/types-4h8cbtF_.d.ts +329 -0
  57. package/package.json +17 -13
  58. package/src/HoloScript2DParser.js +0 -227
  59. package/src/HoloScript2DParser.ts +0 -261
  60. package/src/HoloScriptCodeParser.js +0 -1102
  61. package/src/HoloScriptCodeParser.ts +0 -1188
  62. package/src/HoloScriptDebugger.js +0 -458
  63. package/src/HoloScriptParser.js +0 -338
  64. package/src/HoloScriptParser.ts +0 -397
  65. package/src/HoloScriptPlusParser.js +0 -371
  66. package/src/HoloScriptPlusParser.ts +0 -543
  67. package/src/HoloScriptRuntime.js +0 -1399
  68. package/src/HoloScriptRuntime.test.js +0 -351
  69. package/src/HoloScriptRuntime.test.ts +0 -436
  70. package/src/HoloScriptRuntime.ts +0 -1653
  71. package/src/HoloScriptTypeChecker.js +0 -356
  72. package/src/HoloScriptTypeChecker.ts +0 -475
  73. package/src/__tests__/GraphicsServices.test.js +0 -357
  74. package/src/__tests__/GraphicsServices.test.ts +0 -427
  75. package/src/__tests__/HoloScriptPlusParser.test.js +0 -317
  76. package/src/__tests__/HoloScriptPlusParser.test.ts +0 -392
  77. package/src/__tests__/integration.test.js +0 -336
  78. package/src/__tests__/integration.test.ts +0 -416
  79. package/src/__tests__/performance.bench.js +0 -218
  80. package/src/__tests__/performance.bench.ts +0 -262
  81. package/src/__tests__/type-checker.test.js +0 -60
  82. package/src/__tests__/type-checker.test.ts +0 -73
  83. package/src/index.js +0 -217
  84. package/src/index.ts +0 -426
  85. package/src/interop/Interoperability.js +0 -413
  86. package/src/interop/Interoperability.ts +0 -494
  87. package/src/logger.js +0 -42
  88. package/src/logger.ts +0 -57
  89. package/src/parser/EnhancedParser.js +0 -205
  90. package/src/parser/EnhancedParser.ts +0 -251
  91. package/src/parser/HoloScriptPlusParser.js +0 -928
  92. package/src/parser/HoloScriptPlusParser.ts +0 -1089
  93. package/src/runtime/HoloScriptPlusRuntime.js +0 -674
  94. package/src/runtime/HoloScriptPlusRuntime.ts +0 -861
  95. package/src/runtime/PerformanceTelemetry.js +0 -323
  96. package/src/runtime/PerformanceTelemetry.ts +0 -467
  97. package/src/runtime/RuntimeOptimization.js +0 -361
  98. package/src/runtime/RuntimeOptimization.ts +0 -416
  99. package/src/services/HololandGraphicsPipelineService.js +0 -506
  100. package/src/services/HololandGraphicsPipelineService.ts +0 -662
  101. package/src/services/PlatformPerformanceOptimizer.js +0 -356
  102. package/src/services/PlatformPerformanceOptimizer.ts +0 -503
  103. package/src/state/ReactiveState.js +0 -427
  104. package/src/state/ReactiveState.ts +0 -572
  105. package/src/tools/DeveloperExperience.js +0 -376
  106. package/src/tools/DeveloperExperience.ts +0 -438
  107. package/src/traits/AIDriverTrait.js +0 -322
  108. package/src/traits/AIDriverTrait.test.js +0 -329
  109. package/src/traits/AIDriverTrait.test.ts +0 -357
  110. package/src/traits/AIDriverTrait.ts +0 -474
  111. package/src/traits/LightingTrait.js +0 -313
  112. package/src/traits/LightingTrait.test.js +0 -410
  113. package/src/traits/LightingTrait.test.ts +0 -462
  114. package/src/traits/LightingTrait.ts +0 -505
  115. package/src/traits/MaterialTrait.js +0 -194
  116. package/src/traits/MaterialTrait.test.js +0 -286
  117. package/src/traits/MaterialTrait.test.ts +0 -329
  118. package/src/traits/MaterialTrait.ts +0 -324
  119. package/src/traits/RenderingTrait.js +0 -356
  120. package/src/traits/RenderingTrait.test.js +0 -363
  121. package/src/traits/RenderingTrait.test.ts +0 -427
  122. package/src/traits/RenderingTrait.ts +0 -555
  123. package/src/traits/VRTraitSystem.js +0 -740
  124. package/src/traits/VRTraitSystem.ts +0 -1040
  125. package/src/traits/VoiceInputTrait.js +0 -284
  126. package/src/traits/VoiceInputTrait.test.js +0 -226
  127. package/src/traits/VoiceInputTrait.test.ts +0 -252
  128. package/src/traits/VoiceInputTrait.ts +0 -401
  129. package/src/types/AdvancedTypeSystem.js +0 -226
  130. package/src/types/AdvancedTypeSystem.ts +0 -494
  131. package/src/types/HoloScriptPlus.d.ts +0 -853
  132. package/src/types.js +0 -6
  133. package/src/types.ts +0 -369
  134. package/tsconfig.json +0 -23
  135. package/tsup.config.d.ts +0 -2
  136. package/tsup.config.js +0 -18
  137. package/tsup.config.ts +0 -19
@@ -1,336 +0,0 @@
1
- /**
2
- * HoloScript Integration Tests
3
- *
4
- * End-to-end tests that verify the complete pipeline:
5
- * Parser -> Runtime -> Type Checker -> Debugger
6
- */
7
- import { describe, it, expect, beforeEach } from 'vitest';
8
- import { HoloScriptCodeParser } from '../HoloScriptCodeParser';
9
- import { HoloScriptRuntime } from '../HoloScriptRuntime';
10
- import { HoloScriptTypeChecker } from '../HoloScriptTypeChecker';
11
- import { HoloScriptDebugger } from '../HoloScriptDebugger';
12
- describe('HoloScript Integration Tests', () => {
13
- let parser;
14
- let runtime;
15
- let typeChecker;
16
- beforeEach(() => {
17
- parser = new HoloScriptCodeParser();
18
- runtime = new HoloScriptRuntime();
19
- typeChecker = new HoloScriptTypeChecker();
20
- });
21
- describe('Parser -> Runtime Pipeline', () => {
22
- it('should parse and execute a simple orb declaration', async () => {
23
- const code = `
24
- orb myOrb {
25
- name: "TestOrb"
26
- color: "#ff0000"
27
- glow: true
28
- }
29
- `;
30
- const parseResult = parser.parse(code);
31
- expect(parseResult.success).toBe(true);
32
- expect(parseResult.ast.length).toBeGreaterThan(0);
33
- const results = await runtime.executeProgram(parseResult.ast);
34
- expect(results.length).toBeGreaterThan(0);
35
- expect(results[0].success).toBe(true);
36
- });
37
- it('should parse and execute a function definition', async () => {
38
- const code = `
39
- function greet(name: string): string {
40
- return "Hello, " + name
41
- }
42
- `;
43
- const parseResult = parser.parse(code);
44
- expect(parseResult.success).toBe(true);
45
- const results = await runtime.executeProgram(parseResult.ast);
46
- expect(results[0].success).toBe(true);
47
- // Call the function
48
- const callResult = await runtime.callFunction('greet', ['World']);
49
- expect(callResult.success).toBe(true);
50
- });
51
- it('should parse and execute connections between orbs', async () => {
52
- const code = `
53
- orb source {
54
- name: "Source"
55
- }
56
- orb target {
57
- name: "Target"
58
- }
59
- connect source to target as "data"
60
- `;
61
- const parseResult = parser.parse(code);
62
- expect(parseResult.success).toBe(true);
63
- expect(parseResult.ast.length).toBe(3);
64
- const results = await runtime.executeProgram(parseResult.ast);
65
- expect(results.every(r => r.success)).toBe(true);
66
- });
67
- it('should handle program with multiple orbs', async () => {
68
- const code = `
69
- orb dataOrb {
70
- value: 42
71
- name: "DataOrb"
72
- }
73
-
74
- orb outputOrb {
75
- name: "OutputOrb"
76
- }
77
- `;
78
- const parseResult = parser.parse(code);
79
- expect(parseResult.success).toBe(true);
80
- expect(parseResult.ast.length).toBeGreaterThanOrEqual(2);
81
- const results = await runtime.executeProgram(parseResult.ast);
82
- expect(results.length).toBeGreaterThanOrEqual(2);
83
- });
84
- });
85
- describe('Parser -> Type Checker Pipeline', () => {
86
- it('should type check orb declarations', () => {
87
- const code = `
88
- orb typedOrb {
89
- count: 10
90
- name: "TypedOrb"
91
- active: true
92
- }
93
- `;
94
- const parseResult = parser.parse(code);
95
- expect(parseResult.success).toBe(true);
96
- const typeResult = typeChecker.check(parseResult.ast);
97
- expect(typeResult.valid).toBe(true);
98
- expect(typeResult.diagnostics.length).toBe(0);
99
- });
100
- it('should type check function signatures', () => {
101
- const code = `
102
- function add(a: number, b: number): number {
103
- return a + b
104
- }
105
- `;
106
- const parseResult = parser.parse(code);
107
- expect(parseResult.success).toBe(true);
108
- const typeResult = typeChecker.check(parseResult.ast);
109
- expect(typeResult.valid).toBe(true);
110
- });
111
- it('should detect type information', () => {
112
- const code = `
113
- const MAX_VALUE = 100
114
- let counter = 0
115
-
116
- orb configOrb {
117
- limit: MAX_VALUE
118
- }
119
- `;
120
- const parseResult = parser.parse(code);
121
- expect(parseResult.success).toBe(true);
122
- const typeResult = typeChecker.check(parseResult.ast);
123
- expect(typeResult.typeMap.size).toBeGreaterThan(0);
124
- });
125
- });
126
- describe('Full Pipeline: Parse -> Type Check -> Execute', () => {
127
- it('should process a complete program through all stages', async () => {
128
- const code = `
129
- orb sensorOrb {
130
- reading: 75
131
- name: "Sensor"
132
- }
133
-
134
- function checkReading(value: number): boolean {
135
- return value > 50
136
- }
137
- `;
138
- // Stage 1: Parse
139
- const parseResult = parser.parse(code);
140
- expect(parseResult.success).toBe(true);
141
- expect(parseResult.errors.length).toBe(0);
142
- // Stage 2: Type Check
143
- const typeResult = typeChecker.check(parseResult.ast);
144
- expect(typeResult.valid).toBe(true);
145
- // Stage 3: Execute
146
- const execResults = await runtime.executeProgram(parseResult.ast);
147
- expect(execResults.every(r => r.success)).toBe(true);
148
- });
149
- });
150
- describe('Debugger Integration', () => {
151
- it('should load source and set breakpoints', () => {
152
- const debugger_ = new HoloScriptDebugger(runtime);
153
- const code = `
154
- orb debugOrb {
155
- name: "DebugOrb"
156
- }
157
-
158
- function test() {
159
- show debugOrb
160
- }
161
- `;
162
- const loadResult = debugger_.loadSource(code);
163
- expect(loadResult.success).toBe(true);
164
- const bp = debugger_.setBreakpoint(2);
165
- expect(bp.id).toBeDefined();
166
- expect(bp.line).toBe(2);
167
- expect(bp.enabled).toBe(true);
168
- const breakpoints = debugger_.getBreakpoints();
169
- expect(breakpoints.length).toBe(1);
170
- });
171
- it('should step through execution', async () => {
172
- const debugger_ = new HoloScriptDebugger(runtime);
173
- const code = `
174
- orb stepOrb {
175
- name: "StepOrb"
176
- }
177
- `;
178
- debugger_.loadSource(code);
179
- // Start and immediately pause
180
- await debugger_.start();
181
- const state = debugger_.getState();
182
- expect(state.status).toBeDefined();
183
- });
184
- it('should evaluate expressions in debug context', async () => {
185
- const debugger_ = new HoloScriptDebugger(runtime);
186
- const code = `
187
- orb evalOrb {
188
- value: 42
189
- }
190
- `;
191
- debugger_.loadSource(code);
192
- await debugger_.start();
193
- // Wait for execution to complete
194
- const result = await debugger_.evaluate('evalOrb');
195
- expect(result).toBeDefined();
196
- });
197
- it('should handle breakpoint events', async () => {
198
- const debugger_ = new HoloScriptDebugger(runtime);
199
- const events = [];
200
- debugger_.on('breakpoint-hit', () => events.push('breakpoint'));
201
- debugger_.on('state-change', () => events.push('state'));
202
- const code = `
203
- orb eventOrb {
204
- name: "EventOrb"
205
- }
206
- `;
207
- debugger_.loadSource(code);
208
- debugger_.setBreakpoint(2);
209
- await debugger_.start();
210
- // Events should have been captured
211
- expect(events.length).toBeGreaterThanOrEqual(0);
212
- });
213
- });
214
- describe('Error Handling', () => {
215
- it('should handle parse errors gracefully', () => {
216
- const code = `
217
- orb { invalid syntax here
218
- `;
219
- const parseResult = parser.parse(code);
220
- expect(parseResult.success).toBe(false);
221
- expect(parseResult.errors.length).toBeGreaterThan(0);
222
- });
223
- it('should handle runtime errors gracefully', async () => {
224
- const code = `
225
- function errorFunc() {
226
- throw "Error"
227
- }
228
- `;
229
- const parseResult = parser.parse(code);
230
- expect(parseResult.success).toBe(true);
231
- const results = await runtime.executeProgram(parseResult.ast);
232
- // Function definition should succeed
233
- expect(results[0].success).toBe(true);
234
- });
235
- it('should handle debugger errors gracefully', async () => {
236
- const debugger_ = new HoloScriptDebugger(runtime);
237
- // Completely invalid syntax that parser will reject
238
- const loadResult = debugger_.loadSource('{{{{{{');
239
- // Parser may or may not reject this depending on implementation
240
- // Just verify we get a result without crashing
241
- expect(loadResult).toBeDefined();
242
- });
243
- });
244
- describe('Loop Constructs', () => {
245
- it('should parse for loops', () => {
246
- const code = `
247
- for (i = 0; i < 10; i++) {
248
- show i
249
- }
250
- `;
251
- const parseResult = parser.parse(code);
252
- expect(parseResult.success).toBe(true);
253
- expect(parseResult.ast[0].type).toBe('for-loop');
254
- });
255
- it.todo('should parse while loops - needs parser enhancement');
256
- it.todo('should parse forEach loops - needs parser enhancement');
257
- });
258
- describe('Module System', () => {
259
- it.todo('should parse import statements - needs parser enhancement');
260
- it('should parse export statements', () => {
261
- const code = `
262
- export function helper() {
263
- return 42
264
- }
265
- `;
266
- const parseResult = parser.parse(code);
267
- expect(parseResult.success).toBe(true);
268
- expect(parseResult.ast[0].type).toBe('export');
269
- });
270
- it('should parse variable declarations', () => {
271
- const code = `
272
- const MAX = 100
273
- let count = 0
274
- var legacy = true
275
- `;
276
- const parseResult = parser.parse(code);
277
- expect(parseResult.success).toBe(true);
278
- expect(parseResult.ast.length).toBe(3);
279
- expect(parseResult.ast[0].type).toBe('variable-declaration');
280
- });
281
- });
282
- describe('Runtime Context', () => {
283
- it('should maintain variable state across executions', async () => {
284
- const code1 = `
285
- orb stateOrb {
286
- counter: 0
287
- }
288
- `;
289
- const parseResult1 = parser.parse(code1);
290
- await runtime.executeProgram(parseResult1.ast);
291
- // Context should exist after execution
292
- const context = runtime.getContext();
293
- expect(context).toBeDefined();
294
- expect(context.variables).toBeDefined();
295
- });
296
- it('should support function calls with arguments', async () => {
297
- const code = `
298
- function multiply(a: number, b: number): number {
299
- return a * b
300
- }
301
- `;
302
- const parseResult = parser.parse(code);
303
- await runtime.executeProgram(parseResult.ast);
304
- const result = await runtime.callFunction('multiply', [5, 3]);
305
- expect(result.success).toBe(true);
306
- });
307
- it('should reset context on runtime reset', async () => {
308
- const code = `
309
- orb tempOrb {
310
- name: "Temporary"
311
- }
312
- `;
313
- const parseResult = parser.parse(code);
314
- await runtime.executeProgram(parseResult.ast);
315
- const contextBefore = runtime.getContext();
316
- expect(contextBefore).toBeDefined();
317
- runtime.reset();
318
- const contextAfter = runtime.getContext();
319
- // After reset, variables should be empty
320
- expect(contextAfter.variables.size).toBe(0);
321
- });
322
- });
323
- });
324
- describe('HoloScript Bridge Integration', () => {
325
- // These tests would require the Hololand bridge
326
- // Stubbed for now - would need mock world interface
327
- it.skip('should sync orbs to world objects', async () => {
328
- // Would test HoloScriptBridge.loadScript -> world.createObject
329
- });
330
- it.skip('should handle world events', async () => {
331
- // Would test world.emit -> bridge event handling
332
- });
333
- it.skip('should sync runtime state to world', async () => {
334
- // Would test bridge.sync() updating world objects
335
- });
336
- });