@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,129 +0,0 @@
1
- use crate::core::audio::engine::render_audio_with_modules;
2
- use crate::core::parser::statement::Statement;
3
- use crate::core::store::global::GlobalStore;
4
- use devalang_utils::logger::Logger;
5
- use std::io::Write;
6
- use std::{collections::HashMap, fs::create_dir_all};
7
-
8
- pub struct Builder {}
9
-
10
- impl Default for Builder {
11
- fn default() -> Self {
12
- Self::new()
13
- }
14
- }
15
-
16
- impl Builder {
17
- pub fn new() -> Self {
18
- Builder {}
19
- }
20
-
21
- pub fn build_ast(
22
- &self,
23
- modules: &HashMap<String, Vec<Statement>>,
24
- out_dir: &str,
25
- compress: bool,
26
- ) {
27
- for (name, statements) in modules {
28
- let formatted_name = name.split("/").last().unwrap_or(name);
29
- let formatted_name = formatted_name.replace(".deva", "");
30
-
31
- create_dir_all(format!("{}/ast", out_dir)).expect("Failed to create AST directory");
32
-
33
- let file_path = format!("{}/ast/{}.json", out_dir, formatted_name);
34
- let mut file = std::fs::File::create(file_path).expect("Failed to create AST file");
35
- let content = if compress {
36
- serde_json::to_string(&statements).expect("Failed to serialize AST")
37
- } else {
38
- serde_json::to_string_pretty(&statements).expect("Failed to serialize AST")
39
- };
40
-
41
- file.write_all(content.as_bytes())
42
- .expect("Failed to write AST to file");
43
- }
44
- }
45
-
46
- pub fn build_audio(
47
- &self,
48
- modules: &HashMap<String, Vec<Statement>>,
49
- normalized_output_dir: &str,
50
- global_store: &mut GlobalStore,
51
- audio_format: Option<String>,
52
- sample_rate: Option<u32>,
53
- ) {
54
- let logger = Logger::new();
55
-
56
- let audio_engines =
57
- render_audio_with_modules(modules.clone(), normalized_output_dir, global_store);
58
-
59
- create_dir_all(format!("{}/audio", normalized_output_dir))
60
- .expect("Failed to create audio directory");
61
-
62
- for (module_name, mut audio_engine) in audio_engines {
63
- let formatted_module_name = module_name
64
- .split('/')
65
- .next_back()
66
- .unwrap_or(&module_name)
67
- .replace(".deva", "");
68
-
69
- let output_path = format!(
70
- "{}/audio/{}.wav",
71
- normalized_output_dir, formatted_module_name
72
- );
73
-
74
- match audio_engine.generate_wav_file(&output_path, audio_format.clone(), sample_rate) {
75
- Ok(_) => {}
76
- Err(msg) => {
77
- logger.log_error_with_stacktrace(
78
- &format!(
79
- "Unable to generate WAV file for module '{}': {}",
80
- formatted_module_name, msg
81
- ),
82
- &module_name,
83
- );
84
- }
85
- }
86
- }
87
- }
88
-
89
- pub fn build_midi(
90
- &self,
91
- modules: &HashMap<String, Vec<Statement>>,
92
- normalized_output_dir: &str,
93
- global_store: &mut GlobalStore,
94
- ) {
95
- let logger = Logger::new();
96
-
97
- let audio_engines =
98
- render_audio_with_modules(modules.clone(), normalized_output_dir, global_store);
99
-
100
- create_dir_all(format!("{}/midi", normalized_output_dir))
101
- .expect("Failed to create MIDI directory");
102
-
103
- for (module_name, mut audio_engine) in audio_engines {
104
- let formatted_module_name = module_name
105
- .split('/')
106
- .next_back()
107
- .unwrap_or(&module_name)
108
- .replace(".deva", "");
109
-
110
- let output_path = format!(
111
- "{}/midi/{}.mid",
112
- normalized_output_dir, formatted_module_name
113
- );
114
-
115
- match audio_engine.generate_midi_file(&output_path, None, None) {
116
- Ok(_) => {}
117
- Err(msg) => {
118
- logger.log_error_with_stacktrace(
119
- &format!(
120
- "Unable to generate MIDI file for module '{}': {}",
121
- formatted_module_name, msg
122
- ),
123
- &module_name,
124
- );
125
- }
126
- }
127
- }
128
- }
129
- }
@@ -1,27 +0,0 @@
1
- use crate::core::{debugger::Debugger, lexer::token::Token};
2
- use std::{collections::HashMap, fs::create_dir_all};
3
-
4
- pub fn write_lexer_log_file(
5
- output_dir: &str,
6
- file_name: &str,
7
- modules: HashMap<String, Vec<Token>>,
8
- ) {
9
- let debugger = Debugger::new();
10
- let mut content = String::new();
11
-
12
- let log_directory = format!("{}/logs", output_dir);
13
-
14
- create_dir_all(&log_directory).expect("Failed to create log directory");
15
-
16
- for (path, tokens) in modules {
17
- content.push_str(&format!("--- Resolved Tokens for {} ---\n", path));
18
-
19
- for token in tokens {
20
- content.push_str(&format!("{:?}\n", token));
21
- }
22
-
23
- content.push('\n');
24
- }
25
-
26
- debugger.write_log_file(&log_directory, file_name, &content);
27
- }
@@ -1,52 +0,0 @@
1
- use devalang_types::{FunctionTable, VariableTable};
2
- use std::fs::create_dir_all;
3
-
4
- pub fn write_module_variable_log_file(
5
- output_dir: &str,
6
- module_path: &str,
7
- variable_table: &VariableTable,
8
- ) {
9
- let debugger = crate::core::debugger::Debugger::new();
10
- let mut content = String::new();
11
- let module_name = module_path
12
- .split('/')
13
- .next_back()
14
- .unwrap_or("index")
15
- .replace(".deva", "");
16
-
17
- let log_directory = format!("{}/logs/modules/{}", output_dir, module_name);
18
- create_dir_all(&log_directory).expect("Failed to create log directory");
19
-
20
- for (var_name, var_data) in &variable_table.variables {
21
- content.push_str(&format!("{:?} = {:?}\n", var_name, var_data));
22
- }
23
-
24
- content.push('\n');
25
-
26
- debugger.write_log_file(&log_directory, "variables.log", &content);
27
- }
28
-
29
- pub fn write_module_function_log_file(
30
- output_dir: &str,
31
- module_path: &str,
32
- function_table: &FunctionTable,
33
- ) {
34
- let debugger = crate::core::debugger::Debugger::new();
35
- let mut content = String::new();
36
- let module_name = module_path
37
- .split('/')
38
- .next_back()
39
- .unwrap_or("index")
40
- .replace(".deva", "");
41
-
42
- let log_directory = format!("{}/logs/modules/{}", output_dir, module_name);
43
- create_dir_all(&log_directory).expect("Failed to create log directory");
44
-
45
- for (func_name, func_data) in &function_table.functions {
46
- content.push_str(&format!("{:?} = {:?}\n", func_name, func_data));
47
- }
48
-
49
- content.push('\n');
50
-
51
- debugger.write_log_file(&log_directory, "functions.log", &content);
52
- }
@@ -1,30 +0,0 @@
1
- pub mod lexer;
2
- pub mod logs;
3
- pub mod preprocessor;
4
- pub mod store;
5
-
6
- use std::io::Write;
7
-
8
- pub struct Debugger {}
9
-
10
- impl Default for Debugger {
11
- fn default() -> Self {
12
- Self::new()
13
- }
14
- }
15
-
16
- impl Debugger {
17
- pub fn new() -> Self {
18
- Debugger {}
19
- }
20
-
21
- pub fn write_log_file(&self, path: &str, filename: &str, content: &str) {
22
- std::fs::create_dir_all(path).expect("Failed to create directory");
23
-
24
- let file_path = format!("{}/{}", path, filename);
25
- let mut file = std::fs::File::create(file_path).expect("Failed to create file");
26
-
27
- file.write_all(content.as_bytes())
28
- .expect("Failed to write to file");
29
- }
30
- }
@@ -1,27 +0,0 @@
1
- use crate::core::{debugger::Debugger, parser::statement::Statement};
2
- use std::{collections::HashMap, fs::create_dir_all};
3
-
4
- pub fn write_preprocessor_log_file(
5
- output_dir: &str,
6
- file_name: &str,
7
- modules: HashMap<String, Vec<Statement>>,
8
- ) {
9
- let debugger = Debugger::new();
10
- let mut content = String::new();
11
-
12
- let log_directory = format!("{}/logs", output_dir);
13
-
14
- create_dir_all(&log_directory).expect("Failed to create log directory");
15
-
16
- for (path, stmts) in modules {
17
- content.push_str(&format!("--- Resolved Statements for {} ---\n", path));
18
-
19
- for stmt in stmts {
20
- content.push_str(&format!("{:?}\n", stmt));
21
- }
22
-
23
- content.push('\n');
24
- }
25
-
26
- debugger.write_log_file(&log_directory, file_name, &content);
27
- }
@@ -1,38 +0,0 @@
1
- use crate::core::debugger::Debugger;
2
- use devalang_types::{FunctionTable, VariableTable};
3
- use std::fs::create_dir_all;
4
-
5
- pub fn write_variables_log_file(output_dir: &str, file_name: &str, variables: VariableTable) {
6
- let debugger = Debugger::new();
7
- let mut content = String::new();
8
-
9
- let log_directory = format!("{}/logs", output_dir);
10
- create_dir_all(&log_directory).expect("Failed to create log directory");
11
-
12
- for (var_name, var_data) in variables.variables {
13
- content.push_str(&format!("{:?} = {:?}\n", var_name, var_data));
14
- }
15
-
16
- content.push('\n');
17
-
18
- debugger.write_log_file(&log_directory, file_name, &content);
19
- }
20
-
21
- pub fn write_function_log_file(output_dir: &str, file_name: &str, functions: FunctionTable) {
22
- let debugger = Debugger::new();
23
- let mut content = String::new();
24
-
25
- let log_directory = format!("{}/logs", output_dir);
26
- create_dir_all(&log_directory).expect("Failed to create log directory");
27
-
28
- for (_index, function) in functions.functions {
29
- content.push_str(&format!(
30
- "'{}' = [{:?}] => {:?}\n",
31
- function.name, function.parameters, function.body
32
- ));
33
- }
34
-
35
- content.push('\n');
36
-
37
- debugger.write_log_file(&log_directory, file_name, &content);
38
- }
@@ -1,269 +0,0 @@
1
- use crate::core::parser::{
2
- driver::parser::Parser,
3
- statement::{Statement, StatementKind},
4
- };
5
- use devalang_types::Value;
6
- use serde::{Deserialize, Serialize};
7
-
8
- pub struct ErrorHandler {
9
- errors: Vec<Error>,
10
- }
11
-
12
- #[derive(Serialize, Deserialize, Clone, Debug)]
13
- pub enum Severity {
14
- Warning,
15
- Critical,
16
- }
17
-
18
- #[derive(Serialize, Deserialize, Clone, Debug, Default)]
19
- pub struct StackFrame {
20
- pub module: Option<String>,
21
- pub context: Option<String>,
22
- pub line: usize,
23
- pub column: usize,
24
- }
25
-
26
- #[derive(Serialize, Deserialize, Clone, Debug)]
27
- pub struct ErrorResult {
28
- pub message: String,
29
- pub line: usize,
30
- pub column: usize,
31
- pub severity: Severity,
32
- pub stack: Vec<StackFrame>,
33
- }
34
-
35
- #[derive(Clone)]
36
- pub struct Error {
37
- pub message: String,
38
- pub line: usize,
39
- pub column: usize,
40
- }
41
-
42
- impl Default for ErrorHandler {
43
- fn default() -> Self {
44
- Self::new()
45
- }
46
- }
47
-
48
- impl ErrorHandler {
49
- pub fn new() -> Self {
50
- Self { errors: Vec::new() }
51
- }
52
-
53
- pub fn add_error(&mut self, message: String, line: usize, column: usize) {
54
- let error_statement = Error {
55
- message,
56
- line,
57
- column,
58
- };
59
- self.errors.push(error_statement);
60
- }
61
-
62
- pub fn has_errors(&self) -> bool {
63
- !self.errors.is_empty()
64
- }
65
-
66
- pub fn get_errors(&self) -> &Vec<Error> {
67
- &self.errors
68
- }
69
-
70
- pub fn clear_errors(&mut self) {
71
- self.errors.clear();
72
- }
73
-
74
- pub fn detect_from_statements(&mut self, _parser: &mut Parser, statements: &[Statement]) {
75
- for stmt in statements {
76
- match &stmt.kind {
77
- StatementKind::Unknown => {
78
- self.add_error("Unknown statement".to_string(), stmt.line, stmt.column);
79
- }
80
- StatementKind::Error { message } => {
81
- self.add_error(message.clone(), stmt.line, stmt.column);
82
- }
83
- _ => {}
84
- }
85
- }
86
- }
87
- }
88
-
89
- /// Collects errors recursively from statements (mirrors old utils implementation).
90
- pub fn collect_errors_recursively(statements: &[Statement]) -> Vec<ErrorResult> {
91
- let mut errors: Vec<ErrorResult> = Vec::new();
92
-
93
- for stmt in statements {
94
- match &stmt.kind {
95
- StatementKind::Unknown => {
96
- errors.push(ErrorResult {
97
- message: format!("Unknown statement at line {}:{}", stmt.line, stmt.column),
98
- line: stmt.line,
99
- column: stmt.column,
100
- severity: Severity::Warning,
101
- stack: vec![StackFrame {
102
- module: None,
103
- context: Some("Unknown".to_string()),
104
- line: stmt.line,
105
- column: stmt.column,
106
- }],
107
- });
108
- }
109
- StatementKind::Error { message } => {
110
- errors.push(ErrorResult {
111
- message: message.clone(),
112
- line: stmt.line,
113
- column: stmt.column,
114
- severity: Severity::Critical,
115
- stack: vec![StackFrame {
116
- module: None,
117
- context: Some("Error".to_string()),
118
- line: stmt.line,
119
- column: stmt.column,
120
- }],
121
- });
122
- }
123
- StatementKind::Loop => {
124
- if let Some(body_statements) = extract_loop_body_statements(&stmt.value) {
125
- let nested = collect_errors_recursively(body_statements);
126
- errors.extend(nested.into_iter().map(|mut e| {
127
- e.stack.insert(
128
- 0,
129
- StackFrame {
130
- module: None,
131
- context: Some("loop".to_string()),
132
- line: stmt.line,
133
- column: stmt.column,
134
- },
135
- );
136
- e
137
- }));
138
- }
139
- }
140
- _ => {}
141
- }
142
- }
143
-
144
- errors
145
- }
146
-
147
- fn extract_loop_body_statements(value: &Value) -> Option<&[Statement]> {
148
- if let Value::Map(map) = value {
149
- if let Some(Value::Block(statements)) = map.get("body") {
150
- return Some(statements);
151
- }
152
- }
153
- None
154
- }
155
-
156
- pub fn partition_errors(errors: Vec<ErrorResult>) -> (Vec<ErrorResult>, Vec<ErrorResult>) {
157
- let mut warnings = Vec::new();
158
- let mut criticals = Vec::new();
159
- for e in errors {
160
- match e.severity {
161
- Severity::Warning => warnings.push(e),
162
- Severity::Critical => criticals.push(e),
163
- }
164
- }
165
- (warnings, criticals)
166
- }
167
-
168
- pub fn log_errors_with_stack(prefix: &str, warnings: &[ErrorResult], criticals: &[ErrorResult]) {
169
- use devalang_utils::logger::LogLevel;
170
- use devalang_utils::logger::Logger;
171
-
172
- let logger = Logger::new();
173
- if !warnings.is_empty() {
174
- logger.log_message(
175
- LogLevel::Warning,
176
- &format!("{}: {} warning(s)", prefix, warnings.len()),
177
- );
178
- for w in warnings {
179
- logger.log_message(LogLevel::Warning, &format!("- {}", w.message));
180
- if let Some(frame) = w.stack.first() {
181
- let module = frame.module.clone().unwrap_or_default();
182
- logger.log_message(
183
- LogLevel::Debug,
184
- &format!(
185
- " ↳ {}:{}:{} {}",
186
- module,
187
- frame.line,
188
- frame.column,
189
- frame.context.clone().unwrap_or_default()
190
- ),
191
- );
192
- }
193
- if w.stack.len() > 1 {
194
- for (i, f) in w.stack.iter().enumerate().skip(1) {
195
- let module = f.module.clone().unwrap_or_default();
196
- logger.log_message(
197
- LogLevel::Debug,
198
- &format!(
199
- " #{} {}:{}:{} {}",
200
- i,
201
- module,
202
- f.line,
203
- f.column,
204
- f.context.clone().unwrap_or_default()
205
- ),
206
- );
207
- }
208
- }
209
- }
210
- }
211
- if !criticals.is_empty() {
212
- logger.log_message(
213
- LogLevel::Error,
214
- &format!("{}: {} critical error(s)", prefix, criticals.len()),
215
- );
216
- for c in criticals {
217
- logger.log_message(LogLevel::Error, &format!("- {}", c.message));
218
- if let Some(frame) = c.stack.first() {
219
- let module = frame.module.clone().unwrap_or_default();
220
- logger.log_message(
221
- LogLevel::Error,
222
- &format!(
223
- " ↳ {}:{}:{} {}",
224
- module,
225
- frame.line,
226
- frame.column,
227
- frame.context.clone().unwrap_or_default()
228
- ),
229
- );
230
- }
231
- if c.stack.len() > 1 {
232
- for (i, f) in c.stack.iter().enumerate().skip(1) {
233
- let module = f.module.clone().unwrap_or_default();
234
- logger.log_message(
235
- LogLevel::Error,
236
- &format!(
237
- " #{} {}:{}:{} {}",
238
- i,
239
- module,
240
- f.line,
241
- f.column,
242
- f.context.clone().unwrap_or_default()
243
- ),
244
- );
245
- }
246
- }
247
- }
248
- }
249
- }
250
-
251
- /// Collects errors from all modules and annotates stack frames with module names.
252
- pub fn collect_all_errors_with_modules(
253
- statements_by_module: &std::collections::HashMap<String, Vec<Statement>>,
254
- ) -> Vec<ErrorResult> {
255
- let mut all: Vec<ErrorResult> = Vec::new();
256
- for (module, stmts) in statements_by_module.iter() {
257
- let mut errs = collect_errors_recursively(stmts);
258
- for e in errs.iter_mut() {
259
- // annotate first stack frame module if missing
260
- if let Some(first) = e.stack.first_mut() {
261
- if first.module.is_none() {
262
- first.module = Some(module.clone());
263
- }
264
- }
265
- }
266
- all.extend(errs.into_iter());
267
- }
268
- all
269
- }
@@ -1,59 +0,0 @@
1
- use crate::core::lexer::{handler::driver::handle_content_lexing, token::Token};
2
- use devalang_utils::path::normalize_path;
3
- use std::fs;
4
- use std::path::Path;
5
-
6
- pub struct Lexer {}
7
-
8
- impl Default for Lexer {
9
- fn default() -> Self {
10
- Self::new()
11
- }
12
- }
13
-
14
- impl Lexer {
15
- pub fn new() -> Self {
16
- Lexer {}
17
- }
18
-
19
- pub fn lex_from_source(&self, source: &str) -> Result<Vec<Token>, String> {
20
- handle_content_lexing(source.to_string())
21
- }
22
-
23
- pub fn lex_tokens(&self, entrypoint: &str) -> Result<Vec<Token>, String> {
24
- let path = normalize_path(entrypoint);
25
- let resolved_path = Self::resolve_entry_path(&path)?;
26
-
27
- let file_content = fs::read_to_string(&resolved_path).map_err(|e| {
28
- format!(
29
- "Failed to read the entrypoint file '{}': {}",
30
- resolved_path, e
31
- )
32
- })?;
33
-
34
- handle_content_lexing(file_content).map_err(|e| format!("Failed to lex the content: {}", e))
35
- }
36
-
37
- fn resolve_entry_path(path: &str) -> Result<String, String> {
38
- let candidate = Path::new(path);
39
-
40
- if candidate.is_dir() {
41
- let index_path = candidate.join("index.deva");
42
- if index_path.exists() {
43
- Ok(index_path.to_string_lossy().replace("\\", "/"))
44
- } else {
45
- Err(format!(
46
- "Expected 'index.deva' in directory '{}', but it was not found",
47
- path
48
- ))
49
- }
50
- } else if candidate.is_file() {
51
- return Ok(path.to_string());
52
- } else {
53
- return Err(format!(
54
- "Provided entrypoint '{}' is not a valid file or directory",
55
- path
56
- ));
57
- }
58
- }
59
- }