Struct serde_json::Error [−][src]
pub struct Error { /* fields omitted */ }
This type represents all possible errors that can occur when serializing or deserializing JSON data.
Methods
impl Error
[src]
impl Error
pub fn line(&self) -> usize
[src]
pub fn line(&self) -> usize
One-based line number at which the error was detected.
Characters in the first line of the input (before the first newline character) are in line 1.
pub fn column(&self) -> usize
[src]
pub fn column(&self) -> usize
One-based column number at which the error was detected.
The first character in the input and any characters immediately following a newline character are in column 1.
Note that errors may occur in column 0, for example if a read from an IO stream fails immediately following a previously read newline character.
pub fn classify(&self) -> Category
[src]
pub fn classify(&self) -> Category
Categorizes the cause of this error.
Category::Io
- failure to read or write bytes on an IO streamCategory::Syntax
- input that is not syntactically valid JSONCategory::Data
- input data that is semantically incorrectCategory::Eof
- unexpected end of the input data
pub fn is_io(&self) -> bool
[src]
pub fn is_io(&self) -> bool
Returns true if this error was caused by a failure to read or write bytes on an IO stream.
pub fn is_syntax(&self) -> bool
[src]
pub fn is_syntax(&self) -> bool
Returns true if this error was caused by input that was not syntactically valid JSON.
pub fn is_data(&self) -> bool
[src]
pub fn is_data(&self) -> bool
Returns true if this error was caused by input data that was semantically incorrect.
For example, JSON containing a number is semantically incorrect when the type being deserialized into holds a String.
pub fn is_eof(&self) -> bool
[src]
pub fn is_eof(&self) -> bool
Returns true if this error was caused by prematurely reaching the end of the input data.
Callers that process streaming input may be interested in retrying the deserialization once more data is available.
Trait Implementations
impl From<Error> for Error
[src]
impl From<Error> for Error
fn from(j: Error) -> Self
[src]
fn from(j: Error) -> Self
Convert a serde_json::Error
into an io::Error
.
JSON syntax and data errors are turned into InvalidData
IO errors.
EOF errors are turned into UnexpectedEof
IO errors.
use std::io; enum MyError { Io(io::Error), Json(serde_json::Error), } impl From<serde_json::Error> for MyError { fn from(err: serde_json::Error) -> MyError { use serde_json::error::Category; match err.classify() { Category::Io => { MyError::Io(err.into()) } Category::Syntax | Category::Data | Category::Eof => { MyError::Json(err) } } } }
impl Error for Error
[src]
impl Error for Error
fn description(&self) -> &str
[src]
fn description(&self) -> &str
This method is soft-deprecated. Read more
fn cause(&self) -> Option<&Error>
[src]
fn cause(&self) -> Option<&Error>
The lower-level cause of this error, if any. Read more
impl Display for Error
[src]
impl Display for Error
fn fmt(&self, f: &mut Formatter) -> Result
[src]
fn fmt(&self, f: &mut Formatter) -> Result
Formats the value using the given formatter. Read more
impl Debug for Error
[src]
impl Debug for Error
fn fmt(&self, f: &mut Formatter) -> Result
[src]
fn fmt(&self, f: &mut Formatter) -> Result
Formats the value using the given formatter. Read more
impl Error for Error
[src]
impl Error for Error
fn custom<T: Display>(msg: T) -> Error
[src]
fn custom<T: Display>(msg: T) -> Error
Raised when there is general error when deserializing a type. Read more
fn invalid_type(unexp: Unexpected, exp: &Expected) -> Self
[src]
fn invalid_type(unexp: Unexpected, exp: &Expected) -> Self
Raised when a Deserialize
receives a type different from what it was expecting. Read more
fn invalid_value(unexp: Unexpected, exp: &Expected) -> Self
[src]
fn invalid_value(unexp: Unexpected, exp: &Expected) -> Self
Raised when a Deserialize
receives a value of the right type but that is wrong for some other reason. Read more
fn invalid_length(len: usize, exp: &Expected) -> Self
[src]
fn invalid_length(len: usize, exp: &Expected) -> Self
Raised when deserializing a sequence or map and the input data contains too many or too few elements. Read more
fn unknown_variant(variant: &str, expected: &'static [&'static str]) -> Self
[src]
fn unknown_variant(variant: &str, expected: &'static [&'static str]) -> Self
Raised when a Deserialize
enum type received a variant with an unrecognized name. Read more
fn unknown_field(field: &str, expected: &'static [&'static str]) -> Self
[src]
fn unknown_field(field: &str, expected: &'static [&'static str]) -> Self
Raised when a Deserialize
struct type received a field with an unrecognized name. Read more
fn missing_field(field: &'static str) -> Self
[src]
fn missing_field(field: &'static str) -> Self
Raised when a Deserialize
struct type expected to receive a required field with a particular name but that field was not present in the input. Read more
fn duplicate_field(field: &'static str) -> Self
[src]
fn duplicate_field(field: &'static str) -> Self
Raised when a Deserialize
struct type received more than one of the same field. Read more
impl Error for Error
[src]
impl Error for Error