@octoseq/visualiser 0.1.0-main.8dc1dc3 → 0.1.0-main.96ff69c

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@octoseq/visualiser",
3
- "version": "0.1.0-main.8dc1dc3",
3
+ "version": "0.1.0-main.96ff69c",
4
4
  "description": "WASM-based visualiser for Octoseq",
5
5
  "license": "MIT",
6
6
  "repository": {
@@ -8,6 +8,10 @@ export class WasmVisualiser {
8
8
  * Check if a script is currently loaded.
9
9
  */
10
10
  has_script(): boolean;
11
+ /**
12
+ * Check if a signal variable exists in the current script.
13
+ */
14
+ has_signal(name: string): boolean;
11
15
  /**
12
16
  * Load a Rhai script for controlling the visualiser.
13
17
  * Returns true if the script was loaded successfully.
@@ -89,6 +93,18 @@ export class WasmVisualiser {
89
93
  * - `sample_rate`: Sample rate of the signal.
90
94
  */
91
95
  push_band_signal(band_id: string, band_label: string, feature: string, samples: Float32Array, sample_rate: number): void;
96
+ /**
97
+ * Push a stem-scoped signal for use in scripts.
98
+ * The signal will be available as `inputs.stems[stem_id].{feature}` in Rhai scripts.
99
+ * Stores under both stem_id and stem_label for dual-access support.
100
+ *
101
+ * - `stem_id`: The unique ID of the stem.
102
+ * - `stem_label`: The user-visible label of the stem.
103
+ * - `feature`: Signal type ("energy", "onset", "flux").
104
+ * - `samples`: Signal data.
105
+ * - `sample_rate`: Sample rate of the signal.
106
+ */
107
+ push_stem_signal(stem_id: string, stem_label: string, feature: string, samples: Float32Array, sample_rate: number): void;
92
108
  /**
93
109
  * Set the musical time structure for beat-aware signal processing.
94
110
  * The JSON format matches the TypeScript MusicalTimeStructure type.
@@ -128,11 +144,30 @@ export class WasmVisualiser {
128
144
  * Beat-aware operations will fall back to 120 BPM default.
129
145
  */
130
146
  clear_musical_time(): void;
147
+ /**
148
+ * Clear all stem signals.
149
+ */
150
+ clear_stem_signals(): void;
131
151
  /**
132
152
  * Get frequency bounds for all active bands at a given time.
133
153
  * Returns a JSON array of { bandId, label, lowHz, highHz, enabled } objects.
134
154
  */
135
155
  get_band_bounds_at(time: number): string;
156
+ /**
157
+ * Get all Signal variables from the current script.
158
+ * Returns a JSON array of ScriptSignalInfo objects.
159
+ */
160
+ get_script_signals(): string;
161
+ /**
162
+ * Push a custom signal for use in scripts.
163
+ * The signal will be available as `inputs.customSignals["signal_id"]` in Rhai scripts.
164
+ *
165
+ * - `signal_id`: The unique ID of the custom signal.
166
+ * - `label`: The user-visible label of the signal.
167
+ * - `samples`: Signal data.
168
+ * - `sample_rate`: Sample rate of the signal.
169
+ */
170
+ push_custom_signal(signal_id: string, label: string, samples: Float32Array, sample_rate: number): void;
136
171
  push_rotation_data(samples: Float32Array, sample_rate: number): void;
137
172
  /**
138
173
  * Render with a frame budget timeout.
@@ -157,12 +192,41 @@ export class WasmVisualiser {
157
192
  * Returns true if successful, false if parsing failed.
158
193
  */
159
194
  register_mesh_asset(asset_id: string, obj_content: string): boolean;
195
+ /**
196
+ * Set available stems for script namespace generation.
197
+ * This registers stem IDs and labels so the script engine can generate
198
+ * `inputs.stems["stem_id"]` and `inputs.stems["label"]` accessors.
199
+ *
200
+ * The JSON format should be an array of [id, label] pairs:
201
+ * `[["stem-abc123", "Drums"], ["stem-def456", "Bass"]]`
202
+ *
203
+ * Returns true if successful, false if parsing failed.
204
+ */
205
+ set_available_stems(json: string): boolean;
160
206
  /**
161
207
  * Set the frequency band structure for band-aware processing.
162
208
  * The JSON format matches the TypeScript FrequencyBandStructure type.
163
209
  * Returns true if successful, false if parsing failed.
164
210
  */
165
211
  set_frequency_bands(json: string): boolean;
212
+ /**
213
+ * Analyze a signal chain with localized sampling.
214
+ *
215
+ * Returns JSON with either:
216
+ * - SignalChainAnalysis on success
217
+ * - { "error": "message" } on failure
218
+ *
219
+ * Parameters:
220
+ * - signal_name: Name of the signal variable in the script
221
+ * - center_time: Time to center analysis around (seconds)
222
+ * - window_beats: Number of beats before/after center to sample
223
+ * - sample_count: Number of samples to take
224
+ */
225
+ analyze_signal_chain(signal_name: string, center_time: number, window_beats: number, sample_count: number): string;
226
+ /**
227
+ * Clear all custom signals.
228
+ */
229
+ clear_custom_signals(): void;
166
230
  /**
167
231
  * Get the number of events for a specific band.
168
232
  * Returns 0 if no events are stored for this band.
@@ -173,15 +237,39 @@ export class WasmVisualiser {
173
237
  * Returns a JSON array of strings.
174
238
  */
175
239
  get_band_signal_keys(): string;
240
+ /**
241
+ * Get list of stem keys (IDs and labels) that have signals.
242
+ * Returns a JSON array of strings.
243
+ */
244
+ get_stem_signal_keys(): string;
245
+ /**
246
+ * Check if performance profiling is currently enabled.
247
+ */
248
+ is_profiling_enabled(): boolean;
176
249
  /**
177
250
  * Clear the frequency band structure.
178
251
  */
179
252
  clear_frequency_bands(): void;
253
+ /**
254
+ * Get camera state as JSON for inspector.
255
+ * Returns current position, rotation, target, fov, near, far, mode, and signal flags.
256
+ */
257
+ get_camera_state_json(): string;
258
+ /**
259
+ * Enable or disable performance profiling.
260
+ * When enabled, console timing and collection size logging will be active.
261
+ */
262
+ set_profiling_enabled(enabled: boolean): void;
180
263
  /**
181
264
  * Unregister a mesh asset.
182
265
  * Returns true if the asset was unregistered, false if it didn't exist.
183
266
  */
184
267
  unregister_mesh_asset(asset_id: string): boolean;
268
+ /**
269
+ * Get list of custom signal keys (IDs and labels).
270
+ * Returns a JSON array of strings.
271
+ */
272
+ get_custom_signal_keys(): string;
185
273
  /**
186
274
  * Get the number of events in a named event stream.
187
275
  * Returns 0 if no events are stored for this name.
@@ -206,6 +294,37 @@ export class WasmVisualiser {
206
294
  * Returns a JSON array of objects with id, type, and position fields.
207
295
  */
208
296
  get_entity_positions_json(): string;
297
+ /**
298
+ * Push an authored event stream for script access.
299
+ *
300
+ * The event stream will be available as `inputs.authored["name"]` in Rhai scripts.
301
+ * This is used for user-authored events (promoted or manually created).
302
+ *
303
+ * The JSON format should be an array of event objects with:
304
+ * - time: f32
305
+ * - weight: f32
306
+ * - beat_position: Option<f32>
307
+ * - beat_phase: Option<f32>
308
+ * - cluster_id: Option<u32>
309
+ *
310
+ * Returns true if successful, false if parsing failed.
311
+ */
312
+ push_authored_event_stream(name: string, events_json: string): boolean;
313
+ /**
314
+ * Clear all authored event streams.
315
+ */
316
+ clear_authored_event_streams(): void;
317
+ /**
318
+ * Set available custom signals for script namespace generation.
319
+ * This registers custom signal IDs and labels so the script engine can generate
320
+ * `inputs.customSignals["signal_id"]` accessors.
321
+ *
322
+ * The JSON format should be an array of [id, label] pairs:
323
+ * `[["signal-abc123", "My Signal"], ["signal-def456", "Another Signal"]]`
324
+ *
325
+ * Returns true if successful, false if parsing failed.
326
+ */
327
+ set_available_custom_signals(json: string): boolean;
209
328
  /**
210
329
  * Drain and return any pending structured script diagnostics as JSON.
211
330
  *
@@ -213,6 +332,11 @@ export class WasmVisualiser {
213
332
  * queue so repeated polling does not duplicate messages.
214
333
  */
215
334
  take_script_diagnostics_json(): string;
335
+ /**
336
+ * Get the number of events in an authored event stream.
337
+ * Returns 0 if no events are stored for this name.
338
+ */
339
+ get_authored_event_stream_count(name: string): number;
216
340
  constructor();
217
341
  render(dt: number): void;
218
342
  resize(width: number, height: number): void;
@@ -240,33 +364,47 @@ export interface InitOutput {
240
364
  readonly __wbg_wasmvisualiser_free: (a: number, b: number) => void;
241
365
  readonly create_visualiser: (a: any) => any;
242
366
  readonly get_script_api_metadata_json: () => [number, number];
367
+ readonly wasmvisualiser_analyze_signal_chain: (a: number, b: number, c: number, d: number, e: number, f: number) => [number, number];
368
+ readonly wasmvisualiser_clear_authored_event_streams: (a: number) => void;
243
369
  readonly wasmvisualiser_clear_band_events: (a: number) => void;
244
370
  readonly wasmvisualiser_clear_band_signals: (a: number) => void;
371
+ readonly wasmvisualiser_clear_custom_signals: (a: number) => void;
245
372
  readonly wasmvisualiser_clear_event_streams: (a: number) => void;
246
373
  readonly wasmvisualiser_clear_frequency_bands: (a: number) => void;
247
374
  readonly wasmvisualiser_clear_isolation: (a: number) => void;
248
375
  readonly wasmvisualiser_clear_musical_time: (a: number) => void;
249
376
  readonly wasmvisualiser_clear_signals: (a: number) => void;
377
+ readonly wasmvisualiser_clear_stem_signals: (a: number) => void;
378
+ readonly wasmvisualiser_get_authored_event_stream_count: (a: number, b: number, c: number) => number;
250
379
  readonly wasmvisualiser_get_band_bounds_at: (a: number, b: number) => [number, number];
251
380
  readonly wasmvisualiser_get_band_event_count: (a: number, b: number, c: number) => number;
252
381
  readonly wasmvisualiser_get_band_signal_keys: (a: number) => [number, number];
382
+ readonly wasmvisualiser_get_camera_state_json: (a: number) => [number, number];
253
383
  readonly wasmvisualiser_get_current_vals: (a: number) => [number, number];
384
+ readonly wasmvisualiser_get_custom_signal_keys: (a: number) => [number, number];
254
385
  readonly wasmvisualiser_get_entity_positions_json: (a: number) => [number, number];
255
386
  readonly wasmvisualiser_get_event_stream_count: (a: number, b: number, c: number) => number;
256
387
  readonly wasmvisualiser_get_frequency_band_count: (a: number) => number;
257
388
  readonly wasmvisualiser_get_script_error: (a: number) => [number, number];
389
+ readonly wasmvisualiser_get_script_signals: (a: number) => [number, number];
258
390
  readonly wasmvisualiser_get_signal_names: (a: number) => [number, number];
391
+ readonly wasmvisualiser_get_stem_signal_keys: (a: number) => [number, number];
259
392
  readonly wasmvisualiser_has_frequency_bands: (a: number) => number;
260
393
  readonly wasmvisualiser_has_script: (a: number) => number;
394
+ readonly wasmvisualiser_has_signal: (a: number, b: number, c: number) => number;
395
+ readonly wasmvisualiser_is_profiling_enabled: (a: number) => number;
261
396
  readonly wasmvisualiser_isolate_entity: (a: number, b: bigint) => void;
262
397
  readonly wasmvisualiser_list_mesh_assets: (a: number) => [number, number];
263
398
  readonly wasmvisualiser_load_script: (a: number, b: number, c: number) => number;
264
399
  readonly wasmvisualiser_new: () => number;
400
+ readonly wasmvisualiser_push_authored_event_stream: (a: number, b: number, c: number, d: number, e: number) => number;
265
401
  readonly wasmvisualiser_push_band_events: (a: number, b: number, c: number, d: number, e: number) => number;
266
402
  readonly wasmvisualiser_push_band_signal: (a: number, b: number, c: number, d: number, e: number, f: number, g: number, h: number, i: number, j: number) => void;
403
+ readonly wasmvisualiser_push_custom_signal: (a: number, b: number, c: number, d: number, e: number, f: number, g: number, h: number) => void;
267
404
  readonly wasmvisualiser_push_data: (a: number, b: number, c: number, d: number) => void;
268
405
  readonly wasmvisualiser_push_event_stream: (a: number, b: number, c: number, d: number, e: number) => number;
269
406
  readonly wasmvisualiser_push_signal: (a: number, b: number, c: number, d: number, e: number, f: number) => void;
407
+ readonly wasmvisualiser_push_stem_signal: (a: number, b: number, c: number, d: number, e: number, f: number, g: number, h: number, i: number, j: number) => void;
270
408
  readonly wasmvisualiser_push_zoom_data: (a: number, b: number, c: number, d: number) => void;
271
409
  readonly wasmvisualiser_register_mesh_asset: (a: number, b: number, c: number, d: number, e: number) => number;
272
410
  readonly wasmvisualiser_render: (a: number, b: number) => void;
@@ -274,20 +412,23 @@ export interface InitOutput {
274
412
  readonly wasmvisualiser_resize: (a: number, b: number, c: number) => void;
275
413
  readonly wasmvisualiser_run_analysis: (a: number, b: number, c: number, d: number, e: number) => [number, number];
276
414
  readonly wasmvisualiser_run_analysis_with_events: (a: number, b: number, c: number, d: number, e: number) => [number, number];
415
+ readonly wasmvisualiser_set_available_custom_signals: (a: number, b: number, c: number) => number;
416
+ readonly wasmvisualiser_set_available_stems: (a: number, b: number, c: number) => number;
277
417
  readonly wasmvisualiser_set_debug_options: (a: number, b: number, c: number) => void;
278
418
  readonly wasmvisualiser_set_frequency_bands: (a: number, b: number, c: number) => number;
279
419
  readonly wasmvisualiser_set_musical_time: (a: number, b: number, c: number) => number;
420
+ readonly wasmvisualiser_set_profiling_enabled: (a: number, b: number) => void;
280
421
  readonly wasmvisualiser_set_sigmoid_k: (a: number, b: number) => void;
281
422
  readonly wasmvisualiser_set_time: (a: number, b: number) => void;
282
423
  readonly wasmvisualiser_take_script_diagnostics_json: (a: number) => [number, number];
283
424
  readonly wasmvisualiser_unregister_mesh_asset: (a: number, b: number, c: number) => number;
284
- readonly init_panic_hook: () => void;
285
425
  readonly wasmvisualiser_push_rotation_data: (a: number, b: number, c: number, d: number) => void;
286
- readonly wasm_bindgen__convert__closures_____invoke__h9d1c5a23ecfcd5c8: (a: number, b: number, c: any) => void;
287
- readonly wasm_bindgen__closure__destroy__heb49a8f426ac2d2e: (a: number, b: number) => void;
288
- readonly wasm_bindgen__convert__closures_____invoke__h53437a38721e89f7: (a: number, b: number, c: any) => void;
289
- readonly wasm_bindgen__closure__destroy__hf5eaa61ced318e08: (a: number, b: number) => void;
290
- readonly wasm_bindgen__convert__closures_____invoke__h320f3d825d3712ba: (a: number, b: number, c: any, d: any) => void;
426
+ readonly init_panic_hook: () => void;
427
+ readonly wasm_bindgen__convert__closures_____invoke__hd456749e88b4d731: (a: number, b: number, c: any) => void;
428
+ readonly wasm_bindgen__closure__destroy__hff2bb8e37b7072b2: (a: number, b: number) => void;
429
+ readonly wasm_bindgen__convert__closures_____invoke__h09705603bb35b975: (a: number, b: number, c: any) => void;
430
+ readonly wasm_bindgen__closure__destroy__h6518d8d5fffe1051: (a: number, b: number) => void;
431
+ readonly wasm_bindgen__convert__closures_____invoke__h12a8c25a05856851: (a: number, b: number, c: any, d: any) => void;
291
432
  readonly __wbindgen_malloc: (a: number, b: number) => number;
292
433
  readonly __wbindgen_realloc: (a: number, b: number, c: number, d: number) => number;
293
434
  readonly __wbindgen_exn_store: (a: number) => void;
package/pkg/visualiser.js CHANGED
@@ -241,16 +241,16 @@ if (!('encodeInto' in cachedTextEncoder)) {
241
241
 
242
242
  let WASM_VECTOR_LEN = 0;
243
243
 
244
- function wasm_bindgen__convert__closures_____invoke__h9d1c5a23ecfcd5c8(arg0, arg1, arg2) {
245
- wasm.wasm_bindgen__convert__closures_____invoke__h9d1c5a23ecfcd5c8(arg0, arg1, arg2);
244
+ function wasm_bindgen__convert__closures_____invoke__hd456749e88b4d731(arg0, arg1, arg2) {
245
+ wasm.wasm_bindgen__convert__closures_____invoke__hd456749e88b4d731(arg0, arg1, arg2);
246
246
  }
247
247
 
248
- function wasm_bindgen__convert__closures_____invoke__h53437a38721e89f7(arg0, arg1, arg2) {
249
- wasm.wasm_bindgen__convert__closures_____invoke__h53437a38721e89f7(arg0, arg1, arg2);
248
+ function wasm_bindgen__convert__closures_____invoke__h09705603bb35b975(arg0, arg1, arg2) {
249
+ wasm.wasm_bindgen__convert__closures_____invoke__h09705603bb35b975(arg0, arg1, arg2);
250
250
  }
251
251
 
252
- function wasm_bindgen__convert__closures_____invoke__h320f3d825d3712ba(arg0, arg1, arg2, arg3) {
253
- wasm.wasm_bindgen__convert__closures_____invoke__h320f3d825d3712ba(arg0, arg1, arg2, arg3);
252
+ function wasm_bindgen__convert__closures_____invoke__h12a8c25a05856851(arg0, arg1, arg2, arg3) {
253
+ wasm.wasm_bindgen__convert__closures_____invoke__h12a8c25a05856851(arg0, arg1, arg2, arg3);
254
254
  }
255
255
 
256
256
  const __wbindgen_enum_GpuCompilationMessageType = ["error", "warning", "info"];
@@ -293,6 +293,17 @@ export class WasmVisualiser {
293
293
  const ret = wasm.wasmvisualiser_has_script(this.__wbg_ptr);
294
294
  return ret !== 0;
295
295
  }
296
+ /**
297
+ * Check if a signal variable exists in the current script.
298
+ * @param {string} name
299
+ * @returns {boolean}
300
+ */
301
+ has_signal(name) {
302
+ const ptr0 = passStringToWasm0(name, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
303
+ const len0 = WASM_VECTOR_LEN;
304
+ const ret = wasm.wasmvisualiser_has_signal(this.__wbg_ptr, ptr0, len0);
305
+ return ret !== 0;
306
+ }
296
307
  /**
297
308
  * Load a Rhai script for controlling the visualiser.
298
309
  * Returns true if the script was loaded successfully.
@@ -491,6 +502,33 @@ export class WasmVisualiser {
491
502
  const len3 = WASM_VECTOR_LEN;
492
503
  wasm.wasmvisualiser_push_band_signal(this.__wbg_ptr, ptr0, len0, ptr1, len1, ptr2, len2, ptr3, len3, sample_rate);
493
504
  }
505
+ /**
506
+ * Push a stem-scoped signal for use in scripts.
507
+ * The signal will be available as `inputs.stems[stem_id].{feature}` in Rhai scripts.
508
+ * Stores under both stem_id and stem_label for dual-access support.
509
+ *
510
+ * - `stem_id`: The unique ID of the stem.
511
+ * - `stem_label`: The user-visible label of the stem.
512
+ * - `feature`: Signal type ("energy", "onset", "flux").
513
+ * - `samples`: Signal data.
514
+ * - `sample_rate`: Sample rate of the signal.
515
+ * @param {string} stem_id
516
+ * @param {string} stem_label
517
+ * @param {string} feature
518
+ * @param {Float32Array} samples
519
+ * @param {number} sample_rate
520
+ */
521
+ push_stem_signal(stem_id, stem_label, feature, samples, sample_rate) {
522
+ const ptr0 = passStringToWasm0(stem_id, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
523
+ const len0 = WASM_VECTOR_LEN;
524
+ const ptr1 = passStringToWasm0(stem_label, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
525
+ const len1 = WASM_VECTOR_LEN;
526
+ const ptr2 = passStringToWasm0(feature, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
527
+ const len2 = WASM_VECTOR_LEN;
528
+ const ptr3 = passArrayF32ToWasm0(samples, wasm.__wbindgen_malloc);
529
+ const len3 = WASM_VECTOR_LEN;
530
+ wasm.wasmvisualiser_push_stem_signal(this.__wbg_ptr, ptr0, len0, ptr1, len1, ptr2, len2, ptr3, len3, sample_rate);
531
+ }
494
532
  /**
495
533
  * Set the musical time structure for beat-aware signal processing.
496
534
  * The JSON format matches the TypeScript MusicalTimeStructure type.
@@ -557,6 +595,12 @@ export class WasmVisualiser {
557
595
  clear_musical_time() {
558
596
  wasm.wasmvisualiser_clear_musical_time(this.__wbg_ptr);
559
597
  }
598
+ /**
599
+ * Clear all stem signals.
600
+ */
601
+ clear_stem_signals() {
602
+ wasm.wasmvisualiser_clear_stem_signals(this.__wbg_ptr);
603
+ }
560
604
  /**
561
605
  * Get frequency bounds for all active bands at a given time.
562
606
  * Returns a JSON array of { bandId, label, lowHz, highHz, enabled } objects.
@@ -575,6 +619,45 @@ export class WasmVisualiser {
575
619
  wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
576
620
  }
577
621
  }
622
+ /**
623
+ * Get all Signal variables from the current script.
624
+ * Returns a JSON array of ScriptSignalInfo objects.
625
+ * @returns {string}
626
+ */
627
+ get_script_signals() {
628
+ let deferred1_0;
629
+ let deferred1_1;
630
+ try {
631
+ const ret = wasm.wasmvisualiser_get_script_signals(this.__wbg_ptr);
632
+ deferred1_0 = ret[0];
633
+ deferred1_1 = ret[1];
634
+ return getStringFromWasm0(ret[0], ret[1]);
635
+ } finally {
636
+ wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
637
+ }
638
+ }
639
+ /**
640
+ * Push a custom signal for use in scripts.
641
+ * The signal will be available as `inputs.customSignals["signal_id"]` in Rhai scripts.
642
+ *
643
+ * - `signal_id`: The unique ID of the custom signal.
644
+ * - `label`: The user-visible label of the signal.
645
+ * - `samples`: Signal data.
646
+ * - `sample_rate`: Sample rate of the signal.
647
+ * @param {string} signal_id
648
+ * @param {string} label
649
+ * @param {Float32Array} samples
650
+ * @param {number} sample_rate
651
+ */
652
+ push_custom_signal(signal_id, label, samples, sample_rate) {
653
+ const ptr0 = passStringToWasm0(signal_id, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
654
+ const len0 = WASM_VECTOR_LEN;
655
+ const ptr1 = passStringToWasm0(label, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
656
+ const len1 = WASM_VECTOR_LEN;
657
+ const ptr2 = passArrayF32ToWasm0(samples, wasm.__wbindgen_malloc);
658
+ const len2 = WASM_VECTOR_LEN;
659
+ wasm.wasmvisualiser_push_custom_signal(this.__wbg_ptr, ptr0, len0, ptr1, len1, ptr2, len2, sample_rate);
660
+ }
578
661
  /**
579
662
  * @param {Float32Array} samples
580
663
  * @param {number} sample_rate
@@ -629,6 +712,24 @@ export class WasmVisualiser {
629
712
  const ret = wasm.wasmvisualiser_register_mesh_asset(this.__wbg_ptr, ptr0, len0, ptr1, len1);
630
713
  return ret !== 0;
631
714
  }
715
+ /**
716
+ * Set available stems for script namespace generation.
717
+ * This registers stem IDs and labels so the script engine can generate
718
+ * `inputs.stems["stem_id"]` and `inputs.stems["label"]` accessors.
719
+ *
720
+ * The JSON format should be an array of [id, label] pairs:
721
+ * `[["stem-abc123", "Drums"], ["stem-def456", "Bass"]]`
722
+ *
723
+ * Returns true if successful, false if parsing failed.
724
+ * @param {string} json
725
+ * @returns {boolean}
726
+ */
727
+ set_available_stems(json) {
728
+ const ptr0 = passStringToWasm0(json, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
729
+ const len0 = WASM_VECTOR_LEN;
730
+ const ret = wasm.wasmvisualiser_set_available_stems(this.__wbg_ptr, ptr0, len0);
731
+ return ret !== 0;
732
+ }
632
733
  /**
633
734
  * Set the frequency band structure for band-aware processing.
634
735
  * The JSON format matches the TypeScript FrequencyBandStructure type.
@@ -642,6 +743,44 @@ export class WasmVisualiser {
642
743
  const ret = wasm.wasmvisualiser_set_frequency_bands(this.__wbg_ptr, ptr0, len0);
643
744
  return ret !== 0;
644
745
  }
746
+ /**
747
+ * Analyze a signal chain with localized sampling.
748
+ *
749
+ * Returns JSON with either:
750
+ * - SignalChainAnalysis on success
751
+ * - { "error": "message" } on failure
752
+ *
753
+ * Parameters:
754
+ * - signal_name: Name of the signal variable in the script
755
+ * - center_time: Time to center analysis around (seconds)
756
+ * - window_beats: Number of beats before/after center to sample
757
+ * - sample_count: Number of samples to take
758
+ * @param {string} signal_name
759
+ * @param {number} center_time
760
+ * @param {number} window_beats
761
+ * @param {number} sample_count
762
+ * @returns {string}
763
+ */
764
+ analyze_signal_chain(signal_name, center_time, window_beats, sample_count) {
765
+ let deferred2_0;
766
+ let deferred2_1;
767
+ try {
768
+ const ptr0 = passStringToWasm0(signal_name, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
769
+ const len0 = WASM_VECTOR_LEN;
770
+ const ret = wasm.wasmvisualiser_analyze_signal_chain(this.__wbg_ptr, ptr0, len0, center_time, window_beats, sample_count);
771
+ deferred2_0 = ret[0];
772
+ deferred2_1 = ret[1];
773
+ return getStringFromWasm0(ret[0], ret[1]);
774
+ } finally {
775
+ wasm.__wbindgen_free(deferred2_0, deferred2_1, 1);
776
+ }
777
+ }
778
+ /**
779
+ * Clear all custom signals.
780
+ */
781
+ clear_custom_signals() {
782
+ wasm.wasmvisualiser_clear_custom_signals(this.__wbg_ptr);
783
+ }
645
784
  /**
646
785
  * Get the number of events for a specific band.
647
786
  * Returns 0 if no events are stored for this band.
@@ -671,12 +810,62 @@ export class WasmVisualiser {
671
810
  wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
672
811
  }
673
812
  }
813
+ /**
814
+ * Get list of stem keys (IDs and labels) that have signals.
815
+ * Returns a JSON array of strings.
816
+ * @returns {string}
817
+ */
818
+ get_stem_signal_keys() {
819
+ let deferred1_0;
820
+ let deferred1_1;
821
+ try {
822
+ const ret = wasm.wasmvisualiser_get_stem_signal_keys(this.__wbg_ptr);
823
+ deferred1_0 = ret[0];
824
+ deferred1_1 = ret[1];
825
+ return getStringFromWasm0(ret[0], ret[1]);
826
+ } finally {
827
+ wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
828
+ }
829
+ }
830
+ /**
831
+ * Check if performance profiling is currently enabled.
832
+ * @returns {boolean}
833
+ */
834
+ is_profiling_enabled() {
835
+ const ret = wasm.wasmvisualiser_is_profiling_enabled(this.__wbg_ptr);
836
+ return ret !== 0;
837
+ }
674
838
  /**
675
839
  * Clear the frequency band structure.
676
840
  */
677
841
  clear_frequency_bands() {
678
842
  wasm.wasmvisualiser_clear_frequency_bands(this.__wbg_ptr);
679
843
  }
844
+ /**
845
+ * Get camera state as JSON for inspector.
846
+ * Returns current position, rotation, target, fov, near, far, mode, and signal flags.
847
+ * @returns {string}
848
+ */
849
+ get_camera_state_json() {
850
+ let deferred1_0;
851
+ let deferred1_1;
852
+ try {
853
+ const ret = wasm.wasmvisualiser_get_camera_state_json(this.__wbg_ptr);
854
+ deferred1_0 = ret[0];
855
+ deferred1_1 = ret[1];
856
+ return getStringFromWasm0(ret[0], ret[1]);
857
+ } finally {
858
+ wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
859
+ }
860
+ }
861
+ /**
862
+ * Enable or disable performance profiling.
863
+ * When enabled, console timing and collection size logging will be active.
864
+ * @param {boolean} enabled
865
+ */
866
+ set_profiling_enabled(enabled) {
867
+ wasm.wasmvisualiser_set_profiling_enabled(this.__wbg_ptr, enabled);
868
+ }
680
869
  /**
681
870
  * Unregister a mesh asset.
682
871
  * Returns true if the asset was unregistered, false if it didn't exist.
@@ -689,6 +878,23 @@ export class WasmVisualiser {
689
878
  const ret = wasm.wasmvisualiser_unregister_mesh_asset(this.__wbg_ptr, ptr0, len0);
690
879
  return ret !== 0;
691
880
  }
881
+ /**
882
+ * Get list of custom signal keys (IDs and labels).
883
+ * Returns a JSON array of strings.
884
+ * @returns {string}
885
+ */
886
+ get_custom_signal_keys() {
887
+ let deferred1_0;
888
+ let deferred1_1;
889
+ try {
890
+ const ret = wasm.wasmvisualiser_get_custom_signal_keys(this.__wbg_ptr);
891
+ deferred1_0 = ret[0];
892
+ deferred1_1 = ret[1];
893
+ return getStringFromWasm0(ret[0], ret[1]);
894
+ } finally {
895
+ wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
896
+ }
897
+ }
692
898
  /**
693
899
  * Get the number of events in a named event stream.
694
900
  * Returns 0 if no events are stored for this name.
@@ -753,6 +959,56 @@ export class WasmVisualiser {
753
959
  wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
754
960
  }
755
961
  }
962
+ /**
963
+ * Push an authored event stream for script access.
964
+ *
965
+ * The event stream will be available as `inputs.authored["name"]` in Rhai scripts.
966
+ * This is used for user-authored events (promoted or manually created).
967
+ *
968
+ * The JSON format should be an array of event objects with:
969
+ * - time: f32
970
+ * - weight: f32
971
+ * - beat_position: Option<f32>
972
+ * - beat_phase: Option<f32>
973
+ * - cluster_id: Option<u32>
974
+ *
975
+ * Returns true if successful, false if parsing failed.
976
+ * @param {string} name
977
+ * @param {string} events_json
978
+ * @returns {boolean}
979
+ */
980
+ push_authored_event_stream(name, events_json) {
981
+ const ptr0 = passStringToWasm0(name, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
982
+ const len0 = WASM_VECTOR_LEN;
983
+ const ptr1 = passStringToWasm0(events_json, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
984
+ const len1 = WASM_VECTOR_LEN;
985
+ const ret = wasm.wasmvisualiser_push_authored_event_stream(this.__wbg_ptr, ptr0, len0, ptr1, len1);
986
+ return ret !== 0;
987
+ }
988
+ /**
989
+ * Clear all authored event streams.
990
+ */
991
+ clear_authored_event_streams() {
992
+ wasm.wasmvisualiser_clear_authored_event_streams(this.__wbg_ptr);
993
+ }
994
+ /**
995
+ * Set available custom signals for script namespace generation.
996
+ * This registers custom signal IDs and labels so the script engine can generate
997
+ * `inputs.customSignals["signal_id"]` accessors.
998
+ *
999
+ * The JSON format should be an array of [id, label] pairs:
1000
+ * `[["signal-abc123", "My Signal"], ["signal-def456", "Another Signal"]]`
1001
+ *
1002
+ * Returns true if successful, false if parsing failed.
1003
+ * @param {string} json
1004
+ * @returns {boolean}
1005
+ */
1006
+ set_available_custom_signals(json) {
1007
+ const ptr0 = passStringToWasm0(json, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
1008
+ const len0 = WASM_VECTOR_LEN;
1009
+ const ret = wasm.wasmvisualiser_set_available_custom_signals(this.__wbg_ptr, ptr0, len0);
1010
+ return ret !== 0;
1011
+ }
756
1012
  /**
757
1013
  * Drain and return any pending structured script diagnostics as JSON.
758
1014
  *
@@ -772,6 +1028,18 @@ export class WasmVisualiser {
772
1028
  wasm.__wbindgen_free(deferred1_0, deferred1_1, 1);
773
1029
  }
774
1030
  }
1031
+ /**
1032
+ * Get the number of events in an authored event stream.
1033
+ * Returns 0 if no events are stored for this name.
1034
+ * @param {string} name
1035
+ * @returns {number}
1036
+ */
1037
+ get_authored_event_stream_count(name) {
1038
+ const ptr0 = passStringToWasm0(name, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
1039
+ const len0 = WASM_VECTOR_LEN;
1040
+ const ret = wasm.wasmvisualiser_get_authored_event_stream_count(this.__wbg_ptr, ptr0, len0);
1041
+ return ret >>> 0;
1042
+ }
775
1043
  constructor() {
776
1044
  const ret = wasm.wasmvisualiser_new();
777
1045
  this.__wbg_ptr = ret >>> 0;
@@ -1459,7 +1727,7 @@ function __wbg_get_imports() {
1459
1727
  const a = state0.a;
1460
1728
  state0.a = 0;
1461
1729
  try {
1462
- return wasm_bindgen__convert__closures_____invoke__h320f3d825d3712ba(a, state0.b, arg0, arg1);
1730
+ return wasm_bindgen__convert__closures_____invoke__h12a8c25a05856851(a, state0.b, arg0, arg1);
1463
1731
  } finally {
1464
1732
  state0.a = a;
1465
1733
  }
@@ -1665,6 +1933,12 @@ function __wbg_get_imports() {
1665
1933
  const ret = arg0.then(arg1);
1666
1934
  return ret;
1667
1935
  };
1936
+ imports.wbg.__wbg_timeEnd_46ed224117e5f2d2 = function(arg0, arg1) {
1937
+ console.timeEnd(getStringFromWasm0(arg0, arg1));
1938
+ };
1939
+ imports.wbg.__wbg_time_c49415b636fbbf3f = function(arg0, arg1) {
1940
+ console.time(getStringFromWasm0(arg0, arg1));
1941
+ };
1668
1942
  imports.wbg.__wbg_type_c0d5d83032e9858a = function(arg0) {
1669
1943
  const ret = arg0.type;
1670
1944
  return (__wbindgen_enum_GpuCompilationMessageType.indexOf(ret) + 1 || 4) - 1;
@@ -1702,14 +1976,14 @@ function __wbg_get_imports() {
1702
1976
  const ret = getStringFromWasm0(arg0, arg1);
1703
1977
  return ret;
1704
1978
  };
1705
- imports.wbg.__wbindgen_cast_3382faf1314a867c = function(arg0, arg1) {
1706
- // Cast intrinsic for `Closure(Closure { dtor_idx: 2460, function: Function { arguments: [NamedExternref("GPUUncapturedErrorEvent")], shim_idx: 2461, ret: Unit, inner_ret: Some(Unit) }, mutable: true }) -> Externref`.
1707
- const ret = makeMutClosure(arg0, arg1, wasm.wasm_bindgen__closure__destroy__heb49a8f426ac2d2e, wasm_bindgen__convert__closures_____invoke__h9d1c5a23ecfcd5c8);
1979
+ imports.wbg.__wbindgen_cast_ad7098fabcb3be64 = function(arg0, arg1) {
1980
+ // Cast intrinsic for `Closure(Closure { dtor_idx: 3454, function: Function { arguments: [Externref], shim_idx: 3455, ret: Unit, inner_ret: Some(Unit) }, mutable: true }) -> Externref`.
1981
+ const ret = makeMutClosure(arg0, arg1, wasm.wasm_bindgen__closure__destroy__hff2bb8e37b7072b2, wasm_bindgen__convert__closures_____invoke__hd456749e88b4d731);
1708
1982
  return ret;
1709
1983
  };
1710
- imports.wbg.__wbindgen_cast_81075635f0fa4021 = function(arg0, arg1) {
1711
- // Cast intrinsic for `Closure(Closure { dtor_idx: 2592, function: Function { arguments: [Externref], shim_idx: 2593, ret: Unit, inner_ret: Some(Unit) }, mutable: true }) -> Externref`.
1712
- const ret = makeMutClosure(arg0, arg1, wasm.wasm_bindgen__closure__destroy__hf5eaa61ced318e08, wasm_bindgen__convert__closures_____invoke__h53437a38721e89f7);
1984
+ imports.wbg.__wbindgen_cast_b71f11108f0008f4 = function(arg0, arg1) {
1985
+ // Cast intrinsic for `Closure(Closure { dtor_idx: 3445, function: Function { arguments: [NamedExternref("GPUUncapturedErrorEvent")], shim_idx: 3446, ret: Unit, inner_ret: Some(Unit) }, mutable: true }) -> Externref`.
1986
+ const ret = makeMutClosure(arg0, arg1, wasm.wasm_bindgen__closure__destroy__h6518d8d5fffe1051, wasm_bindgen__convert__closures_____invoke__h09705603bb35b975);
1713
1987
  return ret;
1714
1988
  };
1715
1989
  imports.wbg.__wbindgen_cast_cb9088102bce6b30 = function(arg0, arg1) {
Binary file
@@ -4,33 +4,47 @@ export const memory: WebAssembly.Memory;
4
4
  export const __wbg_wasmvisualiser_free: (a: number, b: number) => void;
5
5
  export const create_visualiser: (a: any) => any;
6
6
  export const get_script_api_metadata_json: () => [number, number];
7
+ export const wasmvisualiser_analyze_signal_chain: (a: number, b: number, c: number, d: number, e: number, f: number) => [number, number];
8
+ export const wasmvisualiser_clear_authored_event_streams: (a: number) => void;
7
9
  export const wasmvisualiser_clear_band_events: (a: number) => void;
8
10
  export const wasmvisualiser_clear_band_signals: (a: number) => void;
11
+ export const wasmvisualiser_clear_custom_signals: (a: number) => void;
9
12
  export const wasmvisualiser_clear_event_streams: (a: number) => void;
10
13
  export const wasmvisualiser_clear_frequency_bands: (a: number) => void;
11
14
  export const wasmvisualiser_clear_isolation: (a: number) => void;
12
15
  export const wasmvisualiser_clear_musical_time: (a: number) => void;
13
16
  export const wasmvisualiser_clear_signals: (a: number) => void;
17
+ export const wasmvisualiser_clear_stem_signals: (a: number) => void;
18
+ export const wasmvisualiser_get_authored_event_stream_count: (a: number, b: number, c: number) => number;
14
19
  export const wasmvisualiser_get_band_bounds_at: (a: number, b: number) => [number, number];
15
20
  export const wasmvisualiser_get_band_event_count: (a: number, b: number, c: number) => number;
16
21
  export const wasmvisualiser_get_band_signal_keys: (a: number) => [number, number];
22
+ export const wasmvisualiser_get_camera_state_json: (a: number) => [number, number];
17
23
  export const wasmvisualiser_get_current_vals: (a: number) => [number, number];
24
+ export const wasmvisualiser_get_custom_signal_keys: (a: number) => [number, number];
18
25
  export const wasmvisualiser_get_entity_positions_json: (a: number) => [number, number];
19
26
  export const wasmvisualiser_get_event_stream_count: (a: number, b: number, c: number) => number;
20
27
  export const wasmvisualiser_get_frequency_band_count: (a: number) => number;
21
28
  export const wasmvisualiser_get_script_error: (a: number) => [number, number];
29
+ export const wasmvisualiser_get_script_signals: (a: number) => [number, number];
22
30
  export const wasmvisualiser_get_signal_names: (a: number) => [number, number];
31
+ export const wasmvisualiser_get_stem_signal_keys: (a: number) => [number, number];
23
32
  export const wasmvisualiser_has_frequency_bands: (a: number) => number;
24
33
  export const wasmvisualiser_has_script: (a: number) => number;
34
+ export const wasmvisualiser_has_signal: (a: number, b: number, c: number) => number;
35
+ export const wasmvisualiser_is_profiling_enabled: (a: number) => number;
25
36
  export const wasmvisualiser_isolate_entity: (a: number, b: bigint) => void;
26
37
  export const wasmvisualiser_list_mesh_assets: (a: number) => [number, number];
27
38
  export const wasmvisualiser_load_script: (a: number, b: number, c: number) => number;
28
39
  export const wasmvisualiser_new: () => number;
40
+ export const wasmvisualiser_push_authored_event_stream: (a: number, b: number, c: number, d: number, e: number) => number;
29
41
  export const wasmvisualiser_push_band_events: (a: number, b: number, c: number, d: number, e: number) => number;
30
42
  export const wasmvisualiser_push_band_signal: (a: number, b: number, c: number, d: number, e: number, f: number, g: number, h: number, i: number, j: number) => void;
43
+ export const wasmvisualiser_push_custom_signal: (a: number, b: number, c: number, d: number, e: number, f: number, g: number, h: number) => void;
31
44
  export const wasmvisualiser_push_data: (a: number, b: number, c: number, d: number) => void;
32
45
  export const wasmvisualiser_push_event_stream: (a: number, b: number, c: number, d: number, e: number) => number;
33
46
  export const wasmvisualiser_push_signal: (a: number, b: number, c: number, d: number, e: number, f: number) => void;
47
+ export const wasmvisualiser_push_stem_signal: (a: number, b: number, c: number, d: number, e: number, f: number, g: number, h: number, i: number, j: number) => void;
34
48
  export const wasmvisualiser_push_zoom_data: (a: number, b: number, c: number, d: number) => void;
35
49
  export const wasmvisualiser_register_mesh_asset: (a: number, b: number, c: number, d: number, e: number) => number;
36
50
  export const wasmvisualiser_render: (a: number, b: number) => void;
@@ -38,20 +52,23 @@ export const wasmvisualiser_render_with_budget: (a: number, b: number, c: number
38
52
  export const wasmvisualiser_resize: (a: number, b: number, c: number) => void;
39
53
  export const wasmvisualiser_run_analysis: (a: number, b: number, c: number, d: number, e: number) => [number, number];
40
54
  export const wasmvisualiser_run_analysis_with_events: (a: number, b: number, c: number, d: number, e: number) => [number, number];
55
+ export const wasmvisualiser_set_available_custom_signals: (a: number, b: number, c: number) => number;
56
+ export const wasmvisualiser_set_available_stems: (a: number, b: number, c: number) => number;
41
57
  export const wasmvisualiser_set_debug_options: (a: number, b: number, c: number) => void;
42
58
  export const wasmvisualiser_set_frequency_bands: (a: number, b: number, c: number) => number;
43
59
  export const wasmvisualiser_set_musical_time: (a: number, b: number, c: number) => number;
60
+ export const wasmvisualiser_set_profiling_enabled: (a: number, b: number) => void;
44
61
  export const wasmvisualiser_set_sigmoid_k: (a: number, b: number) => void;
45
62
  export const wasmvisualiser_set_time: (a: number, b: number) => void;
46
63
  export const wasmvisualiser_take_script_diagnostics_json: (a: number) => [number, number];
47
64
  export const wasmvisualiser_unregister_mesh_asset: (a: number, b: number, c: number) => number;
48
- export const init_panic_hook: () => void;
49
65
  export const wasmvisualiser_push_rotation_data: (a: number, b: number, c: number, d: number) => void;
50
- export const wasm_bindgen__convert__closures_____invoke__h9d1c5a23ecfcd5c8: (a: number, b: number, c: any) => void;
51
- export const wasm_bindgen__closure__destroy__heb49a8f426ac2d2e: (a: number, b: number) => void;
52
- export const wasm_bindgen__convert__closures_____invoke__h53437a38721e89f7: (a: number, b: number, c: any) => void;
53
- export const wasm_bindgen__closure__destroy__hf5eaa61ced318e08: (a: number, b: number) => void;
54
- export const wasm_bindgen__convert__closures_____invoke__h320f3d825d3712ba: (a: number, b: number, c: any, d: any) => void;
66
+ export const init_panic_hook: () => void;
67
+ export const wasm_bindgen__convert__closures_____invoke__hd456749e88b4d731: (a: number, b: number, c: any) => void;
68
+ export const wasm_bindgen__closure__destroy__hff2bb8e37b7072b2: (a: number, b: number) => void;
69
+ export const wasm_bindgen__convert__closures_____invoke__h09705603bb35b975: (a: number, b: number, c: any) => void;
70
+ export const wasm_bindgen__closure__destroy__h6518d8d5fffe1051: (a: number, b: number) => void;
71
+ export const wasm_bindgen__convert__closures_____invoke__h12a8c25a05856851: (a: number, b: number, c: any, d: any) => void;
55
72
  export const __wbindgen_malloc: (a: number, b: number) => number;
56
73
  export const __wbindgen_realloc: (a: number, b: number, c: number, d: number) => number;
57
74
  export const __wbindgen_exn_store: (a: number) => void;