DeclarationPtrAsId

Struct DeclarationPtrAsId 

Source
pub struct DeclarationPtrAsId;
Expand description

(De)serializes a DeclarationPtr as its id.

On deserialization, each declaration is re-created with default dummy values, except for the id, which will be the same as the original declaration.

It is left to the user to fix these values before use. Before serialization, each object in memory has a unique id; using this information, re-constructing the shared pointers should be possible, as long as the contents of each object were also stored, e.g. with DeclarationPtrFull.

§Examples

Serialisation:

use serde::Serialize;
use serde_json::json;
use serde_with::serde_as;
use conjure_cp_core::ast::{declaration::serde::DeclarationPtrAsId,Name,DeclarationPtr,Domain,Range};

// some struct containing a DeclarationPtr.
#[serde_as]
#[derive(Clone,PartialEq,Eq,Serialize)]
struct Foo {
    #[serde_as(as = "DeclarationPtrAsId")]
    declaration: DeclarationPtr,

    // serde as also supports nesting
    #[serde_as(as = "Vec<(_,DeclarationPtrAsId)>")]
    declarations: Vec<(i32,DeclarationPtr)>,

    c: i32
}

let declaration = DeclarationPtr::new_var(Name::User("a".into()),Domain::Int(vec![Range::Bounded(1,5)]));
let mut declarations: Vec<(i32,DeclarationPtr)>  = vec![];
for i in (1..=2) {
    declarations.push((i,DeclarationPtr::new_var(Name::User(format!("{i}").into()),Domain::Int(vec![Range::Bounded(1,5)]))));
}

let foo = Foo {
    declaration,
    declarations,
    c: 3
};

let json = serde_json::to_value(foo).unwrap();

let expected_json = json!({
    "declaration": 0,
    "declarations": [(1,1),(2,2)],
    "c": 3
});

assert_eq!(json,expected_json);

Deserialisation:

use serde::Deserialize;
use serde_json::json;
use serde_with::serde_as;
use conjure_cp_core::ast::{serde::{HasId},declaration::serde::DeclarationPtrAsId,Name,DeclarationKind, DeclarationPtr,Domain,Range, ReturnType};

// some struct containing a DeclarationPtr.
#[serde_as]
#[derive(Clone,PartialEq,Eq,Deserialize)]
struct Foo {
    #[serde_as(as = "DeclarationPtrAsId")]
    declaration: DeclarationPtr,

    // serde as also supports nesting
    #[serde_as(as = "Vec<(_,DeclarationPtrAsId)>")]
    declarations: Vec<(i32,DeclarationPtr)>,
    c: i32
}

let input_json = json!({
    "declaration": 10,
    "declarations": [(11,11),(12,12)],
    "c": 3
});


let foo: Foo = serde_json::from_value(input_json).unwrap();


// all declarations should have the dummy values: name: User("_UNKNOWN"), kind: value_letting;
assert_eq!(&foo.declaration.name() as &Name,&Name::User("_UNKNOWN".into()));
assert_eq!(&foo.declarations[0].1.name() as &Name,&Name::User("_UNKNOWN".into()));
assert_eq!(&foo.declarations[1].1.name() as &Name,&Name::User("_UNKNOWN".into()));

assert!(matches!(&foo.declaration.kind() as &DeclarationKind,&DeclarationKind::ValueLetting(_)));
assert!(matches!(&foo.declarations[0].1.kind() as &DeclarationKind,&DeclarationKind::ValueLetting(_)));
assert!(matches!(&foo.declarations[1].1.kind() as &DeclarationKind,&DeclarationKind::ValueLetting(_)));

// but ids should be the same

assert_eq!(*&foo.declaration.id(),10);
assert_eq!(*&foo.declarations[0].1.id(),11);
assert_eq!(*&foo.declarations[1].1.id(),12);

Trait Implementations§

Source§

impl<'de> DeserializeAs<'de, DeclarationPtr> for DeclarationPtrAsId

Source§

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

Deserialize this value from the given Serde deserializer.
Source§

impl SerializeAs<DeclarationPtr> for DeclarationPtrAsId

Source§

fn serialize_as<S>( source: &DeclarationPtr, serializer: S, ) -> Result<S::Ok, S::Error>
where S: Serializer,

Serialize this value into the given Serde serializer.

Auto Trait Implementations§

Blanket Implementations§

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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. 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.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 0 bytes