mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-25 11:25:06 +00:00
Auto merge of #114656 - bossmc:rework-no-coverage-attr, r=oli-obk
Rework `no_coverage` to `coverage(off)` As discussed at the tail of https://github.com/rust-lang/rust/issues/84605 this replaces the `no_coverage` attribute with a `coverage` attribute that takes sub-parameters (currently `off` and `on`) to control the coverage instrumentation. Allows future-proofing for things like `coverage(off, reason="Tested live", issue="#12345")` or similar.
This commit is contained in:
commit
3bf4a576f8
2 changed files with 6 additions and 6 deletions
|
@ -239,7 +239,7 @@ pub const INERT_ATTRIBUTES: &[BuiltinAttribute] = &[
|
|||
template!(List: "address, kcfi, memory, thread"), DuplicatesOk,
|
||||
experimental!(no_sanitize)
|
||||
),
|
||||
gated!(no_coverage, Normal, template!(Word), WarnFollowing, experimental!(no_coverage)),
|
||||
gated!(coverage, Normal, template!(Word, List: "on|off"), WarnFollowing, experimental!(coverage)),
|
||||
|
||||
ungated!(
|
||||
doc, Normal, template!(List: "hidden|inline|...", NameValueStr: "string"), DuplicatesOk
|
||||
|
|
|
@ -3505,8 +3505,8 @@ This serves two purposes:
|
|||
"##,
|
||||
},
|
||||
Lint {
|
||||
label: "no_coverage",
|
||||
description: r##"# `no_coverage`
|
||||
label: "coverage",
|
||||
description: r##"# `coverage`
|
||||
|
||||
The tracking issue for this feature is: [#84605]
|
||||
|
||||
|
@ -3514,7 +3514,7 @@ The tracking issue for this feature is: [#84605]
|
|||
|
||||
---
|
||||
|
||||
The `no_coverage` attribute can be used to selectively disable coverage
|
||||
The `coverage` attribute can be used to selectively disable coverage
|
||||
instrumentation in an annotated function. This might be useful to:
|
||||
|
||||
- Avoid instrumentation overhead in a performance critical function
|
||||
|
@ -3524,14 +3524,14 @@ instrumentation in an annotated function. This might be useful to:
|
|||
## Example
|
||||
|
||||
```rust
|
||||
#![feature(no_coverage)]
|
||||
#![feature(coverage)]
|
||||
|
||||
// `foo()` will get coverage instrumentation (by default)
|
||||
fn foo() {
|
||||
// ...
|
||||
}
|
||||
|
||||
#[no_coverage]
|
||||
#[coverage(off)]
|
||||
fn bar() {
|
||||
// ...
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue