rust-clippy/tests/ui/implicit_hasher.rs

101 lines
2.9 KiB
Rust
Raw Normal View History

2018-10-06 16:18:06 +00:00
// Copyright 2014-2018 The Rust Project Developers. See the COPYRIGHT
// file at the top-level directory of this distribution.
//
// 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.
2017-10-05 14:57:31 +00:00
#![allow(unused)]
2017-10-05 14:57:31 +00:00
use std::cmp::Eq;
2018-12-09 22:26:16 +00:00
use std::collections::{HashMap, HashSet};
use std::hash::{BuildHasher, Hash};
2017-10-05 14:57:31 +00:00
pub trait Foo<T>: Sized {
2017-10-05 14:57:31 +00:00
fn make() -> (Self, Self);
}
impl<K: Hash + Eq, V> Foo<i8> for HashMap<K, V> {
fn make() -> (Self, Self) {
// OK, don't suggest to modify these
let _: HashMap<i32, i32> = HashMap::new();
let _: HashSet<i32> = HashSet::new();
(HashMap::new(), HashMap::with_capacity(10))
}
}
impl<K: Hash + Eq, V> Foo<i8> for (HashMap<K, V>,) {
fn make() -> (Self, Self) {
((HashMap::new(),), (HashMap::with_capacity(10),))
}
}
impl Foo<i16> for HashMap<String, String> {
fn make() -> (Self, Self) {
(HashMap::new(), HashMap::with_capacity(10))
}
}
impl<K: Hash + Eq, V, S: BuildHasher + Default> Foo<i32> for HashMap<K, V, S> {
fn make() -> (Self, Self) {
2018-06-14 22:13:12 +00:00
(HashMap::default(), HashMap::with_capacity_and_hasher(10, S::default()))
2017-10-05 14:57:31 +00:00
}
}
impl<S: BuildHasher + Default> Foo<i64> for HashMap<String, String, S> {
fn make() -> (Self, Self) {
2018-06-14 22:13:12 +00:00
(HashMap::default(), HashMap::with_capacity_and_hasher(10, S::default()))
2017-10-05 14:57:31 +00:00
}
}
impl<T: Hash + Eq> Foo<i8> for HashSet<T> {
fn make() -> (Self, Self) {
(HashSet::new(), HashSet::with_capacity(10))
}
}
impl Foo<i16> for HashSet<String> {
fn make() -> (Self, Self) {
(HashSet::new(), HashSet::with_capacity(10))
}
}
impl<T: Hash + Eq, S: BuildHasher + Default> Foo<i32> for HashSet<T, S> {
fn make() -> (Self, Self) {
2018-06-14 22:13:12 +00:00
(HashSet::default(), HashSet::with_capacity_and_hasher(10, S::default()))
2017-10-05 14:57:31 +00:00
}
}
impl<S: BuildHasher + Default> Foo<i64> for HashSet<String, S> {
fn make() -> (Self, Self) {
2018-06-14 22:13:12 +00:00
(HashSet::default(), HashSet::with_capacity_and_hasher(10, S::default()))
2017-10-05 14:57:31 +00:00
}
}
2018-12-09 22:26:16 +00:00
pub fn foo(_map: &mut HashMap<i32, i32>, _set: &mut HashSet<i32>) {}
2017-10-05 14:57:31 +00:00
2017-10-11 03:10:10 +00:00
macro_rules! gen {
(impl) => {
impl<K: Hash + Eq, V> Foo<u8> for HashMap<K, V> {
fn make() -> (Self, Self) {
(HashMap::new(), HashMap::with_capacity(10))
}
}
};
(fn $name:ident) => {
2018-12-09 22:26:16 +00:00
pub fn $name(_map: &mut HashMap<i32, i32>, _set: &mut HashSet<i32>) {}
};
2017-10-11 03:10:10 +00:00
}
#[rustfmt::skip]
gen!(impl);
2017-10-11 03:10:10 +00:00
gen!(fn bar);
// When the macro is in a different file, the suggestion spans can't be combined properly
// and should not cause an ICE
// See #2707
#[macro_use]
2018-12-09 22:26:16 +00:00
#[path = "../auxiliary/test_macro.rs"]
pub mod test_macro;
__implicit_hasher_test_macro!(impl<K, V> for HashMap<K, V> where V: test_macro::A);
2017-10-05 14:57:31 +00:00
fn main() {}