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

Cap lints at warn when cargo installing #6647

Closed
wants to merge 1 commit into from

Conversation

dwijnand
Copy link
Member

@dwijnand dwijnand commented Feb 9, 2019

Fixes #3453

@rust-highfive
Copy link

r? @ehuss

(rust_highfive has picked a reviewer for you, use r? to override)

@ehuss
Copy link
Contributor

ehuss commented Feb 12, 2019

I've been pondering this, since I feel a little uncomfortable with how CompileMode is doing double-duty and is somewhat overloaded. I find it confusing in lower-level code where some variants of mode are not applicable, and likewise in higher-level code some variants aren't valid.

However, I can't think of a clearly better way to handle it. CompileMode could be split into two enums, but the majority of variants would be the same between them.

What do you think about, instead of adding a new mode, add --cap-lints=warn to BuildConfig::extra_rustc_args? It may not be very elegant, but I think it should work. Alternatively, maybe in the future, there could be something that manages configuring lints (such as via external files), and that could have the ability to configure things like this.

@dwijnand
Copy link
Member Author

I tried that approach first but there's a condition later that errors. Something about single crates? My use case passed if I torn out the condition, but I assumed it was there for a reason.

I don't get CompileMode either.

@ehuss
Copy link
Contributor

ehuss commented Feb 12, 2019

I tried that approach first but there's a condition later that errors. Something about single crates? My use case passed if I torn out the condition, but I assumed it was there for a reason.

Are you maybe thinking of CompileOptions::target_rustc_args? That's another way of passing args (for cargo rustc), and has a side-effect of enforcing compiling a single target only. (It's a bit odd, and that could probably be done in a better way.). BuildConfig::extra_rustc_args is currently unused directly by Cargo and is just a simple way to add more arguments to all rustc invocations. It shouldn't cause any errors.

@dwijnand
Copy link
Member Author

Yeah that sounds familiar. Ok, I'll try the other way.

@dwijnand dwijnand changed the title Add CompileMode::Install to cap lints at warn when installing Cap lints at warn when cargo installing Feb 12, 2019
@dwijnand
Copy link
Member Author

@ehuss this is now a 1-line change. WDYT?

@ehuss
Copy link
Contributor

ehuss commented Feb 14, 2019

Hm, I'm sorry, I was mistaken about something. With this change, warnings will be displayed for all dependencies (normally they are cap-lint allow). I was thinking that rustc would only honor the last --cap-lints on the command line, but it looks like it honors the first.

Personally I would try to go with the simplest approach, at least for resolving the issue. I'm thinking maybe just adding a flag to BuildContext that BuildContext::show_warnings could check. Sort of a global way to set --cap-lints=allow. It could be a simple bool, or something more sophisticated (like a way to control the lint level). I would probably just go with a simple bool, and in the future if we add more sophisticated lint controls, it could be extended as needed. How does that sound?

@dwijnand
Copy link
Member Author

I was thinking that rustc would only honor the last --cap-lints on the command line, but it looks like it honors the first.

I'm with you on that assumption. Sounds like a bug in rustc.

How does that sound?

I'm generally anti "boolean blindness". Seeing as you describe it as "set cap lints allow" I'd just call it cap lints and represent allow as a value. I'll propose it and we can go back to boolean if not.

@dwijnand dwijnand requested a review from ehuss February 15, 2019 17:01
@bors
Copy link
Contributor

bors commented Feb 20, 2019

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

@ehuss
Copy link
Contributor

ehuss commented Feb 25, 2019

Just to be clear, this only affects cargo install --path? Why should that behave particularly differently from cargo build, since it is a local project? I don't see a reason it should behave differently in that case.
I feel like #3453 was fixed in 1.15, which started passing cap-lints (I think maybe as a side effect of #3221).

@dwijnand
Copy link
Member Author

I was testing with cargo install --path . but if you're saying that #3453 is already fixed then this PR isn't needed. Thanks for working with me on this, @ehuss.

@dwijnand dwijnand closed this Feb 25, 2019
@dwijnand dwijnand deleted the errorless-installs branch February 25, 2019 22:11
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants