2014-10-03 14:23:09 -07:00
|
|
|
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
|
|
|
|
// file at the top-level directory of this distribution and at
|
|
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
|
|
// option. This file may not be copied, modified, or distributed
|
|
|
|
// except according to those terms.
|
|
|
|
|
|
|
|
//! Traits for working with Errors.
|
|
|
|
//!
|
|
|
|
//! # The `Error` trait
|
|
|
|
//!
|
|
|
|
//! `Error` is a trait representing the basic expectations for error values,
|
|
|
|
//! i.e. values of type `E` in `Result<T, E>`. At a minimum, errors must provide
|
|
|
|
//! a description, but they may optionally provide additional detail and cause
|
|
|
|
//! chain information:
|
|
|
|
//!
|
|
|
|
//! ```
|
|
|
|
//! trait Error: Send {
|
|
|
|
//! fn description(&self) -> &str;
|
|
|
|
//!
|
|
|
|
//! fn detail(&self) -> Option<String> { None }
|
|
|
|
//! fn cause(&self) -> Option<&Error> { None }
|
|
|
|
//! }
|
|
|
|
//! ```
|
|
|
|
//!
|
|
|
|
//! The `cause` method is generally used when errors cross "abstraction
|
|
|
|
//! boundaries", i.e. when a one module must report an error that is "caused"
|
|
|
|
//! by an error from a lower-level module. This setup makes it possible for the
|
|
|
|
//! high-level module to provide its own errors that do not commit to any
|
|
|
|
//! particular implementation, but also reveal some of its implementation for
|
|
|
|
//! debugging via `cause` chains.
|
|
|
|
//!
|
|
|
|
//! # The `FromError` trait
|
|
|
|
//!
|
|
|
|
//! `FromError` is a simple trait that expresses conversions between different
|
|
|
|
//! error types. To provide maximum flexibility, it does not require either of
|
|
|
|
//! the types to actually implement the `Error` trait, although this will be the
|
|
|
|
//! common case.
|
|
|
|
//!
|
|
|
|
//! The main use of this trait is in the `try!` macro, which uses it to
|
|
|
|
//! automatically convert a given error to the error specified in a function's
|
|
|
|
//! return type.
|
|
|
|
//!
|
|
|
|
//! For example,
|
|
|
|
//!
|
|
|
|
//! ```
|
|
|
|
//! use std::error::FromError;
|
|
|
|
//! use std::io::{File, IoError};
|
|
|
|
//! use std::os::{MemoryMap, MapError};
|
|
|
|
//! use std::path::Path;
|
|
|
|
//!
|
|
|
|
//! enum MyError {
|
|
|
|
//! Io(IoError),
|
|
|
|
//! Map(MapError)
|
|
|
|
//! }
|
|
|
|
//!
|
|
|
|
//! impl FromError<IoError> for MyError {
|
|
|
|
//! fn from_error(err: IoError) -> MyError {
|
2014-11-06 00:05:53 -08:00
|
|
|
//! MyError::Io(err)
|
2014-10-03 14:23:09 -07:00
|
|
|
//! }
|
|
|
|
//! }
|
|
|
|
//!
|
|
|
|
//! impl FromError<MapError> for MyError {
|
|
|
|
//! fn from_error(err: MapError) -> MyError {
|
2014-11-06 00:05:53 -08:00
|
|
|
//! MyError::Map(err)
|
2014-10-03 14:23:09 -07:00
|
|
|
//! }
|
|
|
|
//! }
|
|
|
|
//!
|
|
|
|
//! #[allow(unused_variables)]
|
|
|
|
//! fn open_and_map() -> Result<(), MyError> {
|
|
|
|
//! let f = try!(File::open(&Path::new("foo.txt")));
|
|
|
|
//! let m = try!(MemoryMap::new(0, &[]));
|
|
|
|
//! // do something interesting here...
|
|
|
|
//! Ok(())
|
|
|
|
//! }
|
|
|
|
//! ```
|
|
|
|
|
std: Stabilize the std::str module
This commit starts out by consolidating all `str` extension traits into one
`StrExt` trait to be included in the prelude. This means that
`UnicodeStrPrelude`, `StrPrelude`, and `StrAllocating` have all been merged into
one `StrExt` exported by the standard library. Some functionality is currently
duplicated with the `StrExt` present in libcore.
This commit also currently avoids any methods which require any form of pattern
to operate. These functions will be stabilized via a separate RFC.
Next, stability of methods and structures are as follows:
Stable
* from_utf8_unchecked
* CowString - after moving to std::string
* StrExt::as_bytes
* StrExt::as_ptr
* StrExt::bytes/Bytes - also made a struct instead of a typedef
* StrExt::char_indices/CharIndices - CharOffsets was renamed
* StrExt::chars/Chars
* StrExt::is_empty
* StrExt::len
* StrExt::lines/Lines
* StrExt::lines_any/LinesAny
* StrExt::slice_unchecked
* StrExt::trim
* StrExt::trim_left
* StrExt::trim_right
* StrExt::words/Words - also made a struct instead of a typedef
Unstable
* from_utf8 - the error type was changed to a `Result`, but the error type has
yet to prove itself
* from_c_str - this function will be handled by the c_str RFC
* FromStr - this trait will have an associated error type eventually
* StrExt::escape_default - needs iterators at least, unsure if it should make
the cut
* StrExt::escape_unicode - needs iterators at least, unsure if it should make
the cut
* StrExt::slice_chars - this function has yet to prove itself
* StrExt::slice_shift_char - awaiting conventions about slicing and shifting
* StrExt::graphemes/Graphemes - this functionality may only be in libunicode
* StrExt::grapheme_indices/GraphemeIndices - this functionality may only be in
libunicode
* StrExt::width - this functionality may only be in libunicode
* StrExt::utf16_units - this functionality may only be in libunicode
* StrExt::nfd_chars - this functionality may only be in libunicode
* StrExt::nfkd_chars - this functionality may only be in libunicode
* StrExt::nfc_chars - this functionality may only be in libunicode
* StrExt::nfkc_chars - this functionality may only be in libunicode
* StrExt::is_char_boundary - naming is uncertain with container conventions
* StrExt::char_range_at - naming is uncertain with container conventions
* StrExt::char_range_at_reverse - naming is uncertain with container conventions
* StrExt::char_at - naming is uncertain with container conventions
* StrExt::char_at_reverse - naming is uncertain with container conventions
* StrVector::concat - this functionality may be replaced with iterators, but
it's not certain at this time
* StrVector::connect - as with concat, may be deprecated in favor of iterators
Deprecated
* StrAllocating and UnicodeStrPrelude have been merged into StrExit
* eq_slice - compiler implementation detail
* from_str - use the inherent parse() method
* is_utf8 - call from_utf8 instead
* replace - call the method instead
* truncate_utf16_at_nul - this is an implementation detail of windows and does
not need to be exposed.
* utf8_char_width - moved to libunicode
* utf16_items - moved to libunicode
* is_utf16 - moved to libunicode
* Utf16Items - moved to libunicode
* Utf16Item - moved to libunicode
* Utf16Encoder - moved to libunicode
* AnyLines - renamed to LinesAny and made a struct
* SendStr - use CowString<'static> instead
* str::raw - all functionality is deprecated
* StrExt::into_string - call to_string() instead
* StrExt::repeat - use iterators instead
* StrExt::char_len - use .chars().count() instead
* StrExt::is_alphanumeric - use .chars().all(..)
* StrExt::is_whitespace - use .chars().all(..)
Pending deprecation -- while slicing syntax is being worked out, these methods
are all #[unstable]
* Str - while currently used for generic programming, this trait will be
replaced with one of [], deref coercions, or a generic conversion trait.
* StrExt::slice - use slicing syntax instead
* StrExt::slice_to - use slicing syntax instead
* StrExt::slice_from - use slicing syntax instead
* StrExt::lev_distance - deprecated with no replacement
Awaiting stabilization due to patterns and/or matching
* StrExt::contains
* StrExt::contains_char
* StrExt::split
* StrExt::splitn
* StrExt::split_terminator
* StrExt::rsplitn
* StrExt::match_indices
* StrExt::split_str
* StrExt::starts_with
* StrExt::ends_with
* StrExt::trim_chars
* StrExt::trim_left_chars
* StrExt::trim_right_chars
* StrExt::find
* StrExt::rfind
* StrExt::find_str
* StrExt::subslice_offset
2014-12-10 09:02:31 -08:00
|
|
|
use prelude::*;
|
|
|
|
|
|
|
|
use str::Utf8Error;
|
2014-10-03 14:23:09 -07:00
|
|
|
|
|
|
|
/// Base functionality for all errors in Rust.
|
|
|
|
pub trait Error: Send {
|
|
|
|
/// A short description of the error; usually a static string.
|
|
|
|
fn description(&self) -> &str;
|
|
|
|
|
|
|
|
/// A detailed description of the error, usually including dynamic information.
|
|
|
|
fn detail(&self) -> Option<String> { None }
|
|
|
|
|
|
|
|
/// The lower-level cause of this error, if any.
|
|
|
|
fn cause(&self) -> Option<&Error> { None }
|
|
|
|
}
|
|
|
|
|
|
|
|
/// A trait for types that can be converted from a given error type `E`.
|
|
|
|
pub trait FromError<E> {
|
|
|
|
/// Perform the conversion.
|
|
|
|
fn from_error(err: E) -> Self;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Any type is convertable from itself
|
|
|
|
impl<E> FromError<E> for E {
|
|
|
|
fn from_error(err: E) -> E {
|
|
|
|
err
|
|
|
|
}
|
|
|
|
}
|
std: Stabilize the std::str module
This commit starts out by consolidating all `str` extension traits into one
`StrExt` trait to be included in the prelude. This means that
`UnicodeStrPrelude`, `StrPrelude`, and `StrAllocating` have all been merged into
one `StrExt` exported by the standard library. Some functionality is currently
duplicated with the `StrExt` present in libcore.
This commit also currently avoids any methods which require any form of pattern
to operate. These functions will be stabilized via a separate RFC.
Next, stability of methods and structures are as follows:
Stable
* from_utf8_unchecked
* CowString - after moving to std::string
* StrExt::as_bytes
* StrExt::as_ptr
* StrExt::bytes/Bytes - also made a struct instead of a typedef
* StrExt::char_indices/CharIndices - CharOffsets was renamed
* StrExt::chars/Chars
* StrExt::is_empty
* StrExt::len
* StrExt::lines/Lines
* StrExt::lines_any/LinesAny
* StrExt::slice_unchecked
* StrExt::trim
* StrExt::trim_left
* StrExt::trim_right
* StrExt::words/Words - also made a struct instead of a typedef
Unstable
* from_utf8 - the error type was changed to a `Result`, but the error type has
yet to prove itself
* from_c_str - this function will be handled by the c_str RFC
* FromStr - this trait will have an associated error type eventually
* StrExt::escape_default - needs iterators at least, unsure if it should make
the cut
* StrExt::escape_unicode - needs iterators at least, unsure if it should make
the cut
* StrExt::slice_chars - this function has yet to prove itself
* StrExt::slice_shift_char - awaiting conventions about slicing and shifting
* StrExt::graphemes/Graphemes - this functionality may only be in libunicode
* StrExt::grapheme_indices/GraphemeIndices - this functionality may only be in
libunicode
* StrExt::width - this functionality may only be in libunicode
* StrExt::utf16_units - this functionality may only be in libunicode
* StrExt::nfd_chars - this functionality may only be in libunicode
* StrExt::nfkd_chars - this functionality may only be in libunicode
* StrExt::nfc_chars - this functionality may only be in libunicode
* StrExt::nfkc_chars - this functionality may only be in libunicode
* StrExt::is_char_boundary - naming is uncertain with container conventions
* StrExt::char_range_at - naming is uncertain with container conventions
* StrExt::char_range_at_reverse - naming is uncertain with container conventions
* StrExt::char_at - naming is uncertain with container conventions
* StrExt::char_at_reverse - naming is uncertain with container conventions
* StrVector::concat - this functionality may be replaced with iterators, but
it's not certain at this time
* StrVector::connect - as with concat, may be deprecated in favor of iterators
Deprecated
* StrAllocating and UnicodeStrPrelude have been merged into StrExit
* eq_slice - compiler implementation detail
* from_str - use the inherent parse() method
* is_utf8 - call from_utf8 instead
* replace - call the method instead
* truncate_utf16_at_nul - this is an implementation detail of windows and does
not need to be exposed.
* utf8_char_width - moved to libunicode
* utf16_items - moved to libunicode
* is_utf16 - moved to libunicode
* Utf16Items - moved to libunicode
* Utf16Item - moved to libunicode
* Utf16Encoder - moved to libunicode
* AnyLines - renamed to LinesAny and made a struct
* SendStr - use CowString<'static> instead
* str::raw - all functionality is deprecated
* StrExt::into_string - call to_string() instead
* StrExt::repeat - use iterators instead
* StrExt::char_len - use .chars().count() instead
* StrExt::is_alphanumeric - use .chars().all(..)
* StrExt::is_whitespace - use .chars().all(..)
Pending deprecation -- while slicing syntax is being worked out, these methods
are all #[unstable]
* Str - while currently used for generic programming, this trait will be
replaced with one of [], deref coercions, or a generic conversion trait.
* StrExt::slice - use slicing syntax instead
* StrExt::slice_to - use slicing syntax instead
* StrExt::slice_from - use slicing syntax instead
* StrExt::lev_distance - deprecated with no replacement
Awaiting stabilization due to patterns and/or matching
* StrExt::contains
* StrExt::contains_char
* StrExt::split
* StrExt::splitn
* StrExt::split_terminator
* StrExt::rsplitn
* StrExt::match_indices
* StrExt::split_str
* StrExt::starts_with
* StrExt::ends_with
* StrExt::trim_chars
* StrExt::trim_left_chars
* StrExt::trim_right_chars
* StrExt::find
* StrExt::rfind
* StrExt::find_str
* StrExt::subslice_offset
2014-12-10 09:02:31 -08:00
|
|
|
|
|
|
|
impl Error for Utf8Error {
|
|
|
|
fn description(&self) -> &str {
|
|
|
|
match *self {
|
|
|
|
Utf8Error::TooShort => "invalid utf-8: not enough bytes",
|
|
|
|
Utf8Error::InvalidByte(..) => "invalid utf-8: corrupt contents",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn detail(&self) -> Option<String> { Some(self.to_string()) }
|
|
|
|
}
|