docs: introduce primary param in label (#413)

This commit is contained in:
bohan 2025-03-02 09:55:37 +08:00 committed by GitHub
parent 9ba6fad769
commit a93afcf7e3
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 32 additions and 0 deletions

View File

@ -51,6 +51,7 @@ diagnostic error code: ruget::api::bad_json
- [... handler options](#-handler-options)
- [... dynamic diagnostics](#-dynamic-diagnostics)
- [... syntax highlighting](#-syntax-highlighting)
- [... primary label](#-primary-label)
- [... collection of labels](#-collection-of-labels)
- [Acknowledgements](#acknowledgements)
- [License](#license)
@ -689,6 +690,37 @@ trait to [`MietteHandlerOpts`] by calling the
[`with_syntax_highlighting`](MietteHandlerOpts::with_syntax_highlighting)
method. See the [`highlighters`] module docs for more details.
#### ... primary label
You can use the `primary` parameter to `label` to indicate that the label
is the primary label.
```rust
#[derive(Debug, Diagnostic, Error)]
#[error("oops!")]
struct MyError {
#[label(primary, "main issue")]
primary_span: SourceSpan,
#[label("other label")]
other_span: SourceSpan,
}
```
The `primary` parameter can be used at most once:
```rust
#[derive(Debug, Diagnostic, Error)]
#[error("oops!")]
struct MyError {
#[label(primary, "main issue")]
primary_span: SourceSpan,
#[label(primary, "other label")] // Error: Cannot have more than one primary label.
other_span: SourceSpan,
}
```
#### ... collection of labels
When the number of labels is unknown, you can use a collection of `SourceSpan`