-
Notifications
You must be signed in to change notification settings - Fork 58
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
add dependency on clvm-traits. add ToNodePtr and FromNodePtr traits, …
…refining ToClvm and FromClvm traits
- Loading branch information
Showing
5 changed files
with
303 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,115 @@ | ||
use crate::{allocator::NodePtr, Allocator}; | ||
|
||
use clvm_traits::{ClvmDecoder, FromClvmError, FromClvm}; | ||
|
||
pub trait FromNodePtr { | ||
fn from_node_ptr(a: &Allocator, node: NodePtr) -> Result<Self, FromClvmError> | ||
where | ||
Self: Sized; | ||
} | ||
|
||
impl<T> FromNodePtr for T | ||
where | ||
T: FromClvm<NodePtr>, | ||
{ | ||
fn from_node_ptr(a: &Allocator, node: NodePtr) -> Result<Self, FromClvmError> | ||
where | ||
Self: Sized, | ||
{ | ||
T::from_clvm(a, node) | ||
} | ||
} | ||
|
||
impl FromClvm<NodePtr> for NodePtr { | ||
fn from_clvm( | ||
_decoder: &impl ClvmDecoder<Node = NodePtr>, | ||
node: NodePtr, | ||
) -> Result<Self, FromClvmError> { | ||
Ok(node) | ||
} | ||
} | ||
|
||
#[cfg(test)] | ||
mod tests { | ||
use crate::{allocator::NodePtr, serde::node_from_bytes, Allocator}; | ||
|
||
use super::*; | ||
|
||
fn decode<T>(a: &mut Allocator, hex: &str) -> Result<T, FromClvmError> | ||
where | ||
T: FromClvm<NodePtr>, | ||
{ | ||
let bytes = hex::decode(hex).unwrap(); | ||
let actual = node_from_bytes(a, &bytes).unwrap(); | ||
T::from_clvm(a, actual) | ||
} | ||
|
||
#[test] | ||
fn test_nodeptr() { | ||
let a = &mut Allocator::new(); | ||
let ptr = a.one(); | ||
assert_eq!(NodePtr::from_clvm(a, ptr).unwrap(), ptr); | ||
} | ||
|
||
#[test] | ||
fn test_primitives() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!(decode(a, "80"), Ok(0u8)); | ||
assert_eq!(decode(a, "80"), Ok(0i8)); | ||
assert_eq!(decode(a, "05"), Ok(5u8)); | ||
assert_eq!(decode(a, "05"), Ok(5u32)); | ||
assert_eq!(decode(a, "05"), Ok(5i32)); | ||
assert_eq!(decode(a, "81e5"), Ok(-27i32)); | ||
assert_eq!(decode(a, "80"), Ok(-0)); | ||
assert_eq!(decode(a, "8180"), Ok(-128i8)); | ||
} | ||
|
||
#[test] | ||
fn test_pair() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!(decode(a, "ff0502"), Ok((5, 2))); | ||
assert_eq!(decode(a, "ff81b8ff8301600980"), Ok((-72, (90121, ())))); | ||
assert_eq!( | ||
decode(a, "ffff80ff80ff80ffff80ff80ff80808080"), | ||
Ok((((), ((), ((), (((), ((), ((), ()))), ())))), ())) | ||
); | ||
} | ||
|
||
#[test] | ||
fn test_nil() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!(decode(a, "80"), Ok(())); | ||
} | ||
|
||
#[test] | ||
fn test_array() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!(decode(a, "ff01ff02ff03ff0480"), Ok([1, 2, 3, 4])); | ||
assert_eq!(decode(a, "80"), Ok([] as [i32; 0])); | ||
} | ||
|
||
#[test] | ||
fn test_vec() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!(decode(a, "ff01ff02ff03ff0480"), Ok(vec![1, 2, 3, 4])); | ||
assert_eq!(decode(a, "80"), Ok(Vec::<i32>::new())); | ||
} | ||
|
||
#[test] | ||
fn test_option() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!(decode(a, "8568656c6c6f"), Ok(Some("hello".to_string()))); | ||
assert_eq!(decode(a, "80"), Ok(None::<String>)); | ||
|
||
// Empty strings get decoded as None instead, since both values are represented by nil bytes. | ||
// This could be considered either intended behavior or not, depending on the way it's used. | ||
assert_ne!(decode(a, "80"), Ok(Some("".to_string()))); | ||
} | ||
|
||
#[test] | ||
fn test_string() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!(decode(a, "8568656c6c6f"), Ok("hello".to_string())); | ||
assert_eq!(decode(a, "80"), Ok("".to_string())); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,143 @@ | ||
use crate::{allocator::NodePtr, Allocator}; | ||
|
||
use clvm_traits::{ClvmEncoder, ToClvmError, ToClvm}; | ||
|
||
pub trait ToNodePtr { | ||
fn to_node_ptr(&self, a: &mut Allocator) -> Result<NodePtr, ToClvmError>; | ||
} | ||
|
||
impl<T> ToNodePtr for T | ||
where | ||
T: ToClvm<NodePtr>, | ||
{ | ||
fn to_node_ptr(&self, a: &mut Allocator) -> Result<NodePtr, ToClvmError> { | ||
self.to_clvm(a) | ||
} | ||
} | ||
|
||
impl ToClvm<NodePtr> for NodePtr { | ||
fn to_clvm( | ||
&self, | ||
_encoder: &mut impl ClvmEncoder<Node = NodePtr>, | ||
) -> Result<NodePtr, ToClvmError> { | ||
Ok(*self) | ||
} | ||
} | ||
|
||
#[cfg(test)] | ||
mod tests { | ||
use crate::{serde::node_to_bytes, Allocator}; | ||
use hex::ToHex; | ||
|
||
use super::*; | ||
|
||
fn encode<T>(a: &mut Allocator, value: T) -> Result<String, ToClvmError> | ||
where | ||
T: ToClvm<NodePtr>, | ||
{ | ||
let actual = value.to_clvm(a).unwrap(); | ||
let actual_bytes = node_to_bytes(a, actual).unwrap(); | ||
Ok(actual_bytes.encode_hex()) | ||
} | ||
|
||
#[test] | ||
fn test_nodeptr() { | ||
let a = &mut Allocator::new(); | ||
let ptr = a.one(); | ||
assert_eq!(ptr.to_clvm(a).unwrap(), ptr); | ||
} | ||
|
||
#[test] | ||
fn test_primitives() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!(encode(a, 0u8), Ok("80".to_owned())); | ||
assert_eq!(encode(a, 0i8), Ok("80".to_owned())); | ||
assert_eq!(encode(a, 5u8), Ok("05".to_owned())); | ||
assert_eq!(encode(a, 5u32), Ok("05".to_owned())); | ||
assert_eq!(encode(a, 5i32), Ok("05".to_owned())); | ||
assert_eq!(encode(a, -27i32), Ok("81e5".to_owned())); | ||
assert_eq!(encode(a, -0), Ok("80".to_owned())); | ||
assert_eq!(encode(a, -128i8), Ok("8180".to_owned())); | ||
} | ||
|
||
#[test] | ||
fn test_reference() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!(encode(a, [1, 2, 3]), encode(a, [1, 2, 3])); | ||
assert_eq!(encode(a, Some(42)), encode(a, Some(42))); | ||
assert_eq!(encode(a, Some(&42)), encode(a, Some(42))); | ||
assert_eq!(encode(a, Some(&42)), encode(a, Some(42))); | ||
} | ||
|
||
#[test] | ||
fn test_pair() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!(encode(a, (5, 2)), Ok("ff0502".to_owned())); | ||
assert_eq!( | ||
encode(a, (-72, (90121, ()))), | ||
Ok("ff81b8ff8301600980".to_owned()) | ||
); | ||
assert_eq!( | ||
encode(a, (((), ((), ((), (((), ((), ((), ()))), ())))), ())), | ||
Ok("ffff80ff80ff80ffff80ff80ff80808080".to_owned()) | ||
); | ||
} | ||
|
||
#[test] | ||
fn test_nil() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!(encode(a, ()), Ok("80".to_owned())); | ||
} | ||
|
||
#[test] | ||
fn test_slice() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!( | ||
encode(a, [1, 2, 3, 4].as_slice()), | ||
Ok("ff01ff02ff03ff0480".to_owned()) | ||
); | ||
assert_eq!(encode(a, [0; 0].as_slice()), Ok("80".to_owned())); | ||
} | ||
|
||
#[test] | ||
fn test_array() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!(encode(a, [1, 2, 3, 4]), Ok("ff01ff02ff03ff0480".to_owned())); | ||
assert_eq!(encode(a, [0; 0]), Ok("80".to_owned())); | ||
} | ||
|
||
#[test] | ||
fn test_vec() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!( | ||
encode(a, vec![1, 2, 3, 4]), | ||
Ok("ff01ff02ff03ff0480".to_owned()) | ||
); | ||
assert_eq!(encode(a, vec![0; 0]), Ok("80".to_owned())); | ||
} | ||
|
||
#[test] | ||
fn test_option() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!(encode(a, Some("hello")), Ok("8568656c6c6f".to_owned())); | ||
assert_eq!(encode(a, None::<&str>), Ok("80".to_owned())); | ||
assert_eq!(encode(a, Some("")), Ok("80".to_owned())); | ||
} | ||
|
||
#[test] | ||
fn test_str() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!(encode(a, "hello"), Ok("8568656c6c6f".to_owned())); | ||
assert_eq!(encode(a, ""), Ok("80".to_owned())); | ||
} | ||
|
||
#[test] | ||
fn test_string() { | ||
let a = &mut Allocator::new(); | ||
assert_eq!( | ||
encode(a, "hello".to_string()), | ||
Ok("8568656c6c6f".to_owned()) | ||
); | ||
assert_eq!(encode(a, "".to_string()), Ok("80".to_owned())); | ||
} | ||
} |