use wdl_analysis::stdlib::STDLIB as ANALYSIS_STDLIB;
use wdl_ast::Diagnostic;
use super::CallContext;
use super::Callback;
use super::Function;
use super::Signature;
use crate::Array;
use crate::PrimitiveValue;
use crate::Value;
fn squote(context: CallContext<'_>) -> Result<Value, Diagnostic> {
debug_assert_eq!(context.arguments.len(), 1);
debug_assert!(context.return_type_eq(ANALYSIS_STDLIB.array_string_type().clone()));
let array = context.arguments[0]
.value
.as_array()
.expect("value should be an array");
let elements = array
.as_slice()
.iter()
.map(|v| match v {
Value::None(_) => PrimitiveValue::new_string("''").into(),
Value::Primitive(v) => {
PrimitiveValue::new_string(format!("'{v}'", v = v.raw(Some(context.inner()))))
.into()
}
_ => panic!("expected an array of primitive values"),
})
.collect();
Ok(Array::new_unchecked(context.return_type, elements).into())
}
pub const fn descriptor() -> Function {
Function::new(
const {
&[Signature::new(
"(array: Array[P]) -> Array[String] where `P`: any primitive type",
Callback::Sync(squote),
)]
},
)
}
#[cfg(test)]
mod test {
use pretty_assertions::assert_eq;
use wdl_ast::version::V1;
use crate::v1::test::TestEnv;
use crate::v1::test::eval_v1_expr;
#[tokio::test]
async fn squote() {
let env = TestEnv::default();
let value = eval_v1_expr(&env, V1::One, "squote([1, 2, 3])")
.await
.unwrap();
let elements: Vec<_> = value
.as_array()
.unwrap()
.as_slice()
.iter()
.map(|v| v.as_string().unwrap().as_str())
.collect();
assert_eq!(elements, ["'1'", "'2'", "'3'"]);
let value = eval_v1_expr(&env, V1::One, "squote([1.0, 1.1, 1.2])")
.await
.unwrap();
let elements: Vec<_> = value
.as_array()
.unwrap()
.as_slice()
.iter()
.map(|v| v.as_string().unwrap().as_str())
.collect();
assert_eq!(elements, ["'1.000000'", "'1.100000'", "'1.200000'"]);
let value = eval_v1_expr(&env, V1::One, "squote(['bar', 'baz', 'qux'])")
.await
.unwrap();
let elements: Vec<_> = value
.as_array()
.unwrap()
.as_slice()
.iter()
.map(|v| v.as_string().unwrap().as_str())
.collect();
assert_eq!(elements, ["'bar'", "'baz'", "'qux'"]);
let value = eval_v1_expr(&env, V1::One, "squote(['bar', None, 'qux'])")
.await
.unwrap();
let elements: Vec<_> = value
.as_array()
.unwrap()
.as_slice()
.iter()
.map(|v| v.as_string().unwrap().as_str())
.collect();
assert_eq!(elements, ["'bar'", "''", "'qux'"]);
let value = eval_v1_expr(&env, V1::One, "squote([])").await.unwrap();
assert!(value.unwrap_array().is_empty());
}
}