@devaloop/devalang 0.0.1-beta.3 → 0.1.2

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 (346) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +251 -221
  3. package/out-tsc/api.d.ts +180 -0
  4. package/out-tsc/api.d.ts.map +1 -0
  5. package/out-tsc/api.js +286 -0
  6. package/out-tsc/api.js.map +1 -0
  7. package/out-tsc/bin/index.d.ts +12 -0
  8. package/out-tsc/bin/index.d.ts.map +1 -0
  9. package/out-tsc/bin/index.js +20 -54
  10. package/out-tsc/bin/index.js.map +1 -0
  11. package/out-tsc/examples/basic-usage.d.ts +8 -0
  12. package/out-tsc/examples/basic-usage.d.ts.map +1 -0
  13. package/out-tsc/examples/basic-usage.js +113 -0
  14. package/out-tsc/examples/basic-usage.js.map +1 -0
  15. package/out-tsc/index.d.ts +19 -5
  16. package/out-tsc/index.d.ts.map +1 -0
  17. package/out-tsc/index.js +24 -6
  18. package/out-tsc/index.js.map +1 -0
  19. package/out-tsc/scripts/copy-wasm-dts.d.ts +7 -0
  20. package/out-tsc/scripts/copy-wasm-dts.d.ts.map +1 -0
  21. package/out-tsc/scripts/copy-wasm-dts.js +36 -32
  22. package/out-tsc/scripts/copy-wasm-dts.js.map +1 -0
  23. package/out-tsc/scripts/postinstall.d.ts +1 -0
  24. package/out-tsc/scripts/postinstall.d.ts.map +1 -0
  25. package/out-tsc/scripts/postinstall.js +4 -1
  26. package/out-tsc/scripts/postinstall.js.map +1 -0
  27. package/out-tsc/scripts/version/bump.d.ts +5 -1
  28. package/out-tsc/scripts/version/bump.d.ts.map +1 -0
  29. package/out-tsc/scripts/version/bump.js +122 -44
  30. package/out-tsc/scripts/version/bump.js.map +1 -0
  31. package/out-tsc/scripts/version/fetch.d.ts +12 -1
  32. package/out-tsc/scripts/version/fetch.d.ts.map +1 -0
  33. package/out-tsc/scripts/version/fetch.js +68 -24
  34. package/out-tsc/scripts/version/fetch.js.map +1 -0
  35. package/out-tsc/scripts/version/index.d.ts +6 -0
  36. package/out-tsc/scripts/version/index.d.ts.map +1 -0
  37. package/out-tsc/scripts/version/index.js +44 -22
  38. package/out-tsc/scripts/version/index.js.map +1 -0
  39. package/out-tsc/scripts/version/sync.d.ts +5 -1
  40. package/out-tsc/scripts/version/sync.d.ts.map +1 -0
  41. package/out-tsc/scripts/version/sync.js +95 -29
  42. package/out-tsc/scripts/version/sync.js.map +1 -0
  43. package/out-tsc/types.d.ts +68 -0
  44. package/out-tsc/types.d.ts.map +1 -0
  45. package/out-tsc/{core/types/value.js → types.js} +4 -0
  46. package/out-tsc/types.js.map +1 -0
  47. package/out-tsc/wasm.d.ts +8 -0
  48. package/out-tsc/wasm.d.ts.map +1 -0
  49. package/out-tsc/{core/index.js → wasm.js} +9 -6
  50. package/out-tsc/wasm.js.map +1 -0
  51. package/package.json +42 -42
  52. package/.cargo/config.toml +0 -2
  53. package/.devalang +0 -9
  54. package/.github/workflows/ci.yml +0 -103
  55. package/Cargo.toml +0 -84
  56. package/docs/CHANGELOG.md +0 -622
  57. package/docs/CONTRIBUTING.md +0 -101
  58. package/docs/ROADMAP.md +0 -38
  59. package/docs/TODO.md +0 -71
  60. package/examples/automation.deva +0 -42
  61. package/examples/bank.deva +0 -7
  62. package/examples/bus.deva +0 -10
  63. package/examples/chain.deva +0 -19
  64. package/examples/condition.deva +0 -20
  65. package/examples/duration.deva +0 -9
  66. package/examples/effect.deva +0 -2
  67. package/examples/events.deva +0 -12
  68. package/examples/filter.deva +0 -11
  69. package/examples/function.deva +0 -15
  70. package/examples/group.deva +0 -12
  71. package/examples/index.deva +0 -63
  72. package/examples/lfo.deva +0 -9
  73. package/examples/loop.deva +0 -10
  74. package/examples/pattern.deva +0 -8
  75. package/examples/plugin.deva +0 -16
  76. package/examples/routing.deva +0 -23
  77. package/examples/samples/hat-808.wav +0 -0
  78. package/examples/samples/kick-808.wav +0 -0
  79. package/examples/synth.deva +0 -24
  80. package/examples/synth_types.deva +0 -17
  81. package/examples/variables.deva +0 -9
  82. package/out-tsc/bin/project-version.json +0 -6
  83. package/out-tsc/core/functions/index.d.ts +0 -42
  84. package/out-tsc/core/functions/index.js +0 -87
  85. package/out-tsc/core/index.d.ts +0 -6
  86. package/out-tsc/core/types/index.d.ts +0 -4
  87. package/out-tsc/core/types/index.js +0 -20
  88. package/out-tsc/core/types/plugin.d.ts +0 -18
  89. package/out-tsc/core/types/plugin.js +0 -2
  90. package/out-tsc/core/types/result.d.ts +0 -27
  91. package/out-tsc/core/types/result.js +0 -2
  92. package/out-tsc/core/types/statement.d.ts +0 -106
  93. package/out-tsc/core/types/statement.js +0 -2
  94. package/out-tsc/core/types/value.d.ts +0 -43
  95. package/out-tsc/pkg/devalang_core.d.ts +0 -15
  96. package/out-tsc/pkg/devalang_core.js +0 -65
  97. package/out-tsc/pkg/devalang_core_bg.wasm.d.ts +0 -34
  98. package/out-tsc/scripts/version/copy-to-binary.d.ts +0 -1
  99. package/out-tsc/scripts/version/copy-to-binary.js +0 -79
  100. package/project-version.json +0 -6
  101. package/rust/bindings/Cargo.toml +0 -9
  102. package/rust/bindings/src/lib.rs +0 -86
  103. package/rust/cli/addon/commands.rs +0 -35
  104. package/rust/cli/addon/download.rs +0 -234
  105. package/rust/cli/addon/install.rs +0 -33
  106. package/rust/cli/addon/list.rs +0 -224
  107. package/rust/cli/addon/metadata.rs +0 -124
  108. package/rust/cli/addon/mod.rs +0 -8
  109. package/rust/cli/addon/remove.rs +0 -271
  110. package/rust/cli/addon/update.rs +0 -305
  111. package/rust/cli/addon/utils.rs +0 -109
  112. package/rust/cli/build/commands.rs +0 -153
  113. package/rust/cli/build/mod.rs +0 -2
  114. package/rust/cli/build/process.rs +0 -165
  115. package/rust/cli/check/mod.rs +0 -208
  116. package/rust/cli/discover/commands.rs +0 -275
  117. package/rust/cli/discover/config.rs +0 -109
  118. package/rust/cli/discover/fs.rs +0 -19
  119. package/rust/cli/discover/install.rs +0 -214
  120. package/rust/cli/discover/metadata.rs +0 -48
  121. package/rust/cli/discover/mod.rs +0 -5
  122. package/rust/cli/init/commands.rs +0 -88
  123. package/rust/cli/init/mod.rs +0 -1
  124. package/rust/cli/login/commands.rs +0 -124
  125. package/rust/cli/login/mod.rs +0 -1
  126. package/rust/cli/me/commands.rs +0 -52
  127. package/rust/cli/me/mod.rs +0 -1
  128. package/rust/cli/mod.rs +0 -12
  129. package/rust/cli/parser.rs +0 -320
  130. package/rust/cli/play/commands.rs +0 -375
  131. package/rust/cli/play/io.rs +0 -17
  132. package/rust/cli/play/mod.rs +0 -5
  133. package/rust/cli/play/process.rs +0 -159
  134. package/rust/cli/play/realtime.rs +0 -91
  135. package/rust/cli/play/utils.rs +0 -23
  136. package/rust/cli/telemetry/commands.rs +0 -22
  137. package/rust/cli/telemetry/event_creator.rs +0 -80
  138. package/rust/cli/telemetry/mod.rs +0 -3
  139. package/rust/cli/telemetry/send.rs +0 -51
  140. package/rust/cli/template/commands.rs +0 -69
  141. package/rust/cli/template/mod.rs +0 -1
  142. package/rust/cli/update/commands.rs +0 -6
  143. package/rust/cli/update/mod.rs +0 -1
  144. package/rust/config/driver.rs +0 -112
  145. package/rust/config/mod.rs +0 -3
  146. package/rust/config/ops.rs +0 -26
  147. package/rust/config/settings.rs +0 -101
  148. package/rust/core/audio/engine/driver.rs +0 -237
  149. package/rust/core/audio/engine/export.rs +0 -169
  150. package/rust/core/audio/engine/helpers.rs +0 -178
  151. package/rust/core/audio/engine/mod.rs +0 -56
  152. package/rust/core/audio/engine/notes/dsp.rs +0 -88
  153. package/rust/core/audio/engine/notes/mod.rs +0 -53
  154. package/rust/core/audio/engine/notes/params.rs +0 -294
  155. package/rust/core/audio/engine/sample/insert.rs +0 -300
  156. package/rust/core/audio/engine/sample/mod.rs +0 -40
  157. package/rust/core/audio/engine/sample/padding.rs +0 -170
  158. package/rust/core/audio/evaluator/condition.rs +0 -61
  159. package/rust/core/audio/evaluator/mod.rs +0 -9
  160. package/rust/core/audio/evaluator/numeric.rs +0 -152
  161. package/rust/core/audio/evaluator/rhs.rs +0 -16
  162. package/rust/core/audio/evaluator/string_expr.rs +0 -94
  163. package/rust/core/audio/interpreter/driver.rs +0 -574
  164. package/rust/core/audio/interpreter/mod.rs +0 -2
  165. package/rust/core/audio/interpreter/statements/arrow_call/interprete.rs +0 -179
  166. package/rust/core/audio/interpreter/statements/arrow_call/methods/chord.rs +0 -398
  167. package/rust/core/audio/interpreter/statements/arrow_call/methods/effects.rs +0 -323
  168. package/rust/core/audio/interpreter/statements/arrow_call/methods/mod.rs +0 -3
  169. package/rust/core/audio/interpreter/statements/arrow_call/methods/note.rs +0 -371
  170. package/rust/core/audio/interpreter/statements/arrow_call/mod.rs +0 -3
  171. package/rust/core/audio/interpreter/statements/arrow_call/types/arp.rs +0 -192
  172. package/rust/core/audio/interpreter/statements/arrow_call/types/mod.rs +0 -24
  173. package/rust/core/audio/interpreter/statements/arrow_call/types/pad.rs +0 -116
  174. package/rust/core/audio/interpreter/statements/arrow_call/types/pluck.rs +0 -97
  175. package/rust/core/audio/interpreter/statements/arrow_call/types/sub.rs +0 -100
  176. package/rust/core/audio/interpreter/statements/automate.rs +0 -16
  177. package/rust/core/audio/interpreter/statements/call.rs +0 -325
  178. package/rust/core/audio/interpreter/statements/condition.rs +0 -72
  179. package/rust/core/audio/interpreter/statements/function.rs +0 -24
  180. package/rust/core/audio/interpreter/statements/let_.rs +0 -36
  181. package/rust/core/audio/interpreter/statements/load.rs +0 -17
  182. package/rust/core/audio/interpreter/statements/loop_.rs +0 -115
  183. package/rust/core/audio/interpreter/statements/mod.rs +0 -12
  184. package/rust/core/audio/interpreter/statements/sleep.rs +0 -28
  185. package/rust/core/audio/interpreter/statements/spawn.rs +0 -302
  186. package/rust/core/audio/interpreter/statements/tempo.rs +0 -40
  187. package/rust/core/audio/interpreter/statements/trigger.rs +0 -242
  188. package/rust/core/audio/loader/mod.rs +0 -1
  189. package/rust/core/audio/loader/trigger.rs +0 -98
  190. package/rust/core/audio/mod.rs +0 -6
  191. package/rust/core/audio/player.rs +0 -70
  192. package/rust/core/audio/special/easing.rs +0 -189
  193. package/rust/core/audio/special/env.rs +0 -45
  194. package/rust/core/audio/special/math.rs +0 -134
  195. package/rust/core/audio/special/mod.rs +0 -9
  196. package/rust/core/audio/special/modulator.rs +0 -143
  197. package/rust/core/builder/mod.rs +0 -129
  198. package/rust/core/debugger/lexer.rs +0 -27
  199. package/rust/core/debugger/logs.rs +0 -52
  200. package/rust/core/debugger/mod.rs +0 -30
  201. package/rust/core/debugger/preprocessor.rs +0 -27
  202. package/rust/core/debugger/store.rs +0 -38
  203. package/rust/core/error/mod.rs +0 -269
  204. package/rust/core/lexer/driver.rs +0 -59
  205. package/rust/core/lexer/handler/arrow.rs +0 -82
  206. package/rust/core/lexer/handler/at.rs +0 -21
  207. package/rust/core/lexer/handler/brace.rs +0 -41
  208. package/rust/core/lexer/handler/colon.rs +0 -21
  209. package/rust/core/lexer/handler/comment.rs +0 -30
  210. package/rust/core/lexer/handler/dot.rs +0 -21
  211. package/rust/core/lexer/handler/driver.rs +0 -337
  212. package/rust/core/lexer/handler/identifier.rs +0 -47
  213. package/rust/core/lexer/handler/indent.rs +0 -66
  214. package/rust/core/lexer/handler/mod.rs +0 -15
  215. package/rust/core/lexer/handler/newline.rs +0 -23
  216. package/rust/core/lexer/handler/number.rs +0 -31
  217. package/rust/core/lexer/handler/operator.rs +0 -46
  218. package/rust/core/lexer/handler/parenthesis.rs +0 -41
  219. package/rust/core/lexer/handler/slash.rs +0 -21
  220. package/rust/core/lexer/handler/string.rs +0 -63
  221. package/rust/core/lexer/mod.rs +0 -3
  222. package/rust/core/lexer/token.rs +0 -91
  223. package/rust/core/mod.rs +0 -9
  224. package/rust/core/parser/driver/block.rs +0 -111
  225. package/rust/core/parser/driver/cursor.rs +0 -82
  226. package/rust/core/parser/driver/driver_impl.rs +0 -159
  227. package/rust/core/parser/driver/mod.rs +0 -6
  228. package/rust/core/parser/driver/parse_array.rs +0 -120
  229. package/rust/core/parser/driver/parse_map.rs +0 -247
  230. package/rust/core/parser/driver/parser.rs +0 -160
  231. package/rust/core/parser/handler/arrow_call.rs +0 -328
  232. package/rust/core/parser/handler/at.rs +0 -279
  233. package/rust/core/parser/handler/bank.rs +0 -104
  234. package/rust/core/parser/handler/condition.rs +0 -83
  235. package/rust/core/parser/handler/dot.rs +0 -148
  236. package/rust/core/parser/handler/identifier/automate.rs +0 -254
  237. package/rust/core/parser/handler/identifier/call.rs +0 -91
  238. package/rust/core/parser/handler/identifier/emit.rs +0 -70
  239. package/rust/core/parser/handler/identifier/function.rs +0 -113
  240. package/rust/core/parser/handler/identifier/group.rs +0 -89
  241. package/rust/core/parser/handler/identifier/let_.rs +0 -173
  242. package/rust/core/parser/handler/identifier/mod.rs +0 -55
  243. package/rust/core/parser/handler/identifier/on.rs +0 -107
  244. package/rust/core/parser/handler/identifier/print.rs +0 -49
  245. package/rust/core/parser/handler/identifier/sleep.rs +0 -96
  246. package/rust/core/parser/handler/identifier/spawn.rs +0 -91
  247. package/rust/core/parser/handler/identifier/synth.rs +0 -171
  248. package/rust/core/parser/handler/loop_.rs +0 -194
  249. package/rust/core/parser/handler/mod.rs +0 -9
  250. package/rust/core/parser/handler/pattern.rs +0 -97
  251. package/rust/core/parser/handler/tempo.rs +0 -105
  252. package/rust/core/parser/mod.rs +0 -3
  253. package/rust/core/parser/statement.rs +0 -10
  254. package/rust/core/plugin/loader.rs +0 -137
  255. package/rust/core/plugin/mod.rs +0 -2
  256. package/rust/core/plugin/runner/mod.rs +0 -11
  257. package/rust/core/plugin/runner/non_wasm.rs +0 -481
  258. package/rust/core/plugin/runner/wasm32.rs +0 -44
  259. package/rust/core/preprocessor/loader/inject.rs +0 -313
  260. package/rust/core/preprocessor/loader/loader_helpers.rs +0 -110
  261. package/rust/core/preprocessor/loader/mod.rs +0 -235
  262. package/rust/core/preprocessor/mod.rs +0 -4
  263. package/rust/core/preprocessor/module.rs +0 -55
  264. package/rust/core/preprocessor/processor/handlers.rs +0 -107
  265. package/rust/core/preprocessor/processor/mod.rs +0 -1
  266. package/rust/core/preprocessor/resolver/bank.rs +0 -49
  267. package/rust/core/preprocessor/resolver/call.rs +0 -124
  268. package/rust/core/preprocessor/resolver/condition.rs +0 -95
  269. package/rust/core/preprocessor/resolver/driver.rs +0 -324
  270. package/rust/core/preprocessor/resolver/function.rs +0 -69
  271. package/rust/core/preprocessor/resolver/group.rs +0 -122
  272. package/rust/core/preprocessor/resolver/let_.rs +0 -32
  273. package/rust/core/preprocessor/resolver/loop_.rs +0 -318
  274. package/rust/core/preprocessor/resolver/mod.rs +0 -16
  275. package/rust/core/preprocessor/resolver/pattern.rs +0 -95
  276. package/rust/core/preprocessor/resolver/spawn.rs +0 -99
  277. package/rust/core/preprocessor/resolver/synth.rs +0 -54
  278. package/rust/core/preprocessor/resolver/tempo.rs +0 -48
  279. package/rust/core/preprocessor/resolver/trigger.rs +0 -116
  280. package/rust/core/preprocessor/resolver/value.rs +0 -176
  281. package/rust/core/store/global.rs +0 -57
  282. package/rust/core/store/mod.rs +0 -1
  283. package/rust/lib.rs +0 -323
  284. package/rust/macros/Cargo.toml +0 -14
  285. package/rust/macros/src/lib.rs +0 -52
  286. package/rust/main.rs +0 -557
  287. package/rust/types/Cargo.toml +0 -11
  288. package/rust/types/src/addons.rs +0 -57
  289. package/rust/types/src/ast.rs +0 -202
  290. package/rust/types/src/config.rs +0 -82
  291. package/rust/types/src/lib.rs +0 -15
  292. package/rust/types/src/plugin.rs +0 -20
  293. package/rust/types/src/store.rs +0 -139
  294. package/rust/types/src/telemetry.rs +0 -85
  295. package/rust/utils/Cargo.toml +0 -29
  296. package/rust/utils/src/error.rs +0 -186
  297. package/rust/utils/src/file.rs +0 -477
  298. package/rust/utils/src/first_usage.rs +0 -97
  299. package/rust/utils/src/lib.rs +0 -9
  300. package/rust/utils/src/logger.rs +0 -200
  301. package/rust/utils/src/path.rs +0 -158
  302. package/rust/utils/src/signature.rs +0 -41
  303. package/rust/utils/src/spinner.rs +0 -20
  304. package/rust/utils/src/version.rs +0 -58
  305. package/rust/utils/src/watcher.rs +0 -46
  306. package/rust/web/api.rs +0 -5
  307. package/rust/web/auth.rs +0 -5
  308. package/rust/web/cdn.rs +0 -34
  309. package/rust/web/forge.rs +0 -5
  310. package/rust/web/mod.rs +0 -5
  311. package/rust/web/sso.rs +0 -5
  312. package/templates/minimal/.devalang +0 -5
  313. package/templates/minimal/README.md +0 -218
  314. package/templates/minimal/src/index.deva +0 -2
  315. package/templates/welcome/.devalang +0 -5
  316. package/templates/welcome/README.md +0 -218
  317. package/templates/welcome/samples/kick-808.wav +0 -0
  318. package/templates/welcome/src/index.deva +0 -61
  319. package/templates/welcome/src/variables.deva +0 -3
  320. package/tests/integration.rs +0 -21
  321. package/tests/rust/cli_check_build.rs +0 -21
  322. package/tests/rust/cli_help.rs +0 -12
  323. package/tests/rust/cli_template_list.rs +0 -10
  324. package/tests/rust/cli_version.rs +0 -11
  325. package/tests/typescript/index.spec.ts +0 -136
  326. package/tests/typescript/playhead.spec.ts +0 -36
  327. package/tests/typescript/render_e2e.spec.ts +0 -77
  328. package/tsconfig.json +0 -115
  329. package/typescript/bin/index.ts +0 -28
  330. package/typescript/core/functions/index.ts +0 -94
  331. package/typescript/core/index.ts +0 -6
  332. package/typescript/core/types/index.ts +0 -4
  333. package/typescript/core/types/plugin.ts +0 -19
  334. package/typescript/core/types/result.ts +0 -29
  335. package/typescript/core/types/statement.ts +0 -47
  336. package/typescript/core/types/value.ts +0 -29
  337. package/typescript/index.ts +0 -8
  338. package/typescript/pkg/devalang_core.d.ts +0 -4
  339. package/typescript/pkg/devalang_core.ts +0 -65
  340. package/typescript/scripts/copy-wasm-dts.ts +0 -41
  341. package/typescript/scripts/postinstall.ts +0 -85
  342. package/typescript/scripts/version/bump.ts +0 -44
  343. package/typescript/scripts/version/copy-to-binary.ts +0 -82
  344. package/typescript/scripts/version/fetch.ts +0 -18
  345. package/typescript/scripts/version/index.ts +0 -25
  346. package/typescript/scripts/version/sync.ts +0 -24
@@ -1,313 +0,0 @@
1
- use crate::core::parser::statement::Statement;
2
- use crate::core::plugin::loader::load_plugin;
3
- use crate::core::preprocessor::module::Module;
4
- use crate::core::store::global::GlobalStore;
5
- use devalang_types::Value;
6
- use std::{collections::HashMap, path::Path};
7
-
8
- pub fn inject_bank_triggers(
9
- module: &mut Module,
10
- bank_name: &str,
11
- alias_override: Option<String>,
12
- ) -> Result<(), String> {
13
- let default_alias = bank_name
14
- .split('.')
15
- .next_back()
16
- .unwrap_or(bank_name)
17
- .to_string();
18
- let alias_ref = alias_override.as_deref().unwrap_or(&default_alias);
19
-
20
- let root = match devalang_utils::path::get_deva_dir() {
21
- Ok(dir) => dir,
22
- Err(_) => Path::new("./.deva").to_path_buf(),
23
- };
24
-
25
- // Try both plural and singular folder names and both layouts (flat and nested)
26
- let mut parsed_bankfile_opt: Option<devalang_types::BankFile> = None;
27
- let sds = ["banks", "bank"];
28
- for sd in &sds {
29
- // candidate: .deva/<sd>/<bank_name>/bank.toml (flat dir name)
30
- let candidate1 = root.join(sd).join(bank_name).join("bank.toml");
31
- if candidate1.exists() {
32
- let content = std::fs::read_to_string(&candidate1)
33
- .map_err(|e| format!("Failed to read '{}': {}", candidate1.display(), e))?;
34
- if let Ok(parsed) = toml::from_str::<devalang_types::BankFile>(&content) {
35
- parsed_bankfile_opt = Some(parsed);
36
- break;
37
- }
38
- }
39
-
40
- // If bank_name uses dot notation, also try nested layout: .deva/<sd>/<publisher>/<name>/bank.toml
41
- if bank_name.contains('.') {
42
- let mut it = bank_name.splitn(2, '.');
43
- let pubr = it.next().unwrap_or("");
44
- let nm = it.next().unwrap_or("");
45
- let candidate2 = root.join(sd).join(pubr).join(nm).join("bank.toml");
46
- if candidate2.exists() {
47
- let content = std::fs::read_to_string(&candidate2)
48
- .map_err(|e| format!("Failed to read '{}': {}", candidate2.display(), e))?;
49
- if let Ok(parsed) = toml::from_str::<devalang_types::BankFile>(&content) {
50
- parsed_bankfile_opt = Some(parsed);
51
- break;
52
- }
53
- }
54
- }
55
- }
56
-
57
- let parsed_bankfile = match parsed_bankfile_opt {
58
- Some(p) => p,
59
- None => return Ok(()),
60
- };
61
-
62
- let mut bank_map = HashMap::new();
63
-
64
- for bank_trigger in parsed_bankfile.triggers.unwrap_or_default() {
65
- let entity_ref = bank_trigger
66
- .path
67
- .clone()
68
- .replace("\\", "/")
69
- .replace("./", "");
70
- let bank_trigger_path = format!("devalang://bank/{}/{}", bank_name, entity_ref);
71
-
72
- bank_map.insert(
73
- bank_trigger.name.clone(),
74
- Value::String(bank_trigger_path.clone()),
75
- );
76
-
77
- if module.variable_table.variables.contains_key(alias_ref) {
78
- eprintln!(
79
- "⚠️ Trigger '{}' already defined in module '{}', skipping injection.",
80
- alias_ref, module.path
81
- );
82
- continue;
83
- }
84
-
85
- module.variable_table.set(
86
- format!("{}.{}", alias_ref, bank_trigger.name),
87
- Value::String(bank_trigger_path.clone()),
88
- );
89
- }
90
-
91
- module
92
- .variable_table
93
- .set(alias_ref.to_string(), Value::Map(bank_map));
94
-
95
- Ok(())
96
- }
97
-
98
- pub fn extract_bank_decls(statements: &[Statement]) -> Vec<(String, Option<String>)> {
99
- let mut banks = Vec::new();
100
-
101
- for stmt in statements {
102
- if let crate::core::parser::statement::StatementKind::Bank { alias } = &stmt.kind {
103
- let name_opt = match &stmt.value {
104
- Value::String(s) => Some(s.clone()),
105
- Value::Identifier(s) => Some(s.clone()),
106
- Value::Number(n) => Some(n.to_string()),
107
- _ => None,
108
- };
109
- if let Some(name) = name_opt {
110
- banks.push((name, alias.clone()));
111
- }
112
- }
113
- }
114
-
115
- banks
116
- }
117
-
118
- pub fn extract_plugin_uses(statements: &[Statement]) -> Vec<(String, String)> {
119
- let mut plugins = Vec::new();
120
-
121
- for stmt in statements {
122
- if let crate::core::parser::statement::StatementKind::Use { name, alias } = &stmt.kind {
123
- let alias_name = alias
124
- .clone()
125
- .unwrap_or_else(|| name.split('.').next_back().unwrap_or(name).to_string());
126
- plugins.push((name.clone(), alias_name));
127
- }
128
- }
129
-
130
- plugins
131
- }
132
-
133
- pub fn load_plugin_and_register(
134
- module: &mut Module,
135
- plugin_name: &str,
136
- alias: &str,
137
- global_store: &mut GlobalStore,
138
- ) {
139
- let mut parts = plugin_name.split('.');
140
- let author = match parts.next() {
141
- Some(a) if !a.is_empty() => a,
142
- _ => {
143
- eprintln!("Invalid plugin name '{}': missing author", plugin_name);
144
- return;
145
- }
146
- };
147
- let name = match parts.next() {
148
- Some(n) if !n.is_empty() => n,
149
- _ => {
150
- eprintln!("Invalid plugin name '{}': missing name", plugin_name);
151
- return;
152
- }
153
- };
154
- if parts.next().is_some() {
155
- eprintln!(
156
- "Invalid plugin name '{}': expected <author>.<name>",
157
- plugin_name
158
- );
159
- return;
160
- }
161
-
162
- let expected_uri = format!("devalang://plugin/{}/{}", author, name);
163
-
164
- let root = match devalang_utils::path::get_deva_dir() {
165
- Ok(dir) => dir,
166
- Err(_) => Path::new("./.deva").to_path_buf(),
167
- };
168
- // Test both 'plugins' and 'plugin' folders
169
- let mut exists_locally = false;
170
- for sd in &["plugins", "plugin"] {
171
- let plugin_dir_preferred = root.join(sd).join(format!("{}/{}", author, name));
172
- let toml_path_preferred = plugin_dir_preferred.join("plugin.toml");
173
- let plugin_dir_fallback = root.join(sd).join(author).join(name);
174
- let toml_path_fallback = plugin_dir_fallback.join("plugin.toml");
175
- if toml_path_preferred.exists() || toml_path_fallback.exists() {
176
- exists_locally = true;
177
- break;
178
- }
179
- }
180
-
181
- if exists_locally {
182
- let cfg_opt = crate::config::ops::load_config(None);
183
- let mut declared = false;
184
- if let Some(cfg) = cfg_opt {
185
- if let Some(list) = cfg.plugins {
186
- declared = list.iter().any(|p| p.path == expected_uri);
187
- }
188
- }
189
- if !declared {
190
- module
191
- .statements
192
- .push(crate::core::parser::statement::Statement {
193
- kind: crate::core::parser::statement::StatementKind::Error {
194
- message: "plugin present in local files but missing in .devalang config"
195
- .to_string(),
196
- },
197
- value: Value::Null,
198
- indent: 0,
199
- line: 0,
200
- column: 0,
201
- });
202
- return;
203
- }
204
- }
205
-
206
- match load_plugin(author, name) {
207
- Ok((info, wasm)) => {
208
- // keep dotted form for config/expected URIs, but inject a slash form into variables
209
- let _uri_dot = format!("devalang://plugin/{}.{}", author, name);
210
- let uri_inject = format!("devalang://plugin/{}/{}", author, name);
211
- global_store
212
- .plugins
213
- .insert(format!("{}:{}", author, name), (info, wasm));
214
- module
215
- .variable_table
216
- .set(alias.to_string(), Value::String(uri_inject.clone()));
217
- global_store
218
- .variables
219
- .set(alias.to_string(), Value::String(uri_inject.clone()));
220
-
221
- if let Some((plugin_info, _)) =
222
- global_store.plugins.get(&format!("{}:{}", author, name))
223
- {
224
- for exp in &plugin_info.exports {
225
- match exp.kind.as_str() {
226
- "number" => {
227
- if let Some(toml::Value::String(s)) = &exp.default {
228
- if let Ok(n) = s.parse::<f32>() {
229
- module
230
- .variable_table
231
- .set(format!("{}.{}", alias, exp.name), Value::Number(n));
232
- }
233
- } else if let Some(toml::Value::Integer(i)) = &exp.default {
234
- module.variable_table.set(
235
- format!("{}.{}", alias, exp.name),
236
- Value::Number(*i as f32),
237
- );
238
- } else if let Some(toml::Value::Float(f)) = &exp.default {
239
- module.variable_table.set(
240
- format!("{}.{}", alias, exp.name),
241
- Value::Number(*f as f32),
242
- );
243
- }
244
- }
245
- "string" => {
246
- if let Some(toml::Value::String(s)) = &exp.default {
247
- module.variable_table.set(
248
- format!("{}.{}", alias, exp.name),
249
- Value::String(s.clone()),
250
- );
251
- }
252
- }
253
- "bool" => {
254
- if let Some(toml::Value::Boolean(b)) = &exp.default {
255
- module
256
- .variable_table
257
- .set(format!("{}.{}", alias, exp.name), Value::Boolean(*b));
258
- }
259
- }
260
- "synth" => {
261
- module.variable_table.set(
262
- format!("{}.{}", alias, exp.name),
263
- Value::String(format!("{}.{}", alias, exp.name)),
264
- );
265
- }
266
- _ => {
267
- if let Some(def) = &exp.default {
268
- let val = match def {
269
- toml::Value::String(s) => Value::String(s.clone()),
270
- toml::Value::Integer(i) => Value::Number(*i as f32),
271
- toml::Value::Float(f) => Value::Number(*f as f32),
272
- toml::Value::Boolean(b) => Value::Boolean(*b),
273
- toml::Value::Array(arr) => Value::Array(
274
- arr.iter()
275
- .map(|v| match v {
276
- toml::Value::String(s) => Value::String(s.clone()),
277
- toml::Value::Integer(i) => Value::Number(*i as f32),
278
- toml::Value::Float(f) => Value::Number(*f as f32),
279
- toml::Value::Boolean(b) => Value::Boolean(*b),
280
- _ => Value::Null,
281
- })
282
- .collect(),
283
- ),
284
- toml::Value::Table(t) => {
285
- let mut m = std::collections::HashMap::new();
286
- for (k, v) in t.iter() {
287
- let vv = match v {
288
- toml::Value::String(s) => Value::String(s.clone()),
289
- toml::Value::Integer(i) => Value::Number(*i as f32),
290
- toml::Value::Float(f) => Value::Number(*f as f32),
291
- toml::Value::Boolean(b) => Value::Boolean(*b),
292
- _ => Value::Null,
293
- };
294
- m.insert(k.clone(), vv);
295
- }
296
- Value::Map(m)
297
- }
298
- _ => Value::Null,
299
- };
300
- if val != Value::Null {
301
- module
302
- .variable_table
303
- .set(format!("{}.{}", alias, exp.name), val);
304
- }
305
- }
306
- }
307
- }
308
- }
309
- }
310
- }
311
- Err(e) => eprintln!("Failed to load plugin {}: {}", plugin_name, e),
312
- }
313
- }
@@ -1,110 +0,0 @@
1
- use crate::core::preprocessor::loader::inject;
2
- use crate::core::{
3
- lexer::{driver::Lexer, token::Token},
4
- parser::driver::parser::Parser,
5
- preprocessor::module::Module,
6
- store::global::GlobalStore,
7
- };
8
- use devalang_utils::logger::{LogLevel, Logger};
9
- use devalang_utils::path::{normalize_path, resolve_relative_path};
10
- use std::collections::HashMap;
11
-
12
- pub fn load_module_recursively(
13
- raw_path: &str,
14
- global_store: &mut GlobalStore,
15
- ) -> HashMap<String, Vec<Token>> {
16
- let path = normalize_path(raw_path);
17
-
18
- // Check if already loaded
19
- if global_store.modules.contains_key(&path) {
20
- return HashMap::new();
21
- }
22
-
23
- let lexer = Lexer::new();
24
- let tokens = match lexer.lex_tokens(&path) {
25
- Ok(t) => t,
26
- Err(e) => {
27
- let logger = Logger::new();
28
- logger.log_message(LogLevel::Error, &format!("Failed to lex '{}': {}", path, e));
29
- return HashMap::new();
30
- }
31
- };
32
-
33
- let mut parser = Parser::new();
34
- parser.set_current_module(path.clone());
35
-
36
- let statements = parser.parse_tokens(tokens.clone(), global_store);
37
-
38
- // Insert module into store
39
- let mut module = Module::new(&path);
40
- module.tokens = tokens.clone();
41
- module.statements = statements.clone();
42
-
43
- // Inject triggers for each bank used in module, respecting aliases
44
- for (bank_name, alias_opt) in inject::extract_bank_decls(&statements) {
45
- if let Err(e) = inject::inject_bank_triggers(&mut module, &bank_name, alias_opt) {
46
- eprintln!("Failed to inject bank triggers for '{}': {}", bank_name, e);
47
- }
48
- }
49
-
50
- for (plugin_name, alias) in inject::extract_plugin_uses(&statements) {
51
- inject::load_plugin_and_register(&mut module, &plugin_name, &alias, global_store);
52
- }
53
-
54
- // Inject module variables and functions into global store
55
- global_store
56
- .variables
57
- .variables
58
- .extend(module.variable_table.variables.clone());
59
- global_store
60
- .functions
61
- .functions
62
- .extend(module.function_table.functions.clone());
63
-
64
- // Inject the module into the global store
65
- global_store.insert_module(path.clone(), module);
66
-
67
- // Load dependencies
68
- load_module_imports(&path, global_store);
69
-
70
- // Return tokens per module
71
- global_store
72
- .modules
73
- .iter()
74
- .map(|(p, m)| (p.clone(), m.tokens.clone()))
75
- .collect()
76
- }
77
-
78
- pub fn load_module_imports(path: &String, global_store: &mut GlobalStore) {
79
- let import_paths: Vec<String> = {
80
- let current_module = match global_store.modules.get(path) {
81
- Some(module) => module,
82
- None => {
83
- eprintln!(
84
- "[warn] Cannot resolve imports: module '{}' not found in store",
85
- path
86
- );
87
- return;
88
- }
89
- };
90
-
91
- current_module
92
- .statements
93
- .iter()
94
- .filter_map(|stmt| {
95
- if let crate::core::parser::statement::StatementKind::Import { source, .. } =
96
- &stmt.kind
97
- {
98
- Some(source.clone())
99
- } else {
100
- None
101
- }
102
- })
103
- .collect()
104
- };
105
-
106
- for import_path in import_paths {
107
- let resolved = resolve_relative_path(path, &import_path);
108
- load_module_recursively(&resolved, global_store);
109
- }
110
- }
@@ -1,235 +0,0 @@
1
- #[cfg(feature = "cli")]
2
- use crate::core::preprocessor::resolver::driver::{
3
- resolve_all_modules, resolve_and_flatten_all_modules,
4
- };
5
- // resolve_relative_path moved to loader_helpers
6
- use crate::core::{
7
- error::ErrorHandler,
8
- lexer::{driver::Lexer, token::Token},
9
- parser::{driver::parser::Parser, statement::Statement},
10
- preprocessor::{module::Module, processor::handlers::process_modules},
11
- store::global::GlobalStore,
12
- };
13
- use devalang_utils::path::normalize_path;
14
- use std::{collections::HashMap, path::Path};
15
-
16
- mod inject;
17
- mod loader_helpers;
18
-
19
- pub struct ModuleLoader {
20
- pub entry: String,
21
- pub output: String,
22
- pub base_dir: String,
23
- }
24
-
25
- impl ModuleLoader {
26
- pub fn new(entry: &str, output: &str) -> Self {
27
- let base_dir = Path::new(entry)
28
- .parent()
29
- .unwrap_or(Path::new(""))
30
- .to_string_lossy()
31
- .replace('\\', "/");
32
-
33
- Self {
34
- entry: entry.to_string(),
35
- output: output.to_string(),
36
- base_dir,
37
- }
38
- }
39
-
40
- pub fn from_raw_source(
41
- entry_path: &str,
42
- output_path: &str,
43
- content: &str,
44
- global_store: &mut GlobalStore,
45
- ) -> Self {
46
- let normalized_entry_path = normalize_path(entry_path);
47
-
48
- let mut module = Module::new(entry_path);
49
- module.content = content.to_string();
50
-
51
- // Insert a module stub containing the provided content into the
52
- // global store. This is used by the WASM APIs and tests which
53
- // operate on in-memory sources instead of files on disk.
54
- global_store.insert_module(normalized_entry_path.to_string(), module);
55
-
56
- Self {
57
- entry: normalized_entry_path.to_string(),
58
- output: output_path.to_string(),
59
- base_dir: "".to_string(),
60
- }
61
- }
62
-
63
- pub fn extract_statements_map(
64
- &self,
65
- global_store: &GlobalStore,
66
- ) -> HashMap<String, Vec<Statement>> {
67
- global_store
68
- .modules
69
- .iter()
70
- .map(|(path, module)| (path.clone(), module.statements.clone()))
71
- .collect()
72
- }
73
-
74
- pub fn load_single_module(&self, global_store: &mut GlobalStore) -> Result<Module, String> {
75
- let mut module = global_store
76
- .modules
77
- .remove(&self.entry)
78
- .ok_or_else(|| format!("Module not found in store for path: {}", self.entry))?;
79
-
80
- // SECTION Lexing the module content
81
- let lexer = Lexer::new();
82
- let tokens = lexer
83
- .lex_from_source(&module.content)
84
- .map_err(|e| format!("Lexer failed: {}", e))?;
85
-
86
- module.tokens = tokens.clone();
87
-
88
- // SECTION Parsing tokens into statements
89
- let mut parser = Parser::new();
90
- parser.set_current_module(self.entry.clone());
91
- let statements = parser.parse_tokens(tokens, global_store);
92
- module.statements = statements;
93
-
94
- // SECTION Injecting bank triggers if any (legacy default for single-module run)
95
- if let Err(e) = inject::inject_bank_triggers(&mut module, "808", None) {
96
- return Err(format!("Failed to inject bank triggers: {}", e));
97
- }
98
-
99
- for (plugin_name, alias) in inject::extract_plugin_uses(&module.statements) {
100
- inject::load_plugin_and_register(&mut module, &plugin_name, &alias, global_store);
101
- }
102
-
103
- global_store
104
- .modules
105
- .insert(self.entry.clone(), module.clone());
106
-
107
- // SECTION Error handling
108
- let mut error_handler = ErrorHandler::new();
109
- error_handler.detect_from_statements(&mut parser, &module.statements);
110
-
111
- Ok(module)
112
- }
113
-
114
- pub fn load_wasm_module(&self, global_store: &mut GlobalStore) -> Result<(), String> {
115
- // Step one : Load the module from the global store
116
- let module = {
117
- let module_ref = global_store
118
- .modules
119
- .get(&self.entry)
120
- .ok_or_else(|| format!("❌ Module not found for path: {}", self.entry))?;
121
-
122
- Module::from_existing(&self.entry, module_ref.content.clone())
123
- };
124
-
125
- // Step two : lexing
126
- let lexer = Lexer::new();
127
- let tokens = lexer
128
- .lex_from_source(&module.content)
129
- .map_err(|e| format!("Lexer failed: {}", e))?;
130
-
131
- // Step three : parsing
132
- let mut parser = Parser::new();
133
- parser.set_current_module(self.entry.clone());
134
-
135
- let statements = parser.parse_tokens(tokens.clone(), global_store);
136
-
137
- let mut updated_module = module;
138
- updated_module.tokens = tokens;
139
- updated_module.statements = statements;
140
-
141
- // Step four : Injecting bank triggers if any
142
- if let Err(e) = inject::inject_bank_triggers(&mut updated_module, "808", None) {
143
- return Err(format!("Failed to inject bank triggers: {}", e));
144
- }
145
-
146
- // Insert the updated module into the global store before processing so
147
- // process_modules can operate on it and populate variable_table, imports,
148
- // and other derived structures.
149
- global_store
150
- .modules
151
- .insert(self.entry.clone(), updated_module.clone());
152
-
153
- // Process modules to populate module.variable_table, import/export tables,
154
- // and other derived structures so runtime execution can resolve groups/synths.
155
- process_modules(self, global_store);
156
-
157
- for (plugin_name, alias) in inject::extract_plugin_uses(&updated_module.statements) {
158
- inject::load_plugin_and_register(
159
- &mut updated_module,
160
- &plugin_name,
161
- &alias,
162
- global_store,
163
- );
164
- }
165
-
166
- // Step four : error handling
167
- let mut error_handler = ErrorHandler::new();
168
- error_handler.detect_from_statements(&mut parser, &updated_module.statements);
169
-
170
- // Final step : also expose module-level variables and functions into the global store
171
- // so runtime evaluation (render_audio) can find group/synth definitions.
172
- // Use the module instance that was actually processed by `process_modules`
173
- // (it lives in `global_store.modules`) because `updated_module` is a local
174
- // clone and won't contain the mutations applied by `process_modules`.
175
- if let Some(stored_module) = global_store.modules.get(&self.entry) {
176
- global_store
177
- .variables
178
- .variables
179
- .extend(stored_module.variable_table.variables.clone());
180
- global_store
181
- .functions
182
- .functions
183
- .extend(stored_module.function_table.functions.clone());
184
- } else {
185
- // Fallback to the local updated_module if for any reason the module
186
- // wasn't inserted into the store (defensive programming).
187
- global_store
188
- .variables
189
- .variables
190
- .extend(updated_module.variable_table.variables.clone());
191
- global_store
192
- .functions
193
- .functions
194
- .extend(updated_module.function_table.functions.clone());
195
- }
196
-
197
- Ok(())
198
- }
199
-
200
- #[cfg(feature = "cli")]
201
- pub fn load_all_modules(
202
- &self,
203
- global_store: &mut GlobalStore,
204
- ) -> (HashMap<String, Vec<Token>>, HashMap<String, Vec<Statement>>) {
205
- // SECTION Load the entry module and its dependencies
206
- let tokens_by_module = self.load_module_recursively(&self.entry, global_store);
207
-
208
- // SECTION Process and resolve modules
209
- process_modules(self, global_store);
210
- resolve_all_modules(self, global_store);
211
-
212
- // SECTION Flatten all modules to get statements (+ injects)
213
- let statements_by_module = resolve_and_flatten_all_modules(global_store);
214
-
215
- (tokens_by_module, statements_by_module)
216
- }
217
-
218
- #[cfg(feature = "cli")]
219
- fn load_module_recursively(
220
- &self,
221
- raw_path: &str,
222
- global_store: &mut GlobalStore,
223
- ) -> HashMap<String, Vec<Token>> {
224
- crate::core::preprocessor::loader::loader_helpers::load_module_recursively(
225
- raw_path,
226
- global_store,
227
- )
228
- }
229
-
230
- #[cfg(feature = "cli")]
231
- #[allow(dead_code)]
232
- fn load_module_imports(&self, path: &String, global_store: &mut GlobalStore) {
233
- crate::core::preprocessor::loader::loader_helpers::load_module_imports(path, global_store)
234
- }
235
- }
@@ -1,4 +0,0 @@
1
- pub mod loader;
2
- pub mod module;
3
- pub mod processor;
4
- pub mod resolver;