#[cfg(any(feature = "arbitrary", test))]
extern crate arbitrary;
extern crate cbordata_derive;
extern crate num_bigint;
extern crate num_traits;
#[cfg(test)]
extern crate rand;
use std::{error, fmt, result};
#[macro_export]
macro_rules! err_at {
($v:ident, msg: $($arg:expr),+) => {{
let prefix = format!("{}:{}", file!(), line!());
Err(Error::$v(prefix, format!($($arg),+)))
}};
($v:ident, $e:expr) => {{
match $e {
Ok(val) => Ok(val),
Err(err) => {
let prefix = format!("{}:{}", file!(), line!());
Err(Error::$v(prefix, format!("{}", err)))
}
}
}};
($v:ident, $e:expr, $($arg:expr),+) => {{
match $e {
Ok(val) => Ok(val),
Err(err) => {
let prefix = format!("{}:{}", file!(), line!());
let msg = format!($($arg),+);
Err(Error::$v(prefix, format!("{} {}", err, msg)))
}
}
}};
}
pub enum Error {
Fatal(String, String),
FailConvert(String, String),
IOError(String, String),
FailCbor(String, String),
}
impl fmt::Display for Error {
fn fmt(&self, f: &mut fmt::Formatter) -> result::Result<(), fmt::Error> {
use Error::*;
match self {
Fatal(p, msg) => write!(f, "{} Fatal: {}", p, msg),
FailConvert(p, msg) => write!(f, "{} FailConvert: {}", p, msg),
IOError(p, msg) => write!(f, "{} IOError: {}", p, msg),
FailCbor(p, msg) => write!(f, "{} FailCbor: {}", p, msg),
}
}
}
impl fmt::Debug for Error {
fn fmt(&self, f: &mut fmt::Formatter) -> result::Result<(), fmt::Error> {
write!(f, "{}", self)
}
}
impl error::Error for Error {}
#[doc(hidden)]
pub use cbordata_derive::*;
mod cbor;
mod types;
pub use cbor::{pretty_print, Cbor, Info, Key, SimpleValue, Tag, RECURSION_LIMIT};
#[inline]
pub fn get_cborize_id(val: &Cbor) -> Option<Cbor> {
match val {
Cbor::Major4(_, items) => items.first().cloned(),
_ => None,
}
}
pub trait IntoCbor {
fn into_cbor(self) -> Result<Cbor>;
}
pub trait FromCbor: Sized {
fn from_cbor(val: Cbor) -> Result<Self>;
}
pub type Result<T> = std::result::Result<T, Error>;