Deny bare trait objects in src/libserialize
This commit is contained in:
parent
c946c2539e
commit
0878453119
@ -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,
|
||||||
|
@ -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/",
|
||||||
|
Loading…
Reference in New Issue
Block a user