use crate::codegen::conversions::ConversionConfig;
use crate::codegen::conversions::field_conversion_to_core;
use crate::codegen::conversions::helpers::{binding_prim_str, needs_f64_cast, needs_i32_cast, needs_i64_cast};
use crate::core::ir::{PrimitiveType, TypeRef};
use ahash::AHashSet;
pub fn field_conversion_from_core(
name: &str,
ty: &TypeRef,
optional: bool,
sanitized: bool,
opaque_types: &AHashSet<String>,
) -> String {
if sanitized {
if let TypeRef::Vec(inner) = ty {
if matches!(inner.as_ref(), TypeRef::Primitive(_)) {
if optional {
return format!(
"{name}: val.{name}.map(|t| {{ let arr: Vec<_> = [t.0, t.1].into_iter().map(|v| v as _).collect(); arr }})"
);
}
return format!("{name}: vec![val.{name}.0 as _, val.{name}.1 as _]");
}
}
if let TypeRef::Optional(opt_inner) = ty {
if let TypeRef::Vec(vec_inner) = opt_inner.as_ref() {
if matches!(vec_inner.as_ref(), TypeRef::Primitive(_)) {
return format!("{name}: val.{name}.map(|t| vec![t.0 as _, t.1 as _])");
}
}
}
if let TypeRef::Map(k, v) = ty {
if matches!(k.as_ref(), TypeRef::String) && matches!(v.as_ref(), TypeRef::String) {
if optional {
return format!(
"{name}: val.{name}.as_ref().map(|m| m.iter().map(|(k, v)| (k.to_string(), v.to_string())).collect())"
);
}
return format!(
"{name}: val.{name}.into_iter().map(|(k, v)| (k.to_string(), v.to_string())).collect()"
);
}
}
if let TypeRef::Vec(outer_inner) = ty {
if let TypeRef::Vec(inner) = outer_inner.as_ref() {
if matches!(inner.as_ref(), TypeRef::String) {
if optional {
return format!(
"{name}: val.{name}.as_ref().map(|v| v.iter().map(|(a, b)| vec![a.to_string(), b.to_string()]).collect::<Vec<Vec<String>>>())"
);
}
return format!(
"{name}: val.{name}.iter().map(|(a, b)| vec![a.to_string(), b.to_string()]).collect::<Vec<Vec<String>>>()"
);
}
}
}
if let TypeRef::Optional(opt_inner) = ty {
if let TypeRef::Vec(outer_inner) = opt_inner.as_ref() {
if let TypeRef::Vec(inner) = outer_inner.as_ref() {
if matches!(inner.as_ref(), TypeRef::String) {
return format!(
"{name}: val.{name}.as_ref().map(|v| v.iter().map(|(a, b)| vec![a.to_string(), b.to_string()]).collect::<Vec<Vec<String>>>())"
);
}
}
}
}
if let TypeRef::Vec(inner) = ty {
if matches!(inner.as_ref(), TypeRef::String) {
if optional {
return format!(
"{name}: val.{name}.as_ref().map(|v| v.iter().map(|i| format!(\"{{:?}}\", i)).collect())"
);
}
return format!("{name}: val.{name}.iter().map(|i| format!(\"{{:?}}\", i)).collect()");
}
}
if let TypeRef::Optional(opt_inner) = ty {
if let TypeRef::Vec(vec_inner) = opt_inner.as_ref() {
if matches!(vec_inner.as_ref(), TypeRef::String) {
return format!(
"{name}: val.{name}.as_ref().map(|v| v.iter().map(|i| format!(\"{{:?}}\", i)).collect())"
);
}
}
}
if matches!(ty, TypeRef::String) {
if optional {
return format!("{name}: val.{name}.as_ref().map(|v| format!(\"{{v:?}}\"))");
}
return format!("{name}: format!(\"{{:?}}\", val.{name})");
}
if optional {
return format!("{name}: val.{name}.as_ref().map(|v| format!(\"{{v:?}}\"))");
}
return format!("{name}: format!(\"{{:?}}\", val.{name})");
}
match ty {
TypeRef::Duration => {
if optional {
return format!("{name}: val.{name}.map(|d| d.as_millis() as u64)");
}
format!("{name}: val.{name}.as_millis() as u64")
}
TypeRef::Path => {
if optional {
format!("{name}: val.{name}.map(|p| p.to_string_lossy().to_string())")
} else {
format!("{name}: val.{name}.to_string_lossy().to_string()")
}
}
TypeRef::Optional(inner) if matches!(inner.as_ref(), TypeRef::Path) => {
format!("{name}: val.{name}.map(|p| p.to_string_lossy().to_string())")
}
TypeRef::Char => {
if optional {
format!("{name}: val.{name}.map(|c| c.to_string())")
} else {
format!("{name}: val.{name}.to_string()")
}
}
TypeRef::Bytes => {
if optional {
format!("{name}: val.{name}.map(|v| v.to_vec().into())")
} else {
format!("{name}: val.{name}.to_vec().into()")
}
}
TypeRef::Named(n) if opaque_types.contains(n.as_str()) => {
if optional {
format!("{name}: val.{name}.map(|v| {n} {{ inner: Arc::new(v) }})")
} else {
format!("{name}: {n} {{ inner: Arc::new(val.{name}) }}")
}
}
TypeRef::Json => {
if optional {
format!("{name}: val.{name}.as_ref().map(ToString::to_string)")
} else {
format!("{name}: val.{name}.to_string()")
}
}
TypeRef::Optional(inner) if matches!(inner.as_ref(), TypeRef::Json) => {
format!("{name}: val.{name}.as_ref().map(ToString::to_string)")
}
TypeRef::Vec(inner) if matches!(inner.as_ref(), TypeRef::Json) => {
if optional {
format!("{name}: val.{name}.as_ref().map(|v| v.iter().map(|i| i.to_string()).collect())")
} else {
format!("{name}: val.{name}.iter().map(ToString::to_string).collect()")
}
}
TypeRef::Vec(inner) if matches!(inner.as_ref(), TypeRef::Optional(oi) if matches!(oi.as_ref(), TypeRef::Json)) => {
if optional {
format!(
"{name}: val.{name}.as_ref().map(|v| v.iter().map(|i| i.as_ref().map(ToString::to_string)).collect())"
)
} else {
format!("{name}: val.{name}.iter().map(|i| i.as_ref().map(ToString::to_string)).collect()")
}
}
TypeRef::Map(_k, v) if matches!(v.as_ref(), TypeRef::Json) => {
if optional {
format!(
"{name}: val.{name}.map(|m| m.into_iter().map(|(k, v)| (k.to_string(), v.to_string())).collect())"
)
} else {
format!("{name}: val.{name}.into_iter().map(|(k, v)| (k.to_string(), v.to_string())).collect()")
}
}
TypeRef::Map(k, _v) if matches!(k.as_ref(), TypeRef::Json) => {
if optional {
format!("{name}: val.{name}.map(|m| m.into_iter().map(|(k, v)| (k.to_string(), v)).collect())")
} else {
format!("{name}: val.{name}.into_iter().map(|(k, v)| (k.to_string(), v)).collect()")
}
}
TypeRef::Map(k, v) if matches!(k.as_ref(), TypeRef::String) && matches!(v.as_ref(), TypeRef::String) => {
if optional {
format!("{name}: val.{name}.map(|m| m.into_iter().map(|(k, v)| (k.into(), v.into())).collect())")
} else {
format!("{name}: val.{name}.into_iter().map(|(k, v)| (k.into(), v.into())).collect()")
}
}
TypeRef::Map(_k, v) if matches!(v.as_ref(), TypeRef::Bytes) => {
if optional {
format!("{name}: val.{name}.map(|m| m.into_iter().map(|(k, v)| (k, v.to_vec().into())).collect())")
} else {
format!("{name}: val.{name}.into_iter().map(|(k, v)| (k, v.to_vec().into())).collect()")
}
}
TypeRef::Map(_k, v) if matches!(v.as_ref(), TypeRef::Named(_)) => {
if optional {
format!("{name}: val.{name}.map(|m| m.into_iter().map(|(k, v)| (k, v.into())).collect())")
} else {
format!("{name}: val.{name}.into_iter().map(|(k, v)| (k, v.into())).collect()")
}
}
TypeRef::Optional(inner) if matches!(inner.as_ref(), TypeRef::Map(_k, v) if matches!(v.as_ref(), TypeRef::Named(_))) =>
{
format!("{name}: val.{name}.map(|m| m.into_iter().map(|(k, v)| (k, v.into())).collect())")
}
TypeRef::Vec(inner) if matches!(inner.as_ref(), TypeRef::Named(_)) => {
if optional {
format!("{name}: val.{name}.map(|v| v.into_iter().map(Into::into).collect())")
} else {
format!("{name}: val.{name}.into_iter().map(Into::into).collect()")
}
}
TypeRef::Optional(inner) if matches!(inner.as_ref(), TypeRef::Vec(vi) if matches!(vi.as_ref(), TypeRef::Named(_))) =>
{
format!("{name}: val.{name}.map(|v| v.into_iter().map(Into::into).collect())")
}
TypeRef::Vec(_) => {
if optional {
format!("{name}: val.{name}.map(|v| v.into_iter().collect())")
} else {
format!("{name}: val.{name}.into_iter().collect()")
}
}
TypeRef::Optional(inner) if matches!(inner.as_ref(), TypeRef::Vec(_)) => {
format!("{name}: val.{name}.map(|v| v.into_iter().collect())")
}
TypeRef::String => {
if optional {
format!("{name}: val.{name}.map(|v| v.to_string())")
} else {
format!("{name}: val.{name}.to_string()")
}
}
_ => field_conversion_to_core(name, ty, optional),
}
}
pub fn field_conversion_from_core_cfg(
name: &str,
ty: &TypeRef,
optional: bool,
sanitized: bool,
opaque_types: &AHashSet<String>,
config: &ConversionConfig,
) -> String {
if sanitized {
if config.map_uses_jsvalue {
if let TypeRef::Map(k, v) = ty {
if matches!(k.as_ref(), TypeRef::String) && matches!(v.as_ref(), TypeRef::String) {
if optional {
return format!(
"{name}: val.{name}.as_ref().and_then(|v| serde_json::to_string(v).ok()).and_then(|s| js_sys::JSON::parse(&s).ok())"
);
}
return format!(
"{name}: js_sys::JSON::parse(&serde_json::to_string(&val.{name}).unwrap_or_default()).unwrap_or(JsValue::NULL)"
);
}
}
if let TypeRef::Vec(inner) = ty {
if matches!(inner.as_ref(), TypeRef::Json) {
if optional {
return format!(
"{name}: val.{name}.as_ref().and_then(|v| serde_wasm_bindgen::to_value(v).ok())"
);
}
return format!("{name}: serde_wasm_bindgen::to_value(&val.{name}).unwrap_or(JsValue::NULL)");
}
}
if let TypeRef::Vec(outer_inner) = ty {
if let TypeRef::Vec(inner) = outer_inner.as_ref() {
if matches!(inner.as_ref(), TypeRef::String) {
if optional {
return format!(
"{name}: val.{name}.as_ref().and_then(|v| serde_wasm_bindgen::to_value(&v.iter().map(|(a, b)| vec![a.to_string(), b.to_string()]).collect::<Vec<Vec<String>>>()).ok())"
);
}
return format!(
"{name}: serde_wasm_bindgen::to_value(&val.{name}.iter().map(|(a, b)| vec![a.to_string(), b.to_string()]).collect::<Vec<Vec<String>>>()).unwrap_or(JsValue::NULL)"
);
}
}
}
if let TypeRef::Optional(opt_inner) = ty {
if let TypeRef::Vec(outer_inner) = opt_inner.as_ref() {
if let TypeRef::Vec(inner) = outer_inner.as_ref() {
if matches!(inner.as_ref(), TypeRef::String) {
return format!(
"{name}: val.{name}.as_ref().and_then(|v| serde_wasm_bindgen::to_value(&v.iter().map(|(a, b)| vec![a.to_string(), b.to_string()]).collect::<Vec<Vec<String>>>()).ok())"
);
}
}
}
}
}
return field_conversion_from_core(name, ty, optional, sanitized, opaque_types);
}
if config.map_uses_jsvalue {
if let Some(tagged_names) = config.tagged_data_enum_names {
let bare_named = matches!(ty, TypeRef::Named(n) if tagged_names.contains(n));
let optional_named = matches!(ty, TypeRef::Optional(inner)
if matches!(inner.as_ref(), TypeRef::Named(n) if tagged_names.contains(n)));
let vec_named = matches!(ty, TypeRef::Vec(inner)
if matches!(inner.as_ref(), TypeRef::Named(n) if tagged_names.contains(n)));
let optional_vec_named = matches!(ty, TypeRef::Optional(outer)
if matches!(outer.as_ref(), TypeRef::Vec(inner)
if matches!(inner.as_ref(), TypeRef::Named(n) if tagged_names.contains(n))));
if bare_named {
if optional {
return format!("{name}: val.{name}.as_ref().and_then(|v| serde_wasm_bindgen::to_value(v).ok())");
}
return format!("{name}: serde_wasm_bindgen::to_value(&val.{name}).unwrap_or(JsValue::NULL)");
}
if optional_named {
return format!("{name}: val.{name}.as_ref().and_then(|v| serde_wasm_bindgen::to_value(v).ok())");
}
if vec_named {
if optional {
return format!("{name}: val.{name}.as_ref().and_then(|v| serde_wasm_bindgen::to_value(v).ok())");
}
return format!("{name}: serde_wasm_bindgen::to_value(&val.{name}).unwrap_or(JsValue::NULL)");
}
if optional_vec_named {
return format!("{name}: val.{name}.as_ref().and_then(|v| serde_wasm_bindgen::to_value(v).ok())");
}
}
}
if let Some(untagged_names) = config.untagged_data_enum_names {
let direct_named = matches!(ty, TypeRef::Named(n) if untagged_names.contains(n));
let optional_named = matches!(ty, TypeRef::Optional(inner)
if matches!(inner.as_ref(), TypeRef::Named(n) if untagged_names.contains(n)));
let vec_named = matches!(ty, TypeRef::Vec(inner)
if matches!(inner.as_ref(), TypeRef::Named(n) if untagged_names.contains(n)));
let optional_vec_named = matches!(ty, TypeRef::Optional(outer)
if matches!(outer.as_ref(), TypeRef::Vec(inner)
if matches!(inner.as_ref(), TypeRef::Named(n) if untagged_names.contains(n))));
if direct_named {
if optional {
return format!("{name}: val.{name}.as_ref().and_then(|v| serde_json::to_value(v).ok())");
}
return format!("{name}: serde_json::to_value(&val.{name}).unwrap_or(serde_json::Value::Null)");
}
if optional_named {
return format!("{name}: val.{name}.as_ref().and_then(|v| serde_json::to_value(v).ok())");
}
if vec_named {
if optional {
return format!(
"{name}: val.{name}.as_ref().map(|v| v.iter().filter_map(|x| serde_json::to_value(x).ok()).collect())"
);
}
return format!("{name}: val.{name}.iter().filter_map(|x| serde_json::to_value(x).ok()).collect()");
}
if optional_vec_named {
return format!(
"{name}: val.{name}.as_ref().map(|v| v.iter().filter_map(|x| serde_json::to_value(x).ok()).collect())"
);
}
}
if config.vec_named_to_string {
if let TypeRef::Vec(inner) = ty {
if matches!(inner.as_ref(), TypeRef::Named(_)) {
if optional {
return format!("{name}: val.{name}.as_ref().and_then(|v| serde_json::to_string(v).ok())");
}
return format!("{name}: serde_json::to_string(&val.{name}).unwrap_or_default()");
}
}
}
if config.map_as_string && matches!(ty, TypeRef::Map(_, _)) {
if optional {
return format!("{name}: val.{name}.as_ref().map(|m| format!(\"{{m:?}}\"))");
}
return format!("{name}: format!(\"{{:?}}\", val.{name})");
}
if config.map_as_string {
if let TypeRef::Optional(inner) = ty {
if matches!(inner.as_ref(), TypeRef::Map(_, _)) {
return format!("{name}: val.{name}.as_ref().map(|m| format!(\"{{m:?}}\"))");
}
}
}
if config.map_uses_jsvalue {
let is_nested_vec = matches!(ty, TypeRef::Vec(inner) if matches!(inner.as_ref(), TypeRef::Vec(_)));
let is_map = matches!(ty, TypeRef::Map(_, _));
if is_map {
if optional {
return format!(
"{name}: val.{name}.as_ref().and_then(|v| serde_json::to_string(v).ok()).and_then(|s| js_sys::JSON::parse(&s).ok())"
);
}
return format!(
"{name}: js_sys::JSON::parse(&serde_json::to_string(&val.{name}).unwrap_or_default()).unwrap_or(JsValue::NULL)"
);
}
if is_nested_vec {
if optional {
return format!("{name}: val.{name}.as_ref().and_then(|v| serde_wasm_bindgen::to_value(v).ok())");
}
return format!("{name}: serde_wasm_bindgen::to_value(&val.{name}).unwrap_or(JsValue::NULL)");
}
if let TypeRef::Optional(inner) = ty {
let is_inner_nested = matches!(inner.as_ref(), TypeRef::Vec(vi) if matches!(vi.as_ref(), TypeRef::Vec(_)));
let is_inner_map = matches!(inner.as_ref(), TypeRef::Map(_, _));
if is_inner_map {
return format!(
"{name}: val.{name}.as_ref().and_then(|v| serde_json::to_string(v).ok()).and_then(|s| js_sys::JSON::parse(&s).ok())"
);
}
if is_inner_nested {
return format!("{name}: val.{name}.as_ref().and_then(|v| serde_wasm_bindgen::to_value(v).ok())");
}
}
}
let prefix = config.type_name_prefix;
let is_enum_string = |n: &str| -> bool { config.enum_string_names.as_ref().is_some_and(|names| names.contains(n)) };
match ty {
TypeRef::Primitive(p) if config.cast_large_ints_to_i64 && needs_i64_cast(p) => {
let cast_to = binding_prim_str(p);
if optional {
format!("{name}: val.{name}.map(|v| v as {cast_to})")
} else {
format!("{name}: val.{name} as {cast_to}")
}
}
TypeRef::Optional(inner)
if config.cast_large_ints_to_i64
&& matches!(inner.as_ref(), TypeRef::Primitive(p) if needs_i64_cast(p)) =>
{
if let TypeRef::Primitive(p) = inner.as_ref() {
let cast_to = binding_prim_str(p);
format!("{name}: val.{name}.map(|v| v as {cast_to})")
} else {
field_conversion_from_core(name, ty, optional, sanitized, opaque_types)
}
}
TypeRef::Primitive(p) if config.cast_uints_to_i32 && needs_i32_cast(p) => {
if optional {
format!("{name}: val.{name}.map(|v| v as i32)")
} else {
format!("{name}: val.{name} as i32")
}
}
TypeRef::Optional(inner)
if config.cast_uints_to_i32 && matches!(inner.as_ref(), TypeRef::Primitive(p) if needs_i32_cast(p)) =>
{
format!("{name}: val.{name}.map(|v| v as i32)")
}
TypeRef::Vec(inner)
if config.cast_uints_to_i32 && matches!(inner.as_ref(), TypeRef::Primitive(p) if needs_i32_cast(p)) =>
{
if let TypeRef::Primitive(_p) = inner.as_ref() {
if optional {
format!("{name}: val.{name}.as_ref().map(|v| v.iter().map(|&x| x as i32).collect())")
} else {
format!("{name}: val.{name}.iter().map(|&v| v as i32).collect()")
}
} else {
field_conversion_from_core(name, ty, optional, sanitized, opaque_types)
}
}
TypeRef::Primitive(p) if config.cast_large_ints_to_f64 && needs_f64_cast(p) => {
if optional {
format!("{name}: val.{name}.map(|v| v as f64)")
} else {
format!("{name}: val.{name} as f64")
}
}
TypeRef::Optional(inner)
if config.cast_large_ints_to_f64
&& matches!(inner.as_ref(), TypeRef::Primitive(p) if needs_f64_cast(p)) =>
{
format!("{name}: val.{name}.map(|v| v as f64)")
}
TypeRef::Vec(inner)
if config.cast_large_ints_to_f64
&& matches!(inner.as_ref(), TypeRef::Primitive(p) if needs_f64_cast(p)) =>
{
if optional {
format!("{name}: val.{name}.as_ref().map(|v| v.iter().map(|&x| x as f64).collect())")
} else {
format!("{name}: val.{name}.iter().map(|&v| v as f64).collect()")
}
}
TypeRef::Optional(inner)
if config.cast_large_ints_to_f64
&& matches!(inner.as_ref(), TypeRef::Vec(vi) if matches!(vi.as_ref(), TypeRef::Primitive(p) if needs_f64_cast(p))) =>
{
format!("{name}: val.{name}.as_ref().map(|v| v.iter().map(|&x| x as f64).collect())")
}
TypeRef::Vec(outer)
if config.cast_large_ints_to_f64
&& matches!(outer.as_ref(), TypeRef::Vec(inner) if matches!(inner.as_ref(), TypeRef::Primitive(p) if needs_f64_cast(p))) =>
{
if optional {
format!(
"{name}: val.{name}.as_ref().map(|v| v.iter().map(|inner| inner.iter().map(|&x| x as f64).collect()).collect())"
)
} else {
format!("{name}: val.{name}.iter().map(|inner| inner.iter().map(|&x| x as f64).collect()).collect()")
}
}
TypeRef::Optional(inner)
if config.cast_large_ints_to_f64
&& matches!(inner.as_ref(), TypeRef::Vec(outer) if matches!(outer.as_ref(), TypeRef::Vec(prim) if matches!(prim.as_ref(), TypeRef::Primitive(p) if needs_f64_cast(p)))) =>
{
format!(
"{name}: val.{name}.as_ref().map(|v| v.iter().map(|inner| inner.iter().map(|&x| x as f64).collect()).collect())"
)
}
TypeRef::Map(_k, v)
if config.cast_large_ints_to_f64 && matches!(v.as_ref(), TypeRef::Primitive(p) if needs_f64_cast(p)) =>
{
if optional {
format!("{name}: val.{name}.as_ref().map(|m| m.iter().map(|(k, v)| (k.clone(), *v as f64)).collect())")
} else {
format!("{name}: val.{name}.iter().map(|(k, v)| (k.clone(), *v as f64)).collect()")
}
}
TypeRef::Duration if config.cast_large_ints_to_f64 => {
if optional {
format!("{name}: val.{name}.map(|d| d.as_millis() as f64)")
} else {
format!("{name}: val.{name}.as_millis() as f64")
}
}
TypeRef::Primitive(PrimitiveType::F32) if config.cast_f32_to_f64 => {
if optional {
format!("{name}: val.{name}.map(|v| v as f64)")
} else {
format!("{name}: val.{name} as f64")
}
}
TypeRef::Duration if config.cast_large_ints_to_i64 => {
if optional {
format!("{name}: val.{name}.map(|d| d.as_millis() as u64 as i64)")
} else {
format!("{name}: val.{name}.as_millis() as u64 as i64")
}
}
TypeRef::Named(n) if opaque_types.contains(n.as_str()) && !prefix.is_empty() => {
let prefixed = format!("{prefix}{n}");
if optional {
format!("{name}: val.{name}.map(|v| {prefixed} {{ inner: Arc::new(v) }})")
} else {
format!("{name}: {prefixed} {{ inner: Arc::new(val.{name}) }}")
}
}
TypeRef::Named(n) if is_enum_string(n) => {
if optional {
format!(
"{name}: val.{name}.as_ref().map(|v| serde_json::to_value(v).ok().and_then(|s| s.as_str().map(String::from)).unwrap_or_default())"
)
} else {
format!(
"{name}: serde_json::to_value(val.{name}).ok().and_then(|s| s.as_str().map(String::from)).unwrap_or_default()"
)
}
}
TypeRef::Vec(inner) if matches!(inner.as_ref(), TypeRef::Named(n) if is_enum_string(n)) => {
if optional {
format!(
"{name}: val.{name}.as_ref().map(|v| v.iter().map(|x| serde_json::to_value(x).ok().and_then(|s| s.as_str().map(String::from)).unwrap_or_default()).collect())"
)
} else {
format!(
"{name}: val.{name}.iter().map(|v| serde_json::to_value(v).ok().and_then(|s| s.as_str().map(String::from)).unwrap_or_default()).collect()"
)
}
}
TypeRef::Optional(inner) if matches!(inner.as_ref(), TypeRef::Vec(vi) if matches!(vi.as_ref(), TypeRef::Named(n) if is_enum_string(n))) =>
{
format!(
"{name}: val.{name}.as_ref().map(|v| v.iter().map(|x| serde_json::to_value(x).ok().and_then(|s| s.as_str().map(String::from)).unwrap_or_default()).collect())"
)
}
TypeRef::Vec(inner)
if config.cast_f32_to_f64 && matches!(inner.as_ref(), TypeRef::Primitive(PrimitiveType::F32)) =>
{
if optional {
format!("{name}: val.{name}.as_ref().map(|v| v.iter().map(|&x| x as f64).collect())")
} else {
format!("{name}: val.{name}.iter().map(|&v| v as f64).collect()")
}
}
TypeRef::Optional(inner)
if config.cast_f32_to_f64
&& matches!(inner.as_ref(), TypeRef::Vec(vi) if matches!(vi.as_ref(), TypeRef::Primitive(PrimitiveType::F32))) =>
{
format!("{name}: val.{name}.as_ref().map(|v| v.iter().map(|&x| x as f64).collect())")
}
TypeRef::Optional(inner)
if config.cast_large_ints_to_i64
&& matches!(inner.as_ref(), TypeRef::Vec(vi) if matches!(vi.as_ref(), TypeRef::Primitive(p) if needs_i64_cast(p))) =>
{
if let TypeRef::Vec(vi) = inner.as_ref() {
if let TypeRef::Primitive(p) = vi.as_ref() {
let cast_to = binding_prim_str(p);
if sanitized {
format!("{name}: val.{name}.map(|(a, b)| vec![a as {cast_to}, b as {cast_to}])")
} else {
format!("{name}: val.{name}.as_ref().map(|v| v.iter().map(|&x| x as {cast_to}).collect())")
}
} else {
field_conversion_from_core(name, ty, optional, sanitized, opaque_types)
}
} else {
field_conversion_from_core(name, ty, optional, sanitized, opaque_types)
}
}
TypeRef::Vec(outer)
if config.cast_f32_to_f64
&& matches!(outer.as_ref(), TypeRef::Vec(inner) if matches!(inner.as_ref(), TypeRef::Primitive(PrimitiveType::F32))) =>
{
if optional {
format!(
"{name}: val.{name}.as_ref().map(|v| v.iter().map(|inner| inner.iter().map(|&x| x as f64).collect()).collect())"
)
} else {
format!("{name}: val.{name}.iter().map(|inner| inner.iter().map(|&x| x as f64).collect()).collect()")
}
}
TypeRef::Optional(inner)
if config.cast_f32_to_f64
&& matches!(inner.as_ref(), TypeRef::Vec(outer) if matches!(outer.as_ref(), TypeRef::Vec(prim) if matches!(prim.as_ref(), TypeRef::Primitive(PrimitiveType::F32)))) =>
{
format!(
"{name}: val.{name}.as_ref().map(|v| v.iter().map(|inner| inner.iter().map(|&x| x as f64).collect()).collect())"
)
}
TypeRef::Optional(inner)
if config.cast_large_ints_to_i64
&& matches!(inner.as_ref(), TypeRef::Primitive(p) if needs_i64_cast(p)) =>
{
if let TypeRef::Primitive(p) = inner.as_ref() {
let cast_to = binding_prim_str(p);
format!("{name}: val.{name}.map(|v| v as {cast_to})")
} else {
field_conversion_from_core(name, ty, optional, sanitized, opaque_types)
}
}
TypeRef::Map(_k, v)
if config.cast_large_ints_to_i64 && matches!(v.as_ref(), TypeRef::Primitive(p) if needs_i64_cast(p)) =>
{
if let TypeRef::Primitive(p) = v.as_ref() {
let cast_to = binding_prim_str(p);
if optional {
format!(
"{name}: val.{name}.as_ref().map(|m| m.iter().map(|(k, v)| (k.clone(), *v as {cast_to})).collect())"
)
} else {
format!("{name}: val.{name}.iter().map(|(k, v)| (k.clone(), *v as {cast_to})).collect()")
}
} else {
field_conversion_from_core(name, ty, optional, sanitized, opaque_types)
}
}
TypeRef::Vec(inner)
if config.cast_large_ints_to_i64
&& matches!(inner.as_ref(), TypeRef::Primitive(p) if needs_i64_cast(p)) =>
{
if let TypeRef::Primitive(p) = inner.as_ref() {
let cast_to = binding_prim_str(p);
if sanitized {
if optional {
format!("{name}: val.{name}.map(|(a, b)| vec![a as {cast_to}, b as {cast_to}])")
} else {
format!("{name}: {{ let (a, b) = val.{name}; vec![a as {cast_to}, b as {cast_to}] }}")
}
} else if optional {
format!("{name}: val.{name}.as_ref().map(|v| v.iter().map(|&x| x as {cast_to}).collect())")
} else {
format!("{name}: val.{name}.iter().map(|&v| v as {cast_to}).collect()")
}
} else {
field_conversion_from_core(name, ty, optional, sanitized, opaque_types)
}
}
TypeRef::Vec(outer)
if config.cast_large_ints_to_i64
&& matches!(outer.as_ref(), TypeRef::Vec(inner) if matches!(inner.as_ref(), TypeRef::Primitive(p) if needs_i64_cast(p))) =>
{
if let TypeRef::Vec(inner) = outer.as_ref() {
if let TypeRef::Primitive(p) = inner.as_ref() {
let cast_to = binding_prim_str(p);
if optional {
format!(
"{name}: val.{name}.as_ref().map(|v| v.iter().map(|inner| inner.iter().map(|&x| x as {cast_to}).collect()).collect())"
)
} else {
format!(
"{name}: val.{name}.iter().map(|inner| inner.iter().map(|&x| x as {cast_to}).collect()).collect()"
)
}
} else {
field_conversion_from_core(name, ty, optional, sanitized, opaque_types)
}
} else {
field_conversion_from_core(name, ty, optional, sanitized, opaque_types)
}
}
TypeRef::Json if config.json_to_string => {
if optional {
format!("{name}: val.{name}.as_ref().map(ToString::to_string)")
} else {
format!("{name}: val.{name}.to_string()")
}
}
TypeRef::Json if config.json_as_value => {
format!("{name}: val.{name}")
}
TypeRef::Optional(inner) if config.json_as_value && matches!(inner.as_ref(), TypeRef::Json) => {
format!("{name}: val.{name}")
}
TypeRef::Vec(inner) if config.json_as_value && matches!(inner.as_ref(), TypeRef::Json) => {
if optional {
format!("{name}: Some(val.{name})")
} else {
format!("{name}: val.{name}")
}
}
TypeRef::Map(_k, v) if config.json_as_value && matches!(v.as_ref(), TypeRef::Json) => {
if optional {
format!("{name}: val.{name}.map(|m| m.into_iter().map(|(k, v)| (k.into(), v)).collect())")
} else {
format!("{name}: val.{name}.into_iter().map(|(k, v)| (k.into(), v)).collect()")
}
}
TypeRef::Json if config.map_uses_jsvalue => {
if optional {
format!("{name}: val.{name}.as_ref().and_then(|v| serde_wasm_bindgen::to_value(v).ok())")
} else {
format!("{name}: serde_wasm_bindgen::to_value(&val.{name}).unwrap_or(JsValue::NULL)")
}
}
TypeRef::Vec(inner) if config.map_uses_jsvalue && matches!(inner.as_ref(), TypeRef::Json) => {
if optional {
format!("{name}: val.{name}.as_ref().and_then(|v| serde_wasm_bindgen::to_value(v).ok())")
} else {
format!("{name}: serde_wasm_bindgen::to_value(&val.{name}).unwrap_or(JsValue::NULL)")
}
}
TypeRef::Optional(inner)
if config.map_uses_jsvalue
&& matches!(inner.as_ref(), TypeRef::Vec(vi) if matches!(vi.as_ref(), TypeRef::Json)) =>
{
format!("{name}: val.{name}.as_ref().and_then(|v| serde_wasm_bindgen::to_value(v).ok())")
}
_ => field_conversion_from_core(name, ty, optional, sanitized, opaque_types),
}
}