# Test printing Handles.

assert_subprinter_registered('SpiderMonkey', 'instantiations-of-JS::Rooted')
assert_subprinter_registered('SpiderMonkey', 'instantiations-of-JS::Handle')
assert_subprinter_registered('SpiderMonkey', 'instantiations-of-JS::MutableHandle')
assert_subprinter_registered('SpiderMonkey', 'instantiations-of-js::BarrieredBase')

run_fragment('Root.handle')

assert_pretty('obj', '(JSObject * const)  [object global] delegate')
assert_pretty('mutableObj', '(JSObject *)  [object global] delegate')

run_fragment('Root.HeapSlot')

# This depends on implementation details of arrays, but since HeapSlot is
# not a public type, I'm not sure how to avoid doing *something* ugly.
assert_pretty('((js::NativeObject *) array.get())->elements_[0]', '$jsval("plinth")')

run_fragment('Root.barriers');

assert_pretty('prebarriered', '(JSObject *)  [object Object]');
assert_pretty('heapptr', '(JSObject *)  [object Object]');
assert_pretty('relocatable', '(JSObject *)  [object Object]');
assert_pretty('val', '$jsval((JSObject *)  [object Object])');
assert_pretty('heapValue', '$jsval((JSObject *)  [object Object])');
assert_pretty('prebarrieredValue', '$jsval((JSObject *)  [object Object])');
assert_pretty('relocatableValue', '$jsval((JSObject *)  [object Object])');