tblgen

Module error

source
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::{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§

Enums§

Traits§

Type Aliases§