1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
use chakracore_sys::*;
use context::ContextGuard;
use super::{Value, Object};
use Property;
macro_rules! ctor {
($name:ident, $errtype:ident, $doc:expr) => {
#[doc=$doc]
pub fn $name(guard: &ContextGuard, message: &str) -> Self {
create_error(guard, message, $errtype)
}
};
}
pub struct Error(JsValueRef);
impl Error {
ctor!(new, JsCreateError, "Creates a new error.");
ctor!(range_error, JsCreateRangeError, "Creates a new range error.");
ctor!(reference_error, JsCreateReferenceError, "Creates a new reference error.");
ctor!(syntax_error, JsCreateSyntaxError, "Creates a new syntax error.");
ctor!(type_error, JsCreateTypeError, "Creates a new type error.");
ctor!(uri_error, JsCreateURIError, "Creates a new URI error.");
pub fn message(&self, guard: &ContextGuard) -> String {
let property = Property::new(guard, "message");
self.get(guard, &property).to_string(guard)
}
is_same!(Error, "Returns true if the value is an `Error`.");
}
type ErrorCall = unsafe extern "system" fn(JsValueRef, *mut JsValueRef) -> JsErrorCode;
fn create_error(guard: &ContextGuard, message: &str, api: ErrorCall) -> Error {
let message = super::String::new(guard, message);
let mut value = JsValueRef::new();
unsafe {
jsassert!(api(message.as_raw(), &mut value));
Error::from_raw(value)
}
}
reference!(Error);
inherit!(Error, Object);
subtype!(Error, Value);
#[cfg(test)]
mod tests {
use {test, value};
#[test]
fn string_conversion() {
test::run_with_context(|guard| {
let error = value::Error::type_error(guard, "FooBar");
assert_eq!(error.to_string(guard), "TypeError: FooBar");
});
}
}