invoke with hand-written code and tests
This commit is contained in:
		
							parent
							
								
									15ecbaf59c
								
							
						
					
					
						commit
						44ea98801b
					
				| @ -57,6 +57,8 @@ pub fn expand_ipc_implementation( | ||||
| 		Err(Error) => { return; } | ||||
| 	}; | ||||
| 
 | ||||
| 	push_proxy(cx, &builder, &item, push); | ||||
| 
 | ||||
| 	push(Annotatable::Item(impl_item)) | ||||
| } | ||||
| 
 | ||||
| @ -220,6 +222,22 @@ fn implement_dispatch_arm(cx: &ExtCtxt, builder: &aster::AstBuilder, index: u32, | ||||
| 	quote_arm!(cx, $index_ident => { $invoke_expr } ) | ||||
| } | ||||
| 
 | ||||
| fn push_proxy_struct(cx: &ExtCtxt, builder: &aster::AstBuilder, item: &Item, push: &mut FnMut(Annotatable)) { | ||||
| 	let proxy_ident = builder.id(format!("{}Proxy", item.ident.name.as_str())); | ||||
| 
 | ||||
| 	let proxy_struct_item = quote_item!(cx, | ||||
| 		pub struct $proxy_ident <S: ::ipc::IpcSocket> { | ||||
| 			socket: ::std::cell::RefCell<S>, | ||||
| 			phantom: ::std::marker::PhantomData<S>, | ||||
| 		}); | ||||
| 
 | ||||
| 	push(Annotatable::Item(proxy_struct_item.expect(&format!("could not generate proxy struct for {:?}", proxy_ident.name)))); | ||||
| } | ||||
| 
 | ||||
| fn push_proxy(cx: &ExtCtxt, builder: &aster::AstBuilder, item: &Item, push: &mut FnMut(Annotatable)) { | ||||
| 	push_proxy_struct(cx, builder, item, push) | ||||
| } | ||||
| 
 | ||||
| fn implement_interface( | ||||
| 	cx: &ExtCtxt, | ||||
| 	builder: &aster::AstBuilder, | ||||
| @ -274,11 +292,6 @@ fn implement_interface( | ||||
| 					_ => vec![] | ||||
| 				} | ||||
| 			} | ||||
| 			fn invoke<W>(&self, _method_num: u16, _payload: &Option<Vec<u8>>, _w: &mut W) | ||||
| 				where W: ::std::io::Write | ||||
| 			{ | ||||
| 			} | ||||
| 
 | ||||
| 		} | ||||
| 	).unwrap()) | ||||
| } | ||||
|  | ||||
| @ -7,3 +7,4 @@ license = "GPL-3.0" | ||||
| [features] | ||||
| 
 | ||||
| [dependencies] | ||||
| ethcore-devtools = { path = "../../devtools" } | ||||
|  | ||||
| @ -19,6 +19,28 @@ | ||||
| pub trait IpcInterface<T> { | ||||
| 	/// reads the message from io, dispatches the call and returns result
 | ||||
| 	fn dispatch<R>(&self, r: &mut R) -> Vec<u8> where R: ::std::io::Read; | ||||
| 	/// encodes the invocation, writes payload and waits for result
 | ||||
| 	fn invoke<W>(&self, method_num: u16, params: &Option<Vec<u8>>, w: &mut W) where W: ::std::io::Write; | ||||
| } | ||||
| 
 | ||||
| pub fn invoke<W>(method_num: u16, params: &Option<Vec<u8>>, w: &mut W) where W: ::std::io::Write { | ||||
| 	let buf_len = match *params { None => 2, Some(ref val) => val.len() + 2 }; | ||||
| 	let mut buf = vec![0u8; buf_len]; | ||||
| 	buf[0] = (method_num & (255<<8)) as u8; | ||||
| 	buf[1] = (method_num >> 8) as u8; | ||||
| 	if params.is_some() { | ||||
| 		buf[2..buf_len].clone_from_slice(params.as_ref().unwrap()); | ||||
| 	} | ||||
| 	if w.write(&buf).unwrap() != buf_len | ||||
| 	{ | ||||
| 		panic!("failed to write to socket"); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| pub trait IpcSocket: ::std::io::Read + ::std::io::Write { | ||||
| 	fn ready(&self) -> ::std::sync::atomic::AtomicBool; | ||||
| } | ||||
| 
 | ||||
| impl IpcSocket for ::devtools::TestSocket { | ||||
| 	fn ready(&self) -> ::std::sync::atomic::AtomicBool { | ||||
| 		::std::sync::atomic::AtomicBool::new(true) | ||||
| 	} | ||||
| } | ||||
|  | ||||
| @ -16,5 +16,7 @@ | ||||
| 
 | ||||
| //! IPC RPC interface
 | ||||
| 
 | ||||
| extern crate ethcore_devtools as devtools; | ||||
| 
 | ||||
| pub mod interface; | ||||
| pub use interface::IpcInterface; | ||||
| pub use interface::{IpcInterface, IpcSocket, invoke}; | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user