2023-07-27 13:23:04 +00:00
|
|
|
//@aux-build:proc_macro_derive.rs
|
2020-01-08 16:31:27 +00:00
|
|
|
|
2024-04-08 12:12:32 +00:00
|
|
|
#![allow(unused, clippy::duplicated_attributes)]
|
2020-01-08 16:31:27 +00:00
|
|
|
#![warn(clippy::useless_attribute)]
|
|
|
|
#![warn(unreachable_pub)]
|
|
|
|
#![feature(rustc_private)]
|
|
|
|
|
|
|
|
#![allow(dead_code)]
|
2024-02-14 16:51:45 +00:00
|
|
|
#![cfg_attr(clippy, allow(dead_code))]
|
2020-01-08 16:31:27 +00:00
|
|
|
#[rustfmt::skip]
|
|
|
|
#[allow(unused_imports)]
|
|
|
|
#[allow(unused_extern_crates)]
|
|
|
|
#[macro_use]
|
2020-03-30 09:02:14 +00:00
|
|
|
extern crate rustc_middle;
|
2020-01-08 16:31:27 +00:00
|
|
|
|
|
|
|
#[macro_use]
|
|
|
|
extern crate proc_macro_derive;
|
|
|
|
|
2022-11-19 18:13:17 +00:00
|
|
|
fn test_indented_attr() {
|
|
|
|
#![allow(clippy::almost_swapped)]
|
|
|
|
use std::collections::HashSet;
|
|
|
|
|
|
|
|
let _ = HashSet::<u32>::default();
|
|
|
|
}
|
|
|
|
|
2020-01-08 16:31:27 +00:00
|
|
|
// don't lint on unused_import for `use` items
|
|
|
|
#[allow(unused_imports)]
|
|
|
|
use std::collections;
|
|
|
|
|
2020-03-02 09:22:05 +00:00
|
|
|
// don't lint on unused for `use` items
|
|
|
|
#[allow(unused)]
|
|
|
|
use std::option;
|
|
|
|
|
2020-01-08 16:31:27 +00:00
|
|
|
// don't lint on deprecated for `use` items
|
|
|
|
mod foo {
|
|
|
|
#[deprecated]
|
|
|
|
pub struct Bar;
|
|
|
|
}
|
|
|
|
#[allow(deprecated)]
|
|
|
|
pub use foo::Bar;
|
|
|
|
|
|
|
|
// This should not trigger the lint. There's lint level definitions inside the external derive
|
|
|
|
// that would trigger the useless_attribute lint.
|
|
|
|
#[derive(DeriveSomething)]
|
|
|
|
struct Baz;
|
|
|
|
|
|
|
|
// don't lint on unreachable_pub for `use` items
|
|
|
|
mod a {
|
|
|
|
mod b {
|
|
|
|
#[allow(dead_code)]
|
|
|
|
#[allow(unreachable_pub)]
|
2022-03-27 12:41:09 +00:00
|
|
|
pub struct C;
|
2020-01-08 16:31:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[allow(unreachable_pub)]
|
|
|
|
pub use self::b::C;
|
|
|
|
}
|
|
|
|
|
2020-09-01 03:09:32 +00:00
|
|
|
// don't lint on clippy::wildcard_imports for `use` items
|
|
|
|
#[allow(clippy::wildcard_imports)]
|
|
|
|
pub use std::io::prelude::*;
|
|
|
|
|
|
|
|
// don't lint on clippy::enum_glob_use for `use` items
|
|
|
|
#[allow(clippy::enum_glob_use)]
|
|
|
|
pub use std::cmp::Ordering::*;
|
|
|
|
|
2022-04-23 11:23:18 +00:00
|
|
|
// don't lint on clippy::redundant_pub_crate
|
|
|
|
mod c {
|
|
|
|
#[allow(clippy::redundant_pub_crate)]
|
|
|
|
pub(crate) struct S;
|
|
|
|
}
|
|
|
|
|
2022-11-19 18:13:17 +00:00
|
|
|
// https://github.com/rust-lang/rust-clippy/issues/7511
|
|
|
|
pub mod split {
|
|
|
|
#[allow(clippy::module_name_repetitions)]
|
|
|
|
pub use regex::SplitN;
|
2020-01-08 16:31:27 +00:00
|
|
|
}
|
|
|
|
|
2022-11-19 18:13:17 +00:00
|
|
|
// https://github.com/rust-lang/rust-clippy/issues/8768
|
|
|
|
#[allow(clippy::single_component_path_imports)]
|
|
|
|
use regex;
|
|
|
|
|
2024-02-22 20:53:04 +00:00
|
|
|
mod module {
|
|
|
|
pub(crate) struct Struct;
|
|
|
|
}
|
|
|
|
|
|
|
|
#[rustfmt::skip]
|
2024-02-22 22:12:38 +00:00
|
|
|
#[allow(unused_import_braces)]
|
2024-05-02 18:56:05 +00:00
|
|
|
#[allow(unused_braces)]
|
2024-02-22 20:53:04 +00:00
|
|
|
use module::{Struct};
|
|
|
|
|
2020-01-08 16:31:27 +00:00
|
|
|
fn main() {
|
|
|
|
test_indented_attr();
|
|
|
|
}
|