@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,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
- }