Deny bare trait objects in src/libserialize

This commit is contained in:
ljedrz 2018-07-12 12:49:29 +02:00
parent c946c2539e
commit 0878453119
2 changed files with 10 additions and 8 deletions

View File

@ -371,7 +371,7 @@ impl From<fmt::Error> for EncoderError {
pub type EncodeResult = Result<(), EncoderError>; pub type EncodeResult = Result<(), EncoderError>;
pub type DecodeResult<T> = Result<T, DecoderError>; pub type DecodeResult<T> = Result<T, DecoderError>;
fn escape_str(wr: &mut fmt::Write, v: &str) -> EncodeResult { fn escape_str(wr: &mut dyn fmt::Write, v: &str) -> EncodeResult {
wr.write_str("\"")?; wr.write_str("\"")?;
let mut start = 0; let mut start = 0;
@ -433,11 +433,11 @@ fn escape_str(wr: &mut fmt::Write, v: &str) -> EncodeResult {
Ok(()) Ok(())
} }
fn escape_char(writer: &mut fmt::Write, v: char) -> EncodeResult { fn escape_char(writer: &mut dyn fmt::Write, v: char) -> EncodeResult {
escape_str(writer, v.encode_utf8(&mut [0; 4])) escape_str(writer, v.encode_utf8(&mut [0; 4]))
} }
fn spaces(wr: &mut fmt::Write, mut n: usize) -> EncodeResult { fn spaces(wr: &mut dyn fmt::Write, mut n: usize) -> EncodeResult {
const BUF: &'static str = " "; const BUF: &'static str = " ";
while n >= BUF.len() { while n >= BUF.len() {
@ -461,14 +461,14 @@ fn fmt_number_or_null(v: f64) -> string::String {
/// A structure for implementing serialization to JSON. /// A structure for implementing serialization to JSON.
pub struct Encoder<'a> { pub struct Encoder<'a> {
writer: &'a mut (fmt::Write+'a), writer: &'a mut (dyn fmt::Write+'a),
is_emitting_map_key: bool, is_emitting_map_key: bool,
} }
impl<'a> Encoder<'a> { impl<'a> Encoder<'a> {
/// Creates a new JSON encoder whose output will be written to the writer /// Creates a new JSON encoder whose output will be written to the writer
/// specified. /// specified.
pub fn new(writer: &'a mut fmt::Write) -> Encoder<'a> { pub fn new(writer: &'a mut dyn fmt::Write) -> Encoder<'a> {
Encoder { writer: writer, is_emitting_map_key: false, } Encoder { writer: writer, is_emitting_map_key: false, }
} }
} }
@ -707,7 +707,7 @@ impl<'a> ::Encoder for Encoder<'a> {
/// Another encoder for JSON, but prints out human-readable JSON instead of /// Another encoder for JSON, but prints out human-readable JSON instead of
/// compact data /// compact data
pub struct PrettyEncoder<'a> { pub struct PrettyEncoder<'a> {
writer: &'a mut (fmt::Write+'a), writer: &'a mut (dyn fmt::Write+'a),
curr_indent: usize, curr_indent: usize,
indent: usize, indent: usize,
is_emitting_map_key: bool, is_emitting_map_key: bool,
@ -715,7 +715,7 @@ pub struct PrettyEncoder<'a> {
impl<'a> PrettyEncoder<'a> { impl<'a> PrettyEncoder<'a> {
/// Creates a new encoder whose output will be written to the specified writer /// Creates a new encoder whose output will be written to the specified writer
pub fn new(writer: &'a mut fmt::Write) -> PrettyEncoder<'a> { pub fn new(writer: &'a mut dyn fmt::Write) -> PrettyEncoder<'a> {
PrettyEncoder { PrettyEncoder {
writer, writer,
curr_indent: 0, curr_indent: 0,
@ -2053,7 +2053,7 @@ impl<T: Iterator<Item=char>> Builder<T> {
} }
/// Decodes a json value from an `&mut io::Read` /// Decodes a json value from an `&mut io::Read`
pub fn from_reader(rdr: &mut Read) -> Result<Json, BuilderError> { pub fn from_reader(rdr: &mut dyn Read) -> Result<Json, BuilderError> {
let mut contents = Vec::new(); let mut contents = Vec::new();
match rdr.read_to_end(&mut contents) { match rdr.read_to_end(&mut contents) {
Ok(c) => c, Ok(c) => c,

View File

@ -14,6 +14,8 @@
Core encoding and decoding interfaces. Core encoding and decoding interfaces.
*/ */
#![deny(bare_trait_objects)]
#![doc(html_logo_url = "https://www.rust-lang.org/logos/rust-logo-128x128-blk-v2.png", #![doc(html_logo_url = "https://www.rust-lang.org/logos/rust-logo-128x128-blk-v2.png",
html_favicon_url = "https://doc.rust-lang.org/favicon.ico", html_favicon_url = "https://doc.rust-lang.org/favicon.ico",
html_root_url = "https://doc.rust-lang.org/nightly/", html_root_url = "https://doc.rust-lang.org/nightly/",