@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
@@ -0,0 +1,344 @@
1
+ // src/HoloScriptTypeChecker.ts
2
+ var BUILTIN_FUNCTIONS = /* @__PURE__ */ new Map([
3
+ ["add", { type: "function", parameters: [{ name: "a", type: "number" }, { name: "b", type: "number" }], returnType: "number" }],
4
+ ["subtract", { type: "function", parameters: [{ name: "a", type: "number" }, { name: "b", type: "number" }], returnType: "number" }],
5
+ ["multiply", { type: "function", parameters: [{ name: "a", type: "number" }, { name: "b", type: "number" }], returnType: "number" }],
6
+ ["divide", { type: "function", parameters: [{ name: "a", type: "number" }, { name: "b", type: "number" }], returnType: "number" }],
7
+ ["concat", { type: "function", parameters: [{ name: "a", type: "string" }, { name: "b", type: "string" }], returnType: "string" }],
8
+ ["length", { type: "function", parameters: [{ name: "value", type: "any" }], returnType: "number" }],
9
+ ["push", { type: "function", parameters: [{ name: "arr", type: "array" }, { name: "item", type: "any" }], returnType: "array" }],
10
+ ["pop", { type: "function", parameters: [{ name: "arr", type: "array" }], returnType: "any" }],
11
+ ["log", { type: "function", parameters: [{ name: "message", type: "any" }], returnType: "void" }],
12
+ ["print", { type: "function", parameters: [{ name: "message", type: "any" }], returnType: "void" }],
13
+ ["show", { type: "function", parameters: [{ name: "target", type: "orb" }], returnType: "void" }],
14
+ ["hide", { type: "function", parameters: [{ name: "target", type: "orb" }], returnType: "void" }],
15
+ ["pulse", { type: "function", parameters: [{ name: "target", type: "orb" }], returnType: "void" }],
16
+ ["animate", { type: "function", parameters: [{ name: "target", type: "orb" }, { name: "config", type: "object" }], returnType: "void" }],
17
+ ["spawn", { type: "function", parameters: [{ name: "type", type: "string" }, { name: "position", type: "object" }], returnType: "orb" }],
18
+ ["isNumber", { type: "function", parameters: [{ name: "value", type: "any" }], returnType: "boolean" }],
19
+ ["isString", { type: "function", parameters: [{ name: "value", type: "any" }], returnType: "boolean" }],
20
+ ["isArray", { type: "function", parameters: [{ name: "value", type: "any" }], returnType: "boolean" }]
21
+ ]);
22
+ var HoloScriptTypeChecker = class {
23
+ constructor() {
24
+ this.typeMap = /* @__PURE__ */ new Map();
25
+ this.diagnostics = [];
26
+ this.currentLine = 0;
27
+ this.currentColumn = 0;
28
+ BUILTIN_FUNCTIONS.forEach((type, name) => {
29
+ this.typeMap.set(name, type);
30
+ });
31
+ }
32
+ /**
33
+ * Type check an AST
34
+ */
35
+ check(ast) {
36
+ this.diagnostics = [];
37
+ for (const node of ast) {
38
+ this.collectDeclaration(node);
39
+ }
40
+ for (const node of ast) {
41
+ this.checkNode(node);
42
+ }
43
+ return {
44
+ valid: this.diagnostics.filter((d) => d.severity === "error").length === 0,
45
+ diagnostics: this.diagnostics,
46
+ typeMap: new Map(this.typeMap)
47
+ };
48
+ }
49
+ /**
50
+ * Collect type declarations
51
+ */
52
+ collectDeclaration(node) {
53
+ switch (node.type) {
54
+ case "orb":
55
+ this.collectOrbDeclaration(node);
56
+ break;
57
+ case "method":
58
+ this.collectMethodDeclaration(node);
59
+ break;
60
+ case "variable-declaration":
61
+ this.collectVariableDeclaration(node);
62
+ break;
63
+ case "stream":
64
+ this.collectStreamDeclaration(node);
65
+ break;
66
+ }
67
+ }
68
+ collectOrbDeclaration(node) {
69
+ const properties = /* @__PURE__ */ new Map();
70
+ properties.set("position", { type: "object", properties: /* @__PURE__ */ new Map([
71
+ ["x", { type: "number" }],
72
+ ["y", { type: "number" }],
73
+ ["z", { type: "number" }]
74
+ ]) });
75
+ properties.set("color", { type: "string" });
76
+ properties.set("glow", { type: "boolean" });
77
+ properties.set("interactive", { type: "boolean" });
78
+ properties.set("visible", { type: "boolean" });
79
+ for (const [key, value] of Object.entries(node.properties)) {
80
+ properties.set(key, this.inferType(value));
81
+ }
82
+ this.typeMap.set(node.name, {
83
+ type: "orb",
84
+ properties
85
+ });
86
+ }
87
+ collectMethodDeclaration(node) {
88
+ const parameters = node.parameters.map((p) => ({
89
+ name: p.name,
90
+ type: this.parseTypeString(p.dataType),
91
+ optional: p.defaultValue !== void 0,
92
+ defaultValue: p.defaultValue
93
+ }));
94
+ this.typeMap.set(node.name, {
95
+ type: "function",
96
+ parameters,
97
+ returnType: node.returnType ? this.parseTypeString(node.returnType) : "void"
98
+ });
99
+ }
100
+ collectVariableDeclaration(node) {
101
+ let type = "any";
102
+ if (node.dataType) {
103
+ type = this.parseTypeString(node.dataType);
104
+ } else if (node.value !== void 0) {
105
+ type = this.inferType(node.value).type;
106
+ }
107
+ this.typeMap.set(node.name, { type });
108
+ }
109
+ collectStreamDeclaration(node) {
110
+ this.typeMap.set(node.name, {
111
+ type: "stream",
112
+ properties: /* @__PURE__ */ new Map([
113
+ ["source", { type: "string" }],
114
+ ["result", { type: "any" }]
115
+ ])
116
+ });
117
+ }
118
+ /**
119
+ * Check a node for type errors
120
+ */
121
+ checkNode(node) {
122
+ this.currentLine = node.position?.x ?? 0;
123
+ this.currentColumn = node.position?.y ?? 0;
124
+ switch (node.type) {
125
+ case "connection":
126
+ this.checkConnection(node);
127
+ break;
128
+ case "gate":
129
+ this.checkGate(node);
130
+ break;
131
+ case "for-loop":
132
+ this.checkForLoop(node);
133
+ break;
134
+ case "while-loop":
135
+ this.checkWhileLoop(node);
136
+ break;
137
+ case "foreach-loop":
138
+ this.checkForEachLoop(node);
139
+ break;
140
+ case "import":
141
+ this.checkImport(node);
142
+ break;
143
+ case "export":
144
+ this.checkExport(node);
145
+ break;
146
+ }
147
+ }
148
+ checkConnection(node) {
149
+ const fromType = this.typeMap.get(node.from);
150
+ const toType = this.typeMap.get(node.to);
151
+ if (!fromType) {
152
+ this.addDiagnostic("error", `Unknown source '${node.from}' in connection`, "E001");
153
+ }
154
+ if (!toType) {
155
+ this.addDiagnostic("error", `Unknown target '${node.to}' in connection`, "E002");
156
+ }
157
+ if (fromType && toType && node.dataType !== "any") {
158
+ if (fromType.type !== toType.type && fromType.type !== "any" && toType.type !== "any") {
159
+ this.addDiagnostic(
160
+ "warning",
161
+ `Connection from '${node.from}' (${fromType.type}) to '${node.to}' (${toType.type}) may be incompatible`,
162
+ "W001",
163
+ [`Consider using 'as "any"' to bypass type checking`]
164
+ );
165
+ }
166
+ }
167
+ }
168
+ checkGate(node) {
169
+ const conditionVars = this.extractVariables(node.condition);
170
+ for (const varName of conditionVars) {
171
+ if (!this.typeMap.has(varName) && !this.isLiteral(varName)) {
172
+ this.addDiagnostic("error", `Unknown variable '${varName}' in gate condition`, "E003");
173
+ }
174
+ }
175
+ }
176
+ checkForLoop(node) {
177
+ const initVars = this.extractVariables(node.init);
178
+ for (const varName of initVars) {
179
+ if (!this.typeMap.has(varName)) {
180
+ this.typeMap.set(varName, { type: "number" });
181
+ }
182
+ }
183
+ const condVars = this.extractVariables(node.condition);
184
+ for (const varName of condVars) {
185
+ if (!this.typeMap.has(varName) && !this.isLiteral(varName)) {
186
+ this.addDiagnostic("error", `Unknown variable '${varName}' in for loop condition`, "E004");
187
+ }
188
+ }
189
+ }
190
+ checkWhileLoop(node) {
191
+ const condVars = this.extractVariables(node.condition);
192
+ for (const varName of condVars) {
193
+ if (!this.typeMap.has(varName) && !this.isLiteral(varName)) {
194
+ this.addDiagnostic("error", `Unknown variable '${varName}' in while loop condition`, "E005");
195
+ }
196
+ }
197
+ }
198
+ checkForEachLoop(node) {
199
+ if (!this.typeMap.has(node.collection)) {
200
+ this.addDiagnostic("error", `Unknown collection '${node.collection}' in forEach loop`, "E006");
201
+ } else {
202
+ const collectionType = this.typeMap.get(node.collection);
203
+ if (collectionType && collectionType.type !== "array" && collectionType.type !== "any") {
204
+ this.addDiagnostic("error", `'${node.collection}' is not iterable (type: ${collectionType.type})`, "E007");
205
+ }
206
+ }
207
+ this.typeMap.set(node.variable, { type: "any" });
208
+ }
209
+ checkImport(node) {
210
+ if (!node.modulePath) {
211
+ this.addDiagnostic("error", "Import statement missing module path", "E008");
212
+ }
213
+ for (const name of node.imports) {
214
+ this.typeMap.set(name, { type: "any" });
215
+ }
216
+ if (node.defaultImport) {
217
+ this.typeMap.set(node.defaultImport, { type: "any" });
218
+ }
219
+ }
220
+ checkExport(node) {
221
+ if (node.exports) {
222
+ for (const name of node.exports) {
223
+ if (!this.typeMap.has(name)) {
224
+ this.addDiagnostic("error", `Cannot export unknown identifier '${name}'`, "E009");
225
+ }
226
+ }
227
+ }
228
+ }
229
+ /**
230
+ * Infer type from a value
231
+ */
232
+ inferType(value) {
233
+ if (value === null || value === void 0) {
234
+ return { type: "any", nullable: true };
235
+ }
236
+ if (typeof value === "number") {
237
+ return { type: "number" };
238
+ }
239
+ if (typeof value === "string") {
240
+ return { type: "string" };
241
+ }
242
+ if (typeof value === "boolean") {
243
+ return { type: "boolean" };
244
+ }
245
+ if (Array.isArray(value)) {
246
+ const elementType = value.length > 0 ? this.inferType(value[0]).type : "any";
247
+ return { type: "array", elementType };
248
+ }
249
+ if (typeof value === "object") {
250
+ const properties = /* @__PURE__ */ new Map();
251
+ for (const [key, val] of Object.entries(value)) {
252
+ properties.set(key, this.inferType(val));
253
+ }
254
+ return { type: "object", properties };
255
+ }
256
+ return { type: "any" };
257
+ }
258
+ /**
259
+ * Parse type string to HoloScriptType
260
+ */
261
+ parseTypeString(typeStr) {
262
+ const normalized = typeStr.toLowerCase().trim();
263
+ const validTypes = [
264
+ "number",
265
+ "string",
266
+ "boolean",
267
+ "array",
268
+ "object",
269
+ "function",
270
+ "void",
271
+ "any",
272
+ "unknown",
273
+ "never",
274
+ "orb",
275
+ "stream",
276
+ "connection",
277
+ "gate"
278
+ ];
279
+ if (validTypes.includes(normalized)) {
280
+ return normalized;
281
+ }
282
+ return "any";
283
+ }
284
+ /**
285
+ * Extract variable names from an expression string
286
+ */
287
+ extractVariables(expr) {
288
+ const varPattern = /\b([a-zA-Z_][a-zA-Z0-9_]*)\b/g;
289
+ const matches = expr.match(varPattern) || [];
290
+ const keywords = ["true", "false", "null", "undefined", "if", "else", "for", "while", "return"];
291
+ return matches.filter((m) => !keywords.includes(m));
292
+ }
293
+ /**
294
+ * Check if string is a literal
295
+ */
296
+ isLiteral(str) {
297
+ if (/^-?\d+(\.\d+)?$/.test(str)) return true;
298
+ if (str === "true" || str === "false") return true;
299
+ if (/^["'].*["']$/.test(str)) return true;
300
+ return false;
301
+ }
302
+ /**
303
+ * Add a diagnostic
304
+ */
305
+ addDiagnostic(severity, message, code, suggestions) {
306
+ this.diagnostics.push({
307
+ severity,
308
+ message,
309
+ line: this.currentLine,
310
+ column: this.currentColumn,
311
+ code,
312
+ suggestions
313
+ });
314
+ }
315
+ /**
316
+ * Get type info for a name
317
+ */
318
+ getType(name) {
319
+ return this.typeMap.get(name);
320
+ }
321
+ /**
322
+ * Get all registered types
323
+ */
324
+ getAllTypes() {
325
+ return new Map(this.typeMap);
326
+ }
327
+ /**
328
+ * Reset the type checker
329
+ */
330
+ reset() {
331
+ this.typeMap.clear();
332
+ this.diagnostics = [];
333
+ BUILTIN_FUNCTIONS.forEach((type, name) => {
334
+ this.typeMap.set(name, type);
335
+ });
336
+ }
337
+ };
338
+ function createTypeChecker() {
339
+ return new HoloScriptTypeChecker();
340
+ }
341
+
342
+ export { HoloScriptTypeChecker, createTypeChecker };
343
+ //# sourceMappingURL=chunk-2XXE34KS.js.map
344
+ //# sourceMappingURL=chunk-2XXE34KS.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/HoloScriptTypeChecker.ts"],"names":[],"mappings":"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","file":"chunk-2XXE34KS.js","sourcesContent":["/**\n * HoloScript Type Checker\n *\n * Static type analysis for HoloScript code.\n * Validates types, detects errors, and provides type information.\n */\n\nimport type {\n ASTNode,\n OrbNode,\n MethodNode,\n ConnectionNode,\n GateNode,\n StreamNode,\n VariableDeclarationNode,\n ForLoopNode,\n WhileLoopNode,\n ForEachLoopNode,\n ImportNode,\n ExportNode,\n HoloScriptValue,\n} from './types';\n\n// Type system types\nexport type HoloScriptType =\n | 'number'\n | 'string'\n | 'boolean'\n | 'array'\n | 'object'\n | 'function'\n | 'void'\n | 'any'\n | 'unknown'\n | 'never'\n | 'orb'\n | 'stream'\n | 'connection'\n | 'gate';\n\nexport interface TypeInfo {\n type: HoloScriptType;\n elementType?: HoloScriptType; // For arrays\n properties?: Map<string, TypeInfo>; // For objects/orbs\n parameters?: ParameterType[]; // For functions\n returnType?: HoloScriptType; // For functions\n nullable?: boolean;\n}\n\nexport interface ParameterType {\n name: string;\n type: HoloScriptType;\n optional?: boolean;\n defaultValue?: HoloScriptValue;\n}\n\nexport interface TypeDiagnostic {\n severity: 'error' | 'warning' | 'info';\n message: string;\n line: number;\n column: number;\n code: string;\n suggestions?: string[];\n}\n\nexport interface TypeCheckResult {\n valid: boolean;\n diagnostics: TypeDiagnostic[];\n typeMap: Map<string, TypeInfo>;\n}\n\n// Built-in type definitions\nconst BUILTIN_FUNCTIONS: Map<string, TypeInfo> = new Map([\n ['add', { type: 'function', parameters: [{ name: 'a', type: 'number' }, { name: 'b', type: 'number' }], returnType: 'number' }],\n ['subtract', { type: 'function', parameters: [{ name: 'a', type: 'number' }, { name: 'b', type: 'number' }], returnType: 'number' }],\n ['multiply', { type: 'function', parameters: [{ name: 'a', type: 'number' }, { name: 'b', type: 'number' }], returnType: 'number' }],\n ['divide', { type: 'function', parameters: [{ name: 'a', type: 'number' }, { name: 'b', type: 'number' }], returnType: 'number' }],\n ['concat', { type: 'function', parameters: [{ name: 'a', type: 'string' }, { name: 'b', type: 'string' }], returnType: 'string' }],\n ['length', { type: 'function', parameters: [{ name: 'value', type: 'any' }], returnType: 'number' }],\n ['push', { type: 'function', parameters: [{ name: 'arr', type: 'array' }, { name: 'item', type: 'any' }], returnType: 'array' }],\n ['pop', { type: 'function', parameters: [{ name: 'arr', type: 'array' }], returnType: 'any' }],\n ['log', { type: 'function', parameters: [{ name: 'message', type: 'any' }], returnType: 'void' }],\n ['print', { type: 'function', parameters: [{ name: 'message', type: 'any' }], returnType: 'void' }],\n ['show', { type: 'function', parameters: [{ name: 'target', type: 'orb' }], returnType: 'void' }],\n ['hide', { type: 'function', parameters: [{ name: 'target', type: 'orb' }], returnType: 'void' }],\n ['pulse', { type: 'function', parameters: [{ name: 'target', type: 'orb' }], returnType: 'void' }],\n ['animate', { type: 'function', parameters: [{ name: 'target', type: 'orb' }, { name: 'config', type: 'object' }], returnType: 'void' }],\n ['spawn', { type: 'function', parameters: [{ name: 'type', type: 'string' }, { name: 'position', type: 'object' }], returnType: 'orb' }],\n ['isNumber', { type: 'function', parameters: [{ name: 'value', type: 'any' }], returnType: 'boolean' }],\n ['isString', { type: 'function', parameters: [{ name: 'value', type: 'any' }], returnType: 'boolean' }],\n ['isArray', { type: 'function', parameters: [{ name: 'value', type: 'any' }], returnType: 'boolean' }],\n]);\n\nexport class HoloScriptTypeChecker {\n private typeMap: Map<string, TypeInfo> = new Map();\n private diagnostics: TypeDiagnostic[] = [];\n private currentLine: number = 0;\n private currentColumn: number = 0;\n\n constructor() {\n // Initialize with built-in functions\n BUILTIN_FUNCTIONS.forEach((type, name) => {\n this.typeMap.set(name, type);\n });\n }\n\n /**\n * Type check an AST\n */\n check(ast: ASTNode[]): TypeCheckResult {\n this.diagnostics = [];\n\n // First pass: collect declarations\n for (const node of ast) {\n this.collectDeclaration(node);\n }\n\n // Second pass: validate types\n for (const node of ast) {\n this.checkNode(node);\n }\n\n return {\n valid: this.diagnostics.filter(d => d.severity === 'error').length === 0,\n diagnostics: this.diagnostics,\n typeMap: new Map(this.typeMap),\n };\n }\n\n /**\n * Collect type declarations\n */\n private collectDeclaration(node: ASTNode): void {\n switch (node.type) {\n case 'orb':\n this.collectOrbDeclaration(node as OrbNode);\n break;\n case 'method':\n this.collectMethodDeclaration(node as MethodNode);\n break;\n case 'variable-declaration':\n this.collectVariableDeclaration(node as VariableDeclarationNode);\n break;\n case 'stream':\n this.collectStreamDeclaration(node as StreamNode);\n break;\n }\n }\n\n private collectOrbDeclaration(node: OrbNode): void {\n const properties = new Map<string, TypeInfo>();\n\n // Add default orb properties\n properties.set('position', { type: 'object', properties: new Map([\n ['x', { type: 'number' }],\n ['y', { type: 'number' }],\n ['z', { type: 'number' }],\n ])});\n properties.set('color', { type: 'string' });\n properties.set('glow', { type: 'boolean' });\n properties.set('interactive', { type: 'boolean' });\n properties.set('visible', { type: 'boolean' });\n\n // Add user-defined properties\n for (const [key, value] of Object.entries(node.properties)) {\n properties.set(key, this.inferType(value));\n }\n\n this.typeMap.set(node.name, {\n type: 'orb',\n properties,\n });\n }\n\n private collectMethodDeclaration(node: MethodNode): void {\n const parameters: ParameterType[] = node.parameters.map(p => ({\n name: p.name,\n type: this.parseTypeString(p.dataType),\n optional: p.defaultValue !== undefined,\n defaultValue: p.defaultValue,\n }));\n\n this.typeMap.set(node.name, {\n type: 'function',\n parameters,\n returnType: node.returnType ? this.parseTypeString(node.returnType) : 'void',\n });\n }\n\n private collectVariableDeclaration(node: VariableDeclarationNode): void {\n let type: HoloScriptType = 'any';\n\n if (node.dataType) {\n type = this.parseTypeString(node.dataType);\n } else if (node.value !== undefined) {\n type = this.inferType(node.value).type;\n }\n\n this.typeMap.set(node.name, { type });\n }\n\n private collectStreamDeclaration(node: StreamNode): void {\n this.typeMap.set(node.name, {\n type: 'stream',\n properties: new Map([\n ['source', { type: 'string' }],\n ['result', { type: 'any' }],\n ]),\n });\n }\n\n /**\n * Check a node for type errors\n */\n private checkNode(node: ASTNode): void {\n this.currentLine = node.position?.x ?? 0;\n this.currentColumn = node.position?.y ?? 0;\n\n switch (node.type) {\n case 'connection':\n this.checkConnection(node as ConnectionNode);\n break;\n case 'gate':\n this.checkGate(node as GateNode);\n break;\n case 'for-loop':\n this.checkForLoop(node as ForLoopNode);\n break;\n case 'while-loop':\n this.checkWhileLoop(node as WhileLoopNode);\n break;\n case 'foreach-loop':\n this.checkForEachLoop(node as ForEachLoopNode);\n break;\n case 'import':\n this.checkImport(node as ImportNode);\n break;\n case 'export':\n this.checkExport(node as ExportNode);\n break;\n }\n }\n\n private checkConnection(node: ConnectionNode): void {\n const fromType = this.typeMap.get(node.from);\n const toType = this.typeMap.get(node.to);\n\n if (!fromType) {\n this.addDiagnostic('error', `Unknown source '${node.from}' in connection`, 'E001');\n }\n\n if (!toType) {\n this.addDiagnostic('error', `Unknown target '${node.to}' in connection`, 'E002');\n }\n\n // Check if types are compatible\n if (fromType && toType && node.dataType !== 'any') {\n // Warn if connecting incompatible types\n if (fromType.type !== toType.type && fromType.type !== 'any' && toType.type !== 'any') {\n this.addDiagnostic('warning',\n `Connection from '${node.from}' (${fromType.type}) to '${node.to}' (${toType.type}) may be incompatible`,\n 'W001',\n [`Consider using 'as \"any\"' to bypass type checking`]\n );\n }\n }\n }\n\n private checkGate(node: GateNode): void {\n // Validate condition references valid variables\n const conditionVars = this.extractVariables(node.condition);\n for (const varName of conditionVars) {\n if (!this.typeMap.has(varName) && !this.isLiteral(varName)) {\n this.addDiagnostic('error', `Unknown variable '${varName}' in gate condition`, 'E003');\n }\n }\n }\n\n private checkForLoop(node: ForLoopNode): void {\n // Check init references\n const initVars = this.extractVariables(node.init);\n // For loops can declare new variables in init, so we add them\n for (const varName of initVars) {\n if (!this.typeMap.has(varName)) {\n this.typeMap.set(varName, { type: 'number' }); // Loop vars are typically numbers\n }\n }\n\n // Check condition\n const condVars = this.extractVariables(node.condition);\n for (const varName of condVars) {\n if (!this.typeMap.has(varName) && !this.isLiteral(varName)) {\n this.addDiagnostic('error', `Unknown variable '${varName}' in for loop condition`, 'E004');\n }\n }\n }\n\n private checkWhileLoop(node: WhileLoopNode): void {\n const condVars = this.extractVariables(node.condition);\n for (const varName of condVars) {\n if (!this.typeMap.has(varName) && !this.isLiteral(varName)) {\n this.addDiagnostic('error', `Unknown variable '${varName}' in while loop condition`, 'E005');\n }\n }\n }\n\n private checkForEachLoop(node: ForEachLoopNode): void {\n // Check collection exists\n if (!this.typeMap.has(node.collection)) {\n this.addDiagnostic('error', `Unknown collection '${node.collection}' in forEach loop`, 'E006');\n } else {\n const collectionType = this.typeMap.get(node.collection);\n if (collectionType && collectionType.type !== 'array' && collectionType.type !== 'any') {\n this.addDiagnostic('error', `'${node.collection}' is not iterable (type: ${collectionType.type})`, 'E007');\n }\n }\n\n // Add loop variable to scope\n this.typeMap.set(node.variable, { type: 'any' });\n }\n\n private checkImport(node: ImportNode): void {\n if (!node.modulePath) {\n this.addDiagnostic('error', 'Import statement missing module path', 'E008');\n }\n\n // Register imported names as 'any' type (can't resolve external modules)\n for (const name of node.imports) {\n this.typeMap.set(name, { type: 'any' });\n }\n\n if (node.defaultImport) {\n this.typeMap.set(node.defaultImport, { type: 'any' });\n }\n }\n\n private checkExport(node: ExportNode): void {\n if (node.exports) {\n for (const name of node.exports) {\n if (!this.typeMap.has(name)) {\n this.addDiagnostic('error', `Cannot export unknown identifier '${name}'`, 'E009');\n }\n }\n }\n }\n\n /**\n * Infer type from a value\n */\n public inferType(value: HoloScriptValue): TypeInfo {\n if (value === null || value === undefined) {\n return { type: 'any', nullable: true };\n }\n\n if (typeof value === 'number') {\n return { type: 'number' };\n }\n\n if (typeof value === 'string') {\n return { type: 'string' };\n }\n\n if (typeof value === 'boolean') {\n return { type: 'boolean' };\n }\n\n if (Array.isArray(value)) {\n const elementType = value.length > 0 ? this.inferType(value[0]).type : 'any';\n return { type: 'array', elementType };\n }\n\n if (typeof value === 'object') {\n const properties = new Map<string, TypeInfo>();\n for (const [key, val] of Object.entries(value)) {\n properties.set(key, this.inferType(val));\n }\n return { type: 'object', properties };\n }\n\n return { type: 'any' };\n }\n\n /**\n * Parse type string to HoloScriptType\n */\n private parseTypeString(typeStr: string): HoloScriptType {\n const normalized = typeStr.toLowerCase().trim();\n const validTypes: HoloScriptType[] = [\n 'number', 'string', 'boolean', 'array', 'object',\n 'function', 'void', 'any', 'unknown', 'never',\n 'orb', 'stream', 'connection', 'gate'\n ];\n\n if (validTypes.includes(normalized as HoloScriptType)) {\n return normalized as HoloScriptType;\n }\n\n return 'any';\n }\n\n /**\n * Extract variable names from an expression string\n */\n private extractVariables(expr: string): string[] {\n const varPattern = /\\b([a-zA-Z_][a-zA-Z0-9_]*)\\b/g;\n const matches = expr.match(varPattern) || [];\n const keywords = ['true', 'false', 'null', 'undefined', 'if', 'else', 'for', 'while', 'return'];\n return matches.filter(m => !keywords.includes(m));\n }\n\n /**\n * Check if string is a literal\n */\n private isLiteral(str: string): boolean {\n // Number literal\n if (/^-?\\d+(\\.\\d+)?$/.test(str)) return true;\n // Boolean\n if (str === 'true' || str === 'false') return true;\n // String literal\n if (/^[\"'].*[\"']$/.test(str)) return true;\n return false;\n }\n\n /**\n * Add a diagnostic\n */\n private addDiagnostic(\n severity: 'error' | 'warning' | 'info',\n message: string,\n code: string,\n suggestions?: string[]\n ): void {\n this.diagnostics.push({\n severity,\n message,\n line: this.currentLine,\n column: this.currentColumn,\n code,\n suggestions,\n });\n }\n\n /**\n * Get type info for a name\n */\n getType(name: string): TypeInfo | undefined {\n return this.typeMap.get(name);\n }\n\n /**\n * Get all registered types\n */\n getAllTypes(): Map<string, TypeInfo> {\n return new Map(this.typeMap);\n }\n\n /**\n * Reset the type checker\n */\n reset(): void {\n this.typeMap.clear();\n this.diagnostics = [];\n\n // Re-add built-ins\n BUILTIN_FUNCTIONS.forEach((type, name) => {\n this.typeMap.set(name, type);\n });\n }\n}\n\n/**\n * Create a type checker instance\n */\nexport function createTypeChecker(): HoloScriptTypeChecker {\n return new HoloScriptTypeChecker();\n}\n"]}
@@ -0,0 +1,52 @@
1
+ 'use strict';
2
+
3
+ // src/logger.ts
4
+ var NoOpLogger = class {
5
+ debug() {
6
+ }
7
+ info() {
8
+ }
9
+ warn() {
10
+ }
11
+ error() {
12
+ }
13
+ };
14
+ var ConsoleLogger = class {
15
+ debug(message, meta) {
16
+ console.debug(`[HoloScript:DEBUG] ${message}`, meta ?? "");
17
+ }
18
+ info(message, meta) {
19
+ console.info(`[HoloScript:INFO] ${message}`, meta ?? "");
20
+ }
21
+ warn(message, meta) {
22
+ console.warn(`[HoloScript:WARN] ${message}`, meta ?? "");
23
+ }
24
+ error(message, meta) {
25
+ console.error(`[HoloScript:ERROR] ${message}`, meta ?? "");
26
+ }
27
+ };
28
+ var currentLogger = new NoOpLogger();
29
+ function setHoloScriptLogger(logger2) {
30
+ currentLogger = logger2;
31
+ }
32
+ function enableConsoleLogging() {
33
+ currentLogger = new ConsoleLogger();
34
+ }
35
+ function resetLogger() {
36
+ currentLogger = new NoOpLogger();
37
+ }
38
+ var logger = {
39
+ debug: (msg, meta) => currentLogger.debug(msg, meta),
40
+ info: (msg, meta) => currentLogger.info(msg, meta),
41
+ warn: (msg, meta) => currentLogger.warn(msg, meta),
42
+ error: (msg, meta) => currentLogger.error(msg, meta)
43
+ };
44
+
45
+ exports.ConsoleLogger = ConsoleLogger;
46
+ exports.NoOpLogger = NoOpLogger;
47
+ exports.enableConsoleLogging = enableConsoleLogging;
48
+ exports.logger = logger;
49
+ exports.resetLogger = resetLogger;
50
+ exports.setHoloScriptLogger = setHoloScriptLogger;
51
+ //# sourceMappingURL=chunk-3X2EGU7Z.cjs.map
52
+ //# sourceMappingURL=chunk-3X2EGU7Z.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/logger.ts"],"names":["logger"],"mappings":";;;AAaA,IAAM,aAAN,MAA6C;AAAA,EAC3C,KAAA,GAAc;AAAA,EAAC;AAAA,EACf,IAAA,GAAa;AAAA,EAAC;AAAA,EACd,IAAA,GAAa;AAAA,EAAC;AAAA,EACd,KAAA,GAAc;AAAA,EAAC;AACjB;AAEA,IAAM,gBAAN,MAAgD;AAAA,EAC9C,KAAA,CAAM,SAAiB,IAAA,EAAsC;AAC3D,IAAA,OAAA,CAAQ,KAAA,CAAM,CAAA,mBAAA,EAAsB,OAAO,CAAA,CAAA,EAAI,QAAQ,EAAE,CAAA;AAAA,EAC3D;AAAA,EACA,IAAA,CAAK,SAAiB,IAAA,EAAsC;AAC1D,IAAA,OAAA,CAAQ,IAAA,CAAK,CAAA,kBAAA,EAAqB,OAAO,CAAA,CAAA,EAAI,QAAQ,EAAE,CAAA;AAAA,EACzD;AAAA,EACA,IAAA,CAAK,SAAiB,IAAA,EAAsC;AAC1D,IAAA,OAAA,CAAQ,IAAA,CAAK,CAAA,kBAAA,EAAqB,OAAO,CAAA,CAAA,EAAI,QAAQ,EAAE,CAAA;AAAA,EACzD;AAAA,EACA,KAAA,CAAM,SAAiB,IAAA,EAAsC;AAC3D,IAAA,OAAA,CAAQ,KAAA,CAAM,CAAA,mBAAA,EAAsB,OAAO,CAAA,CAAA,EAAI,QAAQ,EAAE,CAAA;AAAA,EAC3D;AACF;AAEA,IAAI,aAAA,GAAkC,IAAI,UAAA,EAAW;AAE9C,SAAS,oBAAoBA,OAAAA,EAAgC;AAClE,EAAA,aAAA,GAAgBA,OAAAA;AAClB;AAEO,SAAS,oBAAA,GAA6B;AAC3C,EAAA,aAAA,GAAgB,IAAI,aAAA,EAAc;AACpC;AAEO,SAAS,WAAA,GAAoB;AAClC,EAAA,aAAA,GAAgB,IAAI,UAAA,EAAW;AACjC;AAEO,IAAM,MAAA,GAA2B;AAAA,EACtC,OAAO,CAAC,GAAA,EAAK,SAAS,aAAA,CAAc,KAAA,CAAM,KAAK,IAAI,CAAA;AAAA,EACnD,MAAM,CAAC,GAAA,EAAK,SAAS,aAAA,CAAc,IAAA,CAAK,KAAK,IAAI,CAAA;AAAA,EACjD,MAAM,CAAC,GAAA,EAAK,SAAS,aAAA,CAAc,IAAA,CAAK,KAAK,IAAI,CAAA;AAAA,EACjD,OAAO,CAAC,GAAA,EAAK,SAAS,aAAA,CAAc,KAAA,CAAM,KAAK,IAAI;AACrD","file":"chunk-3X2EGU7Z.cjs","sourcesContent":["/**\n * @holoscript/core Logger\n *\n * Simple pluggable logger for HoloScript\n */\n\nexport interface HoloScriptLogger {\n debug(message: string, meta?: Record<string, unknown>): void;\n info(message: string, meta?: Record<string, unknown>): void;\n warn(message: string, meta?: Record<string, unknown>): void;\n error(message: string, meta?: Record<string, unknown>): void;\n}\n\nclass NoOpLogger implements HoloScriptLogger {\n debug(): void {}\n info(): void {}\n warn(): void {}\n error(): void {}\n}\n\nclass ConsoleLogger implements HoloScriptLogger {\n debug(message: string, meta?: Record<string, unknown>): void {\n console.debug(`[HoloScript:DEBUG] ${message}`, meta ?? '');\n }\n info(message: string, meta?: Record<string, unknown>): void {\n console.info(`[HoloScript:INFO] ${message}`, meta ?? '');\n }\n warn(message: string, meta?: Record<string, unknown>): void {\n console.warn(`[HoloScript:WARN] ${message}`, meta ?? '');\n }\n error(message: string, meta?: Record<string, unknown>): void {\n console.error(`[HoloScript:ERROR] ${message}`, meta ?? '');\n }\n}\n\nlet currentLogger: HoloScriptLogger = new NoOpLogger();\n\nexport function setHoloScriptLogger(logger: HoloScriptLogger): void {\n currentLogger = logger;\n}\n\nexport function enableConsoleLogging(): void {\n currentLogger = new ConsoleLogger();\n}\n\nexport function resetLogger(): void {\n currentLogger = new NoOpLogger();\n}\n\nexport const logger: HoloScriptLogger = {\n debug: (msg, meta) => currentLogger.debug(msg, meta),\n info: (msg, meta) => currentLogger.info(msg, meta),\n warn: (msg, meta) => currentLogger.warn(msg, meta),\n error: (msg, meta) => currentLogger.error(msg, meta),\n};\n\nexport { NoOpLogger, ConsoleLogger };\n"]}