git.delta.rocks / jrsonnet / refs/commits / 57f709a58e12

difftreelog

perf move resolvePath to native

Yaroslav Bolyukin2024-06-18parent: #71fb4e2.patch.diff
in: master

3 files changed

modifiedcrates/jrsonnet-stdlib/src/arrays.rsdiffbeforeafterboth
208 )208 )
209}209}
210
211#[builtin]
212pub fn builtin_resolve_path(f: String, r: String) -> String {
213 let Some(pos) = f.rfind('/') else {
214 return r;
215 };
216 format!("{}{}", &f[..=pos], r)
217}
210218
211pub fn deep_join_inner(out: &mut String, arr: IndexableVal) -> Result<()> {219pub fn deep_join_inner(out: &mut String, arr: IndexableVal) -> Result<()> {
212 use std::fmt::Write;220 use std::fmt::Write;
modifiedcrates/jrsonnet-stdlib/src/lib.rsdiffbeforeafterboth
--- a/crates/jrsonnet-stdlib/src/lib.rs
+++ b/crates/jrsonnet-stdlib/src/lib.rs
@@ -86,6 +86,7 @@
 		("range", builtin_range::INST),
 		("join", builtin_join::INST),
 		("lines", builtin_lines::INST),
+		("resolvePath", builtin_resolve_path::INST),
 		("deepJoin", builtin_deep_join::INST),
 		("reverse", builtin_reverse::INST),
 		("any", builtin_any::INST),
modifiedcrates/jrsonnet-stdlib/src/std.jsonnetdiffbeforeafterboth
--- a/crates/jrsonnet-stdlib/src/std.jsonnet
+++ b/crates/jrsonnet-stdlib/src/std.jsonnet
@@ -10,8 +10,4 @@
       error ('std.mapWithKey second param must be object, got ' + std.type(obj))
     else
       { [k]: func(k, obj[k]) for k in std.objectFields(obj) },
-
-  resolvePath(f, r)::
-    local arr = std.split(f, '/');
-    std.join('/', std.makeArray(std.length(arr) - 1, function(i) arr[i]) + [r]),
 }