@devaloop/devalang 0.0.1-beta.1 → 0.0.1-beta.3

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 (207) hide show
  1. package/.devalang +9 -10
  2. package/Cargo.toml +84 -80
  3. package/README.md +10 -7
  4. package/docs/CHANGELOG.md +83 -0
  5. package/docs/ROADMAP.md +6 -2
  6. package/docs/TODO.md +3 -14
  7. package/examples/bus.deva +10 -0
  8. package/examples/chain.deva +19 -0
  9. package/examples/effect.deva +2 -0
  10. package/examples/filter.deva +11 -0
  11. package/examples/lfo.deva +9 -0
  12. package/examples/plugin.deva +10 -10
  13. package/examples/routing.deva +23 -0
  14. package/examples/synth.deva +11 -1
  15. package/examples/synth_types.deva +17 -0
  16. package/out-tsc/bin/project-version.json +6 -0
  17. package/out-tsc/core/functions/index.d.ts +5 -0
  18. package/out-tsc/core/functions/index.js +11 -0
  19. package/out-tsc/pkg/devalang_core.d.ts +2 -0
  20. package/out-tsc/pkg/devalang_core.js +17 -2
  21. package/out-tsc/pkg/devalang_core_bg.wasm.d.ts +1 -0
  22. package/out-tsc/scripts/version/copy-to-binary.d.ts +1 -0
  23. package/out-tsc/scripts/version/copy-to-binary.js +79 -0
  24. package/package.json +23 -10
  25. package/project-version.json +3 -3
  26. package/rust/bindings/Cargo.toml +9 -0
  27. package/rust/bindings/src/lib.rs +86 -0
  28. package/rust/cli/addon/commands.rs +35 -0
  29. package/rust/cli/addon/download.rs +234 -0
  30. package/rust/cli/addon/install.rs +33 -0
  31. package/rust/cli/addon/list.rs +224 -0
  32. package/rust/cli/addon/metadata.rs +124 -0
  33. package/rust/cli/addon/mod.rs +8 -0
  34. package/rust/cli/addon/remove.rs +271 -0
  35. package/rust/cli/addon/update.rs +305 -0
  36. package/rust/cli/{install/addon.rs → addon/utils.rs} +34 -43
  37. package/rust/cli/build/commands.rs +153 -103
  38. package/rust/cli/build/mod.rs +2 -2
  39. package/rust/cli/build/process.rs +165 -146
  40. package/rust/cli/check/mod.rs +208 -208
  41. package/rust/cli/discover/commands.rs +53 -31
  42. package/rust/cli/discover/config.rs +2 -4
  43. package/rust/cli/discover/install.rs +139 -28
  44. package/rust/cli/discover/metadata.rs +3 -3
  45. package/rust/cli/login/commands.rs +124 -124
  46. package/rust/cli/me/commands.rs +52 -0
  47. package/rust/cli/me/mod.rs +1 -0
  48. package/rust/cli/mod.rs +2 -2
  49. package/rust/cli/parser.rs +76 -70
  50. package/rust/cli/play/commands.rs +375 -324
  51. package/rust/cli/play/mod.rs +5 -5
  52. package/rust/cli/play/process.rs +159 -150
  53. package/rust/cli/play/realtime.rs +91 -91
  54. package/rust/cli/telemetry/commands.rs +22 -22
  55. package/rust/cli/telemetry/event_creator.rs +80 -80
  56. package/rust/cli/telemetry/mod.rs +3 -3
  57. package/rust/cli/telemetry/send.rs +51 -51
  58. package/rust/cli/template/commands.rs +69 -69
  59. package/rust/config/driver.rs +112 -103
  60. package/rust/config/mod.rs +3 -3
  61. package/rust/config/ops.rs +26 -26
  62. package/rust/config/settings.rs +101 -101
  63. package/rust/core/audio/engine/driver.rs +237 -0
  64. package/rust/core/audio/engine/export.rs +169 -0
  65. package/rust/core/audio/engine/helpers.rs +178 -170
  66. package/rust/core/audio/engine/mod.rs +56 -7
  67. package/rust/core/audio/engine/notes/dsp.rs +88 -0
  68. package/rust/core/audio/engine/notes/mod.rs +53 -0
  69. package/rust/core/audio/engine/notes/params.rs +294 -0
  70. package/rust/core/audio/engine/sample/insert.rs +300 -0
  71. package/rust/core/audio/engine/sample/mod.rs +40 -0
  72. package/rust/core/audio/engine/sample/padding.rs +170 -0
  73. package/rust/core/audio/evaluator/condition.rs +61 -0
  74. package/rust/core/audio/evaluator/mod.rs +9 -0
  75. package/rust/core/audio/{evaluator.rs → evaluator/numeric.rs} +152 -310
  76. package/rust/core/audio/evaluator/rhs.rs +16 -0
  77. package/rust/core/audio/evaluator/string_expr.rs +94 -0
  78. package/rust/core/audio/interpreter/driver.rs +574 -542
  79. package/rust/core/audio/interpreter/mod.rs +2 -14
  80. package/rust/core/audio/interpreter/statements/arrow_call/interprete.rs +179 -0
  81. package/rust/core/audio/interpreter/statements/arrow_call/methods/chord.rs +398 -0
  82. package/rust/core/audio/interpreter/statements/arrow_call/methods/effects.rs +323 -0
  83. package/rust/core/audio/interpreter/statements/arrow_call/methods/mod.rs +3 -0
  84. package/rust/core/audio/interpreter/statements/arrow_call/methods/note.rs +371 -0
  85. package/rust/core/audio/interpreter/statements/arrow_call/mod.rs +3 -0
  86. package/rust/core/audio/interpreter/statements/arrow_call/types/arp.rs +192 -0
  87. package/rust/core/audio/interpreter/statements/arrow_call/types/mod.rs +24 -0
  88. package/rust/core/audio/interpreter/statements/arrow_call/types/pad.rs +116 -0
  89. package/rust/core/audio/interpreter/statements/arrow_call/types/pluck.rs +97 -0
  90. package/rust/core/audio/interpreter/statements/arrow_call/types/sub.rs +100 -0
  91. package/rust/core/audio/interpreter/{automate.rs → statements/automate.rs} +2 -4
  92. package/rust/core/audio/interpreter/{call.rs → statements/call.rs} +36 -5
  93. package/rust/core/audio/interpreter/{condition.rs → statements/condition.rs} +72 -71
  94. package/rust/core/audio/interpreter/{function.rs → statements/function.rs} +24 -26
  95. package/rust/core/audio/interpreter/{let_.rs → statements/let_.rs} +36 -38
  96. package/rust/core/audio/interpreter/{load.rs → statements/load.rs} +17 -19
  97. package/rust/core/audio/interpreter/{loop_.rs → statements/loop_.rs} +115 -114
  98. package/rust/core/audio/interpreter/statements/mod.rs +12 -0
  99. package/rust/core/audio/interpreter/{sleep.rs → statements/sleep.rs} +28 -28
  100. package/rust/core/audio/interpreter/{spawn.rs → statements/spawn.rs} +54 -4
  101. package/rust/core/audio/interpreter/{tempo.rs → statements/tempo.rs} +40 -40
  102. package/rust/core/audio/interpreter/{trigger.rs → statements/trigger.rs} +242 -239
  103. package/rust/core/audio/loader/trigger.rs +98 -97
  104. package/rust/core/audio/mod.rs +6 -7
  105. package/rust/core/audio/special/easing.rs +189 -189
  106. package/rust/core/audio/special/env.rs +45 -45
  107. package/rust/core/audio/special/math.rs +134 -134
  108. package/rust/core/audio/special/modulator.rs +143 -143
  109. package/rust/core/builder/mod.rs +129 -86
  110. package/rust/core/debugger/{module.rs → logs.rs} +52 -55
  111. package/rust/core/debugger/mod.rs +30 -30
  112. package/rust/core/debugger/store.rs +38 -40
  113. package/rust/core/error/mod.rs +269 -269
  114. package/rust/core/lexer/driver.rs +2 -4
  115. package/rust/core/mod.rs +9 -10
  116. package/rust/core/parser/driver/block.rs +111 -0
  117. package/rust/core/parser/driver/cursor.rs +82 -0
  118. package/rust/core/parser/driver/driver_impl.rs +159 -0
  119. package/rust/core/parser/driver/mod.rs +6 -0
  120. package/rust/core/parser/driver/parse_array.rs +120 -0
  121. package/rust/core/parser/driver/parse_map.rs +247 -0
  122. package/rust/core/parser/driver/parser.rs +160 -0
  123. package/rust/core/parser/handler/arrow_call.rs +90 -15
  124. package/rust/core/parser/handler/at.rs +279 -279
  125. package/rust/core/parser/handler/bank.rs +104 -104
  126. package/rust/core/parser/handler/condition.rs +83 -83
  127. package/rust/core/parser/handler/dot.rs +148 -148
  128. package/rust/core/parser/handler/identifier/automate.rs +254 -254
  129. package/rust/core/parser/handler/identifier/call.rs +91 -91
  130. package/rust/core/parser/handler/identifier/emit.rs +70 -70
  131. package/rust/core/parser/handler/identifier/function.rs +113 -113
  132. package/rust/core/parser/handler/identifier/group.rs +89 -89
  133. package/rust/core/parser/handler/identifier/let_.rs +173 -173
  134. package/rust/core/parser/handler/identifier/mod.rs +55 -55
  135. package/rust/core/parser/handler/identifier/on.rs +107 -107
  136. package/rust/core/parser/handler/identifier/print.rs +49 -49
  137. package/rust/core/parser/handler/identifier/sleep.rs +96 -43
  138. package/rust/core/parser/handler/identifier/spawn.rs +91 -91
  139. package/rust/core/parser/handler/identifier/synth.rs +39 -3
  140. package/rust/core/parser/handler/loop_.rs +194 -194
  141. package/rust/core/parser/handler/pattern.rs +25 -2
  142. package/rust/core/parser/handler/tempo.rs +105 -57
  143. package/rust/core/parser/statement.rs +10 -11
  144. package/rust/core/plugin/loader.rs +137 -137
  145. package/rust/core/plugin/runner/mod.rs +11 -0
  146. package/rust/core/plugin/{runner.rs → runner/non_wasm.rs} +206 -72
  147. package/rust/core/plugin/runner/wasm32.rs +44 -0
  148. package/rust/core/preprocessor/loader/inject.rs +313 -0
  149. package/rust/core/preprocessor/loader/loader_helpers.rs +110 -0
  150. package/rust/core/preprocessor/loader/mod.rs +235 -0
  151. package/rust/core/preprocessor/module.rs +55 -60
  152. package/rust/core/preprocessor/{processor.rs → processor/handlers.rs} +107 -114
  153. package/rust/core/preprocessor/processor/mod.rs +1 -0
  154. package/rust/core/preprocessor/resolver/function.rs +69 -69
  155. package/rust/core/preprocessor/resolver/group.rs +122 -94
  156. package/rust/core/preprocessor/resolver/pattern.rs +14 -2
  157. package/rust/core/store/global.rs +57 -61
  158. package/rust/core/store/mod.rs +1 -5
  159. package/rust/lib.rs +323 -308
  160. package/rust/macros/Cargo.toml +14 -0
  161. package/rust/macros/src/lib.rs +52 -0
  162. package/rust/main.rs +336 -143
  163. package/rust/types/Cargo.toml +1 -1
  164. package/rust/types/src/addons.rs +57 -55
  165. package/rust/types/src/config.rs +82 -74
  166. package/rust/types/src/lib.rs +15 -12
  167. package/rust/types/src/plugin.rs +20 -0
  168. package/rust/types/src/store.rs +139 -0
  169. package/rust/types/src/telemetry.rs +85 -85
  170. package/rust/utils/Cargo.toml +5 -2
  171. package/rust/utils/src/file.rs +477 -94
  172. package/rust/utils/src/first_usage.rs +97 -97
  173. package/rust/utils/src/lib.rs +9 -9
  174. package/rust/utils/src/logger.rs +200 -200
  175. package/rust/utils/src/path.rs +158 -88
  176. package/rust/utils/src/signature.rs +41 -41
  177. package/rust/utils/src/spinner.rs +20 -20
  178. package/rust/utils/src/version.rs +58 -27
  179. package/rust/utils/src/watcher.rs +46 -46
  180. package/rust/web/api.rs +5 -5
  181. package/rust/web/auth.rs +5 -0
  182. package/rust/web/cdn.rs +34 -34
  183. package/rust/web/forge.rs +5 -0
  184. package/rust/web/mod.rs +2 -0
  185. package/tests/integration.rs +21 -21
  186. package/typescript/core/functions/index.ts +11 -0
  187. package/typescript/pkg/devalang_core.ts +20 -4
  188. package/typescript/scripts/version/copy-to-binary.ts +82 -0
  189. package/rust/cli/bank/api.rs +0 -122
  190. package/rust/cli/bank/commands.rs +0 -275
  191. package/rust/cli/bank/mod.rs +0 -29
  192. package/rust/cli/install/bank.rs +0 -53
  193. package/rust/cli/install/commands.rs +0 -35
  194. package/rust/cli/install/mod.rs +0 -4
  195. package/rust/cli/install/plugin.rs +0 -61
  196. package/rust/core/audio/engine/sample.rs +0 -366
  197. package/rust/core/audio/engine/synth.rs +0 -325
  198. package/rust/core/audio/interpreter/arrow_call.rs +0 -311
  199. package/rust/core/audio/renderer.rs +0 -54
  200. package/rust/core/parser/driver.rs +0 -584
  201. package/rust/core/preprocessor/loader.rs +0 -637
  202. package/rust/core/store/export.rs +0 -28
  203. package/rust/core/store/function.rs +0 -40
  204. package/rust/core/store/import.rs +0 -28
  205. package/rust/core/store/variable.rs +0 -51
  206. package/rust/core/utils/mod.rs +0 -1
  207. package/rust/core/utils/path.rs +0 -37
@@ -1,86 +1,129 @@
1
- use crate::core::audio::renderer::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
- ) {
52
- let logger = Logger::new();
53
-
54
- let audio_engines =
55
- render_audio_with_modules(modules.clone(), normalized_output_dir, global_store);
56
-
57
- create_dir_all(format!("{}/audio", normalized_output_dir))
58
- .expect("Failed to create audio directory");
59
-
60
- for (module_name, mut audio_engine) in audio_engines {
61
- let formatted_module_name = module_name
62
- .split('/')
63
- .next_back()
64
- .unwrap_or(&module_name)
65
- .replace(".deva", "");
66
-
67
- let output_path = format!(
68
- "{}/audio/{}.wav",
69
- normalized_output_dir, formatted_module_name
70
- );
71
-
72
- match audio_engine.generate_wav_file(&output_path) {
73
- Ok(_) => {}
74
- Err(msg) => {
75
- logger.log_error_with_stacktrace(
76
- &format!(
77
- "Unable to generate WAV file for module '{}': {}",
78
- formatted_module_name, msg
79
- ),
80
- &module_name,
81
- );
82
- }
83
- }
84
- }
85
- }
86
- }
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,55 +1,52 @@
1
- use crate::core::{
2
- debugger::Debugger,
3
- store::{function::FunctionTable, variable::VariableTable},
4
- };
5
- use std::fs::create_dir_all;
6
-
7
- pub fn write_module_variable_log_file(
8
- output_dir: &str,
9
- module_path: &str,
10
- variable_table: &VariableTable,
11
- ) {
12
- let debugger = Debugger::new();
13
- let mut content = String::new();
14
- let module_name = module_path
15
- .split('/')
16
- .next_back()
17
- .unwrap_or("index")
18
- .replace(".deva", "");
19
-
20
- let log_directory = format!("{}/logs/modules/{}", output_dir, module_name);
21
- create_dir_all(&log_directory).expect("Failed to create log directory");
22
-
23
- for (var_name, var_data) in &variable_table.variables {
24
- content.push_str(&format!("{:?} = {:?}\n", var_name, var_data));
25
- }
26
-
27
- content.push('\n');
28
-
29
- debugger.write_log_file(&log_directory, "variables.log", &content);
30
- }
31
-
32
- pub fn write_module_function_log_file(
33
- output_dir: &str,
34
- module_path: &str,
35
- function_table: &FunctionTable,
36
- ) {
37
- let debugger = Debugger::new();
38
- let mut content = String::new();
39
- let module_name = module_path
40
- .split('/')
41
- .next_back()
42
- .unwrap_or("index")
43
- .replace(".deva", "");
44
-
45
- let log_directory = format!("{}/logs/modules/{}", output_dir, module_name);
46
- create_dir_all(&log_directory).expect("Failed to create log directory");
47
-
48
- for (func_name, func_data) in &function_table.functions {
49
- content.push_str(&format!("{:?} = {:?}\n", func_name, func_data));
50
- }
51
-
52
- content.push('\n');
53
-
54
- debugger.write_log_file(&log_directory, "functions.log", &content);
55
- }
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 +1,30 @@
1
- pub mod lexer;
2
- pub mod module;
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
+ 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,40 +1,38 @@
1
- use crate::core::{
2
- debugger::Debugger,
3
- store::{function::FunctionTable, variable::VariableTable},
4
- };
5
- use std::fs::create_dir_all;
6
-
7
- pub fn write_variables_log_file(output_dir: &str, file_name: &str, variables: VariableTable) {
8
- let debugger = Debugger::new();
9
- let mut content = String::new();
10
-
11
- let log_directory = format!("{}/logs", output_dir);
12
- create_dir_all(&log_directory).expect("Failed to create log directory");
13
-
14
- for (var_name, var_data) in variables.variables {
15
- content.push_str(&format!("{:?} = {:?}\n", var_name, var_data));
16
- }
17
-
18
- content.push('\n');
19
-
20
- debugger.write_log_file(&log_directory, file_name, &content);
21
- }
22
-
23
- pub fn write_function_log_file(output_dir: &str, file_name: &str, functions: FunctionTable) {
24
- let debugger = Debugger::new();
25
- let mut content = String::new();
26
-
27
- let log_directory = format!("{}/logs", output_dir);
28
- create_dir_all(&log_directory).expect("Failed to create log directory");
29
-
30
- for (_index, function) in functions.functions {
31
- content.push_str(&format!(
32
- "'{}' = [{:?}] => {:?}\n",
33
- function.name, function.parameters, function.body
34
- ));
35
- }
36
-
37
- content.push('\n');
38
-
39
- debugger.write_log_file(&log_directory, file_name, &content);
40
- }
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
+ }