-
Notifications
You must be signed in to change notification settings - Fork 23
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Eval EXEC <[email protected]>
- Loading branch information
Showing
28 changed files
with
440 additions
and
48 deletions.
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
[package] | ||
name = "molecule" | ||
version = "0.7.3" | ||
version = "0.8.0" | ||
authors = ["Nervos Core Dev <[email protected]>"] | ||
edition = "2018" | ||
description = "Rust bindings for molecule." | ||
|
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,3 @@ | ||
target/ | ||
Cargo.lock | ||
|
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,30 @@ | ||
[package] | ||
name = "molecule-std" | ||
version = "0.0.1" | ||
authors = ["Nervos Core Dev <[email protected]>"] | ||
edition = "2018" | ||
description = "std primitive types for molecule." | ||
homepage = "https://github.com/nervosnetwork/molecule" | ||
repository = "https://github.com/nervosnetwork/molecule" | ||
keywords = ["molecule", "code-generation", "serialization"] | ||
categories = [ | ||
"parser-implementations", | ||
"development-tools::build-utils", | ||
"encoding", | ||
"data-structures" | ||
] | ||
license = "MIT" | ||
|
||
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html | ||
|
||
[dependencies] | ||
molecule = { path = "../../bindings/rust" } | ||
|
||
[features] | ||
default = ["std"] | ||
with-primitive-types = [] | ||
std = ["molecule/bytes", "molecule/faster-hex"] | ||
|
||
[build-dependencies] | ||
codegen = {package ="molecule-codegen", version = "=0.8.0", path = "../../tools/codegen" } | ||
|
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,20 @@ | ||
use codegen::{Compiler, Language}; | ||
|
||
fn compile_schema(schema: &str) { | ||
let mut compiler = Compiler::new(); | ||
compiler | ||
.input_schema_file(schema) | ||
.generate_code(Language::Rust) | ||
.output_dir_set_default() | ||
.expand_primitive(true) | ||
.run() | ||
.unwrap(); | ||
println!("cargo:rerun-if-changed={}", schema); | ||
} | ||
|
||
fn main() { | ||
println!("cargo:rerun-if-changed=primitive_types.mol"); | ||
compile_schema("primitive_types.mol"); | ||
let out_dir = ::std::env::var("OUT_DIR").unwrap(); | ||
println!("{}", out_dir); | ||
} |
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,14 @@ | ||
// Unsigned integers | ||
array uint64 [byte; 8]; | ||
array uint32 [byte; 4]; | ||
array uint16 [byte; 2]; | ||
array uint8 [byte; 1]; | ||
|
||
// Signed integers | ||
array int64 [byte; 8]; | ||
array int32 [byte; 4]; | ||
array int16 [byte; 2]; | ||
array int8 [byte; 1]; | ||
|
||
// Bool | ||
array bool [byte; 1]; |
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,35 @@ | ||
pub use crate as molecule_std; | ||
|
||
pub use molecule::*; | ||
|
||
#[cfg(feature = "with-primitive-types")] | ||
pub mod primitives { | ||
include!(concat!(env!("OUT_DIR"), "/primitive_types.rs")); | ||
} | ||
|
||
pub mod prelude { | ||
pub use molecule::prelude::*; | ||
|
||
#[cfg(feature = "with-primitive-types")] | ||
pub use crate::primitives::*; | ||
} | ||
|
||
#[cfg(feature = "with-primitive-types")] | ||
mod primitives_pack; | ||
|
||
pub mod pack { | ||
use crate::prelude::Entity; | ||
pub trait Unpack<T> { | ||
/// Unpack binary data into rust types. | ||
fn unpack(&self) -> T; | ||
} | ||
|
||
/// A syntactic sugar to convert a rust type into binary data. | ||
pub trait Pack<T: Entity> { | ||
/// Packs a rust type into binary data. | ||
fn pack(&self) -> T; | ||
} | ||
|
||
#[cfg(feature = "with-primitive-types")] | ||
pub use crate::primitives_pack::*; | ||
} |
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,154 @@ | ||
use crate::bytes::*; | ||
use crate::pack::*; | ||
use crate::prelude::*; | ||
|
||
macro_rules! impl_conversion_for_entity_unpack { | ||
($original:ty, $entity:ident) => { | ||
impl Unpack<$original> for $entity { | ||
fn unpack(&self) -> $original { | ||
self.as_reader().unpack() | ||
} | ||
} | ||
}; | ||
} | ||
|
||
impl Pack<Uint64> for u64 { | ||
fn pack(&self) -> Uint64 { | ||
Uint64::new_unchecked(Bytes::from(self.to_le_bytes().to_vec())) | ||
} | ||
} | ||
|
||
impl<'r> Unpack<u64> for Uint64Reader<'r> { | ||
fn unpack(&self) -> u64 { | ||
let mut b = [0u8; 8]; | ||
b.copy_from_slice(self.as_slice()); | ||
u64::from_le_bytes(b) | ||
} | ||
} | ||
impl_conversion_for_entity_unpack!(u64, Uint64); | ||
|
||
impl Pack<Uint32> for u32 { | ||
fn pack(&self) -> Uint32 { | ||
Uint32::new_unchecked(Bytes::from(self.to_le_bytes().to_vec())) | ||
} | ||
} | ||
|
||
impl<'r> Unpack<u32> for Uint32Reader<'r> { | ||
fn unpack(&self) -> u32 { | ||
let mut b = [0u8; 4]; | ||
b.copy_from_slice(self.as_slice()); | ||
u32::from_le_bytes(b) | ||
} | ||
} | ||
impl_conversion_for_entity_unpack!(u32, Uint32); | ||
|
||
impl Pack<Uint16> for u16 { | ||
fn pack(&self) -> Uint16 { | ||
Uint16::new_unchecked(Bytes::from(self.to_le_bytes().to_vec())) | ||
} | ||
} | ||
|
||
impl<'r> Unpack<u16> for Uint16Reader<'r> { | ||
fn unpack(&self) -> u16 { | ||
let mut b = [0u8; 2]; | ||
b.copy_from_slice(self.as_slice()); | ||
u16::from_le_bytes(b) | ||
} | ||
} | ||
impl_conversion_for_entity_unpack!(u16, Uint16); | ||
|
||
impl Pack<Uint8> for u8 { | ||
fn pack(&self) -> Uint8 { | ||
Uint8::new_unchecked(Bytes::from(self.to_le_bytes().to_vec())) | ||
} | ||
} | ||
|
||
impl<'r> Unpack<u8> for Uint8Reader<'r> { | ||
fn unpack(&self) -> u8 { | ||
let mut b = [0u8; 1]; | ||
b.copy_from_slice(self.as_slice()); | ||
u8::from_le_bytes(b) | ||
} | ||
} | ||
impl_conversion_for_entity_unpack!(u8, Uint8); | ||
|
||
// Signed integers | ||
|
||
impl Pack<Int64> for i64 { | ||
fn pack(&self) -> Int64 { | ||
Int64::new_unchecked(Bytes::from(self.to_le_bytes().to_vec())) | ||
} | ||
} | ||
|
||
impl<'r> Unpack<i64> for Int64Reader<'r> { | ||
fn unpack(&self) -> i64 { | ||
let mut b = [0u8; 8]; | ||
b.copy_from_slice(self.as_slice()); | ||
i64::from_le_bytes(b) | ||
} | ||
} | ||
impl_conversion_for_entity_unpack!(i64, Int64); | ||
|
||
impl Pack<Int32> for i32 { | ||
fn pack(&self) -> Int32 { | ||
Int32::new_unchecked(Bytes::from(self.to_le_bytes().to_vec())) | ||
} | ||
} | ||
|
||
impl<'r> Unpack<i32> for Int32Reader<'r> { | ||
fn unpack(&self) -> i32 { | ||
let mut b = [0u8; 4]; | ||
b.copy_from_slice(self.as_slice()); | ||
i32::from_le_bytes(b) | ||
} | ||
} | ||
impl_conversion_for_entity_unpack!(i32, Int32); | ||
|
||
impl Pack<Int16> for i16 { | ||
fn pack(&self) -> Int16 { | ||
Int16::new_unchecked(Bytes::from(self.to_le_bytes().to_vec())) | ||
} | ||
} | ||
|
||
impl<'r> Unpack<i16> for Int16Reader<'r> { | ||
fn unpack(&self) -> i16 { | ||
let mut b = [0u8; 2]; | ||
b.copy_from_slice(self.as_slice()); | ||
i16::from_le_bytes(b) | ||
} | ||
} | ||
impl_conversion_for_entity_unpack!(i16, Int16); | ||
|
||
impl Pack<Int8> for i8 { | ||
fn pack(&self) -> Int8 { | ||
Int8::new_unchecked(Bytes::from(self.to_le_bytes().to_vec())) | ||
} | ||
} | ||
|
||
impl<'r> Unpack<i8> for Int8Reader<'r> { | ||
fn unpack(&self) -> i8 { | ||
let mut b = [0u8; 1]; | ||
b.copy_from_slice(self.as_slice()); | ||
i8::from_le_bytes(b) | ||
} | ||
} | ||
impl_conversion_for_entity_unpack!(i8, Int8); | ||
|
||
// Bool | ||
impl Pack<Bool> for bool { | ||
fn pack(&self) -> Bool { | ||
let b = u8::from(*self); | ||
Bool::new_unchecked(Bytes::from(vec![b])) | ||
} | ||
} | ||
|
||
impl<'r> Unpack<bool> for BoolReader<'r> { | ||
fn unpack(&self) -> bool { | ||
match self.as_slice()[0] { | ||
0 => false, | ||
1 => true, | ||
_ => unreachable!(), | ||
} | ||
} | ||
} | ||
impl_conversion_for_entity_unpack!(bool, Bool); |
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 |
---|---|---|
@@ -1,6 +1,6 @@ | ||
[package] | ||
name = "molecule-codegen" | ||
version = "0.7.3" | ||
version = "0.8.0" | ||
authors = ["Nervos Core Dev <[email protected]>"] | ||
edition = "2018" | ||
description = "Code generator for molecule." | ||
|
@@ -16,7 +16,7 @@ categories = [ | |
license = "MIT" | ||
|
||
[dependencies] | ||
molecule = { version = "=0.7.3", path = "../../bindings/rust", default-features = false } | ||
molecule = { version = "=0.8.0", path = "../../bindings/rust", default-features = false } | ||
property = "0.3.3" | ||
pest = "2.1.3" | ||
pest_derive = "2.1.0" | ||
|
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,14 @@ | ||
// Unsigned integers | ||
array uint64 [byte; 8]; | ||
array uint32 [byte; 4]; | ||
array uint16 [byte; 2]; | ||
array uint8 [byte; 1]; | ||
|
||
// Signed integers | ||
array int64 [byte; 8]; | ||
array int32 [byte; 4]; | ||
array int16 [byte; 2]; | ||
array int8 [byte; 1]; | ||
|
||
// Bool | ||
array bool [byte; 1]; |
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
Oops, something went wrong.