difftreelog
fix std.decodeUTF8 should be lossy by default
in: master
6 files changed
crates/jrsonnet-stdlib/src/encoding.rsdiffbeforeafterboth1use base64::{engine::general_purpose::STANDARD, Engine};1use base64::{engine::general_purpose::STANDARD, Engine};2use jrsonnet_evaluator::{2use jrsonnet_evaluator::{3 bail,3 function::builtin,4 function::builtin,4 runtime_error,5 runtime_error,5 typed::{Either, Either2},6 typed::{Either, Either2},12}13}131414#[builtin]15#[builtin]15pub fn builtin_decode_utf8(arr: IBytes) -> Result<IStr> {16pub fn builtin_decode_utf8(arr: IBytes, #[default(true)] lossy: bool) -> Result<IStr> {16 arr.cast_str().ok_or_else(|| runtime_error!("bad utf8"))17 match arr.clone().cast_str() {18 Some(s) => Ok(s),19 None if lossy => Ok(String::from_utf8_lossy(arr.as_slice()).into()),20 None => {21 bail!("bad utf8")22 }23 }17}24}182519#[builtin]26#[builtin]tests/golden/issue187.jsonnetdiffbeforeafterboth--- /dev/null
+++ b/tests/golden/issue187.jsonnet
@@ -0,0 +1 @@
+std.decodeUTF8(std.encodeUTF8('foo bar ') + [255] + std.encodeUTF8(' baz'))
tests/golden/issue187.jsonnet.goldendiffbeforeafterboth--- /dev/null
+++ b/tests/golden/issue187.jsonnet.golden
@@ -0,0 +1 @@
+"foo bar � baz"
\ No newline at end of file
tests/golden/issue187.rev.jsonnetdiffbeforeafterboth--- /dev/null
+++ b/tests/golden/issue187.rev.jsonnet
@@ -0,0 +1 @@
+std.decodeUTF8(std.encodeUTF8('foo bar ') + [255] + std.encodeUTF8(' baz'), lossy = false)
tests/golden/issue187.rev.jsonnet.goldendiffbeforeafterboth--- /dev/null
+++ b/tests/golden/issue187.rev.jsonnet.golden
@@ -0,0 +1,2 @@
+runtime error: bad utf8
+ issue187.rev.jsonnet:1:1-92: function <builtin_decode_utf8> call
\ No newline at end of file
tests/suite/std_param_names.jsonnetdiffbeforeafterboth--- a/tests/suite/std_param_names.jsonnet
+++ b/tests/suite/std_param_names.jsonnet
@@ -129,7 +129,7 @@
parseJson: ['str'],
parseYaml: ['str'],
encodeUTF8: ['str'],
- decodeUTF8: ['arr'],
+ decodeUTF8: ['arr', 'lossy'],
sum: ['arr'],
avg: ['arr', 'onEmpty'],