diff options
| author | Georg Semmler <github@weiznich.de> | 2024-05-04 14:26:24 +0200 |
|---|---|---|
| committer | Georg Semmler <github@weiznich.de> | 2024-05-19 08:29:27 +0200 |
| commit | 9b45cfdbdde020682d167ffd9f512fd8401d8cfe (patch) | |
| tree | 2a40ffc0d41a681900e75d00ebeeff8a554e261f /compiler/rustc_codegen_llvm/src/errors.rs | |
| parent | bfa3635df920454cdf03f6d268dfaac769375df3 (diff) | |
| download | rust-9b45cfdbdde020682d167ffd9f512fd8401d8cfe.tar.gz rust-9b45cfdbdde020682d167ffd9f512fd8401d8cfe.zip | |
Actually use the `#[do_not_recommend]` attribute if present
This change tweaks the error message generation to actually use the
`#[do_not_recommend]` attribute if present by just skipping the marked
trait impl in favour of the parent impl. It also adds a compile test for
this behaviour. Without this change the test would output the following
error:
```
error[E0277]: the trait bound `&str: Expression` is not satisfied
--> /home/weiznich/Documents/rust/rust/tests/ui/diagnostic_namespace/do_not_recommend.rs:53:15
|
LL | SelectInt.check("bar");
| ^^^^^ the trait `Expression` is not implemented for `&str`, which is required by `&str: AsExpression<Integer>`
|
= help: the following other types implement trait `Expression`:
Bound<T>
SelectInt
note: required for `&str` to implement `AsExpression<Integer>`
--> /home/weiznich/Documents/rust/rust/tests/ui/diagnostic_namespace/do_not_recommend.rs:26:13
|
LL | impl<T, ST> AsExpression<ST> for T
| ^^^^^^^^^^^^^^^^ ^
LL | where
LL | T: Expression<SqlType = ST>,
| ------------------------ unsatisfied trait bound introduced here
```
Note how that mentions `&str: Expression` before and now mentions `&str:
AsExpression<Integer>` instead which is much more helpful for users.
Open points for further changes before stabilization:
* We likely want to move the attribute to the `#[diagnostic]` namespace
to relax the guarantees given?
* How does it interact with the new trait solver?
Diffstat (limited to 'compiler/rustc_codegen_llvm/src/errors.rs')
0 files changed, 0 insertions, 0 deletions
