Implement NativeExecutor, which attempts a native execution and falls back on Wasm otherwise.

This commit is contained in:
Gav
2018-01-23 20:38:01 +01:00
parent 91c659fbc8
commit 1617900c1d
9 changed files with 16 additions and 15 deletions
+5 -5
View File
@@ -10,26 +10,26 @@ use alloc::vec::Vec;
extern crate runtime_support;
use runtime_support::{set_storage, storage, print, blake2_256, twox_128, twox_256, ed25519_verify};
fn test_blake2_256(input: Vec<u8>) -> Vec<u8> {
fn test_blake2_256(input: &[u8]) -> Vec<u8> {
blake2_256(&input).to_vec()
}
fn test_twox_256(input: Vec<u8>) -> Vec<u8> {
fn test_twox_256(input: &[u8]) -> Vec<u8> {
twox_256(&input).to_vec()
}
fn test_twox_128(input: Vec<u8>) -> Vec<u8> {
fn test_twox_128(input: &[u8]) -> Vec<u8> {
twox_128(&input).to_vec()
}
fn test_ed25519_verify(input: Vec<u8>) -> Vec<u8> {
fn test_ed25519_verify(input: &[u8]) -> Vec<u8> {
let sig = &input[0..64];
let pubkey = &input[64..96];
let msg = b"all ok!";
[ed25519_verify(sig, &msg[..], pubkey) as u8].to_vec()
}
fn test_data_in(input: Vec<u8>) -> Vec<u8> {
fn test_data_in(input: &[u8]) -> Vec<u8> {
print(b"set_storage" as &[u8]);
set_storage(b"input", &input);