difftreelog
build(bindings) build with gc
in: master
It will build, but some methods is broken for now
3 files changed
bindings/jsonnet/src/native.rsdiffbeforeafterboth21 ctx: *const c_void,21 ctx: *const c_void,22 mut raw_params: *const *const c_char,22 mut raw_params: *const *const c_char,23) {23) {24 let name = CStr::from_ptr(name).to_str().expect("utf8 name").into();25 let mut params = Vec::new();24 todo!()26 loop {27 if (*raw_params).is_null() {28 break;29 }30 let param = CStr::from_ptr(*raw_params).to_str().expect("not utf8");31 params.push(Param(param.into(), None));32 raw_params = raw_params.offset(1);33 }34 let params = ParamsDesc(Rc::new(params));3536 vm.add_native(37 name,38 Rc::new(NativeCallback::new(params, move |_caller, args| {39 let mut n_args = Vec::new();40 for a in args {41 n_args.push(Some(Box::new(a.clone())));42 }43 n_args.push(None);44 let mut success = 1;45 let v = cb(ctx, &n_args as *const _ as *const *const Val, &mut success);46 let v = *Box::from_raw(v);47 if success == 1 {48 Ok(v)49 } else {50 let e = v.try_cast_str("native error").expect("error msg");51 Err(Error::RuntimeError(e).into())52 }53 })),54 )55}25}5626bindings/jsonnet/src/val_make.rsdiffbeforeafterboth--- a/bindings/jsonnet/src/val_make.rs
+++ b/bindings/jsonnet/src/val_make.rs
@@ -38,7 +38,7 @@
#[no_mangle]
pub extern "C" fn jsonnet_json_make_array(_vm: &EvaluationState) -> *mut Val {
- Box::into_raw(Box::new(Val::Arr(ArrValue::Eager(Rc::new(Vec::new())))))
+ todo!()
}
#[no_mangle]
bindings/jsonnet/src/val_modify.rsdiffbeforeafterboth--- a/bindings/jsonnet/src/val_modify.rs
+++ b/bindings/jsonnet/src/val_modify.rs
@@ -2,9 +2,9 @@
//! Only tested with variables, which haven't altered by code before appearing here
//! In jrsonnet every value is immutable, and this code is probally broken
-use jrsonnet_evaluator::{ArrValue, EvaluationState, LazyBinding, LazyVal, ObjMember, Val};
+use jrsonnet_evaluator::{EvaluationState, LazyBinding, LazyVal, ObjMember, Val};
use jrsonnet_parser::Visibility;
-use std::{ffi::CStr, os::raw::c_char, rc::Rc};
+use std::{ffi::CStr, os::raw::c_char};
/// # Safety
///
@@ -22,7 +22,8 @@
new.push(item);
}
new.push(LazyVal::new_resolved(val.clone()));
- *arr = Val::Arr(ArrValue::Lazy(Rc::new(new)));
+ // *arr = Val::Arr(ArrValue::Lazy(Gc::new(new)));
+ todo!()
}
_ => panic!("should receive array"),
}