2018-08-30 14:18:55 +02:00
|
|
|
//@ run-pass
|
2015-03-22 13:13:15 -07: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> {
|
2024-02-07 10:42:01 +08:00
|
|
|
fn f(&self, _: Edge); //~ WARN methods `f` and `g` are never used
|
2017-06-25 05:29:10 +03:00
|
|
|
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() {
|
2021-08-25 02:39:40 +02:00
|
|
|
let g : Box<HashMap<isize,isize>> = Box::new(HashMap::new());
|
2019-05-28 14:47:21 -04:00
|
|
|
let _g2 : Box<dyn Graph<isize,isize>> = g as Box<dyn Graph<isize,isize>>;
|
2013-07-15 11:12:56 -07:00
|
|
|
}
|