@devaloop/devalang 0.0.1-beta.1 → 0.0.1-beta.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.
- package/.devalang +9 -10
- package/Cargo.toml +5 -4
- package/README.md +7 -5
- package/docs/CHANGELOG.md +42 -0
- package/docs/ROADMAP.md +5 -1
- package/docs/TODO.md +3 -14
- package/examples/bus.deva +10 -0
- package/examples/effect.deva +2 -0
- package/examples/filter.deva +11 -0
- package/examples/lfo.deva +9 -0
- package/examples/synth.deva +11 -1
- package/examples/synth_types.deva +17 -0
- package/out-tsc/core/functions/index.d.ts +5 -0
- package/out-tsc/core/functions/index.js +11 -0
- package/out-tsc/pkg/devalang_core.d.ts +2 -0
- package/out-tsc/pkg/devalang_core.js +17 -2
- package/out-tsc/pkg/devalang_core_bg.wasm.d.ts +8 -7
- package/package.json +1 -1
- package/project-version.json +3 -3
- package/rust/cli/bank/api.rs +122 -122
- package/rust/cli/bank/commands.rs +33 -2
- package/rust/cli/bank/mod.rs +29 -29
- package/rust/cli/build/commands.rs +53 -3
- package/rust/cli/build/mod.rs +2 -2
- package/rust/cli/build/process.rs +26 -7
- package/rust/cli/check/mod.rs +2 -2
- package/rust/cli/discover/commands.rs +253 -253
- package/rust/cli/discover/config.rs +111 -111
- package/rust/cli/discover/fs.rs +19 -19
- package/rust/cli/discover/install.rs +103 -103
- package/rust/cli/discover/metadata.rs +48 -48
- package/rust/cli/discover/mod.rs +5 -5
- package/rust/cli/install/addon.rs +118 -118
- package/rust/cli/install/bank.rs +22 -3
- package/rust/cli/install/commands.rs +35 -35
- package/rust/cli/install/mod.rs +4 -4
- package/rust/cli/install/plugin.rs +80 -61
- package/rust/cli/login/commands.rs +124 -124
- package/rust/cli/mod.rs +12 -12
- package/rust/cli/parser.rs +46 -1
- package/rust/cli/play/commands.rs +71 -20
- package/rust/cli/play/mod.rs +5 -5
- package/rust/cli/play/process.rs +14 -5
- package/rust/cli/play/realtime.rs +91 -91
- package/rust/cli/telemetry/commands.rs +22 -22
- package/rust/cli/telemetry/event_creator.rs +80 -80
- package/rust/cli/telemetry/mod.rs +3 -3
- package/rust/cli/telemetry/send.rs +51 -51
- package/rust/cli/template/commands.rs +69 -69
- package/rust/config/driver.rs +112 -103
- package/rust/config/mod.rs +3 -3
- package/rust/config/ops.rs +26 -26
- package/rust/config/settings.rs +101 -101
- package/rust/core/audio/engine/driver.rs +220 -0
- package/rust/core/audio/engine/export.rs +169 -0
- package/rust/core/audio/engine/helpers.rs +178 -170
- package/rust/core/audio/engine/mod.rs +51 -2
- package/rust/core/audio/engine/notes/dsp.rs +85 -0
- package/rust/core/audio/engine/notes/mod.rs +44 -0
- package/rust/core/audio/engine/notes/params.rs +294 -0
- package/rust/core/audio/engine/sample/insert.rs +199 -0
- package/rust/core/audio/engine/sample/mod.rs +40 -0
- package/rust/core/audio/engine/sample/padding.rs +170 -0
- package/rust/core/audio/evaluator/condition.rs +61 -0
- package/rust/core/audio/evaluator/mod.rs +9 -0
- package/rust/core/audio/{evaluator.rs → evaluator/numeric.rs} +1 -159
- package/rust/core/audio/evaluator/rhs.rs +16 -0
- package/rust/core/audio/evaluator/string_expr.rs +94 -0
- package/rust/core/audio/interpreter/driver.rs +55 -23
- package/rust/core/audio/interpreter/mod.rs +1 -13
- package/rust/core/audio/interpreter/statements/arrow_call/interprete.rs +175 -0
- package/rust/core/audio/interpreter/statements/arrow_call/methods/chord.rs +384 -0
- package/rust/core/audio/interpreter/statements/arrow_call/methods/mod.rs +2 -0
- package/rust/core/audio/interpreter/statements/arrow_call/methods/note.rs +316 -0
- package/rust/core/audio/interpreter/statements/arrow_call/mod.rs +3 -0
- package/rust/core/audio/interpreter/statements/arrow_call/types/arp.rs +192 -0
- package/rust/core/audio/interpreter/statements/arrow_call/types/mod.rs +24 -0
- package/rust/core/audio/interpreter/statements/arrow_call/types/pad.rs +116 -0
- package/rust/core/audio/interpreter/statements/arrow_call/types/pluck.rs +97 -0
- package/rust/core/audio/interpreter/statements/arrow_call/types/sub.rs +100 -0
- package/rust/core/audio/interpreter/{automate.rs → statements/automate.rs} +16 -18
- package/rust/core/audio/interpreter/{call.rs → statements/call.rs} +5 -4
- package/rust/core/audio/interpreter/{condition.rs → statements/condition.rs} +2 -1
- package/rust/core/audio/interpreter/{function.rs → statements/function.rs} +2 -4
- package/rust/core/audio/interpreter/{let_.rs → statements/let_.rs} +2 -4
- package/rust/core/audio/interpreter/{load.rs → statements/load.rs} +2 -4
- package/rust/core/audio/interpreter/{loop_.rs → statements/loop_.rs} +2 -1
- package/rust/core/audio/interpreter/statements/mod.rs +12 -0
- package/rust/core/audio/interpreter/{sleep.rs → statements/sleep.rs} +28 -28
- package/rust/core/audio/interpreter/{spawn.rs → statements/spawn.rs} +3 -2
- package/rust/core/audio/interpreter/{tempo.rs → statements/tempo.rs} +40 -40
- package/rust/core/audio/interpreter/{trigger.rs → statements/trigger.rs} +1 -1
- package/rust/core/audio/loader/trigger.rs +2 -1
- package/rust/core/audio/mod.rs +6 -7
- package/rust/core/audio/player.rs +70 -70
- package/rust/core/audio/special/easing.rs +189 -189
- package/rust/core/audio/special/env.rs +45 -45
- package/rust/core/audio/special/math.rs +134 -134
- package/rust/core/audio/special/mod.rs +9 -9
- package/rust/core/audio/special/modulator.rs +143 -143
- package/rust/core/builder/mod.rs +45 -2
- package/rust/core/debugger/lexer.rs +27 -27
- package/rust/core/debugger/{module.rs → logs.rs} +3 -6
- package/rust/core/debugger/mod.rs +30 -30
- package/rust/core/debugger/preprocessor.rs +27 -27
- package/rust/core/debugger/store.rs +2 -4
- package/rust/core/error/mod.rs +269 -269
- package/rust/core/lexer/driver.rs +59 -61
- package/rust/core/lexer/handler/arrow.rs +82 -82
- package/rust/core/lexer/handler/at.rs +21 -21
- package/rust/core/lexer/handler/brace.rs +41 -41
- package/rust/core/lexer/handler/colon.rs +21 -21
- package/rust/core/lexer/handler/comment.rs +30 -30
- package/rust/core/lexer/handler/dot.rs +21 -21
- package/rust/core/lexer/handler/driver.rs +337 -337
- package/rust/core/lexer/handler/identifier.rs +47 -47
- package/rust/core/lexer/handler/indent.rs +66 -66
- package/rust/core/lexer/handler/mod.rs +15 -15
- package/rust/core/lexer/handler/newline.rs +23 -23
- package/rust/core/lexer/handler/number.rs +31 -31
- package/rust/core/lexer/handler/operator.rs +46 -46
- package/rust/core/lexer/handler/parenthesis.rs +41 -41
- package/rust/core/lexer/handler/slash.rs +21 -21
- package/rust/core/lexer/handler/string.rs +63 -63
- package/rust/core/lexer/mod.rs +3 -3
- package/rust/core/mod.rs +0 -1
- package/rust/core/parser/driver/block.rs +111 -0
- package/rust/core/parser/driver/cursor.rs +82 -0
- package/rust/core/parser/driver/driver_impl.rs +139 -0
- package/rust/core/parser/driver/mod.rs +6 -0
- package/rust/core/parser/driver/parse_array.rs +120 -0
- package/rust/core/parser/driver/parse_map.rs +223 -0
- package/rust/core/parser/driver/parser.rs +160 -0
- package/rust/core/parser/handler/arrow_call.rs +28 -4
- package/rust/core/parser/handler/at.rs +279 -279
- package/rust/core/parser/handler/bank.rs +104 -104
- package/rust/core/parser/handler/condition.rs +83 -83
- package/rust/core/parser/handler/dot.rs +148 -148
- package/rust/core/parser/handler/identifier/automate.rs +254 -254
- package/rust/core/parser/handler/identifier/call.rs +91 -91
- package/rust/core/parser/handler/identifier/emit.rs +70 -70
- package/rust/core/parser/handler/identifier/function.rs +113 -113
- package/rust/core/parser/handler/identifier/group.rs +89 -89
- package/rust/core/parser/handler/identifier/let_.rs +173 -173
- package/rust/core/parser/handler/identifier/mod.rs +55 -55
- package/rust/core/parser/handler/identifier/on.rs +107 -107
- package/rust/core/parser/handler/identifier/print.rs +49 -49
- package/rust/core/parser/handler/identifier/sleep.rs +96 -43
- package/rust/core/parser/handler/identifier/spawn.rs +91 -91
- package/rust/core/parser/handler/identifier/synth.rs +135 -135
- package/rust/core/parser/handler/loop_.rs +194 -194
- package/rust/core/parser/handler/mod.rs +9 -9
- package/rust/core/parser/handler/pattern.rs +1 -1
- package/rust/core/parser/handler/tempo.rs +105 -57
- package/rust/core/parser/statement.rs +10 -11
- package/rust/core/plugin/loader.rs +1 -1
- package/rust/core/plugin/mod.rs +2 -2
- package/rust/core/plugin/runner/mod.rs +11 -0
- package/rust/core/plugin/{runner.rs → runner/non_wasm.rs} +297 -347
- package/rust/core/plugin/runner/wasm32.rs +43 -0
- package/rust/core/preprocessor/loader/inject.rs +278 -0
- package/rust/core/preprocessor/loader/loader_helpers.rs +110 -0
- package/rust/core/preprocessor/loader/mod.rs +235 -0
- package/rust/core/preprocessor/module.rs +2 -7
- package/rust/core/preprocessor/{processor.rs → processor/handlers.rs} +6 -13
- package/rust/core/preprocessor/processor/mod.rs +1 -0
- package/rust/core/preprocessor/resolver/bank.rs +49 -49
- package/rust/core/preprocessor/resolver/call.rs +124 -124
- package/rust/core/preprocessor/resolver/condition.rs +95 -95
- package/rust/core/preprocessor/resolver/driver.rs +324 -324
- package/rust/core/preprocessor/resolver/function.rs +2 -2
- package/rust/core/preprocessor/resolver/group.rs +46 -18
- package/rust/core/preprocessor/resolver/let_.rs +32 -32
- package/rust/core/preprocessor/resolver/loop_.rs +318 -318
- package/rust/core/preprocessor/resolver/mod.rs +16 -16
- package/rust/core/preprocessor/resolver/pattern.rs +83 -83
- package/rust/core/preprocessor/resolver/spawn.rs +99 -99
- package/rust/core/preprocessor/resolver/synth.rs +54 -54
- package/rust/core/preprocessor/resolver/tempo.rs +48 -48
- package/rust/core/preprocessor/resolver/trigger.rs +116 -116
- package/rust/core/preprocessor/resolver/value.rs +176 -176
- package/rust/core/store/global.rs +2 -6
- package/rust/core/store/mod.rs +1 -5
- package/rust/lib.rs +18 -3
- package/rust/main.rs +27 -3
- package/rust/types/Cargo.toml +1 -1
- package/rust/types/src/addons.rs +55 -55
- package/rust/types/src/config.rs +84 -74
- package/rust/types/src/lib.rs +15 -12
- package/rust/types/src/plugin.rs +20 -0
- package/rust/types/src/store.rs +139 -0
- package/rust/types/src/telemetry.rs +85 -85
- package/rust/utils/Cargo.toml +2 -2
- package/rust/utils/src/file.rs +94 -94
- package/rust/utils/src/first_usage.rs +97 -97
- package/rust/utils/src/lib.rs +9 -9
- package/rust/utils/src/logger.rs +200 -200
- package/rust/utils/src/path.rs +129 -88
- package/rust/utils/src/signature.rs +41 -41
- package/rust/utils/src/spinner.rs +20 -20
- package/rust/utils/src/version.rs +27 -27
- package/rust/utils/src/watcher.rs +46 -46
- package/rust/web/api.rs +5 -5
- package/rust/web/cdn.rs +34 -34
- package/rust/web/mod.rs +3 -3
- package/tests/integration.rs +21 -21
- package/typescript/core/functions/index.ts +11 -0
- package/typescript/pkg/devalang_core.ts +20 -4
- package/rust/core/audio/engine/sample.rs +0 -366
- package/rust/core/audio/engine/synth.rs +0 -325
- package/rust/core/audio/interpreter/arrow_call.rs +0 -311
- package/rust/core/audio/renderer.rs +0 -54
- package/rust/core/parser/driver.rs +0 -584
- package/rust/core/preprocessor/loader.rs +0 -637
- package/rust/core/store/export.rs +0 -28
- package/rust/core/store/function.rs +0 -40
- package/rust/core/store/import.rs +0 -28
- package/rust/core/store/variable.rs +0 -51
- package/rust/core/utils/mod.rs +0 -1
- package/rust/core/utils/path.rs +0 -37
|
@@ -1,85 +1,85 @@
|
|
|
1
|
-
use serde::{Deserialize, Serialize};
|
|
2
|
-
|
|
3
|
-
#[derive(Serialize, Deserialize, Default, Clone, Debug, PartialEq)]
|
|
4
|
-
pub enum TelemetryErrorLevel {
|
|
5
|
-
#[default]
|
|
6
|
-
None,
|
|
7
|
-
Warning,
|
|
8
|
-
Critical,
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
#[derive(Debug)]
|
|
12
|
-
pub enum TelemetrySendError {
|
|
13
|
-
Http(String),
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
#[derive(Serialize, Deserialize, Default, Clone, Debug, PartialEq)]
|
|
17
|
-
pub struct TelemetryProjectInfo {
|
|
18
|
-
pub config: Option<TelemetryProjectInfoConfig>,
|
|
19
|
-
pub stats: Option<TelemetryProjectInfoStats>,
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
#[derive(Serialize, Deserialize, Default, Clone, Debug, PartialEq)]
|
|
23
|
-
pub struct TelemetryProjectInfoStats {
|
|
24
|
-
pub counts: TelemetryProjectInfoStatsCounts,
|
|
25
|
-
pub features: TelemetryProjectInfoStatsFeatures,
|
|
26
|
-
pub audio: TelemetryProjectInfoStatsAudio,
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
#[derive(Serialize, Deserialize, Default, Clone, Debug, PartialEq)]
|
|
30
|
-
pub struct TelemetryProjectInfoStatsCounts {
|
|
31
|
-
pub nb_files: usize,
|
|
32
|
-
pub nb_modules: usize,
|
|
33
|
-
pub nb_lines: usize,
|
|
34
|
-
pub nb_banks: usize,
|
|
35
|
-
pub nb_plugins: usize,
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
#[derive(Serialize, Deserialize, Default, Clone, Debug, PartialEq)]
|
|
39
|
-
pub struct TelemetryProjectInfoStatsFeatures {
|
|
40
|
-
pub uses_imports: bool,
|
|
41
|
-
pub uses_functions: bool,
|
|
42
|
-
pub uses_groups: bool,
|
|
43
|
-
pub uses_automations: bool,
|
|
44
|
-
pub uses_loops: bool,
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
#[derive(Serialize, Deserialize, Default, Clone, Debug, PartialEq)]
|
|
48
|
-
pub struct TelemetryProjectInfoStatsAudio {
|
|
49
|
-
pub avg_bpm: Option<u32>,
|
|
50
|
-
pub has_synths: bool,
|
|
51
|
-
pub has_samples: bool,
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
#[derive(Serialize, Deserialize, Default, Clone, Debug, PartialEq)]
|
|
55
|
-
pub struct TelemetryProjectInfoConfig {
|
|
56
|
-
pub entry_defined: bool,
|
|
57
|
-
pub output_defined: bool,
|
|
58
|
-
pub watch_defined: bool,
|
|
59
|
-
pub repeat_defined: bool,
|
|
60
|
-
pub debug_defined: bool,
|
|
61
|
-
pub compress_defined: bool,
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
#[derive(Serialize, Deserialize, Default, Clone, Debug, PartialEq)]
|
|
65
|
-
pub struct TelemetryEvent {
|
|
66
|
-
pub uuid: String,
|
|
67
|
-
pub cli_version: String,
|
|
68
|
-
pub os: String,
|
|
69
|
-
pub command: Vec<String>,
|
|
70
|
-
pub project_info: Option<TelemetryProjectInfo>,
|
|
71
|
-
pub error_level: TelemetryErrorLevel,
|
|
72
|
-
pub error_message: Option<String>,
|
|
73
|
-
pub exit_code: Option<i32>,
|
|
74
|
-
pub timestamp: String,
|
|
75
|
-
pub duration: u64,
|
|
76
|
-
pub success: bool,
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
#[derive(Serialize, Deserialize, Default, Debug)]
|
|
80
|
-
pub struct TelemetrySettings {
|
|
81
|
-
pub uuid: String,
|
|
82
|
-
pub stats: bool,
|
|
83
|
-
pub level: String,
|
|
84
|
-
pub enabled: bool,
|
|
85
|
-
}
|
|
1
|
+
use serde::{Deserialize, Serialize};
|
|
2
|
+
|
|
3
|
+
#[derive(Serialize, Deserialize, Default, Clone, Debug, PartialEq)]
|
|
4
|
+
pub enum TelemetryErrorLevel {
|
|
5
|
+
#[default]
|
|
6
|
+
None,
|
|
7
|
+
Warning,
|
|
8
|
+
Critical,
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
#[derive(Debug)]
|
|
12
|
+
pub enum TelemetrySendError {
|
|
13
|
+
Http(String),
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
#[derive(Serialize, Deserialize, Default, Clone, Debug, PartialEq)]
|
|
17
|
+
pub struct TelemetryProjectInfo {
|
|
18
|
+
pub config: Option<TelemetryProjectInfoConfig>,
|
|
19
|
+
pub stats: Option<TelemetryProjectInfoStats>,
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
#[derive(Serialize, Deserialize, Default, Clone, Debug, PartialEq)]
|
|
23
|
+
pub struct TelemetryProjectInfoStats {
|
|
24
|
+
pub counts: TelemetryProjectInfoStatsCounts,
|
|
25
|
+
pub features: TelemetryProjectInfoStatsFeatures,
|
|
26
|
+
pub audio: TelemetryProjectInfoStatsAudio,
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
#[derive(Serialize, Deserialize, Default, Clone, Debug, PartialEq)]
|
|
30
|
+
pub struct TelemetryProjectInfoStatsCounts {
|
|
31
|
+
pub nb_files: usize,
|
|
32
|
+
pub nb_modules: usize,
|
|
33
|
+
pub nb_lines: usize,
|
|
34
|
+
pub nb_banks: usize,
|
|
35
|
+
pub nb_plugins: usize,
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
#[derive(Serialize, Deserialize, Default, Clone, Debug, PartialEq)]
|
|
39
|
+
pub struct TelemetryProjectInfoStatsFeatures {
|
|
40
|
+
pub uses_imports: bool,
|
|
41
|
+
pub uses_functions: bool,
|
|
42
|
+
pub uses_groups: bool,
|
|
43
|
+
pub uses_automations: bool,
|
|
44
|
+
pub uses_loops: bool,
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
#[derive(Serialize, Deserialize, Default, Clone, Debug, PartialEq)]
|
|
48
|
+
pub struct TelemetryProjectInfoStatsAudio {
|
|
49
|
+
pub avg_bpm: Option<u32>,
|
|
50
|
+
pub has_synths: bool,
|
|
51
|
+
pub has_samples: bool,
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
#[derive(Serialize, Deserialize, Default, Clone, Debug, PartialEq)]
|
|
55
|
+
pub struct TelemetryProjectInfoConfig {
|
|
56
|
+
pub entry_defined: bool,
|
|
57
|
+
pub output_defined: bool,
|
|
58
|
+
pub watch_defined: bool,
|
|
59
|
+
pub repeat_defined: bool,
|
|
60
|
+
pub debug_defined: bool,
|
|
61
|
+
pub compress_defined: bool,
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
#[derive(Serialize, Deserialize, Default, Clone, Debug, PartialEq)]
|
|
65
|
+
pub struct TelemetryEvent {
|
|
66
|
+
pub uuid: String,
|
|
67
|
+
pub cli_version: String,
|
|
68
|
+
pub os: String,
|
|
69
|
+
pub command: Vec<String>,
|
|
70
|
+
pub project_info: Option<TelemetryProjectInfo>,
|
|
71
|
+
pub error_level: TelemetryErrorLevel,
|
|
72
|
+
pub error_message: Option<String>,
|
|
73
|
+
pub exit_code: Option<i32>,
|
|
74
|
+
pub timestamp: String,
|
|
75
|
+
pub duration: u64,
|
|
76
|
+
pub success: bool,
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
#[derive(Serialize, Deserialize, Default, Debug)]
|
|
80
|
+
pub struct TelemetrySettings {
|
|
81
|
+
pub uuid: String,
|
|
82
|
+
pub stats: bool,
|
|
83
|
+
pub level: String,
|
|
84
|
+
pub enabled: bool,
|
|
85
|
+
}
|
package/rust/utils/Cargo.toml
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
[package]
|
|
2
2
|
name = "devalang_utils"
|
|
3
|
-
version = "0.0.
|
|
3
|
+
version = "0.0.2"
|
|
4
4
|
description = "Utility functions and types for Devalang"
|
|
5
5
|
license = "MIT"
|
|
6
6
|
authors = ["Devaloop <contact@devaloop.com>"]
|
|
7
7
|
edition = "2024"
|
|
8
8
|
|
|
9
9
|
[dependencies]
|
|
10
|
-
devalang_types = { path = "../types", version = "0.0.
|
|
10
|
+
devalang_types = { path = "../types", version = "0.0.3" }
|
|
11
11
|
serde = { version = "1.0", features = ["derive"] }
|
|
12
12
|
serde_json = "1.0"
|
|
13
13
|
include_dir = "0.7"
|
package/rust/utils/src/file.rs
CHANGED
|
@@ -1,94 +1,94 @@
|
|
|
1
|
-
use include_dir::{Dir, DirEntry};
|
|
2
|
-
use std::{fs, path::Path};
|
|
3
|
-
|
|
4
|
-
pub fn copy_dir_recursive(dir: &Dir, target_root: &Path, base_path: &Path) {
|
|
5
|
-
for entry in dir.entries() {
|
|
6
|
-
match entry {
|
|
7
|
-
DirEntry::Dir(subdir) => {
|
|
8
|
-
copy_dir_recursive(subdir, target_root, base_path);
|
|
9
|
-
}
|
|
10
|
-
DirEntry::File(file) => {
|
|
11
|
-
// Compute the destination path relative to the provided base.
|
|
12
|
-
let rel_path = match file.path().strip_prefix(base_path) {
|
|
13
|
-
Ok(p) => p.to_owned(),
|
|
14
|
-
Err(_) => {
|
|
15
|
-
eprintln!(
|
|
16
|
-
"Warning: failed to compute relative path for {:?}, skipping",
|
|
17
|
-
file.path()
|
|
18
|
-
);
|
|
19
|
-
continue;
|
|
20
|
-
}
|
|
21
|
-
};
|
|
22
|
-
|
|
23
|
-
let dest_path = target_root.join(rel_path);
|
|
24
|
-
|
|
25
|
-
if let Some(parent) = dest_path.parent() {
|
|
26
|
-
if let Err(e) = fs::create_dir_all(parent) {
|
|
27
|
-
eprintln!(
|
|
28
|
-
"Warning: failed to create directory {}: {}",
|
|
29
|
-
parent.display(),
|
|
30
|
-
e
|
|
31
|
-
);
|
|
32
|
-
continue;
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
if let Err(e) = fs::write(&dest_path, file.contents()) {
|
|
37
|
-
eprintln!("Warning: failed to write {}: {}", dest_path.display(), e);
|
|
38
|
-
continue;
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
pub fn format_file_size(bytes: u64) -> String {
|
|
46
|
-
const KB: u64 = 1024;
|
|
47
|
-
const MB: u64 = 1024 * 1024;
|
|
48
|
-
|
|
49
|
-
if bytes >= MB {
|
|
50
|
-
format!("{:.2} Mb", (bytes as f64) / (MB as f64))
|
|
51
|
-
} else if bytes >= KB {
|
|
52
|
-
format!("{:.2} Kb", (bytes as f64) / (KB as f64))
|
|
53
|
-
} else {
|
|
54
|
-
format!("{} bytes", bytes)
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
pub fn extract_zip_safely(archive_path: &Path, dest: &Path) -> Result<(), String> {
|
|
59
|
-
let file = std::fs::File::open(archive_path)
|
|
60
|
-
.map_err(|e| format!("Failed to open archive {}: {}", archive_path.display(), e))?;
|
|
61
|
-
let mut archive = zip::ZipArchive::new(file)
|
|
62
|
-
.map_err(|e| format!("Failed to read archive {}: {}", archive_path.display(), e))?;
|
|
63
|
-
|
|
64
|
-
for i in 0..archive.len() {
|
|
65
|
-
let mut file = archive
|
|
66
|
-
.by_index(i)
|
|
67
|
-
.map_err(|e| format!("Failed to access archive entry {}: {}", i, e))?;
|
|
68
|
-
|
|
69
|
-
let enclosed = match file.enclosed_name() {
|
|
70
|
-
Some(path) => path.to_owned(),
|
|
71
|
-
None => {
|
|
72
|
-
continue;
|
|
73
|
-
}
|
|
74
|
-
};
|
|
75
|
-
|
|
76
|
-
let outpath = dest.join(enclosed);
|
|
77
|
-
|
|
78
|
-
if file.name().ends_with('/') || file.is_dir() {
|
|
79
|
-
std::fs::create_dir_all(&outpath)
|
|
80
|
-
.map_err(|e| format!("Failed to create dir {}: {}", outpath.display(), e))?;
|
|
81
|
-
} else {
|
|
82
|
-
if let Some(p) = outpath.parent() {
|
|
83
|
-
std::fs::create_dir_all(p)
|
|
84
|
-
.map_err(|e| format!("Failed to create parent {}: {}", p.display(), e))?;
|
|
85
|
-
}
|
|
86
|
-
let mut outfile = std::fs::File::create(&outpath)
|
|
87
|
-
.map_err(|e| format!("Failed to create file {}: {}", outpath.display(), e))?;
|
|
88
|
-
std::io::copy(&mut file, &mut outfile)
|
|
89
|
-
.map_err(|e| format!("Failed to write file {}: {}", outpath.display(), e))?;
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
Ok(())
|
|
94
|
-
}
|
|
1
|
+
use include_dir::{Dir, DirEntry};
|
|
2
|
+
use std::{fs, path::Path};
|
|
3
|
+
|
|
4
|
+
pub fn copy_dir_recursive(dir: &Dir, target_root: &Path, base_path: &Path) {
|
|
5
|
+
for entry in dir.entries() {
|
|
6
|
+
match entry {
|
|
7
|
+
DirEntry::Dir(subdir) => {
|
|
8
|
+
copy_dir_recursive(subdir, target_root, base_path);
|
|
9
|
+
}
|
|
10
|
+
DirEntry::File(file) => {
|
|
11
|
+
// Compute the destination path relative to the provided base.
|
|
12
|
+
let rel_path = match file.path().strip_prefix(base_path) {
|
|
13
|
+
Ok(p) => p.to_owned(),
|
|
14
|
+
Err(_) => {
|
|
15
|
+
eprintln!(
|
|
16
|
+
"Warning: failed to compute relative path for {:?}, skipping",
|
|
17
|
+
file.path()
|
|
18
|
+
);
|
|
19
|
+
continue;
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
let dest_path = target_root.join(rel_path);
|
|
24
|
+
|
|
25
|
+
if let Some(parent) = dest_path.parent() {
|
|
26
|
+
if let Err(e) = fs::create_dir_all(parent) {
|
|
27
|
+
eprintln!(
|
|
28
|
+
"Warning: failed to create directory {}: {}",
|
|
29
|
+
parent.display(),
|
|
30
|
+
e
|
|
31
|
+
);
|
|
32
|
+
continue;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
if let Err(e) = fs::write(&dest_path, file.contents()) {
|
|
37
|
+
eprintln!("Warning: failed to write {}: {}", dest_path.display(), e);
|
|
38
|
+
continue;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
pub fn format_file_size(bytes: u64) -> String {
|
|
46
|
+
const KB: u64 = 1024;
|
|
47
|
+
const MB: u64 = 1024 * 1024;
|
|
48
|
+
|
|
49
|
+
if bytes >= MB {
|
|
50
|
+
format!("{:.2} Mb", (bytes as f64) / (MB as f64))
|
|
51
|
+
} else if bytes >= KB {
|
|
52
|
+
format!("{:.2} Kb", (bytes as f64) / (KB as f64))
|
|
53
|
+
} else {
|
|
54
|
+
format!("{} bytes", bytes)
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
pub fn extract_zip_safely(archive_path: &Path, dest: &Path) -> Result<(), String> {
|
|
59
|
+
let file = std::fs::File::open(archive_path)
|
|
60
|
+
.map_err(|e| format!("Failed to open archive {}: {}", archive_path.display(), e))?;
|
|
61
|
+
let mut archive = zip::ZipArchive::new(file)
|
|
62
|
+
.map_err(|e| format!("Failed to read archive {}: {}", archive_path.display(), e))?;
|
|
63
|
+
|
|
64
|
+
for i in 0..archive.len() {
|
|
65
|
+
let mut file = archive
|
|
66
|
+
.by_index(i)
|
|
67
|
+
.map_err(|e| format!("Failed to access archive entry {}: {}", i, e))?;
|
|
68
|
+
|
|
69
|
+
let enclosed = match file.enclosed_name() {
|
|
70
|
+
Some(path) => path.to_owned(),
|
|
71
|
+
None => {
|
|
72
|
+
continue;
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
|
|
76
|
+
let outpath = dest.join(enclosed);
|
|
77
|
+
|
|
78
|
+
if file.name().ends_with('/') || file.is_dir() {
|
|
79
|
+
std::fs::create_dir_all(&outpath)
|
|
80
|
+
.map_err(|e| format!("Failed to create dir {}: {}", outpath.display(), e))?;
|
|
81
|
+
} else {
|
|
82
|
+
if let Some(p) = outpath.parent() {
|
|
83
|
+
std::fs::create_dir_all(p)
|
|
84
|
+
.map_err(|e| format!("Failed to create parent {}: {}", p.display(), e))?;
|
|
85
|
+
}
|
|
86
|
+
let mut outfile = std::fs::File::create(&outpath)
|
|
87
|
+
.map_err(|e| format!("Failed to create file {}: {}", outpath.display(), e))?;
|
|
88
|
+
std::io::copy(&mut file, &mut outfile)
|
|
89
|
+
.map_err(|e| format!("Failed to write file {}: {}", outpath.display(), e))?;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
Ok(())
|
|
94
|
+
}
|
|
@@ -1,97 +1,97 @@
|
|
|
1
|
-
#[cfg(feature = "cli")]
|
|
2
|
-
use crossterm::style::{Attribute, SetAttribute};
|
|
3
|
-
|
|
4
|
-
#[cfg(feature = "cli")]
|
|
5
|
-
use std::fmt::Write;
|
|
6
|
-
|
|
7
|
-
use crate::logger::{LogLevel, Logger};
|
|
8
|
-
use crate::signature::get_signature;
|
|
9
|
-
use crate::version::get_version;
|
|
10
|
-
use std::env;
|
|
11
|
-
use std::path::PathBuf;
|
|
12
|
-
|
|
13
|
-
fn get_devalang_homedir() -> PathBuf {
|
|
14
|
-
// Prefer explicit env var, then HOME/USERPROFILE, fallback to current dir
|
|
15
|
-
if let Ok(p) = env::var("DEVALANG_HOME") {
|
|
16
|
-
return PathBuf::from(p);
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
if let Ok(p) = env::var("HOME") {
|
|
20
|
-
return PathBuf::from(p).join(".devalang");
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
if let Ok(p) = env::var("USERPROFILE") {
|
|
24
|
-
return PathBuf::from(p).join(".devalang");
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
env::current_dir()
|
|
28
|
-
.unwrap_or_else(|_| PathBuf::from("."))
|
|
29
|
-
.join(".devalang")
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
pub fn check_is_first_usage() -> bool {
|
|
33
|
-
if get_devalang_homedir().exists() == true {
|
|
34
|
-
false
|
|
35
|
-
} else {
|
|
36
|
-
first_usage_welcome();
|
|
37
|
-
true
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
pub fn first_usage_welcome() {
|
|
42
|
-
std::fs::create_dir_all(get_devalang_homedir()).ok();
|
|
43
|
-
|
|
44
|
-
let version = get_version();
|
|
45
|
-
print!("{}", get_signature(&version));
|
|
46
|
-
|
|
47
|
-
let homedir = get_devalang_homedir().display().to_string();
|
|
48
|
-
|
|
49
|
-
let welcome_msg = format!(
|
|
50
|
-
"Welcome to Devalang ! \n\
|
|
51
|
-
It looks like this is your first time using the tool.\n\
|
|
52
|
-
A configuration file will be created in your home directory.\n\
|
|
53
|
-
(location: '{}')",
|
|
54
|
-
homedir
|
|
55
|
-
);
|
|
56
|
-
|
|
57
|
-
#[cfg(feature = "cli")]
|
|
58
|
-
let mut s = String::new();
|
|
59
|
-
#[cfg(feature = "cli")]
|
|
60
|
-
{
|
|
61
|
-
write!(&mut s, "{}", SetAttribute(Attribute::Bold)).unwrap();
|
|
62
|
-
write!(&mut s, "{}", welcome_msg).unwrap();
|
|
63
|
-
write!(&mut s, "{}", SetAttribute(Attribute::Reset)).unwrap();
|
|
64
|
-
|
|
65
|
-
println!("");
|
|
66
|
-
println!("{}", s);
|
|
67
|
-
println!("");
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
#[cfg(not(feature = "cli"))]
|
|
71
|
-
{
|
|
72
|
-
// Fallback: plain output on non-cli (wasm) builds
|
|
73
|
-
println!("");
|
|
74
|
-
println!("{}", welcome_msg);
|
|
75
|
-
println!("");
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
first_usage_ask_for_telemetry();
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
pub fn first_usage_ask_for_telemetry() {
|
|
82
|
-
let telemetry_msg = "Would you like to enable anonymous telemetry ?";
|
|
83
|
-
let telemetry_desc = "This data helps us improve the tool. You can opt-out at any time.";
|
|
84
|
-
|
|
85
|
-
// Non-interactive fallback for first usage: default to telemetry disabled.
|
|
86
|
-
let _ = telemetry_msg;
|
|
87
|
-
let _ = telemetry_desc;
|
|
88
|
-
|
|
89
|
-
let logger = Logger::new();
|
|
90
|
-
|
|
91
|
-
println!("");
|
|
92
|
-
logger.log_message(
|
|
93
|
-
LogLevel::Info,
|
|
94
|
-
"Telemetry disabled by default. You can enable it at any time by using 'devalang telemetry enable'"
|
|
95
|
-
);
|
|
96
|
-
println!("");
|
|
97
|
-
}
|
|
1
|
+
#[cfg(feature = "cli")]
|
|
2
|
+
use crossterm::style::{Attribute, SetAttribute};
|
|
3
|
+
|
|
4
|
+
#[cfg(feature = "cli")]
|
|
5
|
+
use std::fmt::Write;
|
|
6
|
+
|
|
7
|
+
use crate::logger::{LogLevel, Logger};
|
|
8
|
+
use crate::signature::get_signature;
|
|
9
|
+
use crate::version::get_version;
|
|
10
|
+
use std::env;
|
|
11
|
+
use std::path::PathBuf;
|
|
12
|
+
|
|
13
|
+
fn get_devalang_homedir() -> PathBuf {
|
|
14
|
+
// Prefer explicit env var, then HOME/USERPROFILE, fallback to current dir
|
|
15
|
+
if let Ok(p) = env::var("DEVALANG_HOME") {
|
|
16
|
+
return PathBuf::from(p);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
if let Ok(p) = env::var("HOME") {
|
|
20
|
+
return PathBuf::from(p).join(".devalang");
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
if let Ok(p) = env::var("USERPROFILE") {
|
|
24
|
+
return PathBuf::from(p).join(".devalang");
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
env::current_dir()
|
|
28
|
+
.unwrap_or_else(|_| PathBuf::from("."))
|
|
29
|
+
.join(".devalang")
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
pub fn check_is_first_usage() -> bool {
|
|
33
|
+
if get_devalang_homedir().exists() == true {
|
|
34
|
+
false
|
|
35
|
+
} else {
|
|
36
|
+
first_usage_welcome();
|
|
37
|
+
true
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
pub fn first_usage_welcome() {
|
|
42
|
+
std::fs::create_dir_all(get_devalang_homedir()).ok();
|
|
43
|
+
|
|
44
|
+
let version = get_version();
|
|
45
|
+
print!("{}", get_signature(&version));
|
|
46
|
+
|
|
47
|
+
let homedir = get_devalang_homedir().display().to_string();
|
|
48
|
+
|
|
49
|
+
let welcome_msg = format!(
|
|
50
|
+
"Welcome to Devalang ! \n\
|
|
51
|
+
It looks like this is your first time using the tool.\n\
|
|
52
|
+
A configuration file will be created in your home directory.\n\
|
|
53
|
+
(location: '{}')",
|
|
54
|
+
homedir
|
|
55
|
+
);
|
|
56
|
+
|
|
57
|
+
#[cfg(feature = "cli")]
|
|
58
|
+
let mut s = String::new();
|
|
59
|
+
#[cfg(feature = "cli")]
|
|
60
|
+
{
|
|
61
|
+
write!(&mut s, "{}", SetAttribute(Attribute::Bold)).unwrap();
|
|
62
|
+
write!(&mut s, "{}", welcome_msg).unwrap();
|
|
63
|
+
write!(&mut s, "{}", SetAttribute(Attribute::Reset)).unwrap();
|
|
64
|
+
|
|
65
|
+
println!("");
|
|
66
|
+
println!("{}", s);
|
|
67
|
+
println!("");
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
#[cfg(not(feature = "cli"))]
|
|
71
|
+
{
|
|
72
|
+
// Fallback: plain output on non-cli (wasm) builds
|
|
73
|
+
println!("");
|
|
74
|
+
println!("{}", welcome_msg);
|
|
75
|
+
println!("");
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
first_usage_ask_for_telemetry();
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
pub fn first_usage_ask_for_telemetry() {
|
|
82
|
+
let telemetry_msg = "Would you like to enable anonymous telemetry ?";
|
|
83
|
+
let telemetry_desc = "This data helps us improve the tool. You can opt-out at any time.";
|
|
84
|
+
|
|
85
|
+
// Non-interactive fallback for first usage: default to telemetry disabled.
|
|
86
|
+
let _ = telemetry_msg;
|
|
87
|
+
let _ = telemetry_desc;
|
|
88
|
+
|
|
89
|
+
let logger = Logger::new();
|
|
90
|
+
|
|
91
|
+
println!("");
|
|
92
|
+
logger.log_message(
|
|
93
|
+
LogLevel::Info,
|
|
94
|
+
"Telemetry disabled by default. You can enable it at any time by using 'devalang telemetry enable'"
|
|
95
|
+
);
|
|
96
|
+
println!("");
|
|
97
|
+
}
|
package/rust/utils/src/lib.rs
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
pub mod error;
|
|
2
|
-
pub mod file;
|
|
3
|
-
pub mod first_usage;
|
|
4
|
-
pub mod logger;
|
|
5
|
-
pub mod path;
|
|
6
|
-
pub mod signature;
|
|
7
|
-
pub mod spinner;
|
|
8
|
-
pub mod version;
|
|
9
|
-
pub mod watcher;
|
|
1
|
+
pub mod error;
|
|
2
|
+
pub mod file;
|
|
3
|
+
pub mod first_usage;
|
|
4
|
+
pub mod logger;
|
|
5
|
+
pub mod path;
|
|
6
|
+
pub mod signature;
|
|
7
|
+
pub mod spinner;
|
|
8
|
+
pub mod version;
|
|
9
|
+
pub mod watcher;
|