difftreelog
perf move std.lines to native
in: master
3 files changed
crates/jrsonnet-stdlib/src/arrays.rsdiffbeforeafterboth--- a/crates/jrsonnet-stdlib/src/arrays.rs
+++ b/crates/jrsonnet-stdlib/src/arrays.rs
@@ -201,6 +201,14 @@
}
#[builtin]
+pub fn builtin_lines(arr: ArrValue) -> Result<IndexableVal> {
+ builtin_join(
+ IndexableVal::Str("\n".into()),
+ ArrValue::extended(arr, ArrValue::eager(vec![Val::string("")])).into(),
+ )
+}
+
+#[builtin]
pub fn builtin_reverse(arr: ArrValue) -> ArrValue {
arr.reversed()
}
crates/jrsonnet-stdlib/src/lib.rsdiffbeforeafterboth--- a/crates/jrsonnet-stdlib/src/lib.rs
+++ b/crates/jrsonnet-stdlib/src/lib.rs
@@ -85,6 +85,7 @@
("foldr", builtin_foldr::INST),
("range", builtin_range::INST),
("join", builtin_join::INST),
+ ("lines", builtin_lines::INST),
("reverse", builtin_reverse::INST),
("any", builtin_any::INST),
("all", builtin_all::INST),
crates/jrsonnet-stdlib/src/std.jsonnetdiffbeforeafterboth11 else11 else12 { [k]: func(k, obj[k]) for k in std.objectFields(obj) },12 { [k]: func(k, obj[k]) for k in std.objectFields(obj) },131314 lines(arr)::15 std.join('\n', arr + ['']),1617 deepJoin(arr)::14 deepJoin(arr)::18 if std.isString(arr) then15 if std.isString(arr) then19 arr16 arr