jsonbuilder: add set_int for signed ints

Bug: #6615
pull/10052/head
Victor Julien 2 years ago
parent 0ab32be355
commit b8440a0917

@ -597,6 +597,27 @@ impl JsonBuilder {
Ok(self)
}
/// Set a key and a signed integer type on an object.
pub fn set_int(&mut self, key: &str, val: i64) -> Result<&mut Self, JsonError> {
match self.current_state() {
State::ObjectNth => {
self.push(',')?;
}
State::ObjectFirst => {
self.set_state(State::ObjectNth);
}
_ => {
debug_validate_fail!("invalid state");
return Err(JsonError::InvalidState);
}
}
self.push('"')?;
self.push_str(key)?;
self.push_str("\":")?;
self.push_str(&val.to_string())?;
Ok(self)
}
pub fn set_float(&mut self, key: &str, val: f64) -> Result<&mut Self, JsonError> {
match self.current_state() {
State::ObjectNth => {
@ -940,6 +961,14 @@ pub unsafe extern "C" fn jb_set_uint(js: &mut JsonBuilder, key: *const c_char, v
return false;
}
#[no_mangle]
pub unsafe extern "C" fn jb_set_int(js: &mut JsonBuilder, key: *const c_char, val: i64) -> bool {
if let Ok(key) = CStr::from_ptr(key).to_str() {
return js.set_int(key, val).is_ok();
}
return false;
}
#[no_mangle]
pub unsafe extern "C" fn jb_set_float(js: &mut JsonBuilder, key: *const c_char, val: f64) -> bool {
if let Ok(key) = CStr::from_ptr(key).to_str() {

Loading…
Cancel
Save