#toml-config #toml #toml-parser #static #proc-macro #embed

macro static-toml

Effortlessly embed TOML files into your Rust code as static data with custom data structures

5 stable releases

1.3.0 Dec 15, 2024
1.2.0 Nov 25, 2023
1.1.0 Nov 19, 2023
1.0.1 Jul 9, 2023
1.0.0 Jul 8, 2023

#140 in Configuration

Download history 108/week @ 2024-09-20 156/week @ 2024-09-27 84/week @ 2024-10-04 162/week @ 2024-10-11 162/week @ 2024-10-18 178/week @ 2024-10-25 401/week @ 2024-11-01 242/week @ 2024-11-08 228/week @ 2024-11-15 245/week @ 2024-11-22 255/week @ 2024-11-29 244/week @ 2024-12-06 401/week @ 2024-12-13 298/week @ 2024-12-20 443/week @ 2024-12-27 393/week @ 2025-01-03

1,603 downloads per month
Used in 5 crates (4 directly)

MIT license

63KB
1.5K SLoC

static-toml

Effortlessly embed TOML files into your Rust code as static data with custom data structures.


Version License Docs CI

About

Embed TOML files into your Rust binaries via a procedural macro. This library enables the inclusion of TOML files at compile-time and generates static data structures that can be directly accessed by your Rust code without the need for runtime parsing.

Key Features

  • πŸ“ Embed TOML configuration files effortlessly.
  • πŸ”¨ Generate reliable Rust data structures to represent your TOML contents.
  • πŸ”§ Customize your generated types with prefixes and suffixes for flexibility.
  • 🚦 Enjoy clear and concise compile-time error messages for easier debugging.

Usage

First, make sure to add static-toml to your Cargo.toml dependencies: Either by command line:

cargo add static-toml

Or by adding it to your Cargo.toml directly:

[dependencies]
static-toml = "1"

Then, make use of the static_toml! macro to include your TOML file:

# message.toml

[info]
welcome = "Welcome to our application!"
update = "Your data has been updated successfully."

[errors]
file_not_found = "The requested file could not be found."
permission_denied = "You do not have permission to perform this action."
static_toml::static_toml! {
    static MESSAGES = include_toml!("messages.toml");
}

const WELCOME_MESSAGE: &str = MESSAGES.info.welcome;

This will read your TOML file and generate Rust data structures accordingly. Now you can access the values from the TOML file with ease.

In addition to using static, the static_toml! macro also allows the use of const for embedding TOML data. This can be particularly useful in scenarios where a constant value is required, such as within const functions or for const generics. To use this feature, simply replace static with const in the macro call when necessary.

Customization Options

You can configure how the macro should generate data types:

static_toml! {
    #[static_toml(
        prefix = Prefix, 
        suffix = Suffix, 
        root_mod = cfg, 
        values_ident = items, 
        prefer_slices = false,
        auto_doc = true,
        cow
    )]
    static CONFIG = include_toml!("config.toml");
}
  • prefix: Adds a prefix to the generated data types. It's recommended to use PascalCase for the prefix.

  • suffix: Similar to prefix, but it’s a suffix.

  • root_mod: Sets the identifier for the root module that will contain the data types for the TOML file.

  • values_ident: When generating data types for arrays, this specifies a different name for the modules and data types (default is values).

  • prefer_slices: Determines whether the macro should generate fixed-size slices for arrays. If set to false, tuples will be generated (default is true).

  • auto_doc: Controls automatic documentation generation for the static item.

    • true: Always appends generated documentation, including file location and contents, after manual comments.

    • false: Always disables automatic documentation.

    • (default): If left out, the macro decides automatically. Manual comments will suppress auto-doc generation, while no comments will trigger it.

  • cow: Replaces static slices and arrays with std::borrow::Cow, allowing owned data (e.g., String, Vec<T>) instead of requiring 'static slices. Useful when modifying or filling structures dynamically.

Enhancing Your Types

You can use doc comments, derive attributes, and other attributes. Additionally, you can set visibility. Your code can be clean and descriptive.

static_toml! {
    /// The configuration.
    #[derive(Debug)]
    #[allow(missing_docs)]
    pub static CONFIG = include_toml!("config.toml");
}

Error Handling

Encounter compile errors? No worries. static-toml provides informative error messages, whether it's TOML parsing or file access issues.

Example

Suppose you have a simple TOML file like this:

# config.toml
[database]
url = "localhost"
port = 5432

Use the static_toml! macro:

static_toml! {
    static CONFIG = include_toml!("config.toml");
}

And just like that, you have Rust data structures ready to use.

assert_eq!(CONFIG.database.url, "localhost");
assert_eq!(CONFIG.database.port, 5432);

Dependencies

~0.9–1.5MB
~30K SLoC