Don't byteswap Fingerprints when encoding
Byteswapping Fingerprints when encoding is unnessesary and breaks if the Fingerprint is later decoded on a machine with different endianness to the one it was encoded on. Fix by removing the Encodable and Decodable implementations and use the ones derived from RustcEncodable and RustcDecodable. Fixes #42239
This commit is contained in:
parent
f89d8d1844
commit
edefcb2946
@ -8,12 +8,11 @@
|
|||||||
// option. This file may not be copied, modified, or distributed
|
// option. This file may not be copied, modified, or distributed
|
||||||
// except according to those terms.
|
// except according to those terms.
|
||||||
|
|
||||||
use rustc_serialize::{Encodable, Decodable, Encoder, Decoder};
|
|
||||||
use rustc_data_structures::stable_hasher;
|
use rustc_data_structures::stable_hasher;
|
||||||
use std::mem;
|
use std::mem;
|
||||||
use std::slice;
|
use std::slice;
|
||||||
|
|
||||||
#[derive(Eq, PartialEq, Ord, PartialOrd, Hash, Debug, Clone, Copy)]
|
#[derive(Eq, PartialEq, Ord, PartialOrd, Hash, Debug, Clone, Copy, RustcEncodable, RustcDecodable)]
|
||||||
pub struct Fingerprint(u64, u64);
|
pub struct Fingerprint(u64, u64);
|
||||||
|
|
||||||
impl Fingerprint {
|
impl Fingerprint {
|
||||||
@ -37,23 +36,6 @@ pub fn to_hex(&self) -> String {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Encodable for Fingerprint {
|
|
||||||
#[inline]
|
|
||||||
fn encode<S: Encoder>(&self, s: &mut S) -> Result<(), S::Error> {
|
|
||||||
s.emit_u64(self.0.to_le())?;
|
|
||||||
s.emit_u64(self.1.to_le())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Decodable for Fingerprint {
|
|
||||||
#[inline]
|
|
||||||
fn decode<D: Decoder>(d: &mut D) -> Result<Fingerprint, D::Error> {
|
|
||||||
let _0 = u64::from_le(d.read_u64()?);
|
|
||||||
let _1 = u64::from_le(d.read_u64()?);
|
|
||||||
Ok(Fingerprint(_0, _1))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl ::std::fmt::Display for Fingerprint {
|
impl ::std::fmt::Display for Fingerprint {
|
||||||
fn fmt(&self, formatter: &mut ::std::fmt::Formatter) -> Result<(), ::std::fmt::Error> {
|
fn fmt(&self, formatter: &mut ::std::fmt::Formatter) -> Result<(), ::std::fmt::Error> {
|
||||||
write!(formatter, "{:x}-{:x}", self.0, self.1)
|
write!(formatter, "{:x}-{:x}", self.0, self.1)
|
||||||
|
Loading…
Reference in New Issue
Block a user