2018-08-30 14:18:55 +02:00
|
|
|
// run-pass
|
2015-03-22 13:13:15 -07:00
|
|
|
|
2017-06-13 15:52:59 -07:00
|
|
|
#![feature(box_syntax)]
|
2014-02-19 19:29:58 -08:00
|
|
|
|
2014-05-29 19:03:06 -07:00
|
|
|
use std::collections::HashMap;
|
2013-07-15 11:12:56 -07:00
|
|
|
|
|
|
|
trait Graph<Node, Edge> {
|
2017-06-25 05:29:10 +03:00
|
|
|
fn f(&self, _: Edge);
|
|
|
|
fn g(&self, _: Node);
|
2013-07-15 11:12:56 -07:00
|
|
|
}
|
|
|
|
|
2015-03-25 17:06:52 -07:00
|
|
|
impl<E> Graph<isize, E> for HashMap<isize, isize> {
|
2013-07-15 11:12:56 -07:00
|
|
|
fn f(&self, _e: E) {
|
2014-10-09 15:17:22 -04:00
|
|
|
panic!();
|
2013-07-15 11:12:56 -07:00
|
|
|
}
|
2015-03-25 17:06:52 -07:00
|
|
|
fn g(&self, _e: isize) {
|
2015-02-12 10:29:52 -05:00
|
|
|
panic!();
|
|
|
|
}
|
2013-07-15 11:12:56 -07:00
|
|
|
}
|
|
|
|
|
2013-09-25 00:43:37 -07:00
|
|
|
pub fn main() {
|
2015-03-25 17:06:52 -07:00
|
|
|
let g : Box<HashMap<isize,isize>> = box HashMap::new();
|
|
|
|
let _g2 : Box<Graph<isize,isize>> = g as Box<Graph<isize,isize>>;
|
2013-07-15 11:12:56 -07:00
|
|
|
}
|