Struct abi_stable::external_types::serde_json::RawValueRef

source ·
pub struct RawValueRef<'a> { /* private fields */ }
Expand description

An ffi-safe equivalent of &serde_json::value::RawValue

§Example

This defines a function that serializes a struct, and deserializes the json into another one with RawValueRef fields.

use abi_stable::{
    external_types::RawValueRef,
    sabi_extern_fn,
    std_types::{RBoxError, RErr, ROk, RResult, RStr, RString},
};

use serde::{Deserialize, Serialize};

use std::collections::HashMap;

const JSON: &'static str = r##"{"hello":"world"}"##;

let value = RawValueRef::try_from_str(JSON).unwrap();

assert_eq!(serde_json::to_string(&value).unwrap().as_str(), JSON);

#[derive(Serialize)]
pub struct Pair {
    pub first: Vec<u32>,
    pub second: HashMap<RString, RString>,
}

#[derive(Debug, Deserialize)]
pub struct PairDeserialize<'a> {
    #[serde(borrow)]
    pub first: RawValueRef<'a>,

    #[serde(borrow)]
    pub second: RawValueRef<'a>,
}

#[sabi_extern_fn]
fn deserialize_data_structure<'de>(
    input: RStr<'de>,
) -> RResult<PairDeserialize<'de>, RBoxError> {
    match serde_json::from_str::<PairDeserialize>(input.into()) {
        Ok(x) => ROk(x),
        Err(x) => RErr(RBoxError::new(x)),
    }
}


let json = serde_json::to_string(&Pair {
    first: vec![0, 1, 2],
    second: vec![(RString::from("hello"), "world".into())]
        .into_iter()
        .collect(),
})
.unwrap();

let pair = deserialize_data_structure(json.as_str().into()).unwrap();

assert_eq!(pair.first.get(), "[0,1,2]");
assert_eq!(pair.second.get(), r##"{"hello":"world"}"##);

Implementations§

source§

impl<'a> RawValueRef<'a>

source

pub const unsafe fn from_str_unchecked(input: &'a str) -> RawValueRef<'a>

Converts a &str to a RawValueRef<'a> without checking whether it is valid JSON.

§Safety

input must be valid JSON and contain no leading or trailing whitespace.

§Example
use abi_stable::external_types::RawValueRef;

const JSON: &'static str = r##"{"huh":"that is interesting"}"##;

const VALUE: RawValueRef<'_> = unsafe { RawValueRef::from_str_unchecked(JSON) };

assert_eq!(serde_json::to_string(&VALUE).unwrap().as_str(), JSON);
source

pub const unsafe fn from_rstr_unchecked(input: RStr<'a>) -> RawValueRef<'a>

Converts a RStr<'a> to a RawValueRef<'a> without checking whether it is valid JSON.

§Safety

input must be valid JSON and contain no leading or trailing whitespace.

§Example
use abi_stable::{external_types::RawValueRef, std_types::RStr};

const JSON: &'static str = r##"{"huh":"that is interesting"}"##;

let json_rstr = RStr::from(JSON);
let value = unsafe { RawValueRef::from_rstr_unchecked(json_rstr) };

assert_eq!(serde_json::to_string(&value).unwrap().as_str(), JSON);
source

pub fn try_from_str(input: &'a str) -> Result<Self, JsonError>

Attempts to convert a &'a str into a RawValueRef<'a>.

Fails in the same cases as parsing a &'a RawValue from a string does.

§Example
use abi_stable::{external_types::RawValueRef, std_types::RStr};

const JSON: &'static str = r##"{"nope":"oof"}"##;

let raw = RawValueRef::try_from_str(JSON).unwrap();

assert_eq!(raw.get(), JSON);
source

pub fn get(&self) -> &'a str

Gets the json being serialized,as a &str.

§Example
use abi_stable::external_types::RawValueRef;

const JSON: &'static str = r##"{"huh":1007}"##;

let raw = serde_json::from_str::<RawValueRef<'static>>(JSON).unwrap();

assert_eq!(raw.get(), JSON);
source

pub const fn get_rstr(&self) -> RStr<'a>

Gets the json being serialized,as a RStr<'a>.

§Example
use abi_stable::{external_types::RawValueRef, std_types::RStr};

const JSON: &'static str = r##"{"bugs":"life"}"##;

let raw = serde_json::from_str::<RawValueRef<'static>>(JSON).unwrap();

assert_eq!(raw.get_rstr(), RStr::from(JSON));

Trait Implementations§

source§

impl<'a> Clone for RawValueRef<'a>

source§

fn clone(&self) -> RawValueRef<'a>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<'a> Debug for RawValueRef<'a>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<'de: 'a, 'a> Deserialize<'de> for RawValueRef<'a>

source§

fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl<'a> Display for RawValueRef<'a>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<'a> From<&'a RawValue> for RawValueRef<'a>

source§

fn from(v: &'a RawValue) -> Self

Converts to this type from the input type.
source§

impl<'a> GetStaticEquivalent_ for RawValueRef<'a>

source§

type StaticEquivalent = _static_RawValueRef<'static>

The 'static equivalent of Self
source§

impl<'a> Serialize for RawValueRef<'a>

source§

fn serialize<Z>(&self, serializer: Z) -> Result<Z::Ok, Z::Error>
where Z: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl<'a> StableAbi for RawValueRef<'a>

source§

type IsNonZeroType = <RStr<'a> as StableAbi>::IsNonZeroType

Whether this type has a single invalid bit-pattern. Read more
source§

const LAYOUT: &'static TypeLayout = _

The layout of the type provided by implementors.
source§

const ABI_CONSTS: AbiConsts = _

const-equivalents of the associated types.
source§

impl<'a> TryFrom<&'a str> for RawValueRef<'a>

source§

type Error = Error

The type returned in the event of a conversion error.
source§

fn try_from(v: &'a str) -> Result<Self, JsonError>

Performs the conversion.
source§

impl<'a> Copy for RawValueRef<'a>

Auto Trait Implementations§

§

impl<'a> Freeze for RawValueRef<'a>

§

impl<'a> RefUnwindSafe for RawValueRef<'a>

§

impl<'a> Send for RawValueRef<'a>

§

impl<'a> Sync for RawValueRef<'a>

§

impl<'a> Unpin for RawValueRef<'a>

§

impl<'a> UnwindSafe for RawValueRef<'a>

Blanket Implementations§

source§

impl<T> AlignerFor<1> for T

source§

type Aligner = AlignTo1<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<1024> for T

source§

type Aligner = AlignTo1024<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<128> for T

source§

type Aligner = AlignTo128<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<16> for T

source§

type Aligner = AlignTo16<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<16384> for T

source§

type Aligner = AlignTo16384<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<2> for T

source§

type Aligner = AlignTo2<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<2048> for T

source§

type Aligner = AlignTo2048<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<256> for T

source§

type Aligner = AlignTo256<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<32> for T

source§

type Aligner = AlignTo32<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<32768> for T

source§

type Aligner = AlignTo32768<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<4> for T

source§

type Aligner = AlignTo4<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<4096> for T

source§

type Aligner = AlignTo4096<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<512> for T

source§

type Aligner = AlignTo512<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<64> for T

source§

type Aligner = AlignTo64<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<8> for T

source§

type Aligner = AlignTo8<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> AlignerFor<8192> for T

source§

type Aligner = AlignTo8192<T>

The AlignTo* type which aligns Self to ALIGNMENT.
source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<'a, T> RCowCompatibleRef<'a> for T
where T: Clone + 'a,

source§

type RefC = &'a T

The (preferably) ffi-safe equivalent of &Self.
source§

type ROwned = T

The owned version of Self::RefC.
source§

fn as_c_ref(from: &'a T) -> <T as RCowCompatibleRef<'a>>::RefC

Converts a reference to an FFI-safe type
source§

fn as_rust_ref(from: <T as RCowCompatibleRef<'a>>::RefC) -> &'a T

Converts an FFI-safe type to a reference
source§

impl<S> ROExtAcc for S

source§

fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F

Gets a reference to a field, determined by offset. Read more
source§

fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F

Gets a muatble reference to a field, determined by offset. Read more
source§

fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F

Gets a const pointer to a field, the field is determined by offset. Read more
source§

fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F

Gets a mutable pointer to a field, determined by offset. Read more
source§

impl<S> ROExtOps<Aligned> for S

source§

fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F

Replaces a field (determined by offset) with value, returning the previous value of the field. Read more
source§

fn f_swap<F>(&mut self, offset: FieldOffset<S, F, Aligned>, right: &mut S)

Swaps a field (determined by offset) with the same field in right. Read more
source§

fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> F
where F: Copy,

Gets a copy of a field (determined by offset). The field is determined by offset. Read more
source§

impl<S> ROExtOps<Unaligned> for S

source§

fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F

Replaces a field (determined by offset) with value, returning the previous value of the field. Read more
source§

fn f_swap<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, right: &mut S)

Swaps a field (determined by offset) with the same field in right. Read more
source§

fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> F
where F: Copy,

Gets a copy of a field (determined by offset). The field is determined by offset. Read more
source§

impl<T> SelfOps for T
where T: ?Sized,

source§

fn eq_id(&self, other: &Self) -> bool

Compares the address of self with the address of other. Read more
source§

fn piped<F, U>(self, f: F) -> U
where F: FnOnce(Self) -> U, Self: Sized,

Emulates the pipeline operator, allowing method syntax in more places. Read more
source§

fn piped_ref<'a, F, U>(&'a self, f: F) -> U
where F: FnOnce(&'a Self) -> U,

The same as piped except that the function takes &Self Useful for functions that take &Self instead of Self. Read more
source§

fn piped_mut<'a, F, U>(&'a mut self, f: F) -> U
where F: FnOnce(&'a mut Self) -> U,

The same as piped, except that the function takes &mut Self. Useful for functions that take &mut Self instead of Self.
source§

fn mutated<F>(self, f: F) -> Self
where F: FnOnce(&mut Self), Self: Sized,

Mutates self using a closure taking self by mutable reference, passing it along the method chain. Read more
source§

fn observe<F>(self, f: F) -> Self
where F: FnOnce(&Self), Self: Sized,

Observes the value of self, passing it along unmodified. Useful in long method chains. Read more
source§

fn into_<T>(self) -> T
where Self: Into<T>,

Performs a conversion with Into. using the turbofish .into_::<_>() syntax. Read more
source§

fn as_ref_<T>(&self) -> &T
where Self: AsRef<T>, T: ?Sized,

Performs a reference to reference conversion with AsRef, using the turbofish .as_ref_::<_>() syntax. Read more
source§

fn as_mut_<T>(&mut self) -> &mut T
where Self: AsMut<T>, T: ?Sized,

Performs a mutable reference to mutable reference conversion with AsMut, using the turbofish .as_mut_::<_>() syntax. Read more
source§

fn drop_(self)
where Self: Sized,

Drops self using method notation. Alternative to std::mem::drop. Read more
source§

impl<T> ToOwned for T
where T: Clone,

source§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

impl<This> TransmuteElement for This
where This: ?Sized,

source§

unsafe fn transmute_element<T>( self, ) -> <Self as CanTransmuteElement<T>>::TransmutedPtr
where Self: CanTransmuteElement<T>,

Transmutes the element type of this pointer.. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> TypeIdentity for T
where T: ?Sized,

source§

type Type = T

This is always Self.
source§

fn into_type(self) -> Self::Type
where Self: Sized, Self::Type: Sized,

Converts a value back to the original type.
source§

fn as_type(&self) -> &Self::Type

Converts a reference back to the original type.
source§

fn as_type_mut(&mut self) -> &mut Self::Type

Converts a mutable reference back to the original type.
source§

fn into_type_box(self: Box<Self>) -> Box<Self::Type>

Converts a box back to the original type.
source§

fn into_type_arc(this: Arc<Self>) -> Arc<Self::Type>

Converts an Arc back to the original type. Read more
source§

fn into_type_rc(this: Rc<Self>) -> Rc<Self::Type>

Converts an Rc back to the original type. Read more
source§

fn from_type(this: Self::Type) -> Self
where Self: Sized, Self::Type: Sized,

Converts a value back to the original type.
source§

fn from_type_ref(this: &Self::Type) -> &Self

Converts a reference back to the original type.
source§

fn from_type_mut(this: &mut Self::Type) -> &mut Self

Converts a mutable reference back to the original type.
source§

fn from_type_box(this: Box<Self::Type>) -> Box<Self>

Converts a box back to the original type.
source§

fn from_type_arc(this: Arc<Self::Type>) -> Arc<Self>

Converts an Arc back to the original type.
source§

fn from_type_rc(this: Rc<Self::Type>) -> Rc<Self>

Converts an Rc back to the original type.
source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,