DeclarationPtrFull

Struct DeclarationPtrFull 

Source
pub struct DeclarationPtrFull;
Expand description

(De)serializes a DeclarationPtr as the declaration it references.

This makes no attempt to restore the pointers - each value is deserialized into a new DeclarationPtr with a reference count of one.

The shared references can be reconstructed using the ids stored, as before serialization these were unique for each separate instance of T in memory. See DeclarationPtrAsId.

§Examples

Serialisation:

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

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

    // serde as also supports nesting
    #[serde_as(as = "Vec<(_,DeclarationPtrFull)>")]
    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![];

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

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

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

let expected_json = json!({
    "declaration": {
        "name": { "User": "a"},
        "kind": {"DecisionVariable": {"domain": {"Int": [{"Bounded": [1,5]}]}, "category":
        "Decision"}},
        "id": 0
    },

    "declarations": [
        [1,{
        "name": { "User": "1"},
        "id": 1,
        "kind": {"DecisionVariable": {"domain": {"Int": [{"Bounded": [1,5]}]},
        "category":"Decision"}},
        }],
        [2,{
        "name": { "User": "2"},
        "id": 2,
        "kind": {"DecisionVariable": {"domain": {"Int": [{"Bounded": [1,5]}]},"category":
        "Decision"}},
        }]
    ],
         
    "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::DeclarationPtrFull,Name,DeclarationKind, DeclarationPtr,Domain,Range, ReturnType};

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

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

let input_json = json!({
    "declaration": {
        "name": { "User": "a"},
        "kind": {"DecisionVariable": {"domain": {"Int": [{"Bounded": [0,5]}]}, "category":
        "Decision"}},
        "id": 10,
    },

    "declarations": [
        [1,{
        "name": { "User": "1"},
        "kind": {"DecisionVariable": {"domain": {"Int": [{"Bounded": [0,5]}]}, "category":
        "Decision"}},
        "id": 11,
        }],
        [2,{
        "name": { "User": "2"},
        "kind": {"DecisionVariable": {"domain": {"Int": [{"Bounded": [0,5]}]}, "category":
        "Decision"}},
        "id": 12,
        }]
    ],
    "c": 3
});


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

assert_eq!(&foo.declaration.name() as &Name,&Name::User("a".into()));
assert_eq!(&foo.declarations[0].1.name() as &Name,&Name::User("1".into()));
assert_eq!(&foo.declarations[1].1.name() as &Name,&Name::User("2".into()));

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

// ids should be the same as in the json
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 DeclarationPtrFull

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 DeclarationPtrFull

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