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

compile_warning! #3704

Open
trueb2 opened this issue Oct 1, 2024 · 3 comments
Open

compile_warning! #3704

trueb2 opened this issue Oct 1, 2024 · 3 comments

Comments

@trueb2
Copy link

trueb2 commented Oct 1, 2024

Related to #2902 and https://internals.rust-lang.org/t/pre-rfc-add-compile-warning-macro/9370, I want a compile_warning! macro that is similar to compile_error! except that it is not a hard error.

Here is a motivating use case. Say I have two barely compatible features, I would expect to be able to emit a warning based on my knowledge as a developer and experience with interface symmetry. However, it is not possible to do this:

#[cfg(all(feature = "feature_a", feature = "feature_b"))]
compile_warning!("Using 'feature_a' and 'feature_b' together is not recommended.");

There are many reasons why it may not be possible to have truly mutually exclusive features in Rust. I hit this a lot when trying to divvy up the limited static memory on microcontrollers.

I think the #[allow] and #[deny] points in the threads very relevant. It would be good feedback to someone building the crate to see the warning once, then be able to silence the warning. For example:
In a library crate:

#[cfg(all(feature = "feature_a", feature = "feature_b"))]
compile_warning!(foobar, "Using 'feature_a' and 'feature_b' together is not recommended.");

In the consuming crate:

// We checked we want this ill-advised configuration
#[allow(foobar)]
@trueb2
Copy link
Author

trueb2 commented Oct 1, 2024

My workaround to generate the warnings at the moment looks like this

// Emit a warning if neither 'feature_a' nor 'feature_b' is enabled
#[cfg(not(any(feature = "feature_a", feature = "feature_b")))]
fn emit_warning() {
    let warning = "Warning: Neither 'feature_a' nor 'feature_b' feature is set";
}

This gives me a warning (which is more important than silence). On the downside, I don't have a way to override that this is acceptable, and the function names conflict with each copy paste.

warning: unused variable: `warning`
  --> src/bin/asdf:27:9
   |
27 |     let warning = "Warning: Neither 'feature_a' nor 'feature_b' feature is set";
   |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_warning`
   |
   = note: `#[warn(unused_variables)]` on by default

warning: function `emit_warning` is never used
  --> src/bin/asdf:26:4
   |
26 | fn emit_warning() {
   |    ^^^^^^^^^^^^
   |
   = note: `#[warn(dead_code)]` on by default

@LunarLambda
Copy link

Worth noting that by default, cargo does not emit warnings in dependencies, so a compile_warning macro by itself would most likely not be useful for library authors, and I'm not sure if cargo install shows warnings for the binary crate(s) being installed either.

@trueb2
Copy link
Author

trueb2 commented Oct 15, 2024

Good point. It does emit warnings if the library and binary target are in the same workspace, which I find common for embedded project structures.

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

No branches or pull requests

2 participants