@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
package/rust/web/sso.rs DELETED
@@ -1,5 +0,0 @@
1
- pub fn get_sso_url() -> String {
2
- let sso_url = "https://sso.devalang.com";
3
- // let sso_url = "http://localhost:5174";
4
- sso_url.to_string()
5
- }
@@ -1,5 +0,0 @@
1
- [defaults]
2
- entry = "./src"
3
- output = "./output"
4
- watch = false
5
- repeat = false
@@ -1,218 +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
- ![Rust](https://img.shields.io/badge/Made%20with-Rust-orange?logo=rust)
6
- ![TypeScript](https://img.shields.io/badge/Built%20with-TypeScript-blue?logo=typescript)
7
- ![Node.js](https://img.shields.io/badge/Node.js-18%2B-brightgreen?logo=node.js)
8
-
9
- ![Project Status](https://img.shields.io/badge/status-beta-blue)
10
- ![Version](https://img.shields.io/npm/v/@devaloop/devalang)
11
- ![License: MIT](https://img.shields.io/badge/license-MIT-green)
12
-
13
- ![Linux](https://img.shields.io/badge/linux-supported-blue?logo=linux)
14
- ![macOS](https://img.shields.io/badge/macOS-supported-blue?logo=apple)
15
- ![Windows](https://img.shields.io/badge/windows-supported-blue?logo=windows)
16
-
17
- ![npm](https://img.shields.io/npm/dt/@devaloop/devalang)
18
- ![crates](https://img.shields.io/crates/d/devalang)
19
-
20
- ![GitHub Actions Workflow Status](https://img.shields.io/github/actions/workflow/status/devaloop-labs/devalang/.github/workflows/ci.yml)
21
-
22
- # 🦊 Devalang (CORE) — Compose music with code
23
-
24
- Devalang is a tiny domain-specific language (DSL) for music makers, sound designers, and audio hackers.
25
- Compose loops, control samples, render and play audio — all in clean, readable text.
26
-
27
- Whether you're building a track, shaping textures, or performing live, Devalang helps you think in rhythms. It’s designed to be simple, expressive, and fast — because your ideas shouldn’t wait.
28
-
29
- From studio sketches to live sets, Devalang gives you rhythmic control — with the elegance of code.
30
-
31
- > **🚧 Notice 🚧**
32
- >
33
- > Includes synthesis, playback, and rendering features, but is still in early development, and breaking changes may occur.
34
- >
35
- > **NEW**: [Devaforge is now available for creating addons](https://github.com/devaloop-labs/devaforge).
36
- >
37
- > **NEW**: Now available for Windows, Linux, and macOS.
38
-
39
- ## 📚 Quick Access
40
-
41
- - [▶️ Playground](https://playground.devalang.com)
42
- - [📖 Documentation](https://docs.devalang.com)
43
- - [🧩 VSCode Extension](https://marketplace.visualstudio.com/items?itemName=devaloop.devalang-vscode)
44
- - [🎨 Prettier Plugin](https://www.npmjs.com/package/@devaloop/prettier-plugin-devalang)
45
- - [📜 Changelog](./docs/CHANGELOG.md)
46
- - [💡 Examples](./examples/)
47
- - [🌐 Project Website](https://devalang.com)
48
- - [📦 Devaforge on npm](https://www.npmjs.com/package/@devaloop/devaforge)
49
- - [📦 Devalang on npm](https://www.npmjs.com/package/@devaloop/devalang)
50
-
51
- ## ⏱️ Try it now !
52
-
53
- ### Try Devalang in your browser
54
-
55
- > [Have a look at the Playground to try Devalang directly in your browser](https://playground.devalang.com)
56
-
57
- ### Try Devalang in your terminal
58
-
59
- #### With Node.js
60
-
61
- ```bash
62
- npm install -g @devaloop/devalang@latest
63
- ```
64
-
65
- #### With Rust
66
-
67
- ```bash
68
- cargo install devalang
69
- ```
70
-
71
- #### Initialize a new project
72
-
73
- ```bash
74
- devalang init --name my-project --template minimal
75
- ```
76
-
77
- #### Write your first script
78
-
79
- Create a new Devalang file `src/index.deva` in the project directory:
80
-
81
- ```deva
82
- # src/index.deva
83
-
84
- # BPM definition
85
- bpm 125
86
-
87
- # Bank picking (make sure you've installed it)
88
- bank devaloop.808 as my808Bank
89
-
90
- # Pattern literal without options
91
- pattern kickPattern with my808Bank.kick = "x--- x--- x--- x---"
92
-
93
- group myGroup:
94
- # Rhythmic (each beat playing a kick)
95
- # on beat:
96
- # .my808Bank.kick 1/4
97
-
98
- # Synth definition with ADSR
99
- let myLead = synth sine {
100
- attack: 0,
101
- decay: 100,
102
- sustain: 100,
103
- release: 100
104
- }
105
-
106
- # Global automation
107
- automate myLead:
108
- param volume {
109
- 0% = 0.0
110
- 100% = 0.5
111
- }
112
- param pitch {
113
- 0% = -12.0
114
- 100% = 12.0
115
- }
116
-
117
- # Notes in a loop with condition
118
- for i in [1, 2, 3]:
119
- if i == 3:
120
- myLead -> note(C5, { duration: 200 })
121
- print "Playing note C5 for " + i
122
-
123
- # Pause runtime for 500ms
124
- sleep 500
125
-
126
- # Note with automation
127
- myLead -> note(C4, {
128
- duration: 400,
129
- velocity: 0.8,
130
- automate: {
131
- pan: {
132
- 0%: -1.0,
133
- 100%: 0.0
134
- }
135
- }
136
- })
137
-
138
- # Notes with params
139
- myLead -> note(G4, { duration: 600, glide: true, target_freq: 659.25 })
140
- myLead -> note(B3, { duration: 400, slide: true, target_amp: 0.3 })
141
-
142
- # Spawning the group & the pattern to play them in parallel
143
- spawn myGroup
144
- spawn kickPattern
145
- ```
146
-
147
- ### And the best part ? You can play it directly from the command line:
148
-
149
- #### Play the script once
150
-
151
- ```bash
152
- devalang play
153
- ```
154
-
155
- #### **LIVE mode** (repeat the playback + watch mode)
156
-
157
- ```bash
158
- devalang play --repeat
159
- ```
160
-
161
- ### 🎉 You can now hear your Devalang code in action
162
-
163
- > For more examples, check out the [examples directory](./examples/)
164
-
165
- ## ❓ Why Devalang ?
166
-
167
- - 🎹 Prototype audio ideas without opening a DAW, even VSCode with our Playground
168
- - 💻 Integrate sound into code-based workflows
169
- - 🎛️ Control audio parameters through readable syntax
170
- - 🧪 Build musical logic with variables and conditions
171
- - 🔄 Create complex patterns with ease
172
-
173
- ## 🚀 Features
174
-
175
- - ⚡ **Fast Build & Hot Reload** — optimized build process for quicker iteration.
176
- - 🎵 **Audio Engine & Real-time runner** — low-latency playback, render-to-file, and a realtime runner used by `devalang play` for live feedback.
177
- - ▶️ **Live mode (watch + repeat)** — edit and hear changes instantly with `devalang play --repeat` and watch mode.
178
- - 🧩 **Language primitives** — synths, notes, ADSR, maps, arrays, loops, conditionals and functions for expressive musical logic.
179
- - 🎛️ **Per-note automation & modulators** — `automate` maps, `$mod.*`, `$easing.*` and `$math.*` helpers for envelopes and LFOs.
180
- - 🧩 **Module system & structured AST** — import/export variables, stable AST output for debugging and tooling.
181
- - 🧰 **Plugins & Addons (WASM-ready)** — install plugins/banks, `@use` directive, and WASM plugin integration so plugins can render or process audio at runtime.
182
- - 📦 **Addon manager & Devaforge** — CLI commands to discover/install banks, plugins and templates; `devaforge` helps create addons.
183
- - ⚙️ **CLI tooling** — `build`, `check`, `play`, `install`, `init`, `discover`, `telemetry` and more with consistent flags (`--watch`, `--debug`, `--compress`).
184
- - 📂 **Project templates & examples** — quick-start templates and many example projects in `examples/`.
185
- - 🧑‍💻 **TypeScript API & WASM distribution** — Node-friendly package with TypeScript bindings and a WASM build for browser/Node usage.
186
- - 🧰 **Editor & formatting support** — VSCode extension and Prettier plugin to edit Devalang with syntax and formatting support.
187
- - 🎵 **Custom samples & banks** — drop samples into `.deva` and reference them from code; banks of sounds for fast composition.
188
- - 🔄 **Looping, grouping & scheduling** — precise beat-tied scheduling primitives for complex rhythmic patterns.
189
-
190
- ## 📄 Documentation
191
-
192
- ### [Please refer to the online documentation](https://docs.devalang.com) for detailed information on syntax, features, and usage examples
193
-
194
- ## 📰 What's new
195
-
196
- - **Devaforge**: Introduced a new system for creating and managing addons, including a CLI for addon generation.
197
- - **Documentation updates**: Improved documentation for clarity and completeness.
198
- - **Discovering addons**: Introduced a new command to detect addons.
199
- - **Public TypeScript API**: Added a public TypeScript API for easier integration.
200
- - **Improved error messages**: Enhanced error messages for better debugging.
201
- - **Bug fixes**: Various bug fixes and stability improvements.
202
-
203
- ## 🛡️ License
204
-
205
- MIT — see [LICENSE](./LICENSE)
206
-
207
- ## 🤝 Contributing
208
-
209
- Contributions, bug reports and suggestions are welcome !
210
- Feel free to open an issue or submit a pull request.
211
-
212
- For more info, see [docs/CONTRIBUTING.md](./docs/CONTRIBUTING.md).
213
-
214
- ## 📢 Contact
215
-
216
- Feel free to reach out for any inquiries or feedback.
217
-
218
- 📧 [contact@devaloop.com](mailto:contact@devaloop.com)
@@ -1,2 +0,0 @@
1
- # Write your Devalang code here
2
- # ...
@@ -1,5 +0,0 @@
1
- [defaults]
2
- entry = "./src"
3
- output = "./output"
4
- watch = false
5
- repeat = false
@@ -1,218 +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
- ![Rust](https://img.shields.io/badge/Made%20with-Rust-orange?logo=rust)
6
- ![TypeScript](https://img.shields.io/badge/Built%20with-TypeScript-blue?logo=typescript)
7
- ![Node.js](https://img.shields.io/badge/Node.js-18%2B-brightgreen?logo=node.js)
8
-
9
- ![Project Status](https://img.shields.io/badge/status-beta-blue)
10
- ![Version](https://img.shields.io/npm/v/@devaloop/devalang)
11
- ![License: MIT](https://img.shields.io/badge/license-MIT-green)
12
-
13
- ![Linux](https://img.shields.io/badge/linux-supported-blue?logo=linux)
14
- ![macOS](https://img.shields.io/badge/macOS-supported-blue?logo=apple)
15
- ![Windows](https://img.shields.io/badge/windows-supported-blue?logo=windows)
16
-
17
- ![npm](https://img.shields.io/npm/dt/@devaloop/devalang)
18
- ![crates](https://img.shields.io/crates/d/devalang)
19
-
20
- ![GitHub Actions Workflow Status](https://img.shields.io/github/actions/workflow/status/devaloop-labs/devalang/.github/workflows/ci.yml)
21
-
22
- # 🦊 Devalang (CORE) — Compose music with code
23
-
24
- Devalang is a tiny domain-specific language (DSL) for music makers, sound designers, and audio hackers.
25
- Compose loops, control samples, render and play audio — all in clean, readable text.
26
-
27
- Whether you're building a track, shaping textures, or performing live, Devalang helps you think in rhythms. It’s designed to be simple, expressive, and fast — because your ideas shouldn’t wait.
28
-
29
- From studio sketches to live sets, Devalang gives you rhythmic control — with the elegance of code.
30
-
31
- > **🚧 Notice 🚧**
32
- >
33
- > Includes synthesis, playback, and rendering features, but is still in early development, and breaking changes may occur.
34
- >
35
- > **NEW**: [Devaforge is now available for creating addons](https://github.com/devaloop-labs/devaforge).
36
- >
37
- > **NEW**: Now available for Windows, Linux, and macOS.
38
-
39
- ## 📚 Quick Access
40
-
41
- - [▶️ Playground](https://playground.devalang.com)
42
- - [📖 Documentation](https://docs.devalang.com)
43
- - [🧩 VSCode Extension](https://marketplace.visualstudio.com/items?itemName=devaloop.devalang-vscode)
44
- - [🎨 Prettier Plugin](https://www.npmjs.com/package/@devaloop/prettier-plugin-devalang)
45
- - [📜 Changelog](./docs/CHANGELOG.md)
46
- - [💡 Examples](./examples/)
47
- - [🌐 Project Website](https://devalang.com)
48
- - [📦 Devaforge on npm](https://www.npmjs.com/package/@devaloop/devaforge)
49
- - [📦 Devalang on npm](https://www.npmjs.com/package/@devaloop/devalang)
50
-
51
- ## ⏱️ Try it now !
52
-
53
- ### Try Devalang in your browser
54
-
55
- > [Have a look at the Playground to try Devalang directly in your browser](https://playground.devalang.com)
56
-
57
- ### Try Devalang in your terminal
58
-
59
- #### With Node.js
60
-
61
- ```bash
62
- npm install -g @devaloop/devalang@latest
63
- ```
64
-
65
- #### With Rust
66
-
67
- ```bash
68
- cargo install devalang
69
- ```
70
-
71
- #### Initialize a new project
72
-
73
- ```bash
74
- devalang init --name my-project --template minimal
75
- ```
76
-
77
- #### Write your first script
78
-
79
- Create a new Devalang file `src/index.deva` in the project directory:
80
-
81
- ```deva
82
- # src/index.deva
83
-
84
- # BPM definition
85
- bpm 125
86
-
87
- # Bank picking (make sure you've installed it)
88
- bank devaloop.808 as my808Bank
89
-
90
- # Pattern literal without options
91
- pattern kickPattern with my808Bank.kick = "x--- x--- x--- x---"
92
-
93
- group myGroup:
94
- # Rhythmic (each beat playing a kick)
95
- # on beat:
96
- # .my808Bank.kick 1/4
97
-
98
- # Synth definition with ADSR
99
- let myLead = synth sine {
100
- attack: 0,
101
- decay: 100,
102
- sustain: 100,
103
- release: 100
104
- }
105
-
106
- # Global automation
107
- automate myLead:
108
- param volume {
109
- 0% = 0.0
110
- 100% = 0.5
111
- }
112
- param pitch {
113
- 0% = -12.0
114
- 100% = 12.0
115
- }
116
-
117
- # Notes in a loop with condition
118
- for i in [1, 2, 3]:
119
- if i == 3:
120
- myLead -> note(C5, { duration: 200 })
121
- print "Playing note C5 for " + i
122
-
123
- # Pause runtime for 500ms
124
- sleep 500
125
-
126
- # Note with automation
127
- myLead -> note(C4, {
128
- duration: 400,
129
- velocity: 0.8,
130
- automate: {
131
- pan: {
132
- 0%: -1.0,
133
- 100%: 0.0
134
- }
135
- }
136
- })
137
-
138
- # Notes with params
139
- myLead -> note(G4, { duration: 600, glide: true, target_freq: 659.25 })
140
- myLead -> note(B3, { duration: 400, slide: true, target_amp: 0.3 })
141
-
142
- # Spawning the group & the pattern to play them in parallel
143
- spawn myGroup
144
- spawn kickPattern
145
- ```
146
-
147
- ### And the best part ? You can play it directly from the command line:
148
-
149
- #### Play the script once
150
-
151
- ```bash
152
- devalang play
153
- ```
154
-
155
- #### **LIVE mode** (repeat the playback + watch mode)
156
-
157
- ```bash
158
- devalang play --repeat
159
- ```
160
-
161
- ### 🎉 You can now hear your Devalang code in action
162
-
163
- > For more examples, check out the [examples directory](./examples/)
164
-
165
- ## ❓ Why Devalang ?
166
-
167
- - 🎹 Prototype audio ideas without opening a DAW, even VSCode with our Playground
168
- - 💻 Integrate sound into code-based workflows
169
- - 🎛️ Control audio parameters through readable syntax
170
- - 🧪 Build musical logic with variables and conditions
171
- - 🔄 Create complex patterns with ease
172
-
173
- ## 🚀 Features
174
-
175
- - ⚡ **Fast Build & Hot Reload** — optimized build process for quicker iteration.
176
- - 🎵 **Audio Engine & Real-time runner** — low-latency playback, render-to-file, and a realtime runner used by `devalang play` for live feedback.
177
- - ▶️ **Live mode (watch + repeat)** — edit and hear changes instantly with `devalang play --repeat` and watch mode.
178
- - 🧩 **Language primitives** — synths, notes, ADSR, maps, arrays, loops, conditionals and functions for expressive musical logic.
179
- - 🎛️ **Per-note automation & modulators** — `automate` maps, `$mod.*`, `$easing.*` and `$math.*` helpers for envelopes and LFOs.
180
- - 🧩 **Module system & structured AST** — import/export variables, stable AST output for debugging and tooling.
181
- - 🧰 **Plugins & Addons (WASM-ready)** — install plugins/banks, `@use` directive, and WASM plugin integration so plugins can render or process audio at runtime.
182
- - 📦 **Addon manager & Devaforge** — CLI commands to discover/install banks, plugins and templates; `devaforge` helps create addons.
183
- - ⚙️ **CLI tooling** — `build`, `check`, `play`, `install`, `init`, `discover`, `telemetry` and more with consistent flags (`--watch`, `--debug`, `--compress`).
184
- - 📂 **Project templates & examples** — quick-start templates and many example projects in `examples/`.
185
- - 🧑‍💻 **TypeScript API & WASM distribution** — Node-friendly package with TypeScript bindings and a WASM build for browser/Node usage.
186
- - 🧰 **Editor & formatting support** — VSCode extension and Prettier plugin to edit Devalang with syntax and formatting support.
187
- - 🎵 **Custom samples & banks** — drop samples into `.deva` and reference them from code; banks of sounds for fast composition.
188
- - 🔄 **Looping, grouping & scheduling** — precise beat-tied scheduling primitives for complex rhythmic patterns.
189
-
190
- ## 📄 Documentation
191
-
192
- ### [Please refer to the online documentation](https://docs.devalang.com) for detailed information on syntax, features, and usage examples
193
-
194
- ## 📰 What's new
195
-
196
- - **Devaforge**: Introduced a new system for creating and managing addons, including a CLI for addon generation.
197
- - **Documentation updates**: Improved documentation for clarity and completeness.
198
- - **Discovering addons**: Introduced a new command to detect addons.
199
- - **Public TypeScript API**: Added a public TypeScript API for easier integration.
200
- - **Improved error messages**: Enhanced error messages for better debugging.
201
- - **Bug fixes**: Various bug fixes and stability improvements.
202
-
203
- ## 🛡️ License
204
-
205
- MIT — see [LICENSE](./LICENSE)
206
-
207
- ## 🤝 Contributing
208
-
209
- Contributions, bug reports and suggestions are welcome !
210
- Feel free to open an issue or submit a pull request.
211
-
212
- For more info, see [docs/CONTRIBUTING.md](./docs/CONTRIBUTING.md).
213
-
214
- ## 📢 Contact
215
-
216
- Feel free to reach out for any inquiries or feedback.
217
-
218
- 📧 [contact@devaloop.com](mailto:contact@devaloop.com)
@@ -1,61 +0,0 @@
1
- # 🦊 Welcome to Devalang
2
- # Happy live-coding !
3
-
4
- @import { bpmVar } from './variables.deva'
5
- @load "../samples/kick-808.wav" as myKick
6
-
7
- # BPM definition
8
- bpm bpmVar
9
-
10
- group myGroup:
11
- # Rhythmic (each beat playing a kick)
12
- on beat:
13
- .myKick 1/4
14
-
15
- # Synth definition with ADSR
16
- let myLead = synth sine {
17
- attack: 0,
18
- decay: 100,
19
- sustain: 100,
20
- release: 100
21
- }
22
-
23
- # Global automation
24
- automate myLead:
25
- param volume {
26
- 0% = 0.0
27
- 100% = 0.5
28
- }
29
- param pitch {
30
- 0% = -12.0
31
- 100% = 12.0
32
- }
33
-
34
- # Notes in a loop with condition
35
- for i in [1, 2, 3]:
36
- if i == 3:
37
- myLead -> note(C5, { duration: 200 })
38
- print "Playing note C5 for " + i
39
-
40
- # Pause runtime for 500ms
41
- sleep 500
42
-
43
- # Note with automation
44
- myLead -> note(C4, {
45
- duration: 400,
46
- velocity: 0.8,
47
- automate: {
48
- pan: {
49
- 0%: -1.0,
50
- 100%: 0.0
51
- }
52
- }
53
- })
54
-
55
- # Notes with params
56
- myLead -> note(E4, { duration: 400 })
57
- myLead -> note(G4, { duration: 600, glide: true, target_freq: 659.25 })
58
- myLead -> note(B3, { duration: 400, slide: true, target_amp: 0.3 })
59
-
60
- # Calling the group to play it
61
- call myGroup
@@ -1,3 +0,0 @@
1
- let bpmVar = 135
2
-
3
- @export { bpmVar }
@@ -1,21 +0,0 @@
1
- // Aggregator test: include tests from tests/rust/* as distinct modules.
2
- // This keeps sources organized while providing a single integration test
3
- // file that Cargo will compile and run.
4
-
5
- mod rust_tests {
6
- pub mod cli_help {
7
- include!("rust/cli_help.rs");
8
- }
9
- pub mod cli_version {
10
- include!("rust/cli_version.rs");
11
- }
12
- pub mod cli_template_list {
13
- include!("rust/cli_template_list.rs");
14
- }
15
- pub mod cli_check_build {
16
- include!("rust/cli_check_build.rs");
17
- }
18
- }
19
-
20
- // Re-export tests so the test runner finds them at crate root.
21
- pub use rust_tests::*;
@@ -1,21 +0,0 @@
1
- use assert_cmd::Command;
2
- use tempfile::tempdir;
3
-
4
- #[test]
5
- fn cli_check_and_build_no_crash() {
6
- // create a temp output dir and run check/build against examples entry
7
- let out = tempdir().expect("create tempdir");
8
- let out_path = out.path().to_str().unwrap();
9
-
10
- // Run `devalang check --entry examples --output <out> --debug`
11
- let mut cmd = Command::cargo_bin("devalang").expect("binary not found");
12
- cmd.args(["check", "--entry", "examples", "--output", out_path, "--debug"]);
13
- let assert = cmd.assert();
14
- // check may return success or non-zero depending on environment, ensure it doesn't panic
15
- assert.get_output();
16
-
17
- // Run build command similarly; we only assert it runs (not necessarily success on all envs)
18
- let mut cmd2 = Command::cargo_bin("devalang").expect("binary not found");
19
- cmd2.args(["build", "--entry", "examples", "--output", out_path, "--debug"]);
20
- cmd2.assert().get_output();
21
- }
@@ -1,12 +0,0 @@
1
- use assert_cmd::Command;
2
- use predicates::prelude::*;
3
-
4
- #[test]
5
- fn cli_prints_help() {
6
- // Build the binary in debug mode and run it with --help
7
- let mut cmd = Command::cargo_bin("devalang").expect("binary not found");
8
- cmd.arg("--help");
9
- cmd.assert()
10
- .success()
11
- .stdout(predicate::str::contains("devalang"));
12
- }
@@ -1,10 +0,0 @@
1
- use assert_cmd::Command;
2
-
3
- #[test]
4
- fn cli_template_list_runs() {
5
- let mut cmd = Command::cargo_bin("devalang").expect("binary not found");
6
- cmd.args(["template", "list"]);
7
- let assert = cmd.assert();
8
- // ensure it runs without panic; output may vary
9
- assert.get_output();
10
- }
@@ -1,11 +0,0 @@
1
- use assert_cmd::Command;
2
- use predicates::prelude::*;
3
-
4
- #[test]
5
- fn cli_prints_version() {
6
- let mut cmd = Command::cargo_bin("devalang").expect("binary not found");
7
- cmd.arg("--version");
8
- cmd.assert()
9
- .success()
10
- .stdout(predicate::str::contains("devalang"));
11
- }