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