@devaloop/devalang 0.0.1-beta.3 → 0.1.1

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 (345) hide show
  1. package/README.md +182 -152
  2. package/out-tsc/api.d.ts +180 -0
  3. package/out-tsc/api.d.ts.map +1 -0
  4. package/out-tsc/api.js +286 -0
  5. package/out-tsc/api.js.map +1 -0
  6. package/out-tsc/bin/index.d.ts +12 -0
  7. package/out-tsc/bin/index.d.ts.map +1 -0
  8. package/out-tsc/bin/index.js +20 -54
  9. package/out-tsc/bin/index.js.map +1 -0
  10. package/out-tsc/examples/basic-usage.d.ts +8 -0
  11. package/out-tsc/examples/basic-usage.d.ts.map +1 -0
  12. package/out-tsc/examples/basic-usage.js +113 -0
  13. package/out-tsc/examples/basic-usage.js.map +1 -0
  14. package/out-tsc/index.d.ts +19 -5
  15. package/out-tsc/index.d.ts.map +1 -0
  16. package/out-tsc/index.js +24 -6
  17. package/out-tsc/index.js.map +1 -0
  18. package/out-tsc/scripts/copy-wasm-dts.d.ts +7 -0
  19. package/out-tsc/scripts/copy-wasm-dts.d.ts.map +1 -0
  20. package/out-tsc/scripts/copy-wasm-dts.js +36 -32
  21. package/out-tsc/scripts/copy-wasm-dts.js.map +1 -0
  22. package/out-tsc/scripts/postinstall.d.ts +1 -0
  23. package/out-tsc/scripts/postinstall.d.ts.map +1 -0
  24. package/out-tsc/scripts/postinstall.js +4 -1
  25. package/out-tsc/scripts/postinstall.js.map +1 -0
  26. package/out-tsc/scripts/version/bump.d.ts +5 -1
  27. package/out-tsc/scripts/version/bump.d.ts.map +1 -0
  28. package/out-tsc/scripts/version/bump.js +114 -44
  29. package/out-tsc/scripts/version/bump.js.map +1 -0
  30. package/out-tsc/scripts/version/fetch.d.ts +12 -1
  31. package/out-tsc/scripts/version/fetch.d.ts.map +1 -0
  32. package/out-tsc/scripts/version/fetch.js +68 -24
  33. package/out-tsc/scripts/version/fetch.js.map +1 -0
  34. package/out-tsc/scripts/version/index.d.ts +6 -0
  35. package/out-tsc/scripts/version/index.d.ts.map +1 -0
  36. package/out-tsc/scripts/version/index.js +44 -22
  37. package/out-tsc/scripts/version/index.js.map +1 -0
  38. package/out-tsc/scripts/version/sync.d.ts +5 -1
  39. package/out-tsc/scripts/version/sync.d.ts.map +1 -0
  40. package/out-tsc/scripts/version/sync.js +78 -29
  41. package/out-tsc/scripts/version/sync.js.map +1 -0
  42. package/out-tsc/types.d.ts +68 -0
  43. package/out-tsc/types.d.ts.map +1 -0
  44. package/out-tsc/{core/types/value.js → types.js} +4 -0
  45. package/out-tsc/types.js.map +1 -0
  46. package/out-tsc/wasm.d.ts +8 -0
  47. package/out-tsc/wasm.d.ts.map +1 -0
  48. package/out-tsc/{core/index.js → wasm.js} +9 -6
  49. package/out-tsc/wasm.js.map +1 -0
  50. package/package.json +42 -42
  51. package/.cargo/config.toml +0 -2
  52. package/.devalang +0 -9
  53. package/.github/workflows/ci.yml +0 -103
  54. package/Cargo.toml +0 -84
  55. package/docs/CHANGELOG.md +0 -622
  56. package/docs/CONTRIBUTING.md +0 -101
  57. package/docs/ROADMAP.md +0 -38
  58. package/docs/TODO.md +0 -71
  59. package/examples/automation.deva +0 -42
  60. package/examples/bank.deva +0 -7
  61. package/examples/bus.deva +0 -10
  62. package/examples/chain.deva +0 -19
  63. package/examples/condition.deva +0 -20
  64. package/examples/duration.deva +0 -9
  65. package/examples/effect.deva +0 -2
  66. package/examples/events.deva +0 -12
  67. package/examples/filter.deva +0 -11
  68. package/examples/function.deva +0 -15
  69. package/examples/group.deva +0 -12
  70. package/examples/index.deva +0 -63
  71. package/examples/lfo.deva +0 -9
  72. package/examples/loop.deva +0 -10
  73. package/examples/pattern.deva +0 -8
  74. package/examples/plugin.deva +0 -16
  75. package/examples/routing.deva +0 -23
  76. package/examples/samples/hat-808.wav +0 -0
  77. package/examples/samples/kick-808.wav +0 -0
  78. package/examples/synth.deva +0 -24
  79. package/examples/synth_types.deva +0 -17
  80. package/examples/variables.deva +0 -9
  81. package/out-tsc/bin/project-version.json +0 -6
  82. package/out-tsc/core/functions/index.d.ts +0 -42
  83. package/out-tsc/core/functions/index.js +0 -87
  84. package/out-tsc/core/index.d.ts +0 -6
  85. package/out-tsc/core/types/index.d.ts +0 -4
  86. package/out-tsc/core/types/index.js +0 -20
  87. package/out-tsc/core/types/plugin.d.ts +0 -18
  88. package/out-tsc/core/types/plugin.js +0 -2
  89. package/out-tsc/core/types/result.d.ts +0 -27
  90. package/out-tsc/core/types/result.js +0 -2
  91. package/out-tsc/core/types/statement.d.ts +0 -106
  92. package/out-tsc/core/types/statement.js +0 -2
  93. package/out-tsc/core/types/value.d.ts +0 -43
  94. package/out-tsc/pkg/devalang_core.d.ts +0 -15
  95. package/out-tsc/pkg/devalang_core.js +0 -65
  96. package/out-tsc/pkg/devalang_core_bg.wasm.d.ts +0 -34
  97. package/out-tsc/scripts/version/copy-to-binary.d.ts +0 -1
  98. package/out-tsc/scripts/version/copy-to-binary.js +0 -79
  99. package/project-version.json +0 -6
  100. package/rust/bindings/Cargo.toml +0 -9
  101. package/rust/bindings/src/lib.rs +0 -86
  102. package/rust/cli/addon/commands.rs +0 -35
  103. package/rust/cli/addon/download.rs +0 -234
  104. package/rust/cli/addon/install.rs +0 -33
  105. package/rust/cli/addon/list.rs +0 -224
  106. package/rust/cli/addon/metadata.rs +0 -124
  107. package/rust/cli/addon/mod.rs +0 -8
  108. package/rust/cli/addon/remove.rs +0 -271
  109. package/rust/cli/addon/update.rs +0 -305
  110. package/rust/cli/addon/utils.rs +0 -109
  111. package/rust/cli/build/commands.rs +0 -153
  112. package/rust/cli/build/mod.rs +0 -2
  113. package/rust/cli/build/process.rs +0 -165
  114. package/rust/cli/check/mod.rs +0 -208
  115. package/rust/cli/discover/commands.rs +0 -275
  116. package/rust/cli/discover/config.rs +0 -109
  117. package/rust/cli/discover/fs.rs +0 -19
  118. package/rust/cli/discover/install.rs +0 -214
  119. package/rust/cli/discover/metadata.rs +0 -48
  120. package/rust/cli/discover/mod.rs +0 -5
  121. package/rust/cli/init/commands.rs +0 -88
  122. package/rust/cli/init/mod.rs +0 -1
  123. package/rust/cli/login/commands.rs +0 -124
  124. package/rust/cli/login/mod.rs +0 -1
  125. package/rust/cli/me/commands.rs +0 -52
  126. package/rust/cli/me/mod.rs +0 -1
  127. package/rust/cli/mod.rs +0 -12
  128. package/rust/cli/parser.rs +0 -320
  129. package/rust/cli/play/commands.rs +0 -375
  130. package/rust/cli/play/io.rs +0 -17
  131. package/rust/cli/play/mod.rs +0 -5
  132. package/rust/cli/play/process.rs +0 -159
  133. package/rust/cli/play/realtime.rs +0 -91
  134. package/rust/cli/play/utils.rs +0 -23
  135. package/rust/cli/telemetry/commands.rs +0 -22
  136. package/rust/cli/telemetry/event_creator.rs +0 -80
  137. package/rust/cli/telemetry/mod.rs +0 -3
  138. package/rust/cli/telemetry/send.rs +0 -51
  139. package/rust/cli/template/commands.rs +0 -69
  140. package/rust/cli/template/mod.rs +0 -1
  141. package/rust/cli/update/commands.rs +0 -6
  142. package/rust/cli/update/mod.rs +0 -1
  143. package/rust/config/driver.rs +0 -112
  144. package/rust/config/mod.rs +0 -3
  145. package/rust/config/ops.rs +0 -26
  146. package/rust/config/settings.rs +0 -101
  147. package/rust/core/audio/engine/driver.rs +0 -237
  148. package/rust/core/audio/engine/export.rs +0 -169
  149. package/rust/core/audio/engine/helpers.rs +0 -178
  150. package/rust/core/audio/engine/mod.rs +0 -56
  151. package/rust/core/audio/engine/notes/dsp.rs +0 -88
  152. package/rust/core/audio/engine/notes/mod.rs +0 -53
  153. package/rust/core/audio/engine/notes/params.rs +0 -294
  154. package/rust/core/audio/engine/sample/insert.rs +0 -300
  155. package/rust/core/audio/engine/sample/mod.rs +0 -40
  156. package/rust/core/audio/engine/sample/padding.rs +0 -170
  157. package/rust/core/audio/evaluator/condition.rs +0 -61
  158. package/rust/core/audio/evaluator/mod.rs +0 -9
  159. package/rust/core/audio/evaluator/numeric.rs +0 -152
  160. package/rust/core/audio/evaluator/rhs.rs +0 -16
  161. package/rust/core/audio/evaluator/string_expr.rs +0 -94
  162. package/rust/core/audio/interpreter/driver.rs +0 -574
  163. package/rust/core/audio/interpreter/mod.rs +0 -2
  164. package/rust/core/audio/interpreter/statements/arrow_call/interprete.rs +0 -179
  165. package/rust/core/audio/interpreter/statements/arrow_call/methods/chord.rs +0 -398
  166. package/rust/core/audio/interpreter/statements/arrow_call/methods/effects.rs +0 -323
  167. package/rust/core/audio/interpreter/statements/arrow_call/methods/mod.rs +0 -3
  168. package/rust/core/audio/interpreter/statements/arrow_call/methods/note.rs +0 -371
  169. package/rust/core/audio/interpreter/statements/arrow_call/mod.rs +0 -3
  170. package/rust/core/audio/interpreter/statements/arrow_call/types/arp.rs +0 -192
  171. package/rust/core/audio/interpreter/statements/arrow_call/types/mod.rs +0 -24
  172. package/rust/core/audio/interpreter/statements/arrow_call/types/pad.rs +0 -116
  173. package/rust/core/audio/interpreter/statements/arrow_call/types/pluck.rs +0 -97
  174. package/rust/core/audio/interpreter/statements/arrow_call/types/sub.rs +0 -100
  175. package/rust/core/audio/interpreter/statements/automate.rs +0 -16
  176. package/rust/core/audio/interpreter/statements/call.rs +0 -325
  177. package/rust/core/audio/interpreter/statements/condition.rs +0 -72
  178. package/rust/core/audio/interpreter/statements/function.rs +0 -24
  179. package/rust/core/audio/interpreter/statements/let_.rs +0 -36
  180. package/rust/core/audio/interpreter/statements/load.rs +0 -17
  181. package/rust/core/audio/interpreter/statements/loop_.rs +0 -115
  182. package/rust/core/audio/interpreter/statements/mod.rs +0 -12
  183. package/rust/core/audio/interpreter/statements/sleep.rs +0 -28
  184. package/rust/core/audio/interpreter/statements/spawn.rs +0 -302
  185. package/rust/core/audio/interpreter/statements/tempo.rs +0 -40
  186. package/rust/core/audio/interpreter/statements/trigger.rs +0 -242
  187. package/rust/core/audio/loader/mod.rs +0 -1
  188. package/rust/core/audio/loader/trigger.rs +0 -98
  189. package/rust/core/audio/mod.rs +0 -6
  190. package/rust/core/audio/player.rs +0 -70
  191. package/rust/core/audio/special/easing.rs +0 -189
  192. package/rust/core/audio/special/env.rs +0 -45
  193. package/rust/core/audio/special/math.rs +0 -134
  194. package/rust/core/audio/special/mod.rs +0 -9
  195. package/rust/core/audio/special/modulator.rs +0 -143
  196. package/rust/core/builder/mod.rs +0 -129
  197. package/rust/core/debugger/lexer.rs +0 -27
  198. package/rust/core/debugger/logs.rs +0 -52
  199. package/rust/core/debugger/mod.rs +0 -30
  200. package/rust/core/debugger/preprocessor.rs +0 -27
  201. package/rust/core/debugger/store.rs +0 -38
  202. package/rust/core/error/mod.rs +0 -269
  203. package/rust/core/lexer/driver.rs +0 -59
  204. package/rust/core/lexer/handler/arrow.rs +0 -82
  205. package/rust/core/lexer/handler/at.rs +0 -21
  206. package/rust/core/lexer/handler/brace.rs +0 -41
  207. package/rust/core/lexer/handler/colon.rs +0 -21
  208. package/rust/core/lexer/handler/comment.rs +0 -30
  209. package/rust/core/lexer/handler/dot.rs +0 -21
  210. package/rust/core/lexer/handler/driver.rs +0 -337
  211. package/rust/core/lexer/handler/identifier.rs +0 -47
  212. package/rust/core/lexer/handler/indent.rs +0 -66
  213. package/rust/core/lexer/handler/mod.rs +0 -15
  214. package/rust/core/lexer/handler/newline.rs +0 -23
  215. package/rust/core/lexer/handler/number.rs +0 -31
  216. package/rust/core/lexer/handler/operator.rs +0 -46
  217. package/rust/core/lexer/handler/parenthesis.rs +0 -41
  218. package/rust/core/lexer/handler/slash.rs +0 -21
  219. package/rust/core/lexer/handler/string.rs +0 -63
  220. package/rust/core/lexer/mod.rs +0 -3
  221. package/rust/core/lexer/token.rs +0 -91
  222. package/rust/core/mod.rs +0 -9
  223. package/rust/core/parser/driver/block.rs +0 -111
  224. package/rust/core/parser/driver/cursor.rs +0 -82
  225. package/rust/core/parser/driver/driver_impl.rs +0 -159
  226. package/rust/core/parser/driver/mod.rs +0 -6
  227. package/rust/core/parser/driver/parse_array.rs +0 -120
  228. package/rust/core/parser/driver/parse_map.rs +0 -247
  229. package/rust/core/parser/driver/parser.rs +0 -160
  230. package/rust/core/parser/handler/arrow_call.rs +0 -328
  231. package/rust/core/parser/handler/at.rs +0 -279
  232. package/rust/core/parser/handler/bank.rs +0 -104
  233. package/rust/core/parser/handler/condition.rs +0 -83
  234. package/rust/core/parser/handler/dot.rs +0 -148
  235. package/rust/core/parser/handler/identifier/automate.rs +0 -254
  236. package/rust/core/parser/handler/identifier/call.rs +0 -91
  237. package/rust/core/parser/handler/identifier/emit.rs +0 -70
  238. package/rust/core/parser/handler/identifier/function.rs +0 -113
  239. package/rust/core/parser/handler/identifier/group.rs +0 -89
  240. package/rust/core/parser/handler/identifier/let_.rs +0 -173
  241. package/rust/core/parser/handler/identifier/mod.rs +0 -55
  242. package/rust/core/parser/handler/identifier/on.rs +0 -107
  243. package/rust/core/parser/handler/identifier/print.rs +0 -49
  244. package/rust/core/parser/handler/identifier/sleep.rs +0 -96
  245. package/rust/core/parser/handler/identifier/spawn.rs +0 -91
  246. package/rust/core/parser/handler/identifier/synth.rs +0 -171
  247. package/rust/core/parser/handler/loop_.rs +0 -194
  248. package/rust/core/parser/handler/mod.rs +0 -9
  249. package/rust/core/parser/handler/pattern.rs +0 -97
  250. package/rust/core/parser/handler/tempo.rs +0 -105
  251. package/rust/core/parser/mod.rs +0 -3
  252. package/rust/core/parser/statement.rs +0 -10
  253. package/rust/core/plugin/loader.rs +0 -137
  254. package/rust/core/plugin/mod.rs +0 -2
  255. package/rust/core/plugin/runner/mod.rs +0 -11
  256. package/rust/core/plugin/runner/non_wasm.rs +0 -481
  257. package/rust/core/plugin/runner/wasm32.rs +0 -44
  258. package/rust/core/preprocessor/loader/inject.rs +0 -313
  259. package/rust/core/preprocessor/loader/loader_helpers.rs +0 -110
  260. package/rust/core/preprocessor/loader/mod.rs +0 -235
  261. package/rust/core/preprocessor/mod.rs +0 -4
  262. package/rust/core/preprocessor/module.rs +0 -55
  263. package/rust/core/preprocessor/processor/handlers.rs +0 -107
  264. package/rust/core/preprocessor/processor/mod.rs +0 -1
  265. package/rust/core/preprocessor/resolver/bank.rs +0 -49
  266. package/rust/core/preprocessor/resolver/call.rs +0 -124
  267. package/rust/core/preprocessor/resolver/condition.rs +0 -95
  268. package/rust/core/preprocessor/resolver/driver.rs +0 -324
  269. package/rust/core/preprocessor/resolver/function.rs +0 -69
  270. package/rust/core/preprocessor/resolver/group.rs +0 -122
  271. package/rust/core/preprocessor/resolver/let_.rs +0 -32
  272. package/rust/core/preprocessor/resolver/loop_.rs +0 -318
  273. package/rust/core/preprocessor/resolver/mod.rs +0 -16
  274. package/rust/core/preprocessor/resolver/pattern.rs +0 -95
  275. package/rust/core/preprocessor/resolver/spawn.rs +0 -99
  276. package/rust/core/preprocessor/resolver/synth.rs +0 -54
  277. package/rust/core/preprocessor/resolver/tempo.rs +0 -48
  278. package/rust/core/preprocessor/resolver/trigger.rs +0 -116
  279. package/rust/core/preprocessor/resolver/value.rs +0 -176
  280. package/rust/core/store/global.rs +0 -57
  281. package/rust/core/store/mod.rs +0 -1
  282. package/rust/lib.rs +0 -323
  283. package/rust/macros/Cargo.toml +0 -14
  284. package/rust/macros/src/lib.rs +0 -52
  285. package/rust/main.rs +0 -557
  286. package/rust/types/Cargo.toml +0 -11
  287. package/rust/types/src/addons.rs +0 -57
  288. package/rust/types/src/ast.rs +0 -202
  289. package/rust/types/src/config.rs +0 -82
  290. package/rust/types/src/lib.rs +0 -15
  291. package/rust/types/src/plugin.rs +0 -20
  292. package/rust/types/src/store.rs +0 -139
  293. package/rust/types/src/telemetry.rs +0 -85
  294. package/rust/utils/Cargo.toml +0 -29
  295. package/rust/utils/src/error.rs +0 -186
  296. package/rust/utils/src/file.rs +0 -477
  297. package/rust/utils/src/first_usage.rs +0 -97
  298. package/rust/utils/src/lib.rs +0 -9
  299. package/rust/utils/src/logger.rs +0 -200
  300. package/rust/utils/src/path.rs +0 -158
  301. package/rust/utils/src/signature.rs +0 -41
  302. package/rust/utils/src/spinner.rs +0 -20
  303. package/rust/utils/src/version.rs +0 -58
  304. package/rust/utils/src/watcher.rs +0 -46
  305. package/rust/web/api.rs +0 -5
  306. package/rust/web/auth.rs +0 -5
  307. package/rust/web/cdn.rs +0 -34
  308. package/rust/web/forge.rs +0 -5
  309. package/rust/web/mod.rs +0 -5
  310. package/rust/web/sso.rs +0 -5
  311. package/templates/minimal/.devalang +0 -5
  312. package/templates/minimal/README.md +0 -218
  313. package/templates/minimal/src/index.deva +0 -2
  314. package/templates/welcome/.devalang +0 -5
  315. package/templates/welcome/README.md +0 -218
  316. package/templates/welcome/samples/kick-808.wav +0 -0
  317. package/templates/welcome/src/index.deva +0 -61
  318. package/templates/welcome/src/variables.deva +0 -3
  319. package/tests/integration.rs +0 -21
  320. package/tests/rust/cli_check_build.rs +0 -21
  321. package/tests/rust/cli_help.rs +0 -12
  322. package/tests/rust/cli_template_list.rs +0 -10
  323. package/tests/rust/cli_version.rs +0 -11
  324. package/tests/typescript/index.spec.ts +0 -136
  325. package/tests/typescript/playhead.spec.ts +0 -36
  326. package/tests/typescript/render_e2e.spec.ts +0 -77
  327. package/tsconfig.json +0 -115
  328. package/typescript/bin/index.ts +0 -28
  329. package/typescript/core/functions/index.ts +0 -94
  330. package/typescript/core/index.ts +0 -6
  331. package/typescript/core/types/index.ts +0 -4
  332. package/typescript/core/types/plugin.ts +0 -19
  333. package/typescript/core/types/result.ts +0 -29
  334. package/typescript/core/types/statement.ts +0 -47
  335. package/typescript/core/types/value.ts +0 -29
  336. package/typescript/index.ts +0 -8
  337. package/typescript/pkg/devalang_core.d.ts +0 -4
  338. package/typescript/pkg/devalang_core.ts +0 -65
  339. package/typescript/scripts/copy-wasm-dts.ts +0 -41
  340. package/typescript/scripts/postinstall.ts +0 -85
  341. package/typescript/scripts/version/bump.ts +0 -44
  342. package/typescript/scripts/version/copy-to-binary.ts +0 -82
  343. package/typescript/scripts/version/fetch.ts +0 -18
  344. package/typescript/scripts/version/index.ts +0 -25
  345. package/typescript/scripts/version/sync.ts +0 -24
@@ -1,153 +0,0 @@
1
- use crate::config::driver::ProjectConfig;
2
- use devalang_utils::logger::{LogLevel, Logger};
3
- use devalang_utils::path::find_entry_file;
4
- use devalang_utils::watcher::watch_directory;
5
-
6
- #[cfg(feature = "cli")]
7
- pub fn handle_build_command(
8
- config: Option<ProjectConfig>,
9
- entry: Option<String>,
10
- output: Option<String>,
11
- output_format: Vec<crate::cli::parser::OutputFormat>,
12
- audio_format: crate::cli::parser::AudioFormat,
13
- sample_rate: u32,
14
- watch: bool,
15
- debug: bool,
16
- compress: bool,
17
- ) -> Result<(), String> {
18
- // determine fetched values from config or CLI
19
- let fetched_entry = if entry.is_none() {
20
- config
21
- .as_ref()
22
- .and_then(|c| c.defaults.entry.clone())
23
- .unwrap_or_default()
24
- } else {
25
- entry.clone().unwrap_or_default()
26
- };
27
-
28
- let fetched_output = if output.is_none() {
29
- config
30
- .as_ref()
31
- .and_then(|c| c.defaults.output.clone())
32
- .unwrap_or_default()
33
- } else {
34
- output.clone().unwrap_or_default()
35
- };
36
-
37
- let fetched_watch = if watch {
38
- watch
39
- } else {
40
- config
41
- .as_ref()
42
- .and_then(|c| c.defaults.watch)
43
- .unwrap_or(false)
44
- };
45
-
46
- let logger = Logger::new();
47
-
48
- // Determine final audio_format: prefer CLI, else config default if present
49
- let mut final_audio_format = audio_format;
50
- if let Some(cfg) = config.as_ref() {
51
- if let Some(af) = cfg.defaults.audio_format.as_ref() {
52
- // Only override if CLI provided an empty/placeholder — clap provides a default, so we only override when CLI wasn't explicit (rare).
53
- // We'll accept values: "wav16", "wav24", "wav32" (case-insensitive)
54
- let af_low = af.to_lowercase();
55
- final_audio_format = match af_low.as_str() {
56
- "wav24" => crate::cli::parser::AudioFormat::Wav24,
57
- "wav32" => crate::cli::parser::AudioFormat::Wav32,
58
- _ => crate::cli::parser::AudioFormat::Wav16,
59
- };
60
- }
61
- }
62
-
63
- // Determine final output_format: prefer CLI vector, else config default list
64
- let mut final_output_format: Vec<crate::cli::parser::OutputFormat> = output_format.clone();
65
- if final_output_format.is_empty() {
66
- if let Some(cfg) = config.as_ref() {
67
- if let Some(ofs) = cfg.defaults.output_format.as_ref() {
68
- for s in ofs {
69
- match s.to_lowercase().as_str() {
70
- "mid" | "midi" => {
71
- final_output_format.push(crate::cli::parser::OutputFormat::Mid);
72
- }
73
- _ => final_output_format.push(crate::cli::parser::OutputFormat::Wav),
74
- }
75
- }
76
- }
77
- }
78
- }
79
-
80
- if fetched_entry.is_empty() {
81
- logger.log_message(
82
- LogLevel::Error,
83
- "Entry path is not specified. Please provide a valid entry path.",
84
- );
85
- return Err("missing entry path".to_string());
86
- }
87
- if fetched_output.is_empty() {
88
- logger.log_message(
89
- LogLevel::Error,
90
- "Output directory is not specified. Please provide a valid output directory.",
91
- );
92
- return Err("missing output directory".to_string());
93
- }
94
-
95
- let entry_file = match find_entry_file(&fetched_entry) {
96
- Some(p) => p,
97
- None => {
98
- logger.log_message(
99
- LogLevel::Error,
100
- &format!("❌ index.deva not found in directory: {}", fetched_entry),
101
- );
102
- return Err("index.deva not found".to_string());
103
- }
104
- };
105
-
106
- // SECTION Begin build
107
- if fetched_watch {
108
- let _ = crate::cli::build::process::process_build(
109
- entry_file.clone(),
110
- fetched_output.clone(),
111
- final_output_format.clone(),
112
- final_audio_format,
113
- sample_rate,
114
- debug,
115
- compress,
116
- );
117
-
118
- logger.log_message(
119
- LogLevel::Watcher,
120
- &format!("Watching for changes in '{}'...", fetched_entry),
121
- );
122
-
123
- watch_directory(entry_file.clone(), move || {
124
- logger.log_message(LogLevel::Watcher, "Detected changes, re-building...");
125
-
126
- let _ = crate::cli::build::process::process_build(
127
- entry_file.clone(),
128
- fetched_output.clone(),
129
- final_output_format.clone(),
130
- final_audio_format,
131
- sample_rate,
132
- debug,
133
- compress,
134
- );
135
- })
136
- .unwrap();
137
- } else {
138
- let res = crate::cli::build::process::process_build(
139
- entry_file,
140
- fetched_output,
141
- final_output_format,
142
- final_audio_format,
143
- sample_rate,
144
- debug,
145
- compress,
146
- );
147
- if let Err(e) = res {
148
- return Err(e);
149
- }
150
- }
151
-
152
- Ok(())
153
- }
@@ -1,2 +0,0 @@
1
- pub mod commands;
2
- pub mod process;
@@ -1,165 +0,0 @@
1
- use crate::core::{
2
- builder::Builder,
3
- debugger::{
4
- lexer::write_lexer_log_file,
5
- logs::{write_module_function_log_file, write_module_variable_log_file},
6
- preprocessor::write_preprocessor_log_file,
7
- store::{write_function_log_file, write_variables_log_file},
8
- },
9
- preprocessor::loader::ModuleLoader,
10
- store::global::GlobalStore,
11
- };
12
- use devalang_utils::path::normalize_path;
13
- use devalang_utils::{
14
- logger::{LogLevel, Logger},
15
- spinner::start_spinner,
16
- };
17
-
18
- pub struct BuildStatsInput {
19
- pub statements_by_module:
20
- std::collections::HashMap<String, Vec<crate::core::parser::statement::Statement>>,
21
- pub global_store: crate::core::store::global::GlobalStore,
22
- }
23
-
24
- pub fn process_build(
25
- entry: String,
26
- output: String,
27
- output_format: Vec<crate::cli::parser::OutputFormat>,
28
- audio_format: crate::cli::parser::AudioFormat,
29
- sample_rate: u32,
30
- debug: bool,
31
- compress: bool,
32
- ) -> Result<BuildStatsInput, String> {
33
- let spinner = start_spinner("Building...");
34
-
35
- let duration = std::time::Instant::now();
36
-
37
- let normalized_entry_file = normalize_path(&entry);
38
- let normalized_output_dir = normalize_path(&output);
39
-
40
- let mut global_store = GlobalStore::new();
41
- let module_loader = ModuleLoader::new(&normalized_entry_file, &normalized_output_dir);
42
-
43
- // SECTION Load
44
- // NOTE: We use modules in the build command, so we need to load them
45
- let (modules_tokens, modules_statements) = module_loader.load_all_modules(&mut global_store);
46
-
47
- // SECTION Write logs
48
- if debug {
49
- for (module_path, module) in global_store.modules.clone() {
50
- write_module_variable_log_file(
51
- &normalized_output_dir,
52
- &module_path,
53
- &module.variable_table,
54
- );
55
- write_module_function_log_file(
56
- &normalized_output_dir,
57
- &module_path,
58
- &module.function_table,
59
- );
60
- }
61
-
62
- write_lexer_log_file(
63
- &normalized_output_dir,
64
- "lexer_tokens.log",
65
- modules_tokens.clone(),
66
- );
67
- write_preprocessor_log_file(
68
- &normalized_output_dir,
69
- "resolved_statements.log",
70
- modules_statements.clone(),
71
- );
72
- write_variables_log_file(
73
- &normalized_output_dir,
74
- "global_variables.log",
75
- global_store.variables.clone(),
76
- );
77
- write_function_log_file(
78
- &normalized_output_dir,
79
- "global_functions.log",
80
- global_store.functions.clone(),
81
- );
82
- }
83
-
84
- // SECTION Detect build-time errors prior to building
85
- let all_errors = crate::core::error::collect_all_errors_with_modules(&modules_statements);
86
- let (warnings, criticals) = crate::core::error::partition_errors(all_errors);
87
- crate::core::error::log_errors_with_stack("Build", &warnings, &criticals);
88
- if !criticals.is_empty() {
89
- spinner.finish_and_clear();
90
- return Err(format!(
91
- "build failed with {} critical error(s): {}",
92
- criticals.len(),
93
- criticals[0].message
94
- ));
95
- }
96
-
97
- // SECTION Building AST and Audio
98
- let builder = Builder::new();
99
- builder.build_ast(&modules_statements, &normalized_output_dir, compress);
100
-
101
- // generate audio output if requested
102
- if output_format.contains(&crate::cli::parser::OutputFormat::Wav) {
103
- let audio_format_str = format!("{:?}", audio_format);
104
- builder.build_audio(
105
- &modules_statements,
106
- &normalized_output_dir,
107
- &mut global_store,
108
- Some(audio_format_str),
109
- Some(sample_rate),
110
- );
111
- }
112
-
113
- // generate midi output if requested
114
- if output_format.contains(&crate::cli::parser::OutputFormat::Mid) {
115
- builder.build_midi(
116
- &modules_statements,
117
- &normalized_output_dir,
118
- &mut global_store,
119
- );
120
- }
121
-
122
- // SECTION Logging
123
- let logger = Logger::new();
124
-
125
- if debug {
126
- let modules_loaded = global_store.modules.keys().collect::<Vec<_>>();
127
- let global_variables_loaded = global_store.variables.variables.keys().collect::<Vec<_>>();
128
- let global_functions_loaded = global_store.functions.functions.keys().collect::<Vec<_>>();
129
-
130
- logger.log_message_with_trace(
131
- LogLevel::Debug,
132
- &format!("Modules loaded: {}", global_store.modules.len()),
133
- modules_loaded.iter().map(|s| s.as_str()).collect(),
134
- );
135
- logger.log_message_with_trace(
136
- LogLevel::Debug,
137
- &format!(
138
- "Global variables: {}",
139
- global_store.variables.variables.len()
140
- ),
141
- global_variables_loaded.iter().map(|s| s.as_str()).collect(),
142
- );
143
- logger.log_message_with_trace(
144
- LogLevel::Debug,
145
- &format!(
146
- "Global functions: {}",
147
- global_store.functions.functions.len()
148
- ),
149
- global_functions_loaded.iter().map(|s| s.as_str()).collect(),
150
- );
151
- }
152
-
153
- let success_message = format!(
154
- "Build completed successfully in {:.2?}. Output files written to: '{}'",
155
- duration.elapsed(),
156
- normalized_output_dir
157
- );
158
-
159
- spinner.finish_and_clear();
160
- logger.log_message(LogLevel::Success, &success_message);
161
- Ok(BuildStatsInput {
162
- statements_by_module: modules_statements,
163
- global_store,
164
- })
165
- }
@@ -1,208 +0,0 @@
1
- use crate::{
2
- config::driver::ProjectConfig,
3
- core::{
4
- debugger::{
5
- lexer::write_lexer_log_file,
6
- logs::{write_module_function_log_file, write_module_variable_log_file},
7
- preprocessor::write_preprocessor_log_file,
8
- store::{write_function_log_file, write_variables_log_file},
9
- },
10
- preprocessor::loader::ModuleLoader,
11
- store::global::GlobalStore,
12
- },
13
- };
14
- use devalang_utils::path::{find_entry_file, normalize_path};
15
-
16
- use devalang_utils::{
17
- logger::{LogLevel, Logger},
18
- spinner::start_spinner,
19
- watcher::watch_directory,
20
- };
21
-
22
- #[cfg(feature = "cli")]
23
- pub fn handle_check_command(
24
- config: Option<ProjectConfig>,
25
- entry: Option<String>,
26
- output: Option<String>,
27
- watch: bool,
28
- debug: bool,
29
- ) -> Result<(), String> {
30
- let fetched_entry = if entry.is_none() {
31
- config
32
- .as_ref()
33
- .and_then(|c| c.defaults.entry.clone())
34
- .unwrap_or_default()
35
- } else {
36
- entry.clone().unwrap_or_default()
37
- };
38
-
39
- let fetched_output = if output.is_none() {
40
- config
41
- .as_ref()
42
- .and_then(|c| c.defaults.output.clone())
43
- .unwrap_or_default()
44
- } else {
45
- output.clone().unwrap_or_default()
46
- };
47
-
48
- let fetched_watch = if watch {
49
- watch
50
- } else {
51
- config
52
- .as_ref()
53
- .and_then(|c| c.defaults.watch)
54
- .unwrap_or(false)
55
- };
56
-
57
- let logger = Logger::new();
58
-
59
- if fetched_entry.is_empty() {
60
- logger.log_message(
61
- LogLevel::Error,
62
- "Entry path is not specified. Please provide a valid entry path.",
63
- );
64
- return Err("missing entry path".to_string());
65
- }
66
- if fetched_output.is_empty() {
67
- logger.log_message(
68
- LogLevel::Error,
69
- "Output directory is not specified. Please provide a valid output directory.",
70
- );
71
- return Err("missing output directory".to_string());
72
- }
73
-
74
- let entry_file = match find_entry_file(&fetched_entry) {
75
- Some(p) => p,
76
- None => {
77
- logger.log_message(
78
- LogLevel::Error,
79
- &format!("❌ index.deva not found in directory: {}", fetched_entry),
80
- );
81
- return Err("index.deva not found".to_string());
82
- }
83
- };
84
-
85
- // SECTION Begin check
86
- if fetched_watch {
87
- let _ = begin_check(
88
- entry_file.clone(),
89
- fetched_output.clone(),
90
- debug,
91
- config.clone(),
92
- );
93
-
94
- logger.log_message(
95
- LogLevel::Watcher,
96
- &format!("Watching for changes in '{}'...", fetched_entry),
97
- );
98
-
99
- let cfg_for_watch = config.clone();
100
- watch_directory(entry_file.clone(), move || {
101
- logger.log_message(LogLevel::Watcher, "Detected changes, re-checking...");
102
- if let Err(e) = begin_check(
103
- entry_file.clone(),
104
- fetched_output.clone(),
105
- debug,
106
- cfg_for_watch.clone(),
107
- ) {
108
- eprintln!("[check] failed: {}", e);
109
- }
110
- })
111
- .unwrap();
112
- } else {
113
- begin_check(
114
- entry_file.clone(),
115
- fetched_output.clone(),
116
- debug,
117
- config.clone(),
118
- )?;
119
- }
120
- Ok(())
121
- }
122
-
123
- fn begin_check(
124
- entry: String,
125
- output: String,
126
- debug: bool,
127
- _config: Option<ProjectConfig>,
128
- ) -> Result<(), String> {
129
- let spinner = start_spinner("Checking...");
130
-
131
- let duration = std::time::Instant::now();
132
-
133
- let normalized_entry_file = normalize_path(&entry);
134
- let normalized_output_dir = normalize_path(&output);
135
-
136
- let mut global_store = GlobalStore::new();
137
- let module_loader = ModuleLoader::new(&normalized_entry_file, &normalized_output_dir);
138
-
139
- // SECTION Load
140
- // NOTE: We don't use modules in the check command, but we still need to load them
141
- let modules = module_loader.load_all_modules(&mut global_store);
142
-
143
- // Debugging: Log loaded modules and errors
144
- let logger = Logger::new();
145
- logger.log_message(LogLevel::Info, "Loaded modules:");
146
- for module_name in modules.0.keys() {
147
- logger.log_message(LogLevel::Info, &format!("- {}", module_name));
148
- }
149
-
150
- if debug {
151
- for (module_path, module) in global_store.modules.clone() {
152
- write_module_variable_log_file(
153
- &normalized_output_dir,
154
- &module_path,
155
- &module.variable_table,
156
- );
157
- write_module_function_log_file(
158
- &normalized_output_dir,
159
- &module_path,
160
- &module.function_table,
161
- );
162
- }
163
-
164
- write_lexer_log_file(
165
- &normalized_output_dir,
166
- "lexer_tokens.log",
167
- modules.0.clone(),
168
- );
169
- write_preprocessor_log_file(
170
- &normalized_output_dir,
171
- "resolved_statements.log",
172
- modules.1.clone(),
173
- );
174
- write_variables_log_file(
175
- &normalized_output_dir,
176
- "global_variables.log",
177
- global_store.variables.clone(),
178
- );
179
- write_function_log_file(
180
- &normalized_output_dir,
181
- "global_functions.log",
182
- global_store.functions.clone(),
183
- );
184
- }
185
-
186
- let all_errors = crate::core::error::collect_all_errors_with_modules(&modules.1);
187
-
188
- let (warnings, criticals) = crate::core::error::partition_errors(all_errors);
189
- crate::core::error::log_errors_with_stack("Check", &warnings, &criticals);
190
-
191
- if !criticals.is_empty() {
192
- spinner.finish_and_clear();
193
- return Err("check failed with critical errors".to_string());
194
- } else {
195
- logger.log_message(LogLevel::Success, "No errors detected.");
196
-
197
- let success_message = format!(
198
- "Check completed successfully in {:.2?}. Output files written to: '{}'",
199
- duration.elapsed(),
200
- normalized_output_dir
201
- );
202
-
203
- spinner.finish_and_clear();
204
- logger.log_message(LogLevel::Success, &success_message);
205
- }
206
-
207
- Ok(())
208
- }