Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

WIP New lint: borrowed_option #11463

Draft
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

tom-anders
Copy link
Contributor

@tom-anders tom-anders commented Sep 4, 2023

This is inspired by this excellent video: https://www.youtube.com/watch?v=6c7pZYP_iIE

Some things I'd appreciate feedback on:

  • I've added this to the borrowed_box.rs check, since these two lints would share a lot of common code. We should probably rename that file, but to what? borrowed_box_or_option.rs? (same goes for the tests) (Edit: looks like the corresponding issue has been closed for now, so let's keep it like it is for now?
  • There's a special case for ignoring &Box<Any> (see borrowed_box lint and Any #1884), I'm not sure if this is needed for &Option<Any> as well.
  • The wording of What it does and Why is this bad could probably use some improvements, suggestions are welcome!

changelog: new lint: [borrowed_option]
#11463

@rustbot
Copy link
Collaborator

rustbot commented Sep 4, 2023

Thanks for the pull request, and welcome! The Rust team is excited to review your changes, and you should hear from @blyxyas (or someone else) soon.

Please see the contribution instructions for more information. Namely, in order to ensure the minimum review times lag, PR authors and assigned reviewers should ensure that the review label (S-waiting-on-review and S-waiting-on-author) stays updated, invoking these commands when appropriate:

  • @rustbot author: the review is finished, PR author should check the comments and take action accordingly
  • @rustbot review: the author is ready for a review, this PR will be queued again in the reviewer's queue

@rustbot rustbot added the S-waiting-on-review Status: Awaiting review from the assignee but also interested parties label Sep 4, 2023
@blyxyas blyxyas marked this pull request as draft September 4, 2023 15:36
@Centri3
Copy link
Member

Centri3 commented Sep 4, 2023

Regarding &Option<dyn Any>, we don't need the same check since T must be Sized. It's impossible to use &Option<dyn Any>, only &Option<Box<dyn Any>> (or anything else that introduces indirection). This will then suggest Option<&Box<dyn Any>> which is already checked for in the borrowed_box lint.

The lint documentation should provide examples of why it does this (this i.e. exposes implementation details). The example given is fine, but some who aren't too familiar with the borrow checker may question why this exposes implementation details.

@blyxyas
Copy link
Member

blyxyas commented Sep 7, 2023

I've added this to the borrowed_box.rs check, since these two lints would share a lot of common code. We should probably rename that file, but to what? borrowed_box_or_option.rs? (same goes for the tests)

We should probably make a new lint type for borrows and references. cc #11464
I currently have a mildly long review queue, so it will take some days. Until that lint type is created, I'll review this independently ^w^

clippy_lints/src/types/mod.rs Outdated Show resolved Hide resolved
clippy_lints/src/types/mod.rs Outdated Show resolved Hide resolved
clippy_lints/src/types/mod.rs Outdated Show resolved Hide resolved
@bors
Copy link
Contributor

bors commented Oct 23, 2023

☔ The latest upstream changes (presumably #11460) made this pull request unmergeable. Please resolve the merge conflicts.

kawadakk added a commit to kawadakk/arrow-datafusion that referenced this pull request Dec 21, 2023
alamb added a commit to apache/datafusion that referenced this pull request Dec 22, 2023
* Take `&str` instead of `&String` in `ParamValue::get_placeholders_with_values`

<https://rust-lang.github.io/rust-clippy/master/index.html#/ptr_arg>

* Take `Option<&DataType>` instead of `&Option<DataType>` in `ParamValue::get_placeholders_with_values`

<rust-lang/rust-clippy#11463>

* Take `&[_]` instead of `&Vec<_>` in `ParamValues::verify`

<https://rust-lang.github.io/rust-clippy/master/index.html#/ptr_arg>

---------

Co-authored-by: Andrew Lamb <[email protected]>
@xFrednet
Copy link
Member

Hey @tom-anders, this is a ping from triage, since there hasn't been any activity in some time. Could you rebase the branch on master?

If you have any questions, you're always welcome to ask them in this PR or on Zulip.

@rustbot author

@rustbot rustbot added S-waiting-on-author Status: This is awaiting some action from the author. (Use `@rustbot ready` to update this status) and removed S-waiting-on-review Status: Awaiting review from the assignee but also interested parties labels Mar 29, 2024
@tom-anders
Copy link
Contributor Author

@xFrednet Thanks for the reminder! I rebased and also incorporated @blyxyas's suggestions

@tom-anders
Copy link
Contributor Author

(fixed formatting)

@xFrednet
Copy link
Member

Perfect, thank you for the swift update :D

@rustbot ready

@rustbot rustbot added S-waiting-on-review Status: Awaiting review from the assignee but also interested parties and removed S-waiting-on-author Status: This is awaiting some action from the author. (Use `@rustbot ready` to update this status) labels Mar 29, 2024
@xFrednet
Copy link
Member

Hey, this is a ping from triage. @blyxyas can you give this PR a review? It's totally fine if you don't have the time right now, you can reassign the PR to a random team member using r? clippy.

@rustbot ready

@xFrednet
Copy link
Member

Hey, this is triage: It looks like @blyxyas is currently busy, let's pick a new reviewer.

r? clippy

@rustbot rustbot assigned Alexendoo and unassigned blyxyas Jul 23, 2024
@@ -9,7 +9,7 @@

use std::fmt::Display;

pub fn test1(foo: &mut Box<bool>) {
pub fn test1(foo: &mut Box<bool>, bar: &mut Option<bool>) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The tests for borrowed_option should go in a new test file

Comment on lines +196 to +198
/// An `&Option<T>` parameter prevents calling the function if the caller holds a different type, e.g. `Result<T, E>`.
/// Using `Option<&T>` generalizes the function, e.g. allowing to pass `res.ok().as_ref()`
/// Returning `&Option<T>` needlessly exposes implementation details and has no advantage over `Option<&T>`.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You could mention that &Option<T> requires dereferencing to determine the variant whereas Option<&T> does not

Comment on lines +201 to +215
/// ```rust,compile_fail
/// fn foo(bar: &Option<i32>) -> &Option<i32> { bar }
/// fn call_foo(bar: &Result<i32, ()>) {
/// foo(bar.ok()); // does not work
/// }
/// ```
///
/// Use instead:
///
/// ```rust
/// fn foo(bar: Option<&i32>) -> Option<&i32> { bar }
/// fn call_foo(bar: &Result<i32, ()>) {
/// foo(bar.ok().as_ref()); // works!
/// }
/// ```
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's go with a String or anything !Copy rather than i32 to demonstrate the issue

@bors
Copy link
Contributor

bors commented Sep 25, 2024

☔ The latest upstream changes (presumably #13442) made this pull request unmergeable. Please resolve the merge conflicts.

@Alexendoo Alexendoo added S-waiting-on-author Status: This is awaiting some action from the author. (Use `@rustbot ready` to update this status) and removed S-waiting-on-review Status: Awaiting review from the assignee but also interested parties labels Sep 25, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
S-waiting-on-author Status: This is awaiting some action from the author. (Use `@rustbot ready` to update this status)
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants