Don't trigger needless_return lint in macros

This commit is contained in:
flip1995 2021-01-15 10:41:29 +01:00
parent 0c5ba9a883
commit f18cf82ca8
No known key found for this signature in database
GPG key ID: 1CA0DF2AF59D68A5
3 changed files with 33 additions and 0 deletions

View file

@ -86,6 +86,21 @@ fn borrows_but_not_last(value: bool) -> String {
}
}
macro_rules! needed_return {
($e:expr) => {
if $e > 3 {
return;
}
};
}
fn test_return_in_macro() {
// This will return and the macro below won't be executed. Removing the `return` from the macro
// will change semantics.
needed_return!(10);
needed_return!(0);
}
fn main() {
let _ = test_end_of_fn();
let _ = test_no_semicolon();

View file

@ -86,6 +86,21 @@ fn borrows_but_not_last(value: bool) -> String {
}
}
macro_rules! needed_return {
($e:expr) => {
if $e > 3 {
return;
}
};
}
fn test_return_in_macro() {
// This will return and the macro below won't be executed. Removing the `return` from the macro
// will change semantics.
needed_return!(10);
needed_return!(0);
}
fn main() {
let _ = test_end_of_fn();
let _ = test_no_semicolon();