| # `ErrorGuaranteed` |
| The previous sections have been about the error message that a user of the |
| compiler sees. But emitting an error can also have a second important side |
| effect within the compiler source code: it generates an |
| [`ErrorGuaranteed`][errorguar]. |
| |
| `ErrorGuaranteed` is a zero-sized type that is unconstructable outside of the |
| [`rustc_errors`][rerrors] crate. It is generated whenever an error is reported |
| to the user, so that if your compiler code ever encounters a value of type |
| `ErrorGuaranteed`, the compilation is _statically guaranteed to fail_. This is |
| useful for avoiding unsoundness bugs because you can statically check that an |
| error code path leads to a failure. |
| |
| There are some important considerations about the usage of `ErrorGuaranteed`: |
| |
| * It does _not_ convey information about the _kind_ of error. For example, the |
| error may be due (indirectly) to a delayed bug or other compiler error. |
| Thus, you should not rely on |
| `ErrorGuaranteed` when deciding whether to emit an error, or what kind of error |
| to emit. |
| * `ErrorGuaranteed` should not be used to indicate that a compilation _will |
| emit_ an error in the future. It should be used to indicate that an error |
| _has already been_ emitted -- that is, the [`emit()`][emit] function has |
| already been called. For example, if we detect that a future part of the |
| compiler will error, we _cannot_ use `ErrorGuaranteed` unless we first emit |
| an error or delayed bug ourselves. |
| |
| Thankfully, in most cases, it should be statically impossible to abuse |
| `ErrorGuaranteed`. |
| |
| [errorguar]: https://doc.rust-lang.org/nightly/nightly-rustc/rustc_errors/struct.ErrorGuaranteed.html |
| [rerrors]: https://doc.rust-lang.org/nightly/nightly-rustc/rustc_errors/index.html |
| [emit]: https://doc.rust-lang.org/nightly/nightly-rustc/rustc_errors/diagnostic/struct.Diag.html#method.emit |