diff --git a/Cargo.toml b/Cargo.toml index 7be305f..c334f6e 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -14,5 +14,6 @@ categories = [ "cryptography" ] cryptoxide = "0.4" [features] -default = [] -with-bench = [] +default = ["std"] +std = [] +with-bench = [] \ No newline at end of file diff --git a/rust-toolchain b/rust-toolchain new file mode 100644 index 0000000..07ade69 --- /dev/null +++ b/rust-toolchain @@ -0,0 +1 @@ +nightly \ No newline at end of file diff --git a/src/derivation/mod.rs b/src/derivation/mod.rs index e90f4a6..314fa9f 100644 --- a/src/derivation/mod.rs +++ b/src/derivation/mod.rs @@ -1,3 +1,6 @@ +#[cfg(not(feature = "std"))] +use core as std; + mod common; pub mod v2; diff --git a/src/hex.rs b/src/hex.rs index 73cfae6..7854afa 100644 --- a/src/hex.rs +++ b/src/hex.rs @@ -1,3 +1,9 @@ +#[cfg(not(feature = "std"))] +use alloc::string::String; + +#[cfg(not(feature = "std"))] +use alloc::vec::Vec; + const ALPHABET: &'static [u8] = b"0123456789abcdef"; pub fn encode(input: &[u8]) -> String { diff --git a/src/key.rs b/src/key.rs index 5e61650..668dd4c 100644 --- a/src/key.rs +++ b/src/key.rs @@ -1,3 +1,6 @@ +#[cfg(not(feature = "std"))] +use core as std; + use std::fmt; use cryptoxide::constant_time::CtEqual; diff --git a/src/lib.rs b/src/lib.rs index ad3fcab..2b64d08 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -10,12 +10,20 @@ //! In soft derivation, the important property is that given the parent public key, //! one can derive all softly derived children public key. -#![cfg_attr(feature = "with-bench", feature(test))] +#![cfg_attr(not(feature = "std"), no_std)] +#![cfg_attr(not(feature = "std"), feature(error_in_core))] +#![cfg_attr(feature = "with-bench", feature(test))] #[cfg(test)] #[cfg(feature = "with-bench")] extern crate test; +#[cfg(not(feature = "std"))] +extern crate alloc; + +#[cfg(not(feature = "std"))] +extern crate core; + mod derivation; mod hex; mod key; diff --git a/src/securemem.rs b/src/securemem.rs index 109a608..704cabd 100644 --- a/src/securemem.rs +++ b/src/securemem.rs @@ -1,3 +1,6 @@ +#[cfg(not(feature = "std"))] +use core as std; + pub fn zero(to_zero: &mut [u8]) { // the unsafety of this call is bounded to the existence of the pointer // and the accuracy of the length of the array. diff --git a/src/signature.rs b/src/signature.rs index 657ccc1..35845c2 100644 --- a/src/signature.rs +++ b/src/signature.rs @@ -1,3 +1,6 @@ +#[cfg(not(feature = "std"))] +use core as std; + use super::hex; use std::error::Error; use std::fmt;