Merge branch 'master' into rpc-exception-handling
This commit is contained in:
		
						commit
						36104edc63
					
				
							
								
								
									
										261
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										261
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @ -2,7 +2,7 @@ | |||||||
| name = "parity" | name = "parity" | ||||||
| version = "1.1.0" | version = "1.1.0" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "bincode 0.5.3 (registry+https://github.com/rust-lang/crates.io-index)", |  "bincode 0.5.4 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "clippy 0.0.63 (registry+https://github.com/rust-lang/crates.io-index)", |  "clippy 0.0.63 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "ctrlc 1.1.1 (git+https://github.com/tomusdrw/rust-ctrlc.git)", |  "ctrlc 1.1.1 (git+https://github.com/tomusdrw/rust-ctrlc.git)", | ||||||
|  "daemonize 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "daemonize 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| @ -19,11 +19,11 @@ dependencies = [ | |||||||
|  "ethminer 1.1.0", |  "ethminer 1.1.0", | ||||||
|  "ethsync 1.1.0", |  "ethsync 1.1.0", | ||||||
|  "fdlimit 0.1.0", |  "fdlimit 0.1.0", | ||||||
|  "hyper 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "hyper 0.8.1 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "log 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "log 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "num_cpus 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)", |  "num_cpus 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "number_prefix 0.2.5 (registry+https://github.com/rust-lang/crates.io-index)", |  "number_prefix 0.2.5 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rpassword 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "rpassword 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", |  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rustc_version 0.1.7 (registry+https://github.com/rust-lang/crates.io-index)", |  "rustc_version 0.1.7 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "semver 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", |  "semver 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| @ -72,11 +72,11 @@ dependencies = [ | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "bincode" | name = "bincode" | ||||||
| version = "0.5.3" | version = "0.5.4" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "byteorder 0.5.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "byteorder 0.5.1 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "num 0.1.31 (registry+https://github.com/rust-lang/crates.io-index)", |  "num 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", |  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "serde 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "serde 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| @ -91,6 +91,11 @@ name = "bitflags" | |||||||
| version = "0.5.0" | version = "0.5.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "bitflags" | ||||||
|  | version = "0.6.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "blastfig" | name = "blastfig" | ||||||
| version = "0.3.3" | version = "0.3.3" | ||||||
| @ -113,10 +118,10 @@ source = "registry+https://github.com/rust-lang/crates.io-index" | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "chrono" | name = "chrono" | ||||||
| version = "0.2.21" | version = "0.2.22" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "num 0.1.31 (registry+https://github.com/rust-lang/crates.io-index)", |  "num 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)", |  "time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| @ -143,11 +148,11 @@ dependencies = [ | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "cookie" | name = "cookie" | ||||||
| version = "0.2.2" | version = "0.2.3" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)", |  "time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "url 0.5.8 (registry+https://github.com/rust-lang/crates.io-index)", |  "url 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -165,8 +170,8 @@ name = "ctrlc" | |||||||
| version = "1.1.1" | version = "1.1.1" | ||||||
| source = "git+https://github.com/tomusdrw/rust-ctrlc.git#f4927770f89eca80ec250911eea3adcbf579ac48" | source = "git+https://github.com/tomusdrw/rust-ctrlc.git#f4927770f89eca80ec250911eea3adcbf579ac48" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "kernel32-sys 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "kernel32-sys 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "winapi 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "winapi 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| @ -175,7 +180,7 @@ name = "daemonize" | |||||||
| version = "0.2.2" | version = "0.2.2" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -191,7 +196,7 @@ name = "docopt" | |||||||
| version = "0.6.80" | version = "0.6.80" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "regex 0.1.65 (registry+https://github.com/rust-lang/crates.io-index)", |  "regex 0.1.67 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", |  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "strsim 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "strsim 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| @ -207,7 +212,7 @@ version = "0.3.3" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "log 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "log 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "regex 0.1.65 (registry+https://github.com/rust-lang/crates.io-index)", |  "regex 0.1.67 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -216,8 +221,8 @@ version = "0.5.4" | |||||||
| source = "git+https://github.com/ethcore/rust-secp256k1#b6fdd43bbcf6d46adb72a92dd1632a0fc834cbf5" | source = "git+https://github.com/ethcore/rust-secp256k1#b6fdd43bbcf6d46adb72a92dd1632a0fc834cbf5" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "arrayvec 0.3.16 (registry+https://github.com/rust-lang/crates.io-index)", |  "arrayvec 0.3.16 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "gcc 0.3.26 (registry+https://github.com/rust-lang/crates.io-index)", |  "gcc 0.3.27 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rand 0.3.14 (registry+https://github.com/rust-lang/crates.io-index)", |  "rand 0.3.14 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", |  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "serde 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "serde 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| @ -237,19 +242,27 @@ dependencies = [ | |||||||
| name = "ethcore" | name = "ethcore" | ||||||
| version = "1.1.0" | version = "1.1.0" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  |  "bincode 0.5.3 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "clippy 0.0.63 (registry+https://github.com/rust-lang/crates.io-index)", |  "clippy 0.0.63 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "crossbeam 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "crossbeam 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "env_logger 0.3.3 (registry+https://github.com/rust-lang/crates.io-index)", |  "env_logger 0.3.3 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "ethash 1.1.0", |  "ethash 1.1.0", | ||||||
|  "ethcore-devtools 1.1.0", |  "ethcore-devtools 1.1.0", | ||||||
|  |  "ethcore-ipc 1.1.0", | ||||||
|  |  "ethcore-ipc-codegen 1.1.0", | ||||||
|  |  "ethcore-ipc-nano 1.1.0", | ||||||
|  "ethcore-util 1.1.0", |  "ethcore-util 1.1.0", | ||||||
|  "ethjson 0.1.0", |  "ethjson 0.1.0", | ||||||
|  "heapsize 0.3.5 (registry+https://github.com/rust-lang/crates.io-index)", |  "heapsize 0.3.5 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "lazy_static 0.1.15 (registry+https://github.com/rust-lang/crates.io-index)", |  "lazy_static 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "log 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "log 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "num_cpus 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)", |  "num_cpus 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rust-crypto 0.2.35 (registry+https://github.com/rust-lang/crates.io-index)", |  "rust-crypto 0.2.35 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", |  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "semver 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "serde 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "serde_codegen 0.7.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "syntex 0.31.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)", |  "time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| @ -316,7 +329,7 @@ version = "1.1.0" | |||||||
| dependencies = [ | dependencies = [ | ||||||
|  "arrayvec 0.3.16 (registry+https://github.com/rust-lang/crates.io-index)", |  "arrayvec 0.3.16 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "bigint 0.1.0", |  "bigint 0.1.0", | ||||||
|  "chrono 0.2.21 (registry+https://github.com/rust-lang/crates.io-index)", |  "chrono 0.2.22 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "clippy 0.0.63 (registry+https://github.com/rust-lang/crates.io-index)", |  "clippy 0.0.63 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "crossbeam 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "crossbeam 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "elastic-array 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "elastic-array 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| @ -325,10 +338,10 @@ dependencies = [ | |||||||
|  "ethcore-devtools 1.1.0", |  "ethcore-devtools 1.1.0", | ||||||
|  "heapsize 0.3.5 (registry+https://github.com/rust-lang/crates.io-index)", |  "heapsize 0.3.5 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "igd 0.4.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "igd 0.4.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "itertools 0.4.12 (registry+https://github.com/rust-lang/crates.io-index)", |  "itertools 0.4.13 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "json-tests 0.1.0", |  "json-tests 0.1.0", | ||||||
|  "lazy_static 0.1.15 (registry+https://github.com/rust-lang/crates.io-index)", |  "lazy_static 0.1.16 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "log 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "log 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "mio 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "mio 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rand 0.3.14 (registry+https://github.com/rust-lang/crates.io-index)", |  "rand 0.3.14 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| @ -359,7 +372,7 @@ dependencies = [ | |||||||
|  "parity-status 0.2.2 (git+https://github.com/tomusdrw/parity-status.git)", |  "parity-status 0.2.2 (git+https://github.com/tomusdrw/parity-status.git)", | ||||||
|  "parity-wallet 0.1.1 (git+https://github.com/tomusdrw/parity-wallet.git)", |  "parity-wallet 0.1.1 (git+https://github.com/tomusdrw/parity-wallet.git)", | ||||||
|  "parity-webapp 0.1.0 (git+https://github.com/tomusdrw/parity-webapp.git)", |  "parity-webapp 0.1.0 (git+https://github.com/tomusdrw/parity-webapp.git)", | ||||||
|  "url 0.5.8 (registry+https://github.com/rust-lang/crates.io-index)", |  "url 0.5.9 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -407,12 +420,12 @@ dependencies = [ | |||||||
| name = "fdlimit" | name = "fdlimit" | ||||||
| version = "0.1.0" | version = "0.1.0" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "gcc" | name = "gcc" | ||||||
| version = "0.3.26" | version = "0.3.27" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -430,7 +443,7 @@ name = "heapsize" | |||||||
| version = "0.3.5" | version = "0.3.5" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "kernel32-sys 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "kernel32-sys 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -468,10 +481,10 @@ dependencies = [ | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "hyper" | name = "hyper" | ||||||
| version = "0.8.0" | version = "0.8.1" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "cookie 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "cookie 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "httparse 1.1.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "httparse 1.1.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "language-tags 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "language-tags 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "log 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "log 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| @ -483,15 +496,15 @@ dependencies = [ | |||||||
|  "traitobject 0.0.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "traitobject 0.0.1 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "typeable 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "typeable 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "unicase 1.4.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "unicase 1.4.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "url 0.5.8 (registry+https://github.com/rust-lang/crates.io-index)", |  "url 0.5.9 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "hyper" | name = "hyper" | ||||||
| version = "0.9.0-mio" | version = "0.9.0-mio" | ||||||
| source = "git+https://github.com/hyperium/hyper?branch=mio#bf42e7563b7d52f334a1b25ec3dccf031febb990" | source = "git+https://github.com/hyperium/hyper?branch=mio#55c7d7a1d88001e529b3d3b3a6783548ce8c3d06" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "cookie 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "cookie 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "httparse 1.1.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "httparse 1.1.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "language-tags 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "language-tags 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "log 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "log 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| @ -503,10 +516,20 @@ dependencies = [ | |||||||
|  "traitobject 0.0.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "traitobject 0.0.1 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "typeable 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "typeable 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "unicase 1.4.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "unicase 1.4.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "url 0.5.8 (registry+https://github.com/rust-lang/crates.io-index)", |  "url 0.5.9 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "vecio 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "vecio 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "idna" | ||||||
|  | version = "0.1.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | dependencies = [ | ||||||
|  |  "matches 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "unicode-bidi 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "unicode-normalization 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "igd" | name = "igd" | ||||||
| version = "0.4.2" | version = "0.4.2" | ||||||
| @ -514,14 +537,14 @@ source = "registry+https://github.com/rust-lang/crates.io-index" | |||||||
| dependencies = [ | dependencies = [ | ||||||
|  "hyper 0.6.16 (registry+https://github.com/rust-lang/crates.io-index)", |  "hyper 0.6.16 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rand 0.3.14 (registry+https://github.com/rust-lang/crates.io-index)", |  "rand 0.3.14 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "regex 0.1.65 (registry+https://github.com/rust-lang/crates.io-index)", |  "regex 0.1.67 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "xml-rs 0.1.26 (registry+https://github.com/rust-lang/crates.io-index)", |  "xml-rs 0.1.26 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "xmltree 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "xmltree 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "itertools" | name = "itertools" | ||||||
| version = "0.4.12" | version = "0.4.13" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -554,7 +577,7 @@ dependencies = [ | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "kernel32-sys" | name = "kernel32-sys" | ||||||
| version = "0.2.1" | version = "0.2.2" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "winapi 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "winapi 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| @ -573,7 +596,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "lazy_static" | name = "lazy_static" | ||||||
| version = "0.1.15" | version = "0.1.16" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -583,7 +606,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "libc" | name = "libc" | ||||||
| version = "0.2.9" | version = "0.2.10" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -591,7 +614,7 @@ name = "librocksdb-sys" | |||||||
| version = "0.2.3" | version = "0.2.3" | ||||||
| source = "git+https://github.com/arkpar/rust-rocksdb.git#ae44ef33ed1358ffc79aa05ed77839d555daba33" | source = "git+https://github.com/arkpar/rust-rocksdb.git#ae44ef33ed1358ffc79aa05ed77839d555daba33" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -609,14 +632,9 @@ name = "memchr" | |||||||
| version = "0.1.11" | version = "0.1.11" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] |  | ||||||
| name = "mempool" |  | ||||||
| version = "0.3.1" |  | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" |  | ||||||
| 
 |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "mime" | name = "mime" | ||||||
| version = "0.1.3" | version = "0.1.3" | ||||||
| @ -655,7 +673,7 @@ name = "miow" | |||||||
| version = "0.1.2" | version = "0.1.2" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "kernel32-sys 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "kernel32-sys 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "net2 0.2.23 (registry+https://github.com/rust-lang/crates.io-index)", |  "net2 0.2.23 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "winapi 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "winapi 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "ws2_32-sys 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "ws2_32-sys 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| @ -666,7 +684,7 @@ name = "nanomsg" | |||||||
| version = "0.5.0" | version = "0.5.0" | ||||||
| source = "git+https://github.com/ethcore/nanomsg.rs.git#9c81fb3b0f71714b173d0abf14bfd30addf8c7b1" | source = "git+https://github.com/ethcore/nanomsg.rs.git#9c81fb3b0f71714b173d0abf14bfd30addf8c7b1" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "nanomsg-sys 0.5.0 (git+https://github.com/ethcore/nanomsg.rs.git)", |  "nanomsg-sys 0.5.0 (git+https://github.com/ethcore/nanomsg.rs.git)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| @ -675,8 +693,8 @@ name = "nanomsg-sys" | |||||||
| version = "0.5.0" | version = "0.5.0" | ||||||
| source = "git+https://github.com/ethcore/nanomsg.rs.git#9c81fb3b0f71714b173d0abf14bfd30addf8c7b1" | source = "git+https://github.com/ethcore/nanomsg.rs.git#9c81fb3b0f71714b173d0abf14bfd30addf8c7b1" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "gcc 0.3.26 (registry+https://github.com/rust-lang/crates.io-index)", |  "gcc 0.3.27 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -685,8 +703,8 @@ version = "0.2.23" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "cfg-if 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "cfg-if 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "kernel32-sys 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "kernel32-sys 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "winapi 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "winapi 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "ws2_32-sys 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "ws2_32-sys 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| @ -715,19 +733,76 @@ source = "registry+https://github.com/rust-lang/crates.io-index" | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "num" | name = "num" | ||||||
| version = "0.1.31" | version = "0.1.32" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  |  "num-bigint 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "num-complex 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "num-integer 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "num-iter 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "num-rational 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "num-traits 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "num-bigint" | ||||||
|  | version = "0.1.32" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | dependencies = [ | ||||||
|  |  "num-integer 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "num-traits 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rand 0.3.14 (registry+https://github.com/rust-lang/crates.io-index)", |  "rand 0.3.14 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", |  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "num-complex" | ||||||
|  | version = "0.1.32" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | dependencies = [ | ||||||
|  |  "num-traits 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "num-integer" | ||||||
|  | version = "0.1.32" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | dependencies = [ | ||||||
|  |  "num-traits 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "num-iter" | ||||||
|  | version = "0.1.32" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | dependencies = [ | ||||||
|  |  "num-integer 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "num-traits 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "num-rational" | ||||||
|  | version = "0.1.32" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | dependencies = [ | ||||||
|  |  "num-bigint 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "num-integer 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "num-traits 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "num-traits" | ||||||
|  | version = "0.1.32" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "num_cpus" | name = "num_cpus" | ||||||
| version = "0.2.11" | version = "0.2.11" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -735,7 +810,7 @@ name = "number_prefix" | |||||||
| version = "0.2.5" | version = "0.2.5" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "num 0.1.31 (registry+https://github.com/rust-lang/crates.io-index)", |  "num 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -762,7 +837,7 @@ dependencies = [ | |||||||
| [[package]] | [[package]] | ||||||
| name = "parity-webapp" | name = "parity-webapp" | ||||||
| version = "0.1.0" | version = "0.1.0" | ||||||
| source = "git+https://github.com/tomusdrw/parity-webapp.git#a24297256bae0ae0712c6478cd1ad681828b3800" | source = "git+https://github.com/tomusdrw/parity-webapp.git#0bf133f193863ba0e88b0b824a5c330037cce3f1" | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "primal" | name = "primal" | ||||||
| @ -787,7 +862,7 @@ name = "primal-check" | |||||||
| version = "0.2.2" | version = "0.2.2" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "num 0.1.31 (registry+https://github.com/rust-lang/crates.io-index)", |  "num 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -838,7 +913,7 @@ name = "rand" | |||||||
| version = "0.3.14" | version = "0.3.14" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -853,13 +928,13 @@ dependencies = [ | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "regex" | name = "regex" | ||||||
| version = "0.1.65" | version = "0.1.67" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "aho-corasick 0.5.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "aho-corasick 0.5.1 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "memchr 0.1.11 (registry+https://github.com/rust-lang/crates.io-index)", |  "memchr 0.1.11 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "mempool 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)", |  | ||||||
|  "regex-syntax 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "regex-syntax 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "thread_local 0.2.5 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "utf8-ranges 0.1.3 (registry+https://github.com/rust-lang/crates.io-index)", |  "utf8-ranges 0.1.3 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| @ -873,7 +948,7 @@ name = "rocksdb" | |||||||
| version = "0.4.3" | version = "0.4.3" | ||||||
| source = "git+https://github.com/arkpar/rust-rocksdb.git#ae44ef33ed1358ffc79aa05ed77839d555daba33" | source = "git+https://github.com/arkpar/rust-rocksdb.git#ae44ef33ed1358ffc79aa05ed77839d555daba33" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "librocksdb-sys 0.2.3 (git+https://github.com/arkpar/rust-rocksdb.git)", |  "librocksdb-sys 0.2.3 (git+https://github.com/arkpar/rust-rocksdb.git)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| @ -886,16 +961,16 @@ dependencies = [ | |||||||
|  "mio 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "mio 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "quick-error 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "quick-error 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)", |  "time 0.1.35 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "void 1.0.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "void 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "rpassword" | name = "rpassword" | ||||||
| version = "0.2.1" | version = "0.2.2" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "kernel32-sys 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "kernel32-sys 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "termios 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "termios 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "winapi 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "winapi 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| @ -905,7 +980,7 @@ name = "rust-crypto" | |||||||
| version = "0.2.35" | version = "0.2.35" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "gcc 0.3.26 (registry+https://github.com/rust-lang/crates.io-index)", |  "gcc 0.3.27 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "libc 0.1.12 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.1.12 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rand 0.3.14 (registry+https://github.com/rust-lang/crates.io-index)", |  "rand 0.3.14 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", |  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| @ -943,7 +1018,7 @@ name = "serde" | |||||||
| version = "0.6.15" | version = "0.6.15" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "num 0.1.31 (registry+https://github.com/rust-lang/crates.io-index)", |  "num 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -968,7 +1043,7 @@ name = "serde_json" | |||||||
| version = "0.7.0" | version = "0.7.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "num 0.1.31 (registry+https://github.com/rust-lang/crates.io-index)", |  "num 0.1.32 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "serde 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "serde 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| @ -976,7 +1051,7 @@ dependencies = [ | |||||||
| name = "sha3" | name = "sha3" | ||||||
| version = "0.1.0" | version = "0.1.0" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "gcc 0.3.26 (registry+https://github.com/rust-lang/crates.io-index)", |  "gcc 0.3.27 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -1012,7 +1087,7 @@ version = "0.31.0" | |||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "bitflags 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "bitflags 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "log 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "log 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", |  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "term 0.2.14 (registry+https://github.com/rust-lang/crates.io-index)", |  "term 0.2.14 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| @ -1029,7 +1104,7 @@ name = "term" | |||||||
| version = "0.2.14" | version = "0.2.14" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "kernel32-sys 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "kernel32-sys 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "winapi 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "winapi 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| @ -1038,7 +1113,24 @@ name = "termios" | |||||||
| version = "0.2.2" | version = "0.2.2" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "thread-id" | ||||||
|  | version = "2.0.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | dependencies = [ | ||||||
|  |  "kernel32-sys 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "thread_local" | ||||||
|  | version = "0.2.5" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | dependencies = [ | ||||||
|  |  "thread-id 2.0.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -1046,8 +1138,8 @@ name = "time" | |||||||
| version = "0.1.35" | version = "0.1.35" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "kernel32-sys 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "kernel32-sys 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "libc 0.2.9 (registry+https://github.com/rust-lang/crates.io-index)", |  "libc 0.2.10 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "winapi 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "winapi 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| @ -1120,14 +1212,23 @@ dependencies = [ | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "url" | name = "url" | ||||||
| version = "0.5.8" | version = "0.5.9" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "matches 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "matches 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", |  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "unicode-bidi 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", |  "unicode-bidi 0.2.3 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "unicode-normalization 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "unicode-normalization 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "uuid 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "uuid 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  | ] | ||||||
|  | 
 | ||||||
|  | [[package]] | ||||||
|  | name = "url" | ||||||
|  | version = "1.0.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | dependencies = [ | ||||||
|  |  "idna 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "matches 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -1146,7 +1247,7 @@ dependencies = [ | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "uuid" | name = "uuid" | ||||||
| version = "0.2.0" | version = "0.2.1" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "rand 0.3.14 (registry+https://github.com/rust-lang/crates.io-index)", |  "rand 0.3.14 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| @ -1172,7 +1273,7 @@ dependencies = [ | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "void" | name = "void" | ||||||
| version = "1.0.1" | version = "1.0.2" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| @ -1199,12 +1300,12 @@ name = "xml-rs" | |||||||
| version = "0.1.26" | version = "0.1.26" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "bitflags 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "bitflags 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "xml-rs" | name = "xml-rs" | ||||||
| version = "0.2.2" | version = "0.3.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "bitflags 0.3.3 (registry+https://github.com/rust-lang/crates.io-index)", |  "bitflags 0.3.3 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| @ -1212,9 +1313,9 @@ dependencies = [ | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "xmltree" | name = "xmltree" | ||||||
| version = "0.3.1" | version = "0.3.2" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "xml-rs 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "xml-rs 0.3.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -186,7 +186,7 @@ impl BlockProvider for BlockChain { | |||||||
| 		self.extras_db.exists_with_cache(&self.block_details, hash) | 		self.extras_db.exists_with_cache(&self.block_details, hash) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// We do not store tracing information.
 | 	/// We do not store tracing information.
 | ||||||
| 	fn have_tracing(&self) -> bool { false } | 	fn have_tracing(&self) -> bool { false } | ||||||
| 
 | 
 | ||||||
| 	/// Get raw block data
 | 	/// Get raw block data
 | ||||||
| @ -541,7 +541,7 @@ impl BlockChain { | |||||||
| 		Some(ret) | 		Some(ret) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	/// Get inserted block info which is critical to preapre extras updates.
 | 	/// Get inserted block info which is critical to prepare extras updates.
 | ||||||
| 	fn block_info(&self, block_bytes: &[u8]) -> BlockInfo { | 	fn block_info(&self, block_bytes: &[u8]) -> BlockInfo { | ||||||
| 		let block = BlockView::new(block_bytes); | 		let block = BlockView::new(block_bytes); | ||||||
| 		let header = block.header_view(); | 		let header = block.header_view(); | ||||||
| @ -950,21 +950,25 @@ mod tests { | |||||||
| 		assert_eq!(ir1, ImportRoute { | 		assert_eq!(ir1, ImportRoute { | ||||||
| 			enacted: vec![b1_hash], | 			enacted: vec![b1_hash], | ||||||
| 			retracted: vec![], | 			retracted: vec![], | ||||||
|  | 			omitted: vec![], | ||||||
| 		}); | 		}); | ||||||
| 
 | 
 | ||||||
| 		assert_eq!(ir2, ImportRoute { | 		assert_eq!(ir2, ImportRoute { | ||||||
| 			enacted: vec![b2_hash], | 			enacted: vec![b2_hash], | ||||||
| 			retracted: vec![], | 			retracted: vec![], | ||||||
|  | 			omitted: vec![], | ||||||
| 		}); | 		}); | ||||||
| 
 | 
 | ||||||
| 		assert_eq!(ir3b, ImportRoute { | 		assert_eq!(ir3b, ImportRoute { | ||||||
| 			enacted: vec![b3b_hash], | 			enacted: vec![b3b_hash], | ||||||
| 			retracted: vec![], | 			retracted: vec![], | ||||||
|  | 			omitted: vec![], | ||||||
| 		}); | 		}); | ||||||
| 
 | 
 | ||||||
| 		assert_eq!(ir3a, ImportRoute { | 		assert_eq!(ir3a, ImportRoute { | ||||||
| 			enacted: vec![b3a_hash], | 			enacted: vec![b3a_hash], | ||||||
| 			retracted: vec![b3b_hash], | 			retracted: vec![b3b_hash], | ||||||
|  | 			omitted: vec![], | ||||||
| 		}); | 		}); | ||||||
| 
 | 
 | ||||||
| 		assert_eq!(bc.best_block_hash(), best_block_hash); | 		assert_eq!(bc.best_block_hash(), best_block_hash); | ||||||
|  | |||||||
| @ -26,6 +26,8 @@ pub struct ImportRoute { | |||||||
| 	pub retracted: Vec<H256>, | 	pub retracted: Vec<H256>, | ||||||
| 	/// Blocks that were validated by new block.
 | 	/// Blocks that were validated by new block.
 | ||||||
| 	pub enacted: Vec<H256>, | 	pub enacted: Vec<H256>, | ||||||
|  | 	/// Blocks which are neither retracted nor enacted.
 | ||||||
|  | 	pub omitted: Vec<H256>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl ImportRoute { | impl ImportRoute { | ||||||
| @ -33,6 +35,7 @@ impl ImportRoute { | |||||||
| 		ImportRoute { | 		ImportRoute { | ||||||
| 			retracted: vec![], | 			retracted: vec![], | ||||||
| 			enacted: vec![], | 			enacted: vec![], | ||||||
|  | 			omitted: vec![], | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| @ -43,13 +46,19 @@ impl From<BlockInfo> for ImportRoute { | |||||||
| 			BlockLocation::CanonChain => ImportRoute { | 			BlockLocation::CanonChain => ImportRoute { | ||||||
| 				retracted: vec![], | 				retracted: vec![], | ||||||
| 				enacted: vec![info.hash], | 				enacted: vec![info.hash], | ||||||
|  | 				omitted: vec![], | ||||||
|  | 			}, | ||||||
|  | 			BlockLocation::Branch => ImportRoute { | ||||||
|  | 				retracted: vec![], | ||||||
|  | 				enacted: vec![], | ||||||
|  | 				omitted: vec![info.hash], | ||||||
| 			}, | 			}, | ||||||
| 			BlockLocation::Branch => ImportRoute::none(), |  | ||||||
| 			BlockLocation::BranchBecomingCanonChain(mut data) => { | 			BlockLocation::BranchBecomingCanonChain(mut data) => { | ||||||
| 				data.enacted.push(info.hash); | 				data.enacted.push(info.hash); | ||||||
| 				ImportRoute { | 				ImportRoute { | ||||||
| 					retracted: data.retracted, | 					retracted: data.retracted, | ||||||
| 					enacted: data.enacted, | 					enacted: data.enacted, | ||||||
|  | 					omitted: vec![], | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| @ -68,6 +77,7 @@ mod tests { | |||||||
| 		assert_eq!(ImportRoute::none(), ImportRoute { | 		assert_eq!(ImportRoute::none(), ImportRoute { | ||||||
| 			enacted: vec![], | 			enacted: vec![], | ||||||
| 			retracted: vec![], | 			retracted: vec![], | ||||||
|  | 			omitted: vec![], | ||||||
| 		}); | 		}); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| @ -80,7 +90,11 @@ mod tests { | |||||||
| 			location: BlockLocation::Branch, | 			location: BlockLocation::Branch, | ||||||
| 		}; | 		}; | ||||||
| 
 | 
 | ||||||
| 		assert_eq!(ImportRoute::from(info), ImportRoute::none()); | 		assert_eq!(ImportRoute::from(info), ImportRoute { | ||||||
|  | 			retracted: vec![], | ||||||
|  | 			enacted: vec![], | ||||||
|  | 			omitted: vec![H256::from(U256::from(1))], | ||||||
|  | 		}); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	#[test] | 	#[test] | ||||||
| @ -95,6 +109,7 @@ mod tests { | |||||||
| 		assert_eq!(ImportRoute::from(info), ImportRoute { | 		assert_eq!(ImportRoute::from(info), ImportRoute { | ||||||
| 			retracted: vec![], | 			retracted: vec![], | ||||||
| 			enacted: vec![H256::from(U256::from(1))], | 			enacted: vec![H256::from(U256::from(1))], | ||||||
|  | 			omitted: vec![], | ||||||
| 		}); | 		}); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| @ -114,6 +129,7 @@ mod tests { | |||||||
| 		assert_eq!(ImportRoute::from(info), ImportRoute { | 		assert_eq!(ImportRoute::from(info), ImportRoute { | ||||||
| 			retracted: vec![H256::from(U256::from(3)), H256::from(U256::from(4))], | 			retracted: vec![H256::from(U256::from(3)), H256::from(U256::from(4))], | ||||||
| 			enacted: vec![H256::from(U256::from(1)), H256::from(U256::from(2))], | 			enacted: vec![H256::from(U256::from(1)), H256::from(U256::from(2))], | ||||||
|  | 			omitted: vec![], | ||||||
| 		}); | 		}); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | |||||||
| @ -664,9 +664,6 @@ function run_installer() | |||||||
| 
 | 
 | ||||||
| 		[ ! -d "www" ] && git clone https://github.com/cubedro/eth-net-intelligence-api netstats | 		[ ! -d "www" ] && git clone https://github.com/cubedro/eth-net-intelligence-api netstats | ||||||
| 		cd netstats | 		cd netstats | ||||||
| 		git pull |  | ||||||
| 		git checkout 95d595258239a0fdf56b97dedcfb2be62f6170e6 |  | ||||||
| 
 |  | ||||||
| 		sudo npm install | 		sudo npm install | ||||||
| 		sudo npm install pm2 -g | 		sudo npm install pm2 -g | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -492,9 +492,6 @@ function run_installer() | |||||||
| 		[ ! -d "www" ] && git clone https://github.com/cubedro/eth-net-intelligence-api netstats | 		[ ! -d "www" ] && git clone https://github.com/cubedro/eth-net-intelligence-api netstats | ||||||
| 		oldpwd= $(pwd) | 		oldpwd= $(pwd) | ||||||
| 		cd netstats | 		cd netstats | ||||||
| 		git pull |  | ||||||
| 		git checkout 95d595258239a0fdf56b97dedcfb2be62f6170e6 |  | ||||||
| 
 |  | ||||||
| 		sudo npm install | 		sudo npm install | ||||||
| 		sudo npm install pm2 -g | 		sudo npm install pm2 -g | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -298,14 +298,14 @@ fn implement_dispatch_arms( | |||||||
| 		.map(|dispatch| { index = index + 1; implement_dispatch_arm(cx, builder, index as u32, dispatch, buffer, replacements) }).collect() | 		.map(|dispatch| { index = index + 1; implement_dispatch_arm(cx, builder, index as u32, dispatch, buffer, replacements) }).collect() | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| fn strip_ptr(ty: &P<ast::Ty>) -> P<ast::Ty> { | pub fn strip_ptr(ty: &P<ast::Ty>) -> P<ast::Ty> { | ||||||
| 	if let ast::TyKind::Rptr(_, ref ptr_mut) = ty.node { | 	if let ast::TyKind::Rptr(_, ref ptr_mut) = ty.node { | ||||||
| 		ptr_mut.ty.clone() | 		ptr_mut.ty.clone() | ||||||
| 	} | 	} | ||||||
| 	else { ty.clone() } | 	else { ty.clone() } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| fn has_ptr(ty: &P<ast::Ty>) -> bool { | pub fn has_ptr(ty: &P<ast::Ty>) -> bool { | ||||||
| 	if let ast::TyKind::Rptr(_, ref _ptr_mut) = ty.node { | 	if let ast::TyKind::Rptr(_, ref _ptr_mut) = ty.node { | ||||||
| 		true | 		true | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -54,6 +54,7 @@ pub fn register(reg: &mut syntex::Registry) { | |||||||
| 	reg.add_attr("feature(custom_attribute)"); | 	reg.add_attr("feature(custom_attribute)"); | ||||||
| 
 | 
 | ||||||
| 	reg.add_decorator("derive_Ipc", codegen::expand_ipc_implementation); | 	reg.add_decorator("derive_Ipc", codegen::expand_ipc_implementation); | ||||||
|  | 	reg.add_decorator("derive_Binary", serialization::expand_serialization_implementation); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #[cfg(not(feature = "with-syntex"))] | #[cfg(not(feature = "with-syntex"))] | ||||||
| @ -62,4 +63,8 @@ pub fn register(reg: &mut rustc_plugin::Registry) { | |||||||
| 		syntax::parse::token::intern("derive_Ipc"), | 		syntax::parse::token::intern("derive_Ipc"), | ||||||
| 		syntax::ext::base::MultiDecorator( | 		syntax::ext::base::MultiDecorator( | ||||||
| 			Box::new(codegen::expand_ipc_implementation))); | 			Box::new(codegen::expand_ipc_implementation))); | ||||||
|  | 	reg.register_syntax_extension( | ||||||
|  | 		syntax::parse::token::intern("derive_Binary"), | ||||||
|  | 		syntax::ext::base::MultiDecorator( | ||||||
|  | 			Box::new(serialization::expand_serialization_implementation))); | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,4 +15,5 @@ | |||||||
| // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
| 
 | 
 | ||||||
| mod codegen; | mod codegen; | ||||||
|  | mod serialization; | ||||||
| pub mod typegen; | pub mod typegen; | ||||||
|  | |||||||
							
								
								
									
										585
									
								
								ipc/codegen/src/serialization.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										585
									
								
								ipc/codegen/src/serialization.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,585 @@ | |||||||
|  | // Copyright 2015, 2016 Ethcore (UK) Ltd.
 | ||||||
|  | // This file is part of Parity.
 | ||||||
|  | 
 | ||||||
|  | // Parity is free software: you can redistribute it and/or modify
 | ||||||
|  | // it under the terms of the GNU General Public License as published by
 | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or
 | ||||||
|  | // (at your option) any later version.
 | ||||||
|  | 
 | ||||||
|  | // Parity is distributed in the hope that it will be useful,
 | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||||
|  | // GNU General Public License for more details.
 | ||||||
|  | 
 | ||||||
|  | // You should have received a copy of the GNU General Public License
 | ||||||
|  | // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
|  | use aster; | ||||||
|  | 
 | ||||||
|  | use syntax::ast::{ | ||||||
|  | 	MetaItem, | ||||||
|  | 	Item, | ||||||
|  | 	Ident, | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | use syntax::ast; | ||||||
|  | use syntax::codemap::Span; | ||||||
|  | use syntax::ext::base::{Annotatable, ExtCtxt}; | ||||||
|  | use syntax::ext::build::AstBuilder; | ||||||
|  | use syntax::ptr::P; | ||||||
|  | 
 | ||||||
|  | pub struct Error; | ||||||
|  | 
 | ||||||
|  | use super::codegen; | ||||||
|  | 
 | ||||||
|  | pub fn expand_serialization_implementation( | ||||||
|  | 	cx: &mut ExtCtxt, | ||||||
|  | 	span: Span, | ||||||
|  | 	meta_item: &MetaItem, | ||||||
|  | 	annotatable: &Annotatable, | ||||||
|  | 	push: &mut FnMut(Annotatable) | ||||||
|  | ) { | ||||||
|  | 	let item = match *annotatable { | ||||||
|  | 		Annotatable::Item(ref item) => item, | ||||||
|  | 		_ => { | ||||||
|  | 			cx.span_err(meta_item.span, "`#[derive(Binary)]` may only be applied to structs and enums"); | ||||||
|  | 			return; | ||||||
|  | 		}, | ||||||
|  | 	}; | ||||||
|  | 
 | ||||||
|  | 	let builder = aster::AstBuilder::new().span(span); | ||||||
|  | 
 | ||||||
|  | 	let impl_item = match serialize_item(cx, &builder, &item) { | ||||||
|  | 		Ok(item) => item, | ||||||
|  | 		Err(Error) => { | ||||||
|  | 			// An error occured, but it should have been reported already.
 | ||||||
|  | 			return; | ||||||
|  | 		}, | ||||||
|  | 	}; | ||||||
|  | 
 | ||||||
|  | 	push(Annotatable::Item(impl_item)) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | fn serialize_item( | ||||||
|  | 	cx: &ExtCtxt, | ||||||
|  | 	builder: &aster::AstBuilder, | ||||||
|  | 	item: &Item, | ||||||
|  | ) -> Result<P<ast::Item>, Error> { | ||||||
|  | 	let generics = match item.node { | ||||||
|  | 		ast::ItemKind::Struct(_, ref generics) => generics, | ||||||
|  | 		ast::ItemKind::Enum(_, ref generics) => generics, | ||||||
|  | 		_ => { | ||||||
|  | 			cx.span_err( | ||||||
|  | 				item.span, | ||||||
|  | 				"`#[derive(Binary)]` may only be applied to structs and enums"); | ||||||
|  | 			return Err(Error); | ||||||
|  | 		}, | ||||||
|  | 	}; | ||||||
|  | 
 | ||||||
|  | 	let ty = builder.ty().path() | ||||||
|  | 		.segment(item.ident).with_generics(generics.clone()).build() | ||||||
|  | 		.build(); | ||||||
|  | 
 | ||||||
|  | 	let where_clause = &generics.where_clause; | ||||||
|  | 
 | ||||||
|  | 	let binary_expressions = try!(binary_expr(cx, | ||||||
|  | 		&builder, | ||||||
|  | 		&item, | ||||||
|  | 		&generics, | ||||||
|  | 		ty.clone())); | ||||||
|  | 
 | ||||||
|  | 	let (size_expr, read_expr, write_expr) = | ||||||
|  | 		(binary_expressions.size, binary_expressions.read, binary_expressions.write); | ||||||
|  | 
 | ||||||
|  | 	Ok(quote_item!(cx, | ||||||
|  | 		impl $generics ::ipc::BinaryConvertable for $ty $where_clause { | ||||||
|  | 			fn size(&self) -> usize { | ||||||
|  | 				$size_expr | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			fn to_bytes(&self, buffer: &mut [u8], length_stack: &mut VecDeque<usize>) -> Result<(), BinaryConvertError> { | ||||||
|  | 				$write_expr | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			fn from_bytes(buffer: &[u8], length_stack: &mut VecDeque<usize>) -> Result<Self, BinaryConvertError> { | ||||||
|  | 				$read_expr | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			fn len_params() -> usize { | ||||||
|  | 				1 | ||||||
|  | 			} | ||||||
|  |         } | ||||||
|  |     ).unwrap()) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[allow(unreachable_code)] | ||||||
|  | fn binary_expr( | ||||||
|  | 	cx: &ExtCtxt, | ||||||
|  | 	builder: &aster::AstBuilder, | ||||||
|  | 	item: &Item, | ||||||
|  | 	impl_generics: &ast::Generics, | ||||||
|  | 	ty: P<ast::Ty>, | ||||||
|  | ) -> Result<BinaryExpressions, Error> { | ||||||
|  | 	match item.node { | ||||||
|  | 		ast::ItemKind::Struct(ref variant_data, _) => { | ||||||
|  | 			binary_expr_item_struct( | ||||||
|  | 				cx, | ||||||
|  | 				builder, | ||||||
|  | 				impl_generics, | ||||||
|  | 				ty, | ||||||
|  | 				item.span, | ||||||
|  | 				variant_data, | ||||||
|  | 			) | ||||||
|  | 		}, | ||||||
|  | 		ast::ItemKind::Enum(ref enum_def, _) => { | ||||||
|  | 			binary_expr_enum( | ||||||
|  | 				cx, | ||||||
|  | 				builder, | ||||||
|  | 				item.ident, | ||||||
|  | 				impl_generics, | ||||||
|  | 				ty, | ||||||
|  | 				item.span, | ||||||
|  | 				enum_def, | ||||||
|  | 			) | ||||||
|  | 		}, | ||||||
|  | 		_ => { | ||||||
|  | 			cx.span_bug(item.span, | ||||||
|  | 						"expected ItemStruct or ItemEnum in #[derive(Binary)]"); | ||||||
|  | 			Err(Error) | ||||||
|  | 		}, | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | struct BinaryExpressions { | ||||||
|  | 	pub size: P<ast::Expr>, | ||||||
|  | 	pub write: P<ast::Expr>, | ||||||
|  | 	pub read: P<ast::Expr>, | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | fn binary_expr_struct( | ||||||
|  | 	cx: &ExtCtxt, | ||||||
|  | 	builder: &aster::AstBuilder, | ||||||
|  | 	ty: P<ast::Ty>, | ||||||
|  | 	fields: &[ast::StructField], | ||||||
|  | 	value_ident: Option<ast::Ident>, | ||||||
|  | 	instance_ident: Option<ast::Ident>, | ||||||
|  | ) -> Result<BinaryExpressions, Error> { | ||||||
|  | 
 | ||||||
|  | 	let size_exprs: Vec<P<ast::Expr>> = fields.iter().enumerate().map(|(index, field)| { | ||||||
|  | 		let field_type_ident = builder.id( | ||||||
|  | 			&::syntax::print::pprust::ty_to_string( | ||||||
|  | 				&codegen::strip_ptr(&field.ty))); | ||||||
|  | 		let index_ident = builder.id(format!("__field{}", index)); | ||||||
|  | 		value_ident.and_then(|x| { | ||||||
|  | 				let field_id = builder.id(field.ident.unwrap()); | ||||||
|  | 				Some(quote_expr!(cx, | ||||||
|  | 					match $field_type_ident::len_params() { | ||||||
|  | 						0 => mem::size_of::<$field_type_ident>(), | ||||||
|  | 						_ => $x. $field_id .size(), | ||||||
|  | 					})) | ||||||
|  | 			}) | ||||||
|  | 			.unwrap_or_else(|| quote_expr!(cx, match $field_type_ident::len_params() { | ||||||
|  | 				0 => mem::size_of::<$field_type_ident>(), | ||||||
|  | 				_ => $index_ident .size(), | ||||||
|  | 			})) | ||||||
|  | 	}).collect(); | ||||||
|  | 
 | ||||||
|  | 	let first_size_expr = size_exprs[0].clone(); | ||||||
|  | 	let mut total_size_expr = quote_expr!(cx, 0usize + $first_size_expr); | ||||||
|  | 	for index in 1..size_exprs.len() { | ||||||
|  | 		let next_expr = size_exprs[index].clone(); | ||||||
|  | 		total_size_expr = quote_expr!(cx, $total_size_expr + $next_expr); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	let mut write_stmts = Vec::<ast::Stmt>::new(); | ||||||
|  | 	write_stmts.push(quote_stmt!(cx, let mut offset = 0usize;).unwrap()); | ||||||
|  | 
 | ||||||
|  | 	let mut map_stmts = Vec::<ast::Stmt>::new(); | ||||||
|  | 	let field_amount = builder.id(&format!("{}",fields.len())); | ||||||
|  | 	map_stmts.push(quote_stmt!(cx, let mut map = vec![0usize; $field_amount];).unwrap()); | ||||||
|  | 	map_stmts.push(quote_stmt!(cx, let mut total = 0usize;).unwrap()); | ||||||
|  | 	for (index, field) in fields.iter().enumerate() { | ||||||
|  | 		let field_type_ident = builder.id( | ||||||
|  | 			&::syntax::print::pprust::ty_to_string( | ||||||
|  | 				&codegen::strip_ptr(&field.ty))); | ||||||
|  | 
 | ||||||
|  | 		let member_expr = match value_ident { | ||||||
|  | 			Some(x) => { | ||||||
|  | 				let field_id = builder.id(field.ident.unwrap()); | ||||||
|  | 				quote_expr!(cx, $x . $field_id) | ||||||
|  | 			}, | ||||||
|  | 			None => { | ||||||
|  | 				let index_ident = builder.id(format!("__field{}", index)); | ||||||
|  | 				quote_expr!(cx, $index_ident) | ||||||
|  | 			}, | ||||||
|  | 		}; | ||||||
|  | 
 | ||||||
|  | 		write_stmts.push(quote_stmt!(cx, let next_line = offset + match $field_type_ident::len_params() { | ||||||
|  | 				0 => mem::size_of::<$field_type_ident>(), | ||||||
|  | 				_ => { let size = $member_expr .size(); length_stack.push_back(size); size }, | ||||||
|  | 			}).unwrap()); | ||||||
|  | 
 | ||||||
|  | 		write_stmts.push(quote_stmt!(cx, | ||||||
|  | 			if let Err(e) = $member_expr .to_bytes(&mut buffer[offset..next_line], length_stack) { return Err(e) };).unwrap()); | ||||||
|  | 
 | ||||||
|  | 		write_stmts.push(quote_stmt!(cx, offset = next_line; ).unwrap()); | ||||||
|  | 
 | ||||||
|  | 		let field_index = builder.id(&format!("{}", index)); | ||||||
|  | 		map_stmts.push(quote_stmt!(cx, map[$field_index] = total;).unwrap()); | ||||||
|  | 		map_stmts.push(quote_stmt!(cx, let size = match $field_type_ident::len_params() { | ||||||
|  | 				0 => mem::size_of::<$field_type_ident>(), | ||||||
|  | 				_ => length_stack.pop_front().unwrap(), | ||||||
|  | 			}).unwrap()); | ||||||
|  | 		map_stmts.push(quote_stmt!(cx, total = total + size;).unwrap()); | ||||||
|  | 	}; | ||||||
|  | 
 | ||||||
|  | 	let read_expr = match fields.iter().any(|f| codegen::has_ptr(&f.ty)) { | ||||||
|  | 		true => { | ||||||
|  | 			// cannot create structs with pointers
 | ||||||
|  | 			quote_expr!(cx, Err(::ipc::binary::BinaryConvertError)) | ||||||
|  | 		}, | ||||||
|  | 		false => { | ||||||
|  | 			if value_ident.is_some() { | ||||||
|  | 				let instance_create = named_fields_sequence(cx, &ty, fields); | ||||||
|  | 				quote_expr!(cx, { $map_stmts; $instance_create; Ok(result) }) | ||||||
|  | 			} | ||||||
|  | 			else { | ||||||
|  | 				let map_variant = P(fields_sequence(cx, &ty, fields, &instance_ident.unwrap_or(builder.id("Self")))); | ||||||
|  | 				quote_expr!(cx, { $map_stmts; Ok($map_variant) }) | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 	}; | ||||||
|  | 
 | ||||||
|  |     Ok(BinaryExpressions { | ||||||
|  | 		size: total_size_expr, | ||||||
|  | 		write: quote_expr!(cx, { $write_stmts; Ok(()) } ), | ||||||
|  | 		read: read_expr, | ||||||
|  | 	}) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[allow(unreachable_code)] | ||||||
|  | fn binary_expr_item_struct( | ||||||
|  | 	cx: &ExtCtxt, | ||||||
|  | 	builder: &aster::AstBuilder, | ||||||
|  | 	_impl_generics: &ast::Generics, | ||||||
|  | 	ty: P<ast::Ty>, | ||||||
|  | 	span: Span, | ||||||
|  | 	variant_data: &ast::VariantData, | ||||||
|  | ) -> Result<BinaryExpressions, Error> { | ||||||
|  | 	match *variant_data { | ||||||
|  | 		ast::VariantData::Tuple(ref fields, _) => { | ||||||
|  | 			binary_expr_struct( | ||||||
|  | 				cx, | ||||||
|  | 				&builder, | ||||||
|  | 				ty, | ||||||
|  | 				fields, | ||||||
|  | 				Some(builder.id("self")), | ||||||
|  | 				None, | ||||||
|  | 			) | ||||||
|  | 		}, | ||||||
|  | 		ast::VariantData::Struct(ref fields, _) => { | ||||||
|  | 			binary_expr_struct( | ||||||
|  | 				cx, | ||||||
|  | 				&builder, | ||||||
|  | 				ty, | ||||||
|  | 				fields, | ||||||
|  | 				Some(builder.id("self")), | ||||||
|  | 				None, | ||||||
|  | 			) | ||||||
|  | 		}, | ||||||
|  | 		_ => { | ||||||
|  | 			cx.span_bug(span, | ||||||
|  | 				&format!("#[derive(Binary)] Unsupported struct content, expected tuple/struct, found: {:?}", | ||||||
|  | 					variant_data)); | ||||||
|  | 			Err(Error) | ||||||
|  | 		}, | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | fn binary_expr_enum( | ||||||
|  | 	cx: &ExtCtxt, | ||||||
|  | 	builder: &aster::AstBuilder, | ||||||
|  | 	type_ident: Ident, | ||||||
|  | 	impl_generics: &ast::Generics, | ||||||
|  | 	ty: P<ast::Ty>, | ||||||
|  | 	span: Span, | ||||||
|  | 	enum_def: &ast::EnumDef, | ||||||
|  | ) -> Result<BinaryExpressions, Error> { | ||||||
|  | 	let arms: Vec<_> = try!( | ||||||
|  | 		enum_def.variants.iter() | ||||||
|  | 			.enumerate() | ||||||
|  | 			.map(|(variant_index, variant)| { | ||||||
|  | 				binary_expr_variant( | ||||||
|  | 					cx, | ||||||
|  | 					builder, | ||||||
|  | 					type_ident, | ||||||
|  | 					impl_generics, | ||||||
|  | 					ty.clone(), | ||||||
|  | 					span, | ||||||
|  | 					variant, | ||||||
|  | 					variant_index, | ||||||
|  | 				) | ||||||
|  | 			}) | ||||||
|  | 			.collect() | ||||||
|  | 	); | ||||||
|  | 
 | ||||||
|  | 	let (size_arms, write_arms, mut read_arms) = ( | ||||||
|  | 		arms.iter().map(|x| x.size.clone()).collect::<Vec<ast::Arm>>(), | ||||||
|  | 		arms.iter().map(|x| x.write.clone()).collect::<Vec<ast::Arm>>(), | ||||||
|  | 		arms.iter().map(|x| x.read.clone()).collect::<Vec<ast::Arm>>()); | ||||||
|  | 
 | ||||||
|  | 	read_arms.push(quote_arm!(cx, _ => { Err(BinaryConvertError) } )); | ||||||
|  | 
 | ||||||
|  | 	Ok(BinaryExpressions { | ||||||
|  | 		size: quote_expr!(cx, 1usize + match *self { $size_arms }), | ||||||
|  | 		write: quote_expr!(cx, match *self { $write_arms }; ), | ||||||
|  | 		read: quote_expr!(cx, match buffer[0] { $read_arms }), | ||||||
|  | 	}) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | struct BinaryArm { | ||||||
|  | 	size: ast::Arm, | ||||||
|  | 	write: ast::Arm, | ||||||
|  | 	read: ast::Arm, | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | fn fields_sequence( | ||||||
|  | 	ext_cx: &ExtCtxt, | ||||||
|  | 	_ty: &P<ast::Ty>, | ||||||
|  | 	fields: &[ast::StructField], | ||||||
|  | 	variant_ident: &ast::Ident, | ||||||
|  | ) -> ast::Expr { | ||||||
|  | 	use syntax::parse::token; | ||||||
|  | 	use syntax::ast::TokenTree::Token; | ||||||
|  | 
 | ||||||
|  | 	::quasi::parse_expr_panic(&mut ::syntax::parse::new_parser_from_tts( | ||||||
|  | 		ext_cx.parse_sess(), | ||||||
|  | 		ext_cx.cfg(), | ||||||
|  | 		{ | ||||||
|  | 			let _sp = ext_cx.call_site(); | ||||||
|  | 			let mut tt = ::std::vec::Vec::new(); | ||||||
|  | 			tt.push(Token(_sp, token::Ident(variant_ident.clone(), token::Plain))); | ||||||
|  | 			tt.push(Token(_sp, token::OpenDelim(token::Paren))); | ||||||
|  | 
 | ||||||
|  | 			for (idx, field) in fields.iter().enumerate() { | ||||||
|  | 				if field.ident.is_some() { | ||||||
|  | 					tt.push(Token(_sp, token::Ident(field.ident.clone().unwrap(), token::Plain))); | ||||||
|  | 					tt.push(Token(_sp, token::Colon)); | ||||||
|  | 				} | ||||||
|  | 
 | ||||||
|  | 				tt.push(Token(_sp, token::Ident(ext_cx.ident_of("try!"), token::Plain))); | ||||||
|  | 				tt.push(Token(_sp, token::OpenDelim(token::Paren))); | ||||||
|  | 				tt.push(Token( | ||||||
|  | 					_sp, | ||||||
|  | 					token::Ident( | ||||||
|  | 						ext_cx.ident_of(&::syntax::print::pprust::ty_to_string(&field.ty)), | ||||||
|  | 						token::Plain))); | ||||||
|  | 				tt.push(Token(_sp, token::ModSep)); | ||||||
|  | 				tt.push(Token(_sp, token::Ident(ext_cx.ident_of("from_bytes"), token::Plain))); | ||||||
|  | 				tt.push(Token(_sp, token::OpenDelim(token::Paren))); | ||||||
|  | 
 | ||||||
|  | 				tt.push(Token(_sp, token::BinOp(token::And))); | ||||||
|  | 				tt.push(Token(_sp, token::Ident(ext_cx.ident_of("buffer"), token::Plain))); | ||||||
|  | 
 | ||||||
|  | 				tt.push(Token(_sp, token::OpenDelim(token::Bracket))); | ||||||
|  | 				tt.push(Token(_sp, token::Ident(ext_cx.ident_of("map"), token::Plain))); | ||||||
|  | 				tt.push(Token(_sp, token::OpenDelim(token::Bracket))); | ||||||
|  | 				tt.push(Token(_sp, token::Ident(ext_cx.ident_of(&format!("{}", idx)), token::Plain))); | ||||||
|  | 				tt.push(Token(_sp, token::CloseDelim(token::Bracket))); | ||||||
|  | 				tt.push(Token(_sp, token::DotDot)); | ||||||
|  | 
 | ||||||
|  | 				if idx+1 != fields.len() { | ||||||
|  | 					tt.push(Token(_sp, token::Ident(ext_cx.ident_of("map"), token::Plain))); | ||||||
|  | 					tt.push(Token(_sp, token::OpenDelim(token::Bracket))); | ||||||
|  | 					tt.push(Token(_sp, token::Ident(ext_cx.ident_of(&format!("{}", idx+1)), token::Plain))); | ||||||
|  | 					tt.push(Token(_sp, token::CloseDelim(token::Bracket))); | ||||||
|  | 				} | ||||||
|  | 
 | ||||||
|  | 				tt.push(Token(_sp, token::CloseDelim(token::Bracket))); | ||||||
|  | 
 | ||||||
|  | 				tt.push(Token(_sp, token::Comma)); | ||||||
|  | 				tt.push(Token(_sp, token::Ident(ext_cx.ident_of("length_stack"), token::Plain))); | ||||||
|  | 
 | ||||||
|  | 				tt.push(Token(_sp, token::CloseDelim(token::Paren))); | ||||||
|  | 				tt.push(Token(_sp, token::CloseDelim(token::Paren))); | ||||||
|  | 				tt.push(Token(_sp, token::Comma)); | ||||||
|  | 			} | ||||||
|  | 			tt.push(Token(_sp, token::CloseDelim(token::Paren))); | ||||||
|  | 
 | ||||||
|  | 			tt | ||||||
|  | 		}) | ||||||
|  | 	).unwrap() | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | fn named_fields_sequence( | ||||||
|  | 	ext_cx: &ExtCtxt, | ||||||
|  | 	ty: &P<ast::Ty>, | ||||||
|  | 	fields: &[ast::StructField], | ||||||
|  | ) -> ast::Stmt { | ||||||
|  | 	use syntax::parse::token; | ||||||
|  | 	use syntax::ast::TokenTree::Token; | ||||||
|  | 
 | ||||||
|  | 	::quasi::parse_stmt_panic(&mut ::syntax::parse::new_parser_from_tts( | ||||||
|  | 		ext_cx.parse_sess(), | ||||||
|  | 		ext_cx.cfg(), | ||||||
|  | 		{ | ||||||
|  | 			let _sp = ext_cx.call_site(); | ||||||
|  | 			let mut tt = ::std::vec::Vec::new(); | ||||||
|  | 			tt.push(Token(_sp, token::Ident(ext_cx.ident_of("let"), token::Plain))); | ||||||
|  | 			tt.push(Token(_sp, token::Ident(ext_cx.ident_of("result"), token::Plain))); | ||||||
|  | 			tt.push(Token(_sp, token::Eq)); | ||||||
|  | 
 | ||||||
|  | 			tt.push(Token( | ||||||
|  | 				_sp, | ||||||
|  | 			  	token::Ident( | ||||||
|  | 					ext_cx.ident_of(&::syntax::print::pprust::ty_to_string(ty)), | ||||||
|  | 			 		token::Plain))); | ||||||
|  | 
 | ||||||
|  | 			tt.push(Token(_sp, token::OpenDelim(token::Brace))); | ||||||
|  | 
 | ||||||
|  | 			for (idx, field) in fields.iter().enumerate() { | ||||||
|  | 				tt.push(Token(_sp, token::Ident(field.ident.clone().unwrap(), token::Plain))); | ||||||
|  | 				tt.push(Token(_sp, token::Colon)); | ||||||
|  | 
 | ||||||
|  | 				tt.push(Token(_sp, token::Ident(ext_cx.ident_of("try!"), token::Plain))); | ||||||
|  | 				tt.push(Token(_sp, token::OpenDelim(token::Paren))); | ||||||
|  | 				tt.push(Token( | ||||||
|  | 					_sp, | ||||||
|  | 					token::Ident( | ||||||
|  | 						ext_cx.ident_of(&::syntax::print::pprust::ty_to_string(&field.ty)), | ||||||
|  | 						token::Plain))); | ||||||
|  | 				tt.push(Token(_sp, token::ModSep)); | ||||||
|  | 				tt.push(Token(_sp, token::Ident(ext_cx.ident_of("from_bytes"), token::Plain))); | ||||||
|  | 				tt.push(Token(_sp, token::OpenDelim(token::Paren))); | ||||||
|  | 
 | ||||||
|  | 				tt.push(Token(_sp, token::BinOp(token::And))); | ||||||
|  | 				tt.push(Token(_sp, token::Ident(ext_cx.ident_of("buffer"), token::Plain))); | ||||||
|  | 
 | ||||||
|  | 				tt.push(Token(_sp, token::OpenDelim(token::Bracket))); | ||||||
|  | 				tt.push(Token(_sp, token::Ident(ext_cx.ident_of("map"), token::Plain))); | ||||||
|  | 				tt.push(Token(_sp, token::OpenDelim(token::Bracket))); | ||||||
|  | 				tt.push(Token(_sp, token::Ident(ext_cx.ident_of(&format!("{}", idx)), token::Plain))); | ||||||
|  | 				tt.push(Token(_sp, token::CloseDelim(token::Bracket))); | ||||||
|  | 				tt.push(Token(_sp, token::DotDot)); | ||||||
|  | 				if idx + 1 != fields.len() { | ||||||
|  | 					tt.push(Token(_sp, token::Ident(ext_cx.ident_of("map"), token::Plain))); | ||||||
|  | 					tt.push(Token(_sp, token::OpenDelim(token::Bracket))); | ||||||
|  | 					tt.push(Token(_sp, token::Ident(ext_cx.ident_of(&format!("{}", idx+1)), token::Plain))); | ||||||
|  | 					tt.push(Token(_sp, token::CloseDelim(token::Bracket))); | ||||||
|  | 				} | ||||||
|  | 
 | ||||||
|  | 				tt.push(Token(_sp, token::CloseDelim(token::Bracket))); | ||||||
|  | 
 | ||||||
|  | 				tt.push(Token(_sp, token::Comma)); | ||||||
|  | 				tt.push(Token(_sp, token::Ident(ext_cx.ident_of("length_stack"), token::Plain))); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 				tt.push(Token(_sp, token::CloseDelim(token::Paren))); | ||||||
|  | 				tt.push(Token(_sp, token::CloseDelim(token::Paren))); | ||||||
|  | 				tt.push(Token(_sp, token::Comma)); | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			tt.push(Token(_sp, token::CloseDelim(token::Brace))); | ||||||
|  | 			tt | ||||||
|  | 		}) | ||||||
|  | 	).unwrap() | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | fn binary_expr_variant( | ||||||
|  | 	cx: &ExtCtxt, | ||||||
|  | 	builder: &aster::AstBuilder, | ||||||
|  | 	type_ident: Ident, | ||||||
|  | 	_generics: &ast::Generics, | ||||||
|  | 	ty: P<ast::Ty>, | ||||||
|  | 	_span: Span, | ||||||
|  | 	variant: &ast::Variant, | ||||||
|  | 	variant_index: usize, | ||||||
|  | ) -> Result<BinaryArm, Error> { | ||||||
|  | 	let variant_ident = variant.node.name; | ||||||
|  | 	let variant_index_ident = builder.id(format!("{}", variant_index)); | ||||||
|  | 
 | ||||||
|  | 	match variant.node.data { | ||||||
|  | 		ast::VariantData::Unit(_) => { | ||||||
|  | 			let pat = builder.pat().path() | ||||||
|  | 				.id(type_ident).id(variant_ident) | ||||||
|  | 				.build(); | ||||||
|  | 
 | ||||||
|  | 			let variant_val = builder.id(format!("{}::{}", type_ident, variant_ident)); | ||||||
|  | 
 | ||||||
|  | 			Ok(BinaryArm { | ||||||
|  | 				size: quote_arm!(cx, $pat => { 0usize } ), | ||||||
|  | 				write: quote_arm!(cx, $pat => { buffer[0] = $variant_index_ident; Ok(()) } ), | ||||||
|  | 				read: quote_arm!(cx, $variant_index_ident => { Ok($variant_val) } ), | ||||||
|  | 			}) | ||||||
|  | 		}, | ||||||
|  | 		ast::VariantData::Tuple(ref fields, _) => { | ||||||
|  | 			let field_names: Vec<ast::Ident> = (0 .. fields.len()) | ||||||
|  | 				.map(|i| builder.id(format!("__field{}", i))) | ||||||
|  | 				.collect(); | ||||||
|  | 
 | ||||||
|  | 			let pat = builder.pat().enum_() | ||||||
|  | 				.id(type_ident).id(variant_ident).build() | ||||||
|  | 				.with_pats( | ||||||
|  | 					field_names.iter() | ||||||
|  | 						.map(|field| builder.pat().ref_id(field)) | ||||||
|  | 				) | ||||||
|  | 				.build(); | ||||||
|  | 
 | ||||||
|  | 			let binary_expr = try!(binary_expr_struct( | ||||||
|  | 				cx, | ||||||
|  | 				&builder, | ||||||
|  | 				ty, | ||||||
|  | 				fields, | ||||||
|  | 				None, | ||||||
|  | 				Some(builder.id(format!("{}::{}", type_ident, variant_ident))), | ||||||
|  | 			)); | ||||||
|  | 
 | ||||||
|  | 			let (size_expr, write_expr, read_expr) = (binary_expr.size, vec![binary_expr.write], binary_expr.read); | ||||||
|  | 			Ok(BinaryArm { | ||||||
|  | 				size: quote_arm!(cx, $pat => { $size_expr } ), | ||||||
|  | 				write: quote_arm!(cx, | ||||||
|  | 					$pat => { | ||||||
|  | 						buffer[0] = $variant_index_ident; | ||||||
|  | 						let buffer = &mut buffer[1..]; | ||||||
|  | 						$write_expr | ||||||
|  | 				}), | ||||||
|  | 				read: quote_arm!(cx, $variant_index_ident => { $read_expr } ), | ||||||
|  | 			}) | ||||||
|  | 		}, | ||||||
|  | 		ast::VariantData::Struct(ref fields, _) => { | ||||||
|  | 			let field_names: Vec<_> = (0 .. fields.len()) | ||||||
|  | 				.map(|i| builder.id(format!("__field{}", i))) | ||||||
|  | 				.collect(); | ||||||
|  | 
 | ||||||
|  | 			let pat = builder.pat().struct_() | ||||||
|  | 				.id(type_ident).id(variant_ident).build() | ||||||
|  | 				.with_pats( | ||||||
|  | 					field_names.iter() | ||||||
|  | 						.zip(fields.iter()) | ||||||
|  | 						.map(|(id, field)|(field.ident.unwrap(), builder.pat().ref_id(id)))) | ||||||
|  | 				.build(); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 			let binary_expr = try!(binary_expr_struct( | ||||||
|  | 				cx, | ||||||
|  | 				&builder, | ||||||
|  | 				ty, | ||||||
|  | 				fields, | ||||||
|  | 				None, | ||||||
|  | 				Some(builder.id(format!("{}::{}", type_ident, variant_ident))), | ||||||
|  | 			)); | ||||||
|  | 
 | ||||||
|  | 			let (size_expr, write_expr, read_expr) = (binary_expr.size, vec![binary_expr.write], binary_expr.read); | ||||||
|  | 
 | ||||||
|  | 			Ok(BinaryArm { | ||||||
|  | 				size: quote_arm!(cx, $pat => { $size_expr } ), | ||||||
|  | 				write: quote_arm!(cx, | ||||||
|  | 					$pat => { | ||||||
|  | 						buffer[0] = $variant_index_ident; | ||||||
|  | 						let buffer = &mut buffer[1..]; | ||||||
|  | 						$write_expr | ||||||
|  | 				}), | ||||||
|  | 				read: quote_arm!(cx, $pat => { $read_expr } ), | ||||||
|  | 			}) | ||||||
|  | 		}, | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @ -50,7 +50,8 @@ fn is_new_entry(path: &Path) -> Option<String> { | |||||||
| 			ident == "H256"      || | 			ident == "H256"      || | ||||||
| 			ident == "U256"      || | 			ident == "U256"      || | ||||||
| 			ident == "H2048"     || | 			ident == "H2048"     || | ||||||
| 			ident == "Address" | 			ident == "Address"   || | ||||||
|  | 			ident == "Bytes" | ||||||
| 		} | 		} | ||||||
| 	}; | 	}; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -10,3 +10,4 @@ license = "GPL-3.0" | |||||||
| ethcore-devtools = { path = "../../devtools" } | ethcore-devtools = { path = "../../devtools" } | ||||||
| semver = "0.2.0" | semver = "0.2.0" | ||||||
| nanomsg = { git = "https://github.com/ethcore/nanomsg.rs.git" } | nanomsg = { git = "https://github.com/ethcore/nanomsg.rs.git" } | ||||||
|  | ethcore-util = { path = "../../util" } | ||||||
|  | |||||||
							
								
								
									
										357
									
								
								ipc/rpc/src/binary.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										357
									
								
								ipc/rpc/src/binary.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,357 @@ | |||||||
|  | // Copyright 2015, 2016 Ethcore (UK) Ltd.
 | ||||||
|  | // This file is part of Parity.
 | ||||||
|  | 
 | ||||||
|  | // Parity is free software: you can redistribute it and/or modify
 | ||||||
|  | // it under the terms of the GNU General Public License as published by
 | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or
 | ||||||
|  | // (at your option) any later version.
 | ||||||
|  | 
 | ||||||
|  | // Parity is distributed in the hope that it will be useful,
 | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||||
|  | // GNU General Public License for more details.
 | ||||||
|  | 
 | ||||||
|  | // You should have received a copy of the GNU General Public License
 | ||||||
|  | // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
|  | 
 | ||||||
|  | //! Binary representation of types
 | ||||||
|  | 
 | ||||||
|  | use util::bytes::Populatable; | ||||||
|  | use std::mem; | ||||||
|  | use std::collections::VecDeque; | ||||||
|  | 
 | ||||||
|  | #[derive(Debug)] | ||||||
|  | pub struct BinaryConvertError; | ||||||
|  | 
 | ||||||
|  | pub trait BinaryConvertable : Sized { | ||||||
|  | 	fn size(&self) -> usize { | ||||||
|  | 		mem::size_of::<Self>() | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	fn to_bytes(&self, buffer: &mut [u8], length_stack: &mut VecDeque<usize>) -> Result<(), BinaryConvertError>; | ||||||
|  | 
 | ||||||
|  | 	fn from_bytes(buffer: &[u8], length_stack: &mut VecDeque<usize>) -> Result<Self, BinaryConvertError>; | ||||||
|  | 
 | ||||||
|  | 	fn from_empty_bytes() -> Result<Self, BinaryConvertError> { | ||||||
|  | 		Err(BinaryConvertError) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	fn len_params() -> usize { | ||||||
|  | 		0 | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | impl<T> BinaryConvertable for Option<T> where T: BinaryConvertable { | ||||||
|  | 	fn size(&self) -> usize { | ||||||
|  | 		match * self { None => 0, Some(ref val) => val.size() } | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	fn to_bytes(&self, buffer: &mut [u8], length_stack: &mut VecDeque<usize>) -> Result<(), BinaryConvertError> { | ||||||
|  | 		match *self { None => Err(BinaryConvertError), Some(ref val) => val.to_bytes(buffer, length_stack) } | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	fn from_bytes(buffer: &[u8], length_stack: &mut VecDeque<usize>) -> Result<Self, BinaryConvertError> { | ||||||
|  | 		Ok(Some(try!(T::from_bytes(buffer, length_stack)))) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	fn from_empty_bytes() -> Result<Self, BinaryConvertError> { | ||||||
|  | 		Ok(None) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	fn len_params() -> usize { | ||||||
|  | 		1 | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | impl<T> BinaryConvertable for Vec<T> where T: BinaryConvertable { | ||||||
|  | 	fn size(&self) -> usize { | ||||||
|  | 		match T::len_params() { | ||||||
|  | 			0 => mem::size_of::<T>() * self.len(), | ||||||
|  | 			_ => self.iter().fold(0usize, |acc, t| acc + t.size()), | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	fn to_bytes(&self, buffer: &mut [u8], length_stack: &mut VecDeque<usize>) -> Result<(), BinaryConvertError> { | ||||||
|  | 		let mut offset = 0usize; | ||||||
|  | 		for item in self.iter() { | ||||||
|  | 			let next_size = match T::len_params() { | ||||||
|  | 				0 => mem::size_of::<T>(), | ||||||
|  | 				_ => { let size = item.size(); length_stack.push_back(size); size }, | ||||||
|  | 			}; | ||||||
|  | 			if next_size > 0 { | ||||||
|  | 				let item_end = offset + next_size; | ||||||
|  | 				try!(item.to_bytes(&mut buffer[offset..item_end], length_stack)); | ||||||
|  | 				offset = item_end; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 		Ok(()) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	fn from_bytes(buffer: &[u8], length_stack: &mut VecDeque<usize>) -> Result<Self, BinaryConvertError> { | ||||||
|  | 		let mut index = 0; | ||||||
|  | 		let mut result = Self::with_capacity( | ||||||
|  | 			match T::len_params() { | ||||||
|  | 				0 => buffer.len() /  mem::size_of::<T>(), | ||||||
|  | 				_ => 128, | ||||||
|  | 			}); | ||||||
|  | 
 | ||||||
|  | 		loop { | ||||||
|  | 			let next_size = match T::len_params() { | ||||||
|  | 				0 => mem::size_of::<T>(), | ||||||
|  | 				_ => try!(length_stack.pop_front().ok_or(BinaryConvertError)), | ||||||
|  | 			}; | ||||||
|  | 			let item = if next_size == 0 { | ||||||
|  | 				try!(T::from_empty_bytes()) | ||||||
|  | 			} | ||||||
|  | 			else { | ||||||
|  | 				try!(T::from_bytes(&buffer[index..index+next_size], length_stack)) | ||||||
|  | 			}; | ||||||
|  | 			result.push(item); | ||||||
|  | 
 | ||||||
|  | 			index = index + next_size; | ||||||
|  | 			if index == buffer.len() { break; } | ||||||
|  | 			if index > buffer.len() { | ||||||
|  | 				return Err(BinaryConvertError) | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		Ok(result) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	fn from_empty_bytes() -> Result<Self, BinaryConvertError> { | ||||||
|  | 		Ok(Self::new()) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	fn len_params() -> usize { | ||||||
|  | 		1 | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | pub fn deserialize_from<T, R>(r: &mut R) -> Result<T, BinaryConvertError> | ||||||
|  | 	where R: ::std::io::Read, | ||||||
|  | 		T: BinaryConvertable | ||||||
|  | { | ||||||
|  | 	let mut fake_stack = VecDeque::new(); | ||||||
|  | 	let mut length_stack = VecDeque::<usize>::new(); | ||||||
|  | 	let mut size_buffer = [0u8; 8]; | ||||||
|  | 	try!(r.read(&mut size_buffer[..]).map_err(|_| BinaryConvertError)); | ||||||
|  | 	let stack_len = try!(u64::from_bytes(&mut size_buffer[..], &mut fake_stack)) as usize; | ||||||
|  | 	if stack_len > 0 { | ||||||
|  | 		let mut header_buffer = Vec::with_capacity(stack_len * 8); | ||||||
|  | 		unsafe {  header_buffer.set_len(stack_len * 8); }; | ||||||
|  | 
 | ||||||
|  | 		try!(r.read(&mut header_buffer[..]).map_err(|_| BinaryConvertError)); | ||||||
|  | 		for idx in 0..stack_len { | ||||||
|  | 			let stack_item = try!(u64::from_bytes(&header_buffer[idx*8..(idx+1)*8], &mut fake_stack)); | ||||||
|  | 			length_stack.push_back(stack_item as usize); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	try!(r.read(&mut size_buffer[..]).map_err(|_| BinaryConvertError)); | ||||||
|  | 	let size = try!(u64::from_bytes(&size_buffer[..], &mut fake_stack)) as usize; | ||||||
|  | 
 | ||||||
|  | 	let mut data = Vec::with_capacity(size); | ||||||
|  | 	unsafe { data.set_len(size) }; | ||||||
|  | 	try!(r.read(&mut data).map_err(|_| BinaryConvertError)); | ||||||
|  | 
 | ||||||
|  | 	T::from_bytes(&data[..], &mut length_stack) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | pub fn serialize_into<T, W>(t: &T, w: &mut W) -> Result<(), BinaryConvertError> | ||||||
|  | 	where W: ::std::io::Write, | ||||||
|  | 		T: BinaryConvertable | ||||||
|  | { | ||||||
|  | 	let mut length_stack = VecDeque::<usize>::new(); | ||||||
|  | 	let mut fake_stack = VecDeque::new(); | ||||||
|  | 	let mut size_buffer = [0u8; 8]; | ||||||
|  | 
 | ||||||
|  | 	let size = t.size(); | ||||||
|  | 	let mut buffer = Vec::with_capacity(size); | ||||||
|  | 	unsafe { buffer.set_len(size); } | ||||||
|  | 	try!(t.to_bytes(&mut buffer[..], &mut length_stack)); | ||||||
|  | 
 | ||||||
|  | 	let stack_len = length_stack.len(); | ||||||
|  | 	try!((stack_len as u64).to_bytes(&mut size_buffer[..], &mut fake_stack)); | ||||||
|  | 	try!(w.write(&size_buffer[..]).map_err(|_| BinaryConvertError)); | ||||||
|  | 	if stack_len > 0 { | ||||||
|  | 		let mut header_buffer = Vec::with_capacity(stack_len * 8); | ||||||
|  | 		unsafe {  header_buffer.set_len(stack_len * 8); }; | ||||||
|  | 		try!((stack_len as u64).to_bytes(&mut header_buffer[0..8], &mut fake_stack)); | ||||||
|  | 		let mut idx = 0; | ||||||
|  | 		loop { | ||||||
|  | 			match length_stack.pop_front() { | ||||||
|  | 				Some(val) => try!((val as u64).to_bytes(&mut header_buffer[idx * 8..(idx+1) * 8], &mut fake_stack)), | ||||||
|  | 				None => { break; } | ||||||
|  | 			} | ||||||
|  | 			idx = idx + 1; | ||||||
|  | 		} | ||||||
|  | 		try!(w.write(&header_buffer[..]).map_err(|_| BinaryConvertError)); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	try!((size as u64).to_bytes(&mut size_buffer[..], &mut fake_stack)); | ||||||
|  | 	try!(w.write(&size_buffer[..]).map_err(|_| BinaryConvertError)); | ||||||
|  | 
 | ||||||
|  | 	try!(w.write(&buffer[..]).map_err(|_| BinaryConvertError)); | ||||||
|  | 
 | ||||||
|  | 	Ok(()) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | macro_rules! binary_fixed_size { | ||||||
|  | 	($target_ty: ident) => { | ||||||
|  | 		impl BinaryConvertable for $target_ty { | ||||||
|  | 			fn from_bytes(bytes: &[u8], _length_stack: &mut VecDeque<usize>) -> Result<Self, BinaryConvertError> { | ||||||
|  | 				match bytes.len().cmp(&::std::mem::size_of::<$target_ty>()) { | ||||||
|  | 					::std::cmp::Ordering::Less => return Err(BinaryConvertError), | ||||||
|  | 					::std::cmp::Ordering::Greater => return Err(BinaryConvertError), | ||||||
|  | 					::std::cmp::Ordering::Equal => () | ||||||
|  | 				}; | ||||||
|  | 				let mut res: Self = unsafe { ::std::mem::uninitialized() }; | ||||||
|  | 				res.copy_raw(bytes); | ||||||
|  | 				Ok(res) | ||||||
|  | 			} | ||||||
|  | 
 | ||||||
|  | 			fn to_bytes(&self, buffer: &mut [u8], _length_stack: &mut VecDeque<usize>) -> Result<(), BinaryConvertError> { | ||||||
|  | 				let sz = ::std::mem::size_of::<$target_ty>(); | ||||||
|  | 				let ip: *const $target_ty = self; | ||||||
|  | 				let ptr: *const u8 = ip as *const _; | ||||||
|  | 				unsafe { | ||||||
|  | 					::std::ptr::copy(ptr, buffer.as_mut_ptr(), sz); | ||||||
|  | 				} | ||||||
|  | 				Ok(()) | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | binary_fixed_size!(u64); | ||||||
|  | binary_fixed_size!(u32); | ||||||
|  | binary_fixed_size!(bool); | ||||||
|  | 
 | ||||||
|  | #[test] | ||||||
|  | fn vec_serialize() { | ||||||
|  | 	let mut v = Vec::new(); | ||||||
|  | 	v.push(5u64); | ||||||
|  | 	v.push(10u64); | ||||||
|  | 	let mut length_stack = VecDeque::new(); | ||||||
|  | 	let mut data = Vec::with_capacity(v.size()); | ||||||
|  | 	unsafe { data.set_len(v.size()); } | ||||||
|  | 	let result = v.to_bytes(&mut data[..], &mut length_stack); | ||||||
|  | 
 | ||||||
|  | 	assert!(result.is_ok()); | ||||||
|  | 	assert_eq!(5, data[0]); | ||||||
|  | 	assert_eq!(0, data[1]); | ||||||
|  | 	assert_eq!(10, data[8]); | ||||||
|  | 	assert_eq!(0, data[12]); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[test] | ||||||
|  | fn calculates_size() { | ||||||
|  | 	let mut v = Vec::new(); | ||||||
|  | 	v.push(5u64); | ||||||
|  | 	v.push(10u64); | ||||||
|  | 
 | ||||||
|  | 	assert_eq!(16, v.size()); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[test] | ||||||
|  | fn vec_deserialize() { | ||||||
|  | 	let data = [ | ||||||
|  | 		10u8, 0u8, 0u8, 0u8, 0u8, 0u8, 0u8, 0u8, | ||||||
|  | 		5u8, 0u8, 0u8, 0u8, 0u8, 0u8, 0u8, 0u8, | ||||||
|  | 	]; | ||||||
|  | 
 | ||||||
|  | 	let mut length_stack = VecDeque::new(); | ||||||
|  | 	let vec = Vec::<u64>::from_bytes(&data[..], &mut length_stack).unwrap(); | ||||||
|  | 
 | ||||||
|  | 	assert_eq!(vec![10u64, 5u64], vec); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[test] | ||||||
|  | fn vec_deserialize_chained() { | ||||||
|  | 	let mut v = Vec::new(); | ||||||
|  | 	v.push(Some(5u64)); | ||||||
|  | 	v.push(Some(10u64)); | ||||||
|  | 	v.push(None); | ||||||
|  | 	v.push(Some(12u64)); | ||||||
|  | 
 | ||||||
|  | 	let mut length_stack = VecDeque::new(); | ||||||
|  | 	let mut data = Vec::with_capacity(v.size()); | ||||||
|  | 	unsafe { data.set_len(v.size()); } | ||||||
|  | 	let result = v.to_bytes(&mut data[..], &mut length_stack); | ||||||
|  | 
 | ||||||
|  | 	assert!(result.is_ok()); | ||||||
|  | 	assert_eq!(4, length_stack.len()); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[test] | ||||||
|  | fn vec_serialize_deserialize() { | ||||||
|  | 	let mut v = Vec::new(); | ||||||
|  | 	v.push(Some(5u64)); | ||||||
|  | 	v.push(None); | ||||||
|  | 	v.push(Some(10u64)); | ||||||
|  | 	v.push(None); | ||||||
|  | 	v.push(Some(12u64)); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 	let mut data = Vec::with_capacity(v.size()); | ||||||
|  | 	unsafe { data.set_len(v.size()); } | ||||||
|  | 	let mut length_stack = VecDeque::new(); | ||||||
|  | 
 | ||||||
|  | 	v.to_bytes(&mut data[..], &mut length_stack).unwrap(); | ||||||
|  | 	let de_v = Vec::<Option<u64>>::from_bytes(&data[..], &mut length_stack).unwrap(); | ||||||
|  | 
 | ||||||
|  | 	assert_eq!(v, de_v); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[test] | ||||||
|  | fn serialize_into_ok() { | ||||||
|  | 	use std::io::Cursor; | ||||||
|  |     let mut buff = Cursor::new(vec![0; 128]); | ||||||
|  | 
 | ||||||
|  | 	let mut v = Vec::new(); | ||||||
|  | 	v.push(Some(5u64)); | ||||||
|  | 	v.push(None); | ||||||
|  | 	v.push(Some(10u64)); | ||||||
|  | 	v.push(None); | ||||||
|  | 	v.push(Some(12u64)); | ||||||
|  | 
 | ||||||
|  | 	serialize_into(&v, &mut buff).unwrap(); | ||||||
|  | 	assert_eq!(5, buff.get_ref()[0]); | ||||||
|  | 	assert_eq!(8, buff.get_ref()[8]); | ||||||
|  | 	assert_eq!(0, buff.get_ref()[16]); | ||||||
|  | 	assert_eq!(8, buff.get_ref()[24]); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[test] | ||||||
|  | fn deserialize_from_ok() { | ||||||
|  | 	use std::io::Cursor; | ||||||
|  |     let mut buff = Cursor::new(vec![ | ||||||
|  | 		0u8, 0u8, 0u8, 0u8, 0u8, 0u8, 0u8, 0u8, | ||||||
|  | 		16u8, 0u8, 0u8, 0u8, 0u8, 0u8, 0u8, 0u8, | ||||||
|  | 		10u8, 0u8, 0u8, 0u8, 0u8, 0u8, 0u8, 0u8, | ||||||
|  | 		5u8, 0u8, 0u8, 0u8, 0u8, 0u8, 0u8, 0u8, | ||||||
|  | 	]); | ||||||
|  | 
 | ||||||
|  | 	let vec = deserialize_from::<Vec<u64>, _>(&mut buff).unwrap(); | ||||||
|  | 
 | ||||||
|  | 	assert_eq!(vec![10u64, 5u64], vec); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[test] | ||||||
|  | fn serialize_into_deserialize_from() { | ||||||
|  | 	use std::io::{Cursor, SeekFrom, Seek}; | ||||||
|  | 
 | ||||||
|  | 	let mut buff = Cursor::new(vec![0u8; 1024]); | ||||||
|  | 	let mut v = Vec::new(); | ||||||
|  | 	v.push(Some(5u64)); | ||||||
|  | 	v.push(None); | ||||||
|  | 	v.push(Some(10u64)); | ||||||
|  | 	v.push(None); | ||||||
|  | 	v.push(Some(12u64)); | ||||||
|  | 
 | ||||||
|  | 	serialize_into(&v, &mut buff).unwrap(); | ||||||
|  | 	buff.seek(SeekFrom::Start(0)).unwrap(); | ||||||
|  | 	let de_v = deserialize_from::<Vec<Option<u64>>, _>(&mut buff).unwrap(); | ||||||
|  | 	assert_eq!(v, de_v); | ||||||
|  | } | ||||||
| @ -19,6 +19,9 @@ | |||||||
| extern crate ethcore_devtools as devtools; | extern crate ethcore_devtools as devtools; | ||||||
| extern crate semver; | extern crate semver; | ||||||
| extern crate nanomsg; | extern crate nanomsg; | ||||||
|  | extern crate ethcore_util as util; | ||||||
| 
 | 
 | ||||||
| pub mod interface; | pub mod interface; | ||||||
|  | pub mod binary; | ||||||
| pub use interface::{IpcInterface, IpcSocket, invoke, IpcConfig, Handshake, Error, WithSocket}; | pub use interface::{IpcInterface, IpcSocket, invoke, IpcConfig, Handshake, Error, WithSocket}; | ||||||
|  | pub use binary::{BinaryConvertable, BinaryConvertError}; | ||||||
|  | |||||||
							
								
								
									
										19
									
								
								ipc/tests/binary.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								ipc/tests/binary.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,19 @@ | |||||||
|  | // Copyright 2015, 2016 Ethcore (UK) Ltd.
 | ||||||
|  | // This file is part of Parity.
 | ||||||
|  | 
 | ||||||
|  | // Parity is free software: you can redistribute it and/or modify
 | ||||||
|  | // it under the terms of the GNU General Public License as published by
 | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or
 | ||||||
|  | // (at your option) any later version.
 | ||||||
|  | 
 | ||||||
|  | // Parity is distributed in the hope that it will be useful,
 | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||||
|  | // GNU General Public License for more details.
 | ||||||
|  | 
 | ||||||
|  | // You should have received a copy of the GNU General Public License
 | ||||||
|  | // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
|  | 
 | ||||||
|  | #![allow(dead_code, unused_assignments, unused_variables)] // codegen issues
 | ||||||
|  | 
 | ||||||
|  | include!(concat!(env!("OUT_DIR"), "/binary.rs")); | ||||||
							
								
								
									
										38
									
								
								ipc/tests/binary.rs.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								ipc/tests/binary.rs.in
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,38 @@ | |||||||
|  | // Copyright 2015, 2016 Ethcore (UK) Ltd.
 | ||||||
|  | // This file is part of Parity.
 | ||||||
|  | 
 | ||||||
|  | // Parity is free software: you can redistribute it and/or modify
 | ||||||
|  | // it under the terms of the GNU General Public License as published by
 | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or
 | ||||||
|  | // (at your option) any later version.
 | ||||||
|  | 
 | ||||||
|  | // Parity is distributed in the hope that it will be useful,
 | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||||
|  | // GNU General Public License for more details.
 | ||||||
|  | 
 | ||||||
|  | // You should have received a copy of the GNU General Public License
 | ||||||
|  | // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | use ipc::*; | ||||||
|  | use std::mem; | ||||||
|  | use std::collections::VecDeque; | ||||||
|  | 
 | ||||||
|  | #[derive(Binary)] | ||||||
|  | pub enum Root { | ||||||
|  | 	Top, | ||||||
|  | 	Middle(u32, u64), | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[derive(Binary, PartialEq, Debug)] | ||||||
|  | pub struct DoubleRoot { | ||||||
|  | 	pub x1: u32, | ||||||
|  | 	pub x2: u64, | ||||||
|  | 	pub x3: u32, | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[derive(Binary, PartialEq, Debug)] | ||||||
|  | pub struct ReferenceStruct<'a> { | ||||||
|  | 	pub ref_data: &'a u64, | ||||||
|  | } | ||||||
| @ -60,4 +60,13 @@ pub fn main() { | |||||||
| 		registry.expand("", &src, &dst).unwrap(); | 		registry.expand("", &src, &dst).unwrap(); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  | 	// ipc pass
 | ||||||
|  | 	{ | ||||||
|  | 		let src = Path::new("binary.rs.in"); | ||||||
|  | 		let dst = Path::new(&out_dir).join("binary.rs"); | ||||||
|  | 		let mut registry = syntex::Registry::new(); | ||||||
|  | 		codegen::register(&mut registry); | ||||||
|  | 		registry.expand("", &src, &dst).unwrap(); | ||||||
|  | 	} | ||||||
| } | } | ||||||
|  | |||||||
| @ -18,6 +18,7 @@ | |||||||
| mod tests { | mod tests { | ||||||
| 
 | 
 | ||||||
| 	use super::super::service::*; | 	use super::super::service::*; | ||||||
|  | 	use super::super::binary::*; | ||||||
| 	use super::super::nested::{DBClient,DBWriter}; | 	use super::super::nested::{DBClient,DBWriter}; | ||||||
| 	use ipc::*; | 	use ipc::*; | ||||||
| 	use devtools::*; | 	use devtools::*; | ||||||
| @ -143,4 +144,19 @@ mod tests { | |||||||
| 
 | 
 | ||||||
| 		assert!(result.is_ok()); | 		assert!(result.is_ok()); | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	#[test] | ||||||
|  | 	fn can_serialize_dummy_structs() { | ||||||
|  | 		let mut socket = TestSocket::new(); | ||||||
|  | 
 | ||||||
|  | 		let struct_ = DoubleRoot { x1: 0, x2: 100, x3: 100000}; | ||||||
|  | 		let res = ::ipc::binary::serialize_into(&struct_, &mut socket); | ||||||
|  | 
 | ||||||
|  | 		assert!(res.is_ok()); | ||||||
|  | 
 | ||||||
|  | 		let mut read_socket = TestSocket::new_ready(socket.write_buffer.clone()); | ||||||
|  | 		let new_struct: DoubleRoot = ::ipc::binary::deserialize_from(&mut read_socket).unwrap(); | ||||||
|  | 
 | ||||||
|  | 		assert_eq!(struct_, new_struct); | ||||||
|  | 	} | ||||||
| } | } | ||||||
|  | |||||||
| @ -29,3 +29,4 @@ pub mod service; | |||||||
| mod examples; | mod examples; | ||||||
| mod over_nano; | mod over_nano; | ||||||
| mod nested; | mod nested; | ||||||
|  | mod binary; | ||||||
|  | |||||||
| @ -15,7 +15,7 @@ | |||||||
| // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
| 
 | 
 | ||||||
| use std::collections::HashMap; | use std::collections::HashMap; | ||||||
| use std::sync::RwLock; | use std::sync::{Arc, RwLock}; | ||||||
| use util::numbers::U256; | use util::numbers::U256; | ||||||
| use util::hash::H256; | use util::hash::H256; | ||||||
| 
 | 
 | ||||||
| @ -33,13 +33,22 @@ pub trait ExternalMinerService: Send + Sync { | |||||||
| 
 | 
 | ||||||
| /// External Miner.
 | /// External Miner.
 | ||||||
| pub struct ExternalMiner { | pub struct ExternalMiner { | ||||||
| 	hashrates: RwLock<HashMap<H256, U256>>, | 	hashrates: Arc<RwLock<HashMap<H256, U256>>>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl Default for ExternalMiner { | impl Default for ExternalMiner { | ||||||
| 	fn default() -> Self { | 	fn default() -> Self { | ||||||
| 		ExternalMiner { | 		ExternalMiner { | ||||||
| 			hashrates: RwLock::new(HashMap::new()), | 			hashrates: Arc::new(RwLock::new(HashMap::new())), | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | impl ExternalMiner { | ||||||
|  | 	/// Creates new external miner with prefilled hashrates.
 | ||||||
|  | 	pub fn new(hashrates: Arc<RwLock<HashMap<H256, U256>>>) -> Self { | ||||||
|  | 		ExternalMiner { | ||||||
|  | 			hashrates: hashrates | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| @ -57,3 +66,43 @@ impl ExternalMinerService for ExternalMiner { | |||||||
| 		!self.hashrates.read().unwrap().is_empty() | 		!self.hashrates.read().unwrap().is_empty() | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | #[cfg(test)] | ||||||
|  | mod tests { | ||||||
|  | 	use super::*; | ||||||
|  | 	use util::{H256, U256}; | ||||||
|  | 
 | ||||||
|  | 	fn miner() -> ExternalMiner { | ||||||
|  | 		ExternalMiner::default() | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	#[test] | ||||||
|  | 	fn should_return_that_is_mining_if_there_is_at_least_one_entry() { | ||||||
|  | 		// given
 | ||||||
|  | 		let m = miner(); | ||||||
|  | 		assert_eq!(m.is_mining(), false); | ||||||
|  | 
 | ||||||
|  | 		// when
 | ||||||
|  | 		m.submit_hashrate(U256::from(10), H256::from(1)); | ||||||
|  | 
 | ||||||
|  | 		// then
 | ||||||
|  | 		assert_eq!(m.is_mining(), true); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	#[test] | ||||||
|  | 	fn should_sum_up_hashrate() { | ||||||
|  | 		// given
 | ||||||
|  | 		let m = miner(); | ||||||
|  | 		assert_eq!(m.hashrate(), U256::from(0)); | ||||||
|  | 		m.submit_hashrate(U256::from(10), H256::from(1)); | ||||||
|  | 		assert_eq!(m.hashrate(), U256::from(10)); | ||||||
|  | 
 | ||||||
|  | 		// when
 | ||||||
|  | 		m.submit_hashrate(U256::from(15), H256::from(1)); | ||||||
|  | 		m.submit_hashrate(U256::from(20), H256::from(2)); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 		// then
 | ||||||
|  | 		assert_eq!(m.hashrate(), U256::from(35)); | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @ -27,19 +27,13 @@ | |||||||
| //! extern crate ethcore_util as util;
 | //! extern crate ethcore_util as util;
 | ||||||
| //! extern crate ethcore;
 | //! extern crate ethcore;
 | ||||||
| //! extern crate ethminer;
 | //! extern crate ethminer;
 | ||||||
| //! use std::ops::Deref;
 |  | ||||||
| //! use std::env;
 | //! use std::env;
 | ||||||
| //! use std::sync::Arc;
 |  | ||||||
| //! use util::network::{NetworkService, NetworkConfiguration};
 | //! use util::network::{NetworkService, NetworkConfiguration};
 | ||||||
| //! use ethcore::client::{Client, ClientConfig, BlockChainClient};
 | //! use ethcore::client::{Client, ClientConfig};
 | ||||||
| //! use ethcore::ethereum;
 | //! use ethcore::ethereum;
 | ||||||
| //! use ethminer::{Miner, MinerService};
 | //! use ethminer::{Miner, MinerService};
 | ||||||
| //!
 | //!
 | ||||||
| //! fn main() {
 | //! fn main() {
 | ||||||
| //! 	let mut service = NetworkService::start(NetworkConfiguration::new()).unwrap();
 |  | ||||||
| //! 	let dir = env::temp_dir();
 |  | ||||||
| //! 	let client = Client::new(ClientConfig::default(), ethereum::new_frontier(), &dir, service.io().channel());
 |  | ||||||
| //!
 |  | ||||||
| //!		let miner: Miner = Miner::default();
 | //!		let miner: Miner = Miner::default();
 | ||||||
| //!		// get status
 | //!		// get status
 | ||||||
| //!		assert_eq!(miner.status().transactions_in_pending_queue, 0);
 | //!		assert_eq!(miner.status().transactions_in_pending_queue, 0);
 | ||||||
| @ -59,10 +53,12 @@ extern crate env_logger; | |||||||
| extern crate rayon; | extern crate rayon; | ||||||
| 
 | 
 | ||||||
| mod miner; | mod miner; | ||||||
|  | mod external; | ||||||
| mod transaction_queue; | mod transaction_queue; | ||||||
| 
 | 
 | ||||||
| pub use transaction_queue::{TransactionQueue, AccountDetails, TransactionImportResult}; | pub use transaction_queue::{TransactionQueue, AccountDetails, TransactionImportResult}; | ||||||
| pub use miner::{Miner}; | pub use miner::{Miner}; | ||||||
|  | pub use external::{ExternalMiner, ExternalMinerService}; | ||||||
| 
 | 
 | ||||||
| use util::{H256, U256, Address, Bytes}; | use util::{H256, U256, Address, Bytes}; | ||||||
| use ethcore::client::{BlockChainClient}; | use ethcore::client::{BlockChainClient}; | ||||||
|  | |||||||
| @ -577,6 +577,7 @@ impl TransactionQueue { | |||||||
| 	/// Checks if there are any transactions in `future` that should actually be promoted to `current`
 | 	/// Checks if there are any transactions in `future` that should actually be promoted to `current`
 | ||||||
| 	/// (because nonce matches).
 | 	/// (because nonce matches).
 | ||||||
| 	fn move_matching_future_to_current(&mut self, address: Address, mut current_nonce: U256, first_nonce: U256) { | 	fn move_matching_future_to_current(&mut self, address: Address, mut current_nonce: U256, first_nonce: U256) { | ||||||
|  | 		let mut update_last_nonce_to = None; | ||||||
| 		{ | 		{ | ||||||
| 			let by_nonce = self.future.by_address.row_mut(&address); | 			let by_nonce = self.future.by_address.row_mut(&address); | ||||||
| 			if let None = by_nonce { | 			if let None = by_nonce { | ||||||
| @ -589,12 +590,15 @@ impl TransactionQueue { | |||||||
| 				// Put to current
 | 				// Put to current
 | ||||||
| 				let order = order.update_height(current_nonce, first_nonce); | 				let order = order.update_height(current_nonce, first_nonce); | ||||||
| 				self.current.insert(address, current_nonce, order); | 				self.current.insert(address, current_nonce, order); | ||||||
|  | 				update_last_nonce_to = Some(current_nonce); | ||||||
| 				current_nonce = current_nonce + U256::one(); | 				current_nonce = current_nonce + U256::one(); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		self.future.by_address.clear_if_empty(&address); | 		self.future.by_address.clear_if_empty(&address); | ||||||
| 		// Update last inserted nonce
 | 		if let Some(x) = update_last_nonce_to { | ||||||
| 		self.last_nonces.insert(address, current_nonce - U256::one()); | 			// Update last inserted nonce
 | ||||||
|  | 			self.last_nonces.insert(address, x); | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	/// Adds VerifiedTransaction to this queue.
 | 	/// Adds VerifiedTransaction to this queue.
 | ||||||
| @ -1457,4 +1461,29 @@ mod test { | |||||||
| 		// then
 | 		// then
 | ||||||
| 		assert!(txq.top_transactions().is_empty()); | 		assert!(txq.top_transactions().is_empty()); | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	#[test] | ||||||
|  | 	fn should_return_valid_last_nonce_after_remove_all() { | ||||||
|  | 		// given
 | ||||||
|  | 		let mut txq = TransactionQueue::new(); | ||||||
|  | 		let (tx1, tx2) = new_txs(U256::from(4)); | ||||||
|  | 		let sender = tx1.sender().unwrap(); | ||||||
|  | 		let (nonce1, nonce2) = (tx1.nonce, tx2.nonce); | ||||||
|  | 		let details1 = |_a: &Address| AccountDetails { nonce: nonce1, balance: !U256::zero() }; | ||||||
|  | 
 | ||||||
|  | 		// when
 | ||||||
|  | 		// Insert first transaction
 | ||||||
|  | 		assert_eq!(txq.add(tx1, &details1).unwrap(), TransactionImportResult::Current); | ||||||
|  | 		// Second should go to future
 | ||||||
|  | 		assert_eq!(txq.add(tx2, &details1).unwrap(), TransactionImportResult::Future); | ||||||
|  | 		// Now block is imported
 | ||||||
|  | 		txq.remove_all(sender, nonce2 - U256::from(1)); | ||||||
|  | 		// tx2 should be not be promoted to current
 | ||||||
|  | 		assert_eq!(txq.status().pending, 0); | ||||||
|  | 		assert_eq!(txq.status().future, 1); | ||||||
|  | 
 | ||||||
|  | 		// then
 | ||||||
|  | 		assert_eq!(txq.last_nonce(&sender), None); | ||||||
|  | 
 | ||||||
|  | 	} | ||||||
| } | } | ||||||
|  | |||||||
| @ -69,7 +69,7 @@ use util::*; | |||||||
| use util::panics::{MayPanic, ForwardPanic, PanicHandler}; | use util::panics::{MayPanic, ForwardPanic, PanicHandler}; | ||||||
| use ethcore::service::ClientService; | use ethcore::service::ClientService; | ||||||
| use ethsync::EthSync; | use ethsync::EthSync; | ||||||
| use ethminer::{Miner, MinerService}; | use ethminer::{Miner, MinerService, ExternalMiner}; | ||||||
| use daemonize::Daemonize; | use daemonize::Daemonize; | ||||||
| 
 | 
 | ||||||
| use die::*; | use die::*; | ||||||
| @ -153,6 +153,7 @@ fn execute_client(conf: Configuration) { | |||||||
| 	miner.set_minimal_gas_price(conf.gas_price()); | 	miner.set_minimal_gas_price(conf.gas_price()); | ||||||
| 	miner.set_transactions_limit(conf.args.flag_tx_limit); | 	miner.set_transactions_limit(conf.args.flag_tx_limit); | ||||||
| 
 | 
 | ||||||
|  | 	let external_miner = Arc::new(ExternalMiner::default()); | ||||||
| 	let network_settings = Arc::new(conf.network_settings()); | 	let network_settings = Arc::new(conf.network_settings()); | ||||||
| 
 | 
 | ||||||
| 	// Sync
 | 	// Sync
 | ||||||
| @ -171,6 +172,7 @@ fn execute_client(conf: Configuration) { | |||||||
| 		sync: sync.clone(), | 		sync: sync.clone(), | ||||||
| 		secret_store: account_service.clone(), | 		secret_store: account_service.clone(), | ||||||
| 		miner: miner.clone(), | 		miner: miner.clone(), | ||||||
|  | 		external_miner: external_miner.clone(), | ||||||
| 		logger: logger.clone(), | 		logger: logger.clone(), | ||||||
| 		settings: network_settings.clone(), | 		settings: network_settings.clone(), | ||||||
| 	}); | 	}); | ||||||
| @ -187,6 +189,7 @@ fn execute_client(conf: Configuration) { | |||||||
| 		sync: sync.clone(), | 		sync: sync.clone(), | ||||||
| 		secret_store: account_service.clone(), | 		secret_store: account_service.clone(), | ||||||
| 		miner: miner.clone(), | 		miner: miner.clone(), | ||||||
|  | 		external_miner: external_miner.clone(), | ||||||
| 		logger: logger.clone(), | 		logger: logger.clone(), | ||||||
| 		settings: network_settings.clone(), | 		settings: network_settings.clone(), | ||||||
| 	}); | 	}); | ||||||
|  | |||||||
| @ -20,7 +20,7 @@ use std::sync::Arc; | |||||||
| use std::net::SocketAddr; | use std::net::SocketAddr; | ||||||
| use ethcore::client::Client; | use ethcore::client::Client; | ||||||
| use ethsync::EthSync; | use ethsync::EthSync; | ||||||
| use ethminer::Miner; | use ethminer::{Miner, ExternalMiner}; | ||||||
| use util::RotatingLogger; | use util::RotatingLogger; | ||||||
| use util::panics::PanicHandler; | use util::panics::PanicHandler; | ||||||
| use util::keys::store::{AccountService}; | use util::keys::store::{AccountService}; | ||||||
| @ -48,6 +48,7 @@ pub struct Dependencies { | |||||||
| 	pub sync: Arc<EthSync>, | 	pub sync: Arc<EthSync>, | ||||||
| 	pub secret_store: Arc<AccountService>, | 	pub secret_store: Arc<AccountService>, | ||||||
| 	pub miner: Arc<Miner>, | 	pub miner: Arc<Miner>, | ||||||
|  | 	pub external_miner: Arc<ExternalMiner>, | ||||||
| 	pub logger: Arc<RotatingLogger>, | 	pub logger: Arc<RotatingLogger>, | ||||||
| 	pub settings: Arc<NetworkSettings>, | 	pub settings: Arc<NetworkSettings>, | ||||||
| } | } | ||||||
| @ -94,7 +95,7 @@ pub fn setup_rpc_server( | |||||||
| 			"web3" => server.add_delegate(Web3Client::new().to_delegate()), | 			"web3" => server.add_delegate(Web3Client::new().to_delegate()), | ||||||
| 			"net" => server.add_delegate(NetClient::new(&deps.sync).to_delegate()), | 			"net" => server.add_delegate(NetClient::new(&deps.sync).to_delegate()), | ||||||
| 			"eth" => { | 			"eth" => { | ||||||
| 				server.add_delegate(EthClient::new(&deps.client, &deps.sync, &deps.secret_store, &deps.miner).to_delegate()); | 				server.add_delegate(EthClient::new(&deps.client, &deps.sync, &deps.secret_store, &deps.miner, &deps.external_miner).to_delegate()); | ||||||
| 				server.add_delegate(EthFilterClient::new(&deps.client, &deps.miner).to_delegate()); | 				server.add_delegate(EthFilterClient::new(&deps.client, &deps.miner).to_delegate()); | ||||||
| 			}, | 			}, | ||||||
| 			"personal" => server.add_delegate(PersonalClient::new(&deps.secret_store).to_delegate()), | 			"personal" => server.add_delegate(PersonalClient::new(&deps.secret_store).to_delegate()), | ||||||
|  | |||||||
| @ -19,7 +19,7 @@ use std::str::FromStr; | |||||||
| use std::net::SocketAddr; | use std::net::SocketAddr; | ||||||
| use ethcore::client::Client; | use ethcore::client::Client; | ||||||
| use ethsync::EthSync; | use ethsync::EthSync; | ||||||
| use ethminer::Miner; | use ethminer::{Miner, ExternalMiner}; | ||||||
| use util::RotatingLogger; | use util::RotatingLogger; | ||||||
| use util::panics::PanicHandler; | use util::panics::PanicHandler; | ||||||
| use util::keys::store::{AccountService}; | use util::keys::store::{AccountService}; | ||||||
| @ -45,6 +45,7 @@ pub struct Dependencies { | |||||||
| 	pub sync: Arc<EthSync>, | 	pub sync: Arc<EthSync>, | ||||||
| 	pub secret_store: Arc<AccountService>, | 	pub secret_store: Arc<AccountService>, | ||||||
| 	pub miner: Arc<Miner>, | 	pub miner: Arc<Miner>, | ||||||
|  | 	pub external_miner: Arc<ExternalMiner>, | ||||||
| 	pub logger: Arc<RotatingLogger>, | 	pub logger: Arc<RotatingLogger>, | ||||||
| 	pub settings: Arc<NetworkSettings>, | 	pub settings: Arc<NetworkSettings>, | ||||||
| } | } | ||||||
| @ -97,7 +98,7 @@ pub fn setup_webapp_server( | |||||||
| 	let server = webapp::ServerBuilder::new(); | 	let server = webapp::ServerBuilder::new(); | ||||||
| 	server.add_delegate(Web3Client::new().to_delegate()); | 	server.add_delegate(Web3Client::new().to_delegate()); | ||||||
| 	server.add_delegate(NetClient::new(&deps.sync).to_delegate()); | 	server.add_delegate(NetClient::new(&deps.sync).to_delegate()); | ||||||
| 	server.add_delegate(EthClient::new(&deps.client, &deps.sync, &deps.secret_store, &deps.miner).to_delegate()); | 	server.add_delegate(EthClient::new(&deps.client, &deps.sync, &deps.secret_store, &deps.miner, &deps.external_miner).to_delegate()); | ||||||
| 	server.add_delegate(EthFilterClient::new(&deps.client, &deps.miner).to_delegate()); | 	server.add_delegate(EthFilterClient::new(&deps.client, &deps.miner).to_delegate()); | ||||||
| 	server.add_delegate(PersonalClient::new(&deps.secret_store).to_delegate()); | 	server.add_delegate(PersonalClient::new(&deps.secret_store).to_delegate()); | ||||||
| 	server.add_delegate(EthcoreClient::new(&deps.miner, deps.logger.clone(), deps.settings.clone()).to_delegate()); | 	server.add_delegate(EthcoreClient::new(&deps.miner, deps.logger.clone(), deps.settings.clone()).to_delegate()); | ||||||
|  | |||||||
| @ -16,8 +16,6 @@ | |||||||
| 
 | 
 | ||||||
| mod poll_manager; | mod poll_manager; | ||||||
| mod poll_filter; | mod poll_filter; | ||||||
| pub mod external_miner; |  | ||||||
| 
 | 
 | ||||||
| pub use self::poll_manager::PollManager; | pub use self::poll_manager::PollManager; | ||||||
| pub use self::poll_filter::PollFilter; | pub use self::poll_filter::PollFilter; | ||||||
| pub use self::external_miner::{ExternalMinerService, ExternalMiner}; |  | ||||||
|  | |||||||
| @ -22,7 +22,7 @@ use std::collections::HashSet; | |||||||
| use std::sync::{Arc, Weak, Mutex}; | use std::sync::{Arc, Weak, Mutex}; | ||||||
| use std::ops::Deref; | use std::ops::Deref; | ||||||
| use ethsync::{SyncProvider, SyncState}; | use ethsync::{SyncProvider, SyncState}; | ||||||
| use ethminer::{MinerService, AccountDetails}; | use ethminer::{MinerService, AccountDetails, ExternalMinerService}; | ||||||
| use jsonrpc_core::*; | use jsonrpc_core::*; | ||||||
| use util::numbers::*; | use util::numbers::*; | ||||||
| use util::sha3::*; | use util::sha3::*; | ||||||
| @ -36,12 +36,12 @@ use ethcore::transaction::{Transaction as EthTransaction, SignedTransaction, Act | |||||||
| use self::ethash::SeedHashCompute; | use self::ethash::SeedHashCompute; | ||||||
| use v1::traits::{Eth, EthFilter}; | use v1::traits::{Eth, EthFilter}; | ||||||
| use v1::types::{Block, BlockTransactions, BlockNumber, Bytes, SyncStatus, SyncInfo, Transaction, TransactionRequest, CallRequest, OptionalValue, Index, Filter, Log, Receipt}; | use v1::types::{Block, BlockTransactions, BlockNumber, Bytes, SyncStatus, SyncInfo, Transaction, TransactionRequest, CallRequest, OptionalValue, Index, Filter, Log, Receipt}; | ||||||
| use v1::helpers::{PollFilter, PollManager, ExternalMinerService, ExternalMiner}; | use v1::helpers::{PollFilter, PollManager}; | ||||||
| use util::keys::store::AccountProvider; | use util::keys::store::AccountProvider; | ||||||
| use serde; | use serde; | ||||||
| 
 | 
 | ||||||
| /// Eth rpc implementation.
 | /// Eth rpc implementation.
 | ||||||
| pub struct EthClient<C, S, A, M, EM = ExternalMiner> | pub struct EthClient<C, S, A, M, EM> | ||||||
| 	where C: BlockChainClient, | 	where C: BlockChainClient, | ||||||
| 		  S: SyncProvider, | 		  S: SyncProvider, | ||||||
| 		  A: AccountProvider, | 		  A: AccountProvider, | ||||||
| @ -51,22 +51,10 @@ pub struct EthClient<C, S, A, M, EM = ExternalMiner> | |||||||
| 	sync: Weak<S>, | 	sync: Weak<S>, | ||||||
| 	accounts: Weak<A>, | 	accounts: Weak<A>, | ||||||
| 	miner: Weak<M>, | 	miner: Weak<M>, | ||||||
| 	external_miner: EM, | 	external_miner: Arc<EM>, | ||||||
| 	seed_compute: Mutex<SeedHashCompute>, | 	seed_compute: Mutex<SeedHashCompute>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl<C, S, A, M> EthClient<C, S, A, M, ExternalMiner> |  | ||||||
| 	where C: BlockChainClient, |  | ||||||
| 		  S: SyncProvider, |  | ||||||
| 		  A: AccountProvider, |  | ||||||
| 		  M: MinerService { |  | ||||||
| 
 |  | ||||||
| 	/// Creates new EthClient.
 |  | ||||||
| 	pub fn new(client: &Arc<C>, sync: &Arc<S>, accounts: &Arc<A>, miner: &Arc<M>) -> Self { |  | ||||||
| 		EthClient::new_with_external_miner(client, sync, accounts, miner, ExternalMiner::default()) |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| impl<C, S, A, M, EM> EthClient<C, S, A, M, EM> | impl<C, S, A, M, EM> EthClient<C, S, A, M, EM> | ||||||
| 	where C: BlockChainClient, | 	where C: BlockChainClient, | ||||||
| 		  S: SyncProvider, | 		  S: SyncProvider, | ||||||
| @ -74,15 +62,15 @@ impl<C, S, A, M, EM> EthClient<C, S, A, M, EM> | |||||||
| 		  M: MinerService, | 		  M: MinerService, | ||||||
| 		  EM: ExternalMinerService { | 		  EM: ExternalMinerService { | ||||||
| 
 | 
 | ||||||
| 	/// Creates new EthClient with custom external miner.
 | 	/// Creates new EthClient.
 | ||||||
| 	pub fn new_with_external_miner(client: &Arc<C>, sync: &Arc<S>, accounts: &Arc<A>, miner: &Arc<M>, em: EM) | 	pub fn new(client: &Arc<C>, sync: &Arc<S>, accounts: &Arc<A>, miner: &Arc<M>, em: &Arc<EM>) | ||||||
| 		-> EthClient<C, S, A, M, EM> { | 		-> EthClient<C, S, A, M, EM> { | ||||||
| 		EthClient { | 		EthClient { | ||||||
| 			client: Arc::downgrade(client), | 			client: Arc::downgrade(client), | ||||||
| 			sync: Arc::downgrade(sync), | 			sync: Arc::downgrade(sync), | ||||||
| 			miner: Arc::downgrade(miner), | 			miner: Arc::downgrade(miner), | ||||||
| 			accounts: Arc::downgrade(accounts), | 			accounts: Arc::downgrade(accounts), | ||||||
| 			external_miner: em, | 			external_miner: em.clone(), | ||||||
| 			seed_compute: Mutex::new(SeedHashCompute::new()), | 			seed_compute: Mutex::new(SeedHashCompute::new()), | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -24,8 +24,9 @@ use ethcore::client::{TestBlockChainClient, EachBlockWith, Executed, Transaction | |||||||
| use ethcore::log_entry::{LocalizedLogEntry, LogEntry}; | use ethcore::log_entry::{LocalizedLogEntry, LogEntry}; | ||||||
| use ethcore::receipt::LocalizedReceipt; | use ethcore::receipt::LocalizedReceipt; | ||||||
| use ethcore::transaction::{Transaction, Action}; | use ethcore::transaction::{Transaction, Action}; | ||||||
|  | use ethminer::ExternalMiner; | ||||||
| use v1::{Eth, EthClient}; | use v1::{Eth, EthClient}; | ||||||
| use v1::tests::helpers::{TestAccount, TestAccountProvider, TestSyncProvider, Config, TestMinerService, TestExternalMiner}; | use v1::tests::helpers::{TestAccount, TestAccountProvider, TestSyncProvider, Config, TestMinerService}; | ||||||
| 
 | 
 | ||||||
| fn blockchain_client() -> Arc<TestBlockChainClient> { | fn blockchain_client() -> Arc<TestBlockChainClient> { | ||||||
| 	let client = TestBlockChainClient::new(); | 	let client = TestBlockChainClient::new(); | ||||||
| @ -66,8 +67,8 @@ impl Default for EthTester { | |||||||
| 		let ap = accounts_provider(); | 		let ap = accounts_provider(); | ||||||
| 		let miner = miner_service(); | 		let miner = miner_service(); | ||||||
| 		let hashrates = Arc::new(RwLock::new(HashMap::new())); | 		let hashrates = Arc::new(RwLock::new(HashMap::new())); | ||||||
| 		let external_miner = TestExternalMiner::new(hashrates.clone()); | 		let external_miner = Arc::new(ExternalMiner::new(hashrates.clone())); | ||||||
| 		let eth = EthClient::new_with_external_miner(&client, &sync, &ap, &miner, external_miner).to_delegate(); | 		let eth = EthClient::new(&client, &sync, &ap, &miner, &external_miner).to_delegate(); | ||||||
| 		let io = IoHandler::new(); | 		let io = IoHandler::new(); | ||||||
| 		io.add_delegate(eth); | 		io.add_delegate(eth); | ||||||
| 		EthTester { | 		EthTester { | ||||||
|  | |||||||
| @ -1,50 +0,0 @@ | |||||||
| // Copyright 2015, 2016 Ethcore (UK) Ltd.
 |  | ||||||
| // This file is part of Parity.
 |  | ||||||
| 
 |  | ||||||
| // Parity is free software: you can redistribute it and/or modify
 |  | ||||||
| // it under the terms of the GNU General Public License as published by
 |  | ||||||
| // the Free Software Foundation, either version 3 of the License, or
 |  | ||||||
| // (at your option) any later version.
 |  | ||||||
| 
 |  | ||||||
| // Parity is distributed in the hope that it will be useful,
 |  | ||||||
| // but WITHOUT ANY WARRANTY; without even the implied warranty of
 |  | ||||||
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 |  | ||||||
| // GNU General Public License for more details.
 |  | ||||||
| 
 |  | ||||||
| // You should have received a copy of the GNU General Public License
 |  | ||||||
| // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 |  | ||||||
| 
 |  | ||||||
| use std::collections::HashMap; |  | ||||||
| use std::sync::{Arc, RwLock}; |  | ||||||
| use util::numbers::U256; |  | ||||||
| use util::hash::H256; |  | ||||||
| use v1::helpers::ExternalMinerService; |  | ||||||
| 
 |  | ||||||
| /// Test ExternalMinerService;
 |  | ||||||
| pub struct TestExternalMiner { |  | ||||||
| 	/// External miners hashrates.
 |  | ||||||
| 	pub hashrates: Arc<RwLock<HashMap<H256, U256>>> |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| impl TestExternalMiner { |  | ||||||
| 	/// Creates new external miner.
 |  | ||||||
| 	pub fn new(hashrates: Arc<RwLock<HashMap<H256, U256>>>) -> Self { |  | ||||||
| 		TestExternalMiner { |  | ||||||
| 			hashrates: hashrates, |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| impl ExternalMinerService for TestExternalMiner { |  | ||||||
| 	fn submit_hashrate(&self, hashrate: U256, id: H256) { |  | ||||||
| 		self.hashrates.write().unwrap().insert(id, hashrate); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	fn hashrate(&self) -> U256 { |  | ||||||
| 		self.hashrates.read().unwrap().iter().fold(U256::from(0), |sum, (_, v)| sum + *v) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	fn is_mining(&self) -> bool { |  | ||||||
| 		!self.hashrates.read().unwrap().is_empty() |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| @ -19,9 +19,7 @@ | |||||||
| mod account_provider; | mod account_provider; | ||||||
| mod sync_provider; | mod sync_provider; | ||||||
| mod miner_service; | mod miner_service; | ||||||
| mod external_miner; |  | ||||||
| 
 | 
 | ||||||
| pub use self::account_provider::{TestAccount, TestAccountProvider}; | pub use self::account_provider::{TestAccount, TestAccountProvider}; | ||||||
| pub use self::sync_provider::{Config, TestSyncProvider}; | pub use self::sync_provider::{Config, TestSyncProvider}; | ||||||
| pub use self::miner_service::{TestMinerService}; | pub use self::miner_service::{TestMinerService}; | ||||||
| pub use self::external_miner::TestExternalMiner; |  | ||||||
|  | |||||||
| @ -387,7 +387,10 @@ impl ChainSync { | |||||||
| 						self.have_common_block = true; | 						self.have_common_block = true; | ||||||
| 						trace!(target: "sync", "Found common header {} ({})", number, hash); | 						trace!(target: "sync", "Found common header {} ({})", number, hash); | ||||||
| 					} else { | 					} else { | ||||||
| 						trace!(target: "sync", "Header already in chain {} ({})", number, hash); | 						trace!(target: "sync", "Header already in chain {} ({}), restarting", number, hash); | ||||||
|  | 						self.restart(io); | ||||||
|  | 						self.continue_sync(io); | ||||||
|  | 						return Ok(()); | ||||||
| 					} | 					} | ||||||
| 				}, | 				}, | ||||||
| 				_ => { | 				_ => { | ||||||
| @ -462,6 +465,12 @@ impl ChainSync { | |||||||
| 			trace!(target: "sync", "Ignored block bodies while waiting"); | 			trace!(target: "sync", "Ignored block bodies while waiting"); | ||||||
| 			return Ok(()); | 			return Ok(()); | ||||||
| 		} | 		} | ||||||
|  | 		if item_count == 0 { | ||||||
|  | 			trace!(target: "sync", "No bodies returned, restarting"); | ||||||
|  | 			self.restart(io); | ||||||
|  | 			self.continue_sync(io); | ||||||
|  | 			return Ok(()); | ||||||
|  | 		} | ||||||
| 		for i in 0..item_count { | 		for i in 0..item_count { | ||||||
| 			let body = try!(r.at(i)); | 			let body = try!(r.at(i)); | ||||||
| 			let tx = try!(body.at(0)); | 			let tx = try!(body.at(0)); | ||||||
|  | |||||||
| @ -307,10 +307,14 @@ struct EncodableU8 (u8); | |||||||
| 
 | 
 | ||||||
| impl ByteEncodable for EncodableU8 { | impl ByteEncodable for EncodableU8 { | ||||||
| 	fn to_bytes<V: VecLike<u8>>(&self, out: &mut V) { | 	fn to_bytes<V: VecLike<u8>>(&self, out: &mut V) { | ||||||
| 		out.vec_push(self.0) | 		if self.0 != 0 { | ||||||
|  | 			out.vec_push(self.0) | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn bytes_len(&self) -> usize { 1 } | 	fn bytes_len(&self) -> usize { | ||||||
|  | 		match self.0 { 0 => 0, _ => 1 } | ||||||
|  | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl RlpEncodable for u8 { | impl RlpEncodable for u8 { | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user