2016-12-21 15:42:20 +01:00
|
|
|
|
#![feature(associated_type_defaults)]
|
2018-07-28 17:34:52 +02:00
|
|
|
|
#![warn(clippy::linkedlist)]
|
2021-08-12 13:15:15 +02:00
|
|
|
|
#![allow(unused, dead_code, clippy::needless_pass_by_value)]
|
2015-01-10 11:56:58 +05:30
|
|
|
|
|
2017-06-16 11:30:55 +08:00
|
|
|
|
extern crate alloc;
|
2018-07-01 13:36:14 +02:00
|
|
|
|
use alloc::collections::linked_list::LinkedList;
|
2014-11-20 12:37:45 +05:30
|
|
|
|
|
2021-03-19 18:14:48 +09:00
|
|
|
|
const C: LinkedList<i32> = LinkedList::new();
|
2023-07-28 21:35:48 +02:00
|
|
|
|
//~^ ERROR: you seem to be using a `LinkedList`! Perhaps you meant some other data structu
|
2021-03-19 18:14:48 +09:00
|
|
|
|
static S: LinkedList<i32> = LinkedList::new();
|
2023-07-28 21:35:48 +02:00
|
|
|
|
//~^ ERROR: you seem to be using a `LinkedList`! Perhaps you meant some other data structu
|
2021-03-19 18:14:48 +09:00
|
|
|
|
|
2016-12-21 15:42:20 +01:00
|
|
|
|
trait Foo {
|
2017-02-08 14:58:07 +01:00
|
|
|
|
type Baz = LinkedList<u8>;
|
2023-07-28 21:35:48 +02:00
|
|
|
|
//~^ ERROR: you seem to be using a `LinkedList`! Perhaps you meant some other data str
|
2019-07-23 03:59:09 +08:00
|
|
|
|
fn foo(_: LinkedList<u8>);
|
2023-07-28 21:35:48 +02:00
|
|
|
|
//~^ ERROR: you seem to be using a `LinkedList`! Perhaps you meant some other data str
|
2018-12-09 23:26:16 +01:00
|
|
|
|
const BAR: Option<LinkedList<u8>>;
|
2023-07-28 21:35:48 +02:00
|
|
|
|
//~^ ERROR: you seem to be using a `LinkedList`! Perhaps you meant some other data str
|
2016-12-21 15:42:20 +01:00
|
|
|
|
}
|
|
|
|
|
|
2019-01-31 01:15:29 +00:00
|
|
|
|
// Ok, we don’t want to warn for implementations; see issue #605.
|
2016-12-21 15:42:20 +01:00
|
|
|
|
impl Foo for LinkedList<u8> {
|
|
|
|
|
fn foo(_: LinkedList<u8>) {}
|
2018-12-09 23:26:16 +01:00
|
|
|
|
const BAR: Option<LinkedList<u8>> = None;
|
2016-12-21 15:42:20 +01:00
|
|
|
|
}
|
|
|
|
|
|
2021-08-12 13:15:15 +02:00
|
|
|
|
pub struct Bar {
|
|
|
|
|
priv_linked_list_field: LinkedList<u8>,
|
2023-07-28 21:35:48 +02:00
|
|
|
|
//~^ ERROR: you seem to be using a `LinkedList`! Perhaps you meant some other data str
|
2021-08-12 13:15:15 +02:00
|
|
|
|
pub pub_linked_list_field: LinkedList<u8>,
|
|
|
|
|
}
|
2016-12-21 15:42:20 +01:00
|
|
|
|
impl Bar {
|
2017-02-08 14:58:07 +01:00
|
|
|
|
fn foo(_: LinkedList<u8>) {}
|
2023-07-28 21:35:48 +02:00
|
|
|
|
//~^ ERROR: you seem to be using a `LinkedList`! Perhaps you meant some other data str
|
2016-12-21 15:42:20 +01:00
|
|
|
|
}
|
|
|
|
|
|
2021-08-12 13:15:15 +02:00
|
|
|
|
// All of these test should be trigger the lint because they are not
|
|
|
|
|
// part of the public api
|
|
|
|
|
fn test(my_favorite_linked_list: LinkedList<u8>) {}
|
2023-07-28 21:35:48 +02:00
|
|
|
|
//~^ ERROR: you seem to be using a `LinkedList`! Perhaps you meant some other data structu
|
2021-08-12 13:15:15 +02:00
|
|
|
|
fn test_ret() -> Option<LinkedList<u8>> {
|
2023-07-28 21:35:48 +02:00
|
|
|
|
//~^ ERROR: you seem to be using a `LinkedList`! Perhaps you meant some other data structu
|
2021-08-12 13:15:15 +02:00
|
|
|
|
None
|
2014-11-20 12:37:45 +05:30
|
|
|
|
}
|
2021-08-12 13:15:15 +02:00
|
|
|
|
fn test_local_not_linted() {
|
2017-06-11 12:30:48 -04:00
|
|
|
|
let _: LinkedList<u8>;
|
|
|
|
|
}
|
|
|
|
|
|
2021-08-12 13:15:15 +02:00
|
|
|
|
// All of these test should be allowed because they are part of the
|
|
|
|
|
// public api and `avoid_breaking_exported_api` is `false` by default.
|
|
|
|
|
pub fn pub_test(the_most_awesome_linked_list: LinkedList<u8>) {}
|
|
|
|
|
pub fn pub_test_ret() -> Option<LinkedList<u8>> {
|
|
|
|
|
None
|
2015-08-21 18:40:36 +02:00
|
|
|
|
}
|
2021-08-12 13:15:15 +02:00
|
|
|
|
|
|
|
|
|
fn main() {}
|