2018-08-30 07:18:55 -05:00
|
|
|
// run-pass
|
2018-08-31 08:02:01 -05:00
|
|
|
#![allow(non_camel_case_types)]
|
|
|
|
#![allow(non_snake_case)]
|
|
|
|
|
2014-12-22 11:04:23 -06:00
|
|
|
use std::ops::Deref;
|
|
|
|
|
2014-12-07 09:22:06 -06:00
|
|
|
struct Root {
|
|
|
|
jsref: JSRef
|
|
|
|
}
|
|
|
|
|
2015-01-01 13:53:20 -06:00
|
|
|
impl Deref for Root {
|
|
|
|
type Target = JSRef;
|
|
|
|
|
2014-12-07 09:22:06 -06:00
|
|
|
fn deref<'a>(&'a self) -> &'a JSRef {
|
|
|
|
&self.jsref
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-03-30 08:38:27 -05:00
|
|
|
#[derive(Copy, Clone)]
|
2014-12-07 09:22:06 -06:00
|
|
|
struct JSRef {
|
|
|
|
node: *const Node
|
|
|
|
}
|
|
|
|
|
2015-01-01 13:53:20 -06:00
|
|
|
impl Deref for JSRef {
|
|
|
|
type Target = Node;
|
|
|
|
|
2014-12-07 09:22:06 -06:00
|
|
|
fn deref<'a>(&'a self) -> &'a Node {
|
|
|
|
self.get()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
trait INode {
|
|
|
|
fn RemoveChild(&self);
|
|
|
|
}
|
|
|
|
|
|
|
|
impl INode for JSRef {
|
|
|
|
fn RemoveChild(&self) {
|
|
|
|
self.get().RemoveChild(0)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl JSRef {
|
|
|
|
fn AddChild(&self) {
|
|
|
|
self.get().AddChild(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
fn get<'a>(&'a self) -> &'a Node {
|
|
|
|
unsafe {
|
|
|
|
&*self.node
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Node;
|
|
|
|
|
|
|
|
impl Node {
|
2015-03-25 19:06:52 -05:00
|
|
|
fn RemoveChild(&self, _a: usize) {
|
2014-12-07 09:22:06 -06:00
|
|
|
}
|
|
|
|
|
2015-03-25 19:06:52 -05:00
|
|
|
fn AddChild(&self, _a: usize) {
|
2014-12-07 09:22:06 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let n = Node;
|
|
|
|
let jsref = JSRef { node: &n };
|
|
|
|
let root = Root { jsref: jsref };
|
|
|
|
|
|
|
|
root.AddChild();
|
|
|
|
jsref.AddChild();
|
|
|
|
|
|
|
|
root.RemoveChild();
|
|
|
|
jsref.RemoveChild();
|
|
|
|
}
|