fe6ad097c6
Because of type inference, duplicate obligations exist and cause duplicate errors. To avoid this, only display the first error for each (predicate,span). The inclusion of the span is somewhat bikesheddy, but *is* the more conservative option (it does not remove some instability, as duplicate obligations are ignored by `duplicate_set` under some inference conditions). Fixes #28098 cc #21528 (is it a dupe?)
41 lines
1.2 KiB
Rust
41 lines
1.2 KiB
Rust
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
|
|
// file at the top-level directory of this distribution and at
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
// option. This file may not be copied, modified, or distributed
|
|
// except according to those terms.
|
|
|
|
// Tests that unsafe extern fn pointers do not implement any Fn traits.
|
|
|
|
#![feature(unboxed_closures)]
|
|
|
|
use std::ops::{Fn,FnMut,FnOnce};
|
|
|
|
unsafe fn square(x: &isize) -> isize { (*x) * (*x) }
|
|
|
|
fn call_it<F:Fn(&isize)->isize>(_: &F, _: isize) -> isize { 0 }
|
|
fn call_it_mut<F:FnMut(&isize)->isize>(_: &mut F, _: isize) -> isize { 0 }
|
|
fn call_it_once<F:FnOnce(&isize)->isize>(_: F, _: isize) -> isize { 0 }
|
|
|
|
fn a() {
|
|
let x = call_it(&square, 22);
|
|
//~^ ERROR not implemented
|
|
//~| ERROR not implemented
|
|
}
|
|
|
|
fn b() {
|
|
let y = call_it_mut(&mut square, 22);
|
|
//~^ ERROR not implemented
|
|
//~| ERROR not implemented
|
|
}
|
|
|
|
fn c() {
|
|
let z = call_it_once(square, 22);
|
|
//~^ ERROR not implemented
|
|
}
|
|
|
|
fn main() { }
|