rust-clippy/tests/ui/double_must_use.rs
2024-08-09 01:35:28 +05:00

43 lines
1.1 KiB
Rust

#![warn(clippy::double_must_use)]
#![allow(clippy::result_unit_err)]
#[must_use]
pub fn must_use_result() -> Result<(), ()> {
//~^ ERROR: this function has a `#[must_use]` attribute with no message, but returns a type already
unimplemented!();
}
#[must_use]
pub fn must_use_tuple() -> (Result<(), ()>, u8) {
//~^ ERROR: this function has a `#[must_use]` attribute with no message, but returns a type already
unimplemented!();
}
#[must_use]
pub fn must_use_array() -> [Result<(), ()>; 1] {
//~^ ERROR: this function has a `#[must_use]` attribute with no message, but returns a type already
unimplemented!();
}
#[must_use = "With note"]
pub fn must_use_with_note() -> Result<(), ()> {
unimplemented!();
}
// vvvv Should not lint (#10486)
#[must_use]
async fn async_must_use() -> usize {
unimplemented!();
}
#[must_use]
async fn async_must_use_result() -> Result<(), ()> {
//~^ ERROR: this function has a `#[must_use]` attribute with no message, but returns a type already
Ok(())
}
fn main() {
must_use_result();
must_use_tuple();
must_use_with_note();
}