diff --git a/src/libstd/io/error.rs b/src/libstd/io/error.rs index 85b957640fdab..c4e472f158edf 100644 --- a/src/libstd/io/error.rs +++ b/src/libstd/io/error.rs @@ -95,6 +95,13 @@ pub enum ErrorKind { /// A parameter was incorrect. #[stable(feature = "rust1", since = "1.0.0")] InvalidInput, + /// Data not valid for the operation were encountered. + /// + /// Unlike `InvalidInput`, this typically means that the operation + /// parameters were valid, however the error was caused by malformed + /// input data. + #[stable(feature = "io_invalid_data", since = "1.2.0")] + InvalidData, /// The I/O operation's timeout expired, causing it to be canceled. #[stable(feature = "rust1", since = "1.0.0")] TimedOut, diff --git a/src/libstd/io/mod.rs b/src/libstd/io/mod.rs index c664def304e09..3d0dfbba0ab99 100644 --- a/src/libstd/io/mod.rs +++ b/src/libstd/io/mod.rs @@ -80,7 +80,7 @@ fn append_to_string(buf: &mut String, f: F) -> Result let ret = f(g.s); if str::from_utf8(&g.s[g.len..]).is_err() { ret.and_then(|_| { - Err(Error::new(ErrorKind::InvalidInput, + Err(Error::new(ErrorKind::InvalidData, "stream did not contain valid UTF-8")) }) } else { diff --git a/src/libstd/sys/windows/stdio.rs b/src/libstd/sys/windows/stdio.rs index 03547165f5d87..e56722a189d7e 100644 --- a/src/libstd/sys/windows/stdio.rs +++ b/src/libstd/sys/windows/stdio.rs @@ -170,5 +170,5 @@ impl Output { } fn invalid_encoding() -> io::Error { - io::Error::new(io::ErrorKind::InvalidInput, "text was not valid unicode") + io::Error::new(io::ErrorKind::InvalidData, "text was not valid unicode") }