@devaloop/devalang 0.0.1-beta.2 → 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 (329) hide show
  1. package/README.md +177 -146
  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 +50 -37
  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 -81
  55. package/docs/CHANGELOG.md +0 -581
  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/condition.deva +0 -20
  63. package/examples/duration.deva +0 -9
  64. package/examples/effect.deva +0 -2
  65. package/examples/events.deva +0 -12
  66. package/examples/filter.deva +0 -11
  67. package/examples/function.deva +0 -15
  68. package/examples/group.deva +0 -12
  69. package/examples/index.deva +0 -63
  70. package/examples/lfo.deva +0 -9
  71. package/examples/loop.deva +0 -10
  72. package/examples/pattern.deva +0 -8
  73. package/examples/plugin.deva +0 -16
  74. package/examples/samples/hat-808.wav +0 -0
  75. package/examples/samples/kick-808.wav +0 -0
  76. package/examples/synth.deva +0 -24
  77. package/examples/synth_types.deva +0 -17
  78. package/examples/variables.deva +0 -9
  79. package/out-tsc/core/functions/index.d.ts +0 -42
  80. package/out-tsc/core/functions/index.js +0 -87
  81. package/out-tsc/core/index.d.ts +0 -6
  82. package/out-tsc/core/types/index.d.ts +0 -4
  83. package/out-tsc/core/types/index.js +0 -20
  84. package/out-tsc/core/types/plugin.d.ts +0 -18
  85. package/out-tsc/core/types/plugin.js +0 -2
  86. package/out-tsc/core/types/result.d.ts +0 -27
  87. package/out-tsc/core/types/result.js +0 -2
  88. package/out-tsc/core/types/statement.d.ts +0 -106
  89. package/out-tsc/core/types/statement.js +0 -2
  90. package/out-tsc/core/types/value.d.ts +0 -43
  91. package/out-tsc/pkg/devalang_core.d.ts +0 -15
  92. package/out-tsc/pkg/devalang_core.js +0 -65
  93. package/out-tsc/pkg/devalang_core_bg.wasm.d.ts +0 -34
  94. package/project-version.json +0 -6
  95. package/rust/cli/bank/api.rs +0 -122
  96. package/rust/cli/bank/commands.rs +0 -306
  97. package/rust/cli/bank/mod.rs +0 -29
  98. package/rust/cli/build/commands.rs +0 -153
  99. package/rust/cli/build/mod.rs +0 -2
  100. package/rust/cli/build/process.rs +0 -165
  101. package/rust/cli/check/mod.rs +0 -208
  102. package/rust/cli/discover/commands.rs +0 -253
  103. package/rust/cli/discover/config.rs +0 -111
  104. package/rust/cli/discover/fs.rs +0 -19
  105. package/rust/cli/discover/install.rs +0 -103
  106. package/rust/cli/discover/metadata.rs +0 -48
  107. package/rust/cli/discover/mod.rs +0 -5
  108. package/rust/cli/init/commands.rs +0 -88
  109. package/rust/cli/init/mod.rs +0 -1
  110. package/rust/cli/install/addon.rs +0 -118
  111. package/rust/cli/install/bank.rs +0 -72
  112. package/rust/cli/install/commands.rs +0 -35
  113. package/rust/cli/install/mod.rs +0 -4
  114. package/rust/cli/install/plugin.rs +0 -80
  115. package/rust/cli/login/commands.rs +0 -124
  116. package/rust/cli/login/mod.rs +0 -1
  117. package/rust/cli/mod.rs +0 -12
  118. package/rust/cli/parser.rs +0 -359
  119. package/rust/cli/play/commands.rs +0 -375
  120. package/rust/cli/play/io.rs +0 -17
  121. package/rust/cli/play/mod.rs +0 -5
  122. package/rust/cli/play/process.rs +0 -159
  123. package/rust/cli/play/realtime.rs +0 -91
  124. package/rust/cli/play/utils.rs +0 -23
  125. package/rust/cli/telemetry/commands.rs +0 -22
  126. package/rust/cli/telemetry/event_creator.rs +0 -80
  127. package/rust/cli/telemetry/mod.rs +0 -3
  128. package/rust/cli/telemetry/send.rs +0 -51
  129. package/rust/cli/template/commands.rs +0 -69
  130. package/rust/cli/template/mod.rs +0 -1
  131. package/rust/cli/update/commands.rs +0 -6
  132. package/rust/cli/update/mod.rs +0 -1
  133. package/rust/config/driver.rs +0 -112
  134. package/rust/config/mod.rs +0 -3
  135. package/rust/config/ops.rs +0 -26
  136. package/rust/config/settings.rs +0 -101
  137. package/rust/core/audio/engine/driver.rs +0 -220
  138. package/rust/core/audio/engine/export.rs +0 -169
  139. package/rust/core/audio/engine/helpers.rs +0 -178
  140. package/rust/core/audio/engine/mod.rs +0 -56
  141. package/rust/core/audio/engine/notes/dsp.rs +0 -85
  142. package/rust/core/audio/engine/notes/mod.rs +0 -44
  143. package/rust/core/audio/engine/notes/params.rs +0 -294
  144. package/rust/core/audio/engine/sample/insert.rs +0 -199
  145. package/rust/core/audio/engine/sample/mod.rs +0 -40
  146. package/rust/core/audio/engine/sample/padding.rs +0 -170
  147. package/rust/core/audio/evaluator/condition.rs +0 -61
  148. package/rust/core/audio/evaluator/mod.rs +0 -9
  149. package/rust/core/audio/evaluator/numeric.rs +0 -152
  150. package/rust/core/audio/evaluator/rhs.rs +0 -16
  151. package/rust/core/audio/evaluator/string_expr.rs +0 -94
  152. package/rust/core/audio/interpreter/driver.rs +0 -574
  153. package/rust/core/audio/interpreter/mod.rs +0 -2
  154. package/rust/core/audio/interpreter/statements/arrow_call/interprete.rs +0 -175
  155. package/rust/core/audio/interpreter/statements/arrow_call/methods/chord.rs +0 -384
  156. package/rust/core/audio/interpreter/statements/arrow_call/methods/mod.rs +0 -2
  157. package/rust/core/audio/interpreter/statements/arrow_call/methods/note.rs +0 -316
  158. package/rust/core/audio/interpreter/statements/arrow_call/mod.rs +0 -3
  159. package/rust/core/audio/interpreter/statements/arrow_call/types/arp.rs +0 -192
  160. package/rust/core/audio/interpreter/statements/arrow_call/types/mod.rs +0 -24
  161. package/rust/core/audio/interpreter/statements/arrow_call/types/pad.rs +0 -116
  162. package/rust/core/audio/interpreter/statements/arrow_call/types/pluck.rs +0 -97
  163. package/rust/core/audio/interpreter/statements/arrow_call/types/sub.rs +0 -100
  164. package/rust/core/audio/interpreter/statements/automate.rs +0 -16
  165. package/rust/core/audio/interpreter/statements/call.rs +0 -295
  166. package/rust/core/audio/interpreter/statements/condition.rs +0 -72
  167. package/rust/core/audio/interpreter/statements/function.rs +0 -24
  168. package/rust/core/audio/interpreter/statements/let_.rs +0 -36
  169. package/rust/core/audio/interpreter/statements/load.rs +0 -17
  170. package/rust/core/audio/interpreter/statements/loop_.rs +0 -115
  171. package/rust/core/audio/interpreter/statements/mod.rs +0 -12
  172. package/rust/core/audio/interpreter/statements/sleep.rs +0 -28
  173. package/rust/core/audio/interpreter/statements/spawn.rs +0 -253
  174. package/rust/core/audio/interpreter/statements/tempo.rs +0 -40
  175. package/rust/core/audio/interpreter/statements/trigger.rs +0 -239
  176. package/rust/core/audio/loader/mod.rs +0 -1
  177. package/rust/core/audio/loader/trigger.rs +0 -98
  178. package/rust/core/audio/mod.rs +0 -6
  179. package/rust/core/audio/player.rs +0 -70
  180. package/rust/core/audio/special/easing.rs +0 -189
  181. package/rust/core/audio/special/env.rs +0 -45
  182. package/rust/core/audio/special/math.rs +0 -134
  183. package/rust/core/audio/special/mod.rs +0 -9
  184. package/rust/core/audio/special/modulator.rs +0 -143
  185. package/rust/core/builder/mod.rs +0 -129
  186. package/rust/core/debugger/lexer.rs +0 -27
  187. package/rust/core/debugger/logs.rs +0 -52
  188. package/rust/core/debugger/mod.rs +0 -30
  189. package/rust/core/debugger/preprocessor.rs +0 -27
  190. package/rust/core/debugger/store.rs +0 -38
  191. package/rust/core/error/mod.rs +0 -269
  192. package/rust/core/lexer/driver.rs +0 -59
  193. package/rust/core/lexer/handler/arrow.rs +0 -82
  194. package/rust/core/lexer/handler/at.rs +0 -21
  195. package/rust/core/lexer/handler/brace.rs +0 -41
  196. package/rust/core/lexer/handler/colon.rs +0 -21
  197. package/rust/core/lexer/handler/comment.rs +0 -30
  198. package/rust/core/lexer/handler/dot.rs +0 -21
  199. package/rust/core/lexer/handler/driver.rs +0 -337
  200. package/rust/core/lexer/handler/identifier.rs +0 -47
  201. package/rust/core/lexer/handler/indent.rs +0 -66
  202. package/rust/core/lexer/handler/mod.rs +0 -15
  203. package/rust/core/lexer/handler/newline.rs +0 -23
  204. package/rust/core/lexer/handler/number.rs +0 -31
  205. package/rust/core/lexer/handler/operator.rs +0 -46
  206. package/rust/core/lexer/handler/parenthesis.rs +0 -41
  207. package/rust/core/lexer/handler/slash.rs +0 -21
  208. package/rust/core/lexer/handler/string.rs +0 -63
  209. package/rust/core/lexer/mod.rs +0 -3
  210. package/rust/core/lexer/token.rs +0 -91
  211. package/rust/core/mod.rs +0 -9
  212. package/rust/core/parser/driver/block.rs +0 -111
  213. package/rust/core/parser/driver/cursor.rs +0 -82
  214. package/rust/core/parser/driver/driver_impl.rs +0 -139
  215. package/rust/core/parser/driver/mod.rs +0 -6
  216. package/rust/core/parser/driver/parse_array.rs +0 -120
  217. package/rust/core/parser/driver/parse_map.rs +0 -223
  218. package/rust/core/parser/driver/parser.rs +0 -160
  219. package/rust/core/parser/handler/arrow_call.rs +0 -277
  220. package/rust/core/parser/handler/at.rs +0 -279
  221. package/rust/core/parser/handler/bank.rs +0 -104
  222. package/rust/core/parser/handler/condition.rs +0 -83
  223. package/rust/core/parser/handler/dot.rs +0 -148
  224. package/rust/core/parser/handler/identifier/automate.rs +0 -254
  225. package/rust/core/parser/handler/identifier/call.rs +0 -91
  226. package/rust/core/parser/handler/identifier/emit.rs +0 -70
  227. package/rust/core/parser/handler/identifier/function.rs +0 -113
  228. package/rust/core/parser/handler/identifier/group.rs +0 -89
  229. package/rust/core/parser/handler/identifier/let_.rs +0 -173
  230. package/rust/core/parser/handler/identifier/mod.rs +0 -55
  231. package/rust/core/parser/handler/identifier/on.rs +0 -107
  232. package/rust/core/parser/handler/identifier/print.rs +0 -49
  233. package/rust/core/parser/handler/identifier/sleep.rs +0 -96
  234. package/rust/core/parser/handler/identifier/spawn.rs +0 -91
  235. package/rust/core/parser/handler/identifier/synth.rs +0 -135
  236. package/rust/core/parser/handler/loop_.rs +0 -194
  237. package/rust/core/parser/handler/mod.rs +0 -9
  238. package/rust/core/parser/handler/pattern.rs +0 -74
  239. package/rust/core/parser/handler/tempo.rs +0 -105
  240. package/rust/core/parser/mod.rs +0 -3
  241. package/rust/core/parser/statement.rs +0 -10
  242. package/rust/core/plugin/loader.rs +0 -137
  243. package/rust/core/plugin/mod.rs +0 -2
  244. package/rust/core/plugin/runner/mod.rs +0 -11
  245. package/rust/core/plugin/runner/non_wasm.rs +0 -297
  246. package/rust/core/plugin/runner/wasm32.rs +0 -43
  247. package/rust/core/preprocessor/loader/inject.rs +0 -278
  248. package/rust/core/preprocessor/loader/loader_helpers.rs +0 -110
  249. package/rust/core/preprocessor/loader/mod.rs +0 -235
  250. package/rust/core/preprocessor/mod.rs +0 -4
  251. package/rust/core/preprocessor/module.rs +0 -55
  252. package/rust/core/preprocessor/processor/handlers.rs +0 -107
  253. package/rust/core/preprocessor/processor/mod.rs +0 -1
  254. package/rust/core/preprocessor/resolver/bank.rs +0 -49
  255. package/rust/core/preprocessor/resolver/call.rs +0 -124
  256. package/rust/core/preprocessor/resolver/condition.rs +0 -95
  257. package/rust/core/preprocessor/resolver/driver.rs +0 -324
  258. package/rust/core/preprocessor/resolver/function.rs +0 -69
  259. package/rust/core/preprocessor/resolver/group.rs +0 -122
  260. package/rust/core/preprocessor/resolver/let_.rs +0 -32
  261. package/rust/core/preprocessor/resolver/loop_.rs +0 -318
  262. package/rust/core/preprocessor/resolver/mod.rs +0 -16
  263. package/rust/core/preprocessor/resolver/pattern.rs +0 -83
  264. package/rust/core/preprocessor/resolver/spawn.rs +0 -99
  265. package/rust/core/preprocessor/resolver/synth.rs +0 -54
  266. package/rust/core/preprocessor/resolver/tempo.rs +0 -48
  267. package/rust/core/preprocessor/resolver/trigger.rs +0 -116
  268. package/rust/core/preprocessor/resolver/value.rs +0 -176
  269. package/rust/core/store/global.rs +0 -57
  270. package/rust/core/store/mod.rs +0 -1
  271. package/rust/lib.rs +0 -323
  272. package/rust/main.rs +0 -388
  273. package/rust/types/Cargo.toml +0 -11
  274. package/rust/types/src/addons.rs +0 -55
  275. package/rust/types/src/ast.rs +0 -202
  276. package/rust/types/src/config.rs +0 -84
  277. package/rust/types/src/lib.rs +0 -15
  278. package/rust/types/src/plugin.rs +0 -20
  279. package/rust/types/src/store.rs +0 -139
  280. package/rust/types/src/telemetry.rs +0 -85
  281. package/rust/utils/Cargo.toml +0 -26
  282. package/rust/utils/src/error.rs +0 -186
  283. package/rust/utils/src/file.rs +0 -94
  284. package/rust/utils/src/first_usage.rs +0 -97
  285. package/rust/utils/src/lib.rs +0 -9
  286. package/rust/utils/src/logger.rs +0 -200
  287. package/rust/utils/src/path.rs +0 -129
  288. package/rust/utils/src/signature.rs +0 -41
  289. package/rust/utils/src/spinner.rs +0 -20
  290. package/rust/utils/src/version.rs +0 -27
  291. package/rust/utils/src/watcher.rs +0 -46
  292. package/rust/web/api.rs +0 -5
  293. package/rust/web/cdn.rs +0 -34
  294. package/rust/web/mod.rs +0 -3
  295. package/rust/web/sso.rs +0 -5
  296. package/templates/minimal/.devalang +0 -5
  297. package/templates/minimal/README.md +0 -218
  298. package/templates/minimal/src/index.deva +0 -2
  299. package/templates/welcome/.devalang +0 -5
  300. package/templates/welcome/README.md +0 -218
  301. package/templates/welcome/samples/kick-808.wav +0 -0
  302. package/templates/welcome/src/index.deva +0 -61
  303. package/templates/welcome/src/variables.deva +0 -3
  304. package/tests/integration.rs +0 -21
  305. package/tests/rust/cli_check_build.rs +0 -21
  306. package/tests/rust/cli_help.rs +0 -12
  307. package/tests/rust/cli_template_list.rs +0 -10
  308. package/tests/rust/cli_version.rs +0 -11
  309. package/tests/typescript/index.spec.ts +0 -136
  310. package/tests/typescript/playhead.spec.ts +0 -36
  311. package/tests/typescript/render_e2e.spec.ts +0 -77
  312. package/tsconfig.json +0 -115
  313. package/typescript/bin/index.ts +0 -28
  314. package/typescript/core/functions/index.ts +0 -94
  315. package/typescript/core/index.ts +0 -6
  316. package/typescript/core/types/index.ts +0 -4
  317. package/typescript/core/types/plugin.ts +0 -19
  318. package/typescript/core/types/result.ts +0 -29
  319. package/typescript/core/types/statement.ts +0 -47
  320. package/typescript/core/types/value.ts +0 -29
  321. package/typescript/index.ts +0 -8
  322. package/typescript/pkg/devalang_core.d.ts +0 -4
  323. package/typescript/pkg/devalang_core.ts +0 -65
  324. package/typescript/scripts/copy-wasm-dts.ts +0 -41
  325. package/typescript/scripts/postinstall.ts +0 -85
  326. package/typescript/scripts/version/bump.ts +0 -44
  327. package/typescript/scripts/version/fetch.ts +0 -18
  328. package/typescript/scripts/version/index.ts +0 -25
  329. package/typescript/scripts/version/sync.ts +0 -24
package/docs/ROADMAP.md DELETED
@@ -1,38 +0,0 @@
1
- <div align="center">
2
- <img src="https://devalang.com/images/devalang-logo-min.png" alt="Devalang Logo" width="100" />
3
- </div>
4
-
5
- # Roadmap
6
-
7
- Devalang is a work in progress. Here’s what we’re planning next:
8
-
9
- ## Completed
10
-
11
- - ✅ **Audio engine**: Integrate the audio engine for sound playback.
12
- - ✅ **MIDI export**: Implement MIDI export functionality to save compositions as MIDI files.
13
- - ✅ **Basic syntax**: Implement the core syntax for Devalang, including data types and basic statements.
14
- - ✅ **Watch mode**: Add a watch mode to automatically rebuild on file changes.
15
- - ✅ **Module system**: Add support for importing and exporting variables between files using `@import` and `@export`.
16
- - ✅ **AST generation**: Implement the Abstract Syntax Tree (AST) generation for debugging and future compilation.
17
- - ✅ **Basic data types**: Support strings, numbers, booleans, maps, and arrays.
18
- - ✅ **BPM assignment**: Implement `bpm` assignment to set the tempo.
19
- - ✅ **Bank declaration**: Add `bank` declaration to define the instrument set.
20
- - ✅ **Looping system**: Implement a looping system with fixed repetitions using `loop 4:`.
21
- - ✅ **Instruction calls**: Add support for instruction calls with parameters (e.g. `.kick auto {reverb:10, decay:20}`).
22
- - ✅ **Let assignments**: Implement `let` assignments for storing reusable values.
23
- - ✅ **Sample loading**: Add `@load` assignment to load samples (.mp3, .wav) for use as values.
24
- - ✅ **WASM support**: Compile Devalang to WebAssembly for use in web applications and other environments.
25
- - ✅ **VSCode extension**: Create a VSCode extension for syntax highlighting and code completion.
26
-
27
- ## In Progress
28
-
29
- - ⏳ **Addon generator**: Implement addon generation for creating reusable plugins, banks and presets.
30
- - ⏳ **Testing**: Expand test coverage for all features.
31
-
32
- ## Planned
33
-
34
- - ⏳ **MIDI mapping**: Implement MIDI mapping for external control.
35
- - ⏳ **GUI**: Develop a graphical user interface for easier interaction.
36
- - ⏳ **Mixing & Routing**: Implement mixing and routing capabilities for advanced audio control.
37
- - ⏳ **Effect chains**: Implement effect chains for applying multiple effects to a single note or group.
38
- - ⏳ **Smart modules**: Let Devalang detect and use groups, samples, and variables without needing to import them manually.
package/docs/TODO.md DELETED
@@ -1,71 +0,0 @@
1
- <div align="center">
2
- <img src="https://devalang.com/images/devalang-logo-min.png" alt="Devalang Logo" width="100" />
3
- </div>
4
-
5
- # TODOs list
6
-
7
- This is a list of tasks and features to be implemented in Devalang. Note that this is not an exhaustive list, and some items may be added or removed over time.
8
-
9
- ## Commands
10
-
11
- - [x] Init project
12
- - [x] Implement init command
13
- - [x] Implement template selector
14
- - [x] Template
15
- - [x] Implement template list
16
- - [x] Implement template info
17
- - [x] Checking
18
- - [x] Implement watch mode
19
- - [x] Implement debug mode
20
- - [x] Building
21
- - [x] Implement watch mode
22
- - [x] Implement debug mode
23
- - [x] Implement compression mode
24
- - [x] Play
25
- - [x] Implement Audio Engine
26
- - [x] Implement debug mode
27
- - [x] Implement loop mode
28
-
29
- ## Core components
30
-
31
- - [x] Audio Engine
32
- - [x] Lexer
33
- - [x] Parser
34
- - [x] Preprocessor
35
- - [x] Debugger
36
- - [x] Builder
37
-
38
- ## Syntax elements
39
-
40
- - [x] #
41
- - [x] @import
42
- - [x] @export
43
- - [x] @load
44
- - [x] function
45
- - [x] pattern
46
- - [x] group
47
- - [x] call
48
- - [x] spawn
49
- - [x] sleep
50
- - [x] bpm
51
- - [x] bank
52
- - [x] loop
53
- - [x] let
54
- - [x] if
55
- - [x] else
56
- - [x] else if
57
-
58
- ## Triggers
59
-
60
- - [x] Custom triggers
61
- - [x] Event triggers
62
-
63
- ## Banks
64
-
65
- - [x] Implement bank management (e.g. install, remove, list)
66
- - [x] Create example banks
67
-
68
- ## Plugins
69
-
70
- - [x] Implement plugin system (e.g. install, remove, list)
71
- - [ ] Create example plugins
@@ -1,42 +0,0 @@
1
- bpm 120
2
-
3
- group myLead:
4
- let mySynth = synth sine
5
-
6
- # This will automate all notes inside mySynth
7
- # automate mySynth:
8
- # param volume {
9
- # 0% = 0.0
10
- # 100% = 1.0
11
- # }
12
- # param pan {
13
- # 0% = -1.0
14
- # 100% = 1.0
15
- # }
16
- # param pitch {
17
- # 0% = -12.0
18
- # 100% = 12.0
19
- # }
20
-
21
- # This will automate only one note
22
- mySynth -> note(C4, {
23
- duration: 400,
24
- automate: {
25
- pitch: {
26
- 0%: -12.0
27
- 100%: 12.0
28
- },
29
- pan: {
30
- 0%: -1.0,
31
- 100%: 1.0
32
- }
33
- }
34
- })
35
- mySynth -> note(G4, { duration: 400 })
36
- mySynth -> note(E4, { duration: 600 })
37
- mySynth -> note(A4, { duration: 400 })
38
- mySynth -> note(F4, { duration: 800 })
39
- mySynth -> note(D4, { duration: 400 })
40
- mySynth -> note(B3, { duration: 600 })
41
-
42
- call myLead
@@ -1,7 +0,0 @@
1
- # This file demonstrates the use of banks in Devalang.
2
-
3
- bank devaloop.808 as myBank
4
-
5
- .myBank.kick auto
6
- .myBank.snare auto
7
- .myBank.openhat auto
package/examples/bus.deva DELETED
@@ -1,10 +0,0 @@
1
- # NOTE Planned for future release
2
-
3
- # let sidechainBus = bus {
4
- # fx: [
5
- # { type: "compressor", threshold: -20, ratio: 8, attack: 5, release: 100,
6
- # sidechain: myKick }
7
- # ]
8
- # }
9
- # route myLead -> sidechainBus -> masterBus
10
- # route myKick -> myBass -> masterBus
@@ -1,20 +0,0 @@
1
- # This file demonstrates the use of conditional blocks in Devalang.
2
-
3
- @import { duration, default_bank, params, loopCount, tempo } from "./variables.deva"
4
- @import { myGroup } from "./group.deva"
5
-
6
- @load "./samples/kick-808.wav" as kickCustom
7
- @load "./samples/hat-808.wav" as hatCustom
8
-
9
- group conditionBlock:
10
- if tempo > 120:
11
- # Will be executed if the condition is true
12
- .kickCustom auto
13
- else if tempo > 155:
14
- # Will be executed if the condition is false
15
- .hatCustom auto
16
- else:
17
- .kickCustom auto
18
- .hatCustom auto
19
-
20
- @export { conditionBlock }
@@ -1,9 +0,0 @@
1
- # This file demonstrates the use of duration in Devalang.
2
-
3
- @load "./samples/kick-808.wav" as kickCustom
4
- @load "./samples/hat-808.wav" as hatCustom
5
-
6
- .kickCustom 1/4
7
- .hatCustom 1/8
8
- .kickCustom 1/4
9
- .hatCustom 1/8
@@ -1,2 +0,0 @@
1
- # NOTE Planned for future release
2
- # myChord -> note(C4) -> arp({ pattern: "up", rate: 1/8 }) -> slide({ duration: 2000 }) -> echo({ delay: 250, feedback: 0.5 }) -> reverb({ room_size: 0.8 })
@@ -1,12 +0,0 @@
1
- bpm 120
2
-
3
- on beat:
4
- print "kick on each beat"
5
-
6
- on bar:
7
- print "bar!"
8
-
9
- on custom(value):
10
- print "custom event with value: " + value
11
-
12
- emit custom(10)
@@ -1,11 +0,0 @@
1
- let myFilteredSynth = synth sine {
2
- filters: [
3
- { type: "lowpass", cutoff: 800.0, resonance: 1.0 },
4
- { type: "bandpass", cutoff: 400.0, resonance: 1.0 },
5
- { type: "highpass", cutoff: 200.0, resonance: 1.0 }
6
- ],
7
- }
8
-
9
- myFilteredSynth -> note(C4, { duration: 500 })
10
- myFilteredSynth -> note(E4, { duration: 500 })
11
- myFilteredSynth -> note(G4, { duration: 500 })
@@ -1,15 +0,0 @@
1
- # This file demonstrates the use of main features in Devalang.
2
- bpm 135
3
-
4
- bank devaloop.808 as myBank
5
-
6
- let entityTest1 = .myBank.kick auto
7
- let entityTest2 = .myBank.clap auto
8
- let entityTest3 = .myBank.snare auto
9
-
10
- fn myFirstGroup(entity1, entity2, entity3):
11
- .entity1
12
- .entity2
13
- .entity3
14
-
15
- call myFirstGroup(entityTest1, entityTest2, entityTest3)
@@ -1,12 +0,0 @@
1
- # This file demonstrates the use of grouping in Devalang.
2
-
3
- @import { duration, default_bank, params, loopCount, tempo } from "./variables.deva"
4
-
5
- @load "./samples/kick-808.wav" as kickCustom
6
- @load "./samples/hat-808.wav" as hatCustom
7
-
8
- group myGroup:
9
- .kickCustom duration params
10
- .hatCustom duration params
11
-
12
- @export { myGroup }
@@ -1,63 +0,0 @@
1
- # This file demonstrates general use cases of Devalang.
2
-
3
- # BPM definition
4
- bpm 125
5
-
6
- # Bank picking (make sure you've installed it)
7
- bank devaloop.808 as my808Bank
8
-
9
- # Pattern literal without options
10
- pattern kickPattern with my808Bank.kick = "x--- x--- x--- x---"
11
-
12
- group myGroup:
13
- # Rhythmic (each beat playing a kick)
14
- # on beat:
15
- # .my808Bank.kick 1/4
16
-
17
- # Synth definition with ADSR
18
- let myLead = synth sine {
19
- attack: 0,
20
- decay: 100,
21
- sustain: 100,
22
- release: 100
23
- }
24
-
25
- # Global automation
26
- automate myLead:
27
- param volume {
28
- 0% = 0.0
29
- 100% = 0.5
30
- }
31
- param pitch {
32
- 0% = -12.0
33
- 100% = 12.0
34
- }
35
-
36
- # Notes in a loop with condition
37
- for i in [1, 2, 3]:
38
- if i == 3:
39
- myLead -> note(C5, { duration: 200 })
40
- print "Playing note C5 for " + i
41
-
42
- # Pause runtime for 500ms
43
- sleep 500
44
-
45
- # Note with automation
46
- myLead -> note(C4, {
47
- duration: 400,
48
- velocity: 0.8,
49
- automate: {
50
- pan: {
51
- 0%: -1.0,
52
- 100%: 0.0
53
- }
54
- }
55
- })
56
-
57
- # Notes with params
58
- myLead -> note(G4, { duration: 600, glide: true, target_freq: 659.25 })
59
- myLead -> note(B3, { duration: 400, slide: true, target_amp: 0.3 })
60
-
61
- # Spawning the group & the pattern to play them in parallel
62
- spawn myGroup
63
- spawn kickPattern
package/examples/lfo.deva DELETED
@@ -1,9 +0,0 @@
1
- let myLFOSynth = synth sine {
2
- lfo: {
3
- rate: 1/4,
4
- depth: 0.5,
5
- target: "cutoff"
6
- }
7
- }
8
-
9
- myLFOSynth -> note(C4, { duration: 500 })
@@ -1,10 +0,0 @@
1
- # This file demonstrates the use of loops in Devalang.
2
-
3
- group myLoop:
4
- for i in [1, 2, 3]:
5
- print "looping with for" + i
6
-
7
- loop 3:
8
- print "looping with loop"
9
-
10
- @export { myLoop }
@@ -1,8 +0,0 @@
1
- # This file demonstrates the usage of patterns in Devaloop
2
-
3
- bank devaloop.808 as my808
4
-
5
- # Pattern literal without options
6
- pattern kickPattern with my808.kick = "x--- x--- x--- x---"
7
-
8
- call kickPattern
@@ -1,16 +0,0 @@
1
- # This is an example of using a plugin in Devalang.
2
- # Make sure you have the plugin installed in your Devaloop application. (devalang install plugin <author>.<plugin_name>)
3
-
4
- @use devaloop.acid as acidPlugin
5
-
6
- let acidSynth = synth acidPlugin.synth {
7
- waveform: "saw",
8
- accent: 0.1,
9
- decay: 250
10
- }
11
-
12
- group mySynthGroup:
13
- acidSynth -> note(C4, { duration: 600 })
14
- acidSynth -> note(E4, { duration: 600 })
15
-
16
- call mySynthGroup
Binary file
Binary file
@@ -1,24 +0,0 @@
1
- # This file defines a simple synth lead using Devalang's syntax.
2
-
3
- group myLead:
4
- let mySynth = synth sine
5
-
6
- mySynth -> note(C4, { duration: 400 })
7
- mySynth -> note(G4, { duration: 400 })
8
- mySynth -> note(E4, { duration: 600 })
9
- mySynth -> note(A4, { duration: 400 })
10
- mySynth -> note(F4, { duration: 800 })
11
- mySynth -> note(D4, { duration: 400 })
12
- mySynth -> note(B3, { duration: 600 })
13
-
14
- group myChords:
15
- let chordSynth = synth square
16
-
17
- chordSynth -> chord(Cmaj, { duration: 1600 })
18
- chordSynth -> chord(Fmaj, { duration: 1600 })
19
- chordSynth -> chord(Gmaj, { duration: 1600 })
20
- chordSynth -> chord(Am, { duration: 1600 })
21
-
22
- # Play both groups together
23
- spawn myLead
24
- spawn myChords
@@ -1,17 +0,0 @@
1
- let myPad = synth sine {
2
- type: "pad"
3
- }
4
-
5
- let myPluck = synth sine {
6
- type: "pluck"
7
- }
8
-
9
- let myArp = synth sine {
10
- type: "arp",
11
- rate: 16,
12
- step: 2
13
- }
14
-
15
- let mySub = synth sine {
16
- type: "sub",
17
- }
@@ -1,9 +0,0 @@
1
- # This file only exports variables for use in other files.
2
-
3
- let duration = auto
4
- let default_bank = devaloop.808
5
- let params = { decay: 10, delay: 30 }
6
- let loopCount = 5
7
- let tempo = 115
8
-
9
- @export { duration, default_bank, params, loopCount, tempo }
@@ -1,42 +0,0 @@
1
- import { ParseResult } from "../types/result";
2
- import { DebugResult } from "../types/result";
3
- /**
4
- * Parses the user code.
5
- * @param entry_path The entry path for the code.
6
- * @param source The source code to parse.
7
- * @returns ParseResult | any
8
- */
9
- export declare function parse(entry_path: string, source: string): ParseResult | any;
10
- /**
11
- * Renders the debug information for the user code.
12
- * @param user_code The user-provided code to render debug information for.
13
- * @returns DebugResult | any
14
- */
15
- export declare function debug_render(user_code: string): DebugResult | any;
16
- /**
17
- * Renders audio from the user code.
18
- * @param user_code The user-provided code to render audio from.
19
- * @returns Float32Array
20
- */
21
- export declare function render_audio(user_code: string): Float32Array;
22
- /**
23
- * Register a JS callback to receive playhead events { time, line, column } during playback.
24
- * The callback will be called with a single object argument.
25
- * @param cb The callback function to register.
26
- * @returns void
27
- */
28
- export declare function register_playhead_callback(cb: (ev: {
29
- time: number;
30
- line: number;
31
- column: number;
32
- }) => void): any;
33
- /**
34
- * Collects playhead events that have been recorded during playback.
35
- * @returns Array of playhead events { time, line, column }.
36
- */
37
- export declare function collect_playhead_events(): any;
38
- /**
39
- * Unregisters the JS callback for playhead events.
40
- * @returns void
41
- */
42
- export declare function unregister_playhead_callback(): any;
@@ -1,87 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.parse = parse;
4
- exports.debug_render = debug_render;
5
- exports.render_audio = render_audio;
6
- exports.register_playhead_callback = register_playhead_callback;
7
- exports.collect_playhead_events = collect_playhead_events;
8
- exports.unregister_playhead_callback = unregister_playhead_callback;
9
- let wasmPkg = undefined;
10
- try {
11
- // prefer runtime pkg generated by wasm-pack when available
12
- // require at runtime so the package can be used even if wasm hasn't been built
13
- // (this keeps tests and consumers robust).
14
- // eslint-disable-next-line @typescript-eslint/no-var-requires
15
- wasmPkg = require("../../pkg/devalang_core");
16
- }
17
- catch (_e) {
18
- wasmPkg = undefined;
19
- }
20
- /**
21
- * Parses the user code.
22
- * @param entry_path The entry path for the code.
23
- * @param source The source code to parse.
24
- * @returns ParseResult | any
25
- */
26
- function parse(entry_path, source) {
27
- if (wasmPkg && typeof wasmPkg.parse === "function") {
28
- return wasmPkg.parse(entry_path, source);
29
- }
30
- throw new Error("WASM binding 'parse' not available. Build the wasm package or use the JS runtime.");
31
- }
32
- /**
33
- * Renders the debug information for the user code.
34
- * @param user_code The user-provided code to render debug information for.
35
- * @returns DebugResult | any
36
- */
37
- function debug_render(user_code) {
38
- if (wasmPkg && typeof wasmPkg.debug_render === "function") {
39
- return wasmPkg.debug_render(user_code);
40
- }
41
- throw new Error("WASM binding 'debug_render' not available. Build the wasm package or use the JS runtime.");
42
- }
43
- /**
44
- * Renders audio from the user code.
45
- * @param user_code The user-provided code to render audio from.
46
- * @returns Float32Array
47
- */
48
- function render_audio(user_code) {
49
- if (wasmPkg && typeof wasmPkg.render_audio === "function") {
50
- return wasmPkg.render_audio(user_code);
51
- }
52
- // Fallback: indicate missing wasm with an empty buffer rather than breaking consumers.
53
- return new Float32Array(0);
54
- }
55
- /**
56
- * Register a JS callback to receive playhead events { time, line, column } during playback.
57
- * The callback will be called with a single object argument.
58
- * @param cb The callback function to register.
59
- * @returns void
60
- */
61
- function register_playhead_callback(cb) {
62
- if (wasmPkg && typeof wasmPkg.register_playhead_callback === "function") {
63
- return wasmPkg.register_playhead_callback(cb);
64
- }
65
- // no-op fallback
66
- return;
67
- }
68
- /**
69
- * Collects playhead events that have been recorded during playback.
70
- * @returns Array of playhead events { time, line, column }.
71
- */
72
- function collect_playhead_events() {
73
- if (wasmPkg && typeof wasmPkg.collect_playhead_events === "function") {
74
- return wasmPkg.collect_playhead_events();
75
- }
76
- return [];
77
- }
78
- /**
79
- * Unregisters the JS callback for playhead events.
80
- * @returns void
81
- */
82
- function unregister_playhead_callback() {
83
- if (wasmPkg && typeof wasmPkg.unregister_playhead_callback === "function") {
84
- return wasmPkg.unregister_playhead_callback();
85
- }
86
- return;
87
- }
@@ -1,6 +0,0 @@
1
- /**
2
- * Core functionality for the Devalang language.
3
- * This module exports all the core types and functions used in the language.
4
- */
5
- export * from "./types/index";
6
- export * from "./functions/index";
@@ -1,4 +0,0 @@
1
- export * from "./result";
2
- export * from "./statement";
3
- export * from "./value";
4
- export * from "./plugin";
@@ -1,20 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./result"), exports);
18
- __exportStar(require("./statement"), exports);
19
- __exportStar(require("./value"), exports);
20
- __exportStar(require("./plugin"), exports);
@@ -1,18 +0,0 @@
1
- /**
2
- * Represents a plugin export.
3
- */
4
- export interface PluginExport {
5
- name: string;
6
- kind: string;
7
- default?: any;
8
- }
9
- /**
10
- * Represents a plugin.
11
- */
12
- export interface PluginInfo {
13
- author: string;
14
- name: string;
15
- version?: string;
16
- description?: string;
17
- exports: PluginExport[];
18
- }
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,27 +0,0 @@
1
- /**
2
- * Represents an error that occurred during parsing.
3
- */
4
- export interface ErrorResult {
5
- message: string;
6
- line: number;
7
- column: number;
8
- }
9
- /**
10
- * Represents the result of parsing user code.
11
- */
12
- export interface ParseResult {
13
- ok: boolean;
14
- ast: string;
15
- errors: ErrorResult[];
16
- }
17
- /**
18
- * Represents the result of debugging user code.
19
- */
20
- export interface DebugResult {
21
- samples_len: number;
22
- any_nonzero: boolean;
23
- ast: string;
24
- note_count: number;
25
- global_vars: string[];
26
- statements_count: number;
27
- }
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });