Expand description
This module contains error types used by this crate and provides additional error handling utilities for dependent crates.
Disclaimer: this module may change significantly in the future.
All different error types are defined in the TableGenError
enum.
However, most functions return a SourceError<TableGenError>
(has alias
Error
). This error type includes a SourceLocation
, a reference to a
line in a TableGen source file.
To provide information about the source code at this location (e.g. code at
location, file name, line and column), SourceInfo
must be provided to
the error. In this case, the error message will be formatted by LLVM’s
SourceMgr
class.
use tblgen_alt::{TableGenParser, RecordKeeper};
let keeper: RecordKeeper = TableGenParser::new()
.add_source(
r#"
def A {
int i = 5;
}
"#,
)?
.parse()?;
if let Err(e) = keeper.def("A").unwrap().string_value("i") {
println!("{}", e);
// invalid conversion from Int to alloc::string::String
println!("{}", e.add_source_info(keeper.source_info()));
// error: invalid conversion from Int to alloc::string::String
// int a = test;
// ^
}
Note that add_source_info
should be called with the correct source info.
This is not statically enforced, but runtime checks are implemented to check
that the given SourceInfo
matches the SourceLocation
in the error.
If it does not match, the error will be printed without information about
the TableGen source file.
Custom error types that implement std::error::Error
also implement
WithLocation
. That way, a SourceLocation
can be attached to any
error by calling with_location
.
Structs§
- A wrapper around error types which includes a
SourceLocation
. - A location in a TableGen source file.
Enums§
- Enum of TableGen errors.
Traits§
Type Aliases§
- Main error type.