updated for new RLP interface

This commit is contained in:
arkpar 2015-12-17 14:05:13 +01:00
parent ba4620bd6c
commit 6e4850d4ae
2 changed files with 10 additions and 8 deletions

View File

@ -253,7 +253,7 @@ impl EncryptedConnection {
let length = ((((hdec[0] as u32) << 8) + (hdec[1] as u32)) << 8) + (hdec[2] as u32); let length = ((((hdec[0] as u32) << 8) + (hdec[1] as u32)) << 8) + (hdec[2] as u32);
let header_rlp = UntrustedRlp::new(&hdec[3..6]); let header_rlp = UntrustedRlp::new(&hdec[3..6]);
let protocol_id = try!(u16::decode_untrusted(&try!(header_rlp.at(0)))); let protocol_id = try!(header_rlp.val_at::<u16>(0));
self.payload_len = length; self.payload_len = length;
self.protocol_id = protocol_id; self.protocol_id = protocol_id;

View File

@ -38,10 +38,12 @@ pub struct PeerCapabilityInfo {
} }
impl Decodable for PeerCapabilityInfo { impl Decodable for PeerCapabilityInfo {
fn decode_untrusted(rlp: &UntrustedRlp) -> Result<Self, DecoderError> { fn decode<D>(decoder: &D) -> Result<Self, DecoderError> where D: Decoder {
let c = try!(decoder.as_list());
let v: u32 = try!(Decodable::decode(&c[1]));
Ok(PeerCapabilityInfo { Ok(PeerCapabilityInfo {
protocol: try!(String::decode_untrusted(&try!(rlp.at(0)))), protocol: try!(Decodable::decode(&c[0])),
version: try!(u32::decode_untrusted(&try!(rlp.at(1)))) as u8, version: v as u8,
}) })
} }
} }
@ -170,10 +172,10 @@ impl Session {
} }
fn read_hello(&mut self, rlp: &UntrustedRlp, host: &HostInfo) -> Result<(), Error> { fn read_hello(&mut self, rlp: &UntrustedRlp, host: &HostInfo) -> Result<(), Error> {
let protocol = try!(u32::decode_untrusted(&try!(rlp.at(0)))); let protocol = try!(rlp.val_at::<u32>(0));
let client_version = try!(String::decode_untrusted(&try!(rlp.at(1)))); let client_version = try!(rlp.val_at::<String>(1));
let peer_caps: Vec<PeerCapabilityInfo> = try!(Decodable::decode_untrusted(&try!(rlp.at(2)))); let peer_caps = try!(rlp.val_at::<Vec<PeerCapabilityInfo>>(2));
let id = try!(NodeId::decode_untrusted(&try!(rlp.at(4)))); let id = try!(rlp.val_at::<NodeId>(4));
// Intersect with host capabilities // Intersect with host capabilities
// Leave only highset mutually supported capability version // Leave only highset mutually supported capability version