#config-file #config-parser #nix #file-format #error

nix-config-parser

A simple parser for the Nix configuration file format

4 releases

0.2.0 Oct 3, 2023
0.1.3 May 11, 2023
0.1.2 Mar 2, 2023
0.1.1 Feb 27, 2023
0.1.0 Feb 27, 2023

#1519 in Parser implementations

Download history 12/week @ 2023-12-14 8/week @ 2023-12-21 49/week @ 2023-12-28 61/week @ 2024-01-04 20/week @ 2024-01-11 10/week @ 2024-01-18 45/week @ 2024-01-25 6/week @ 2024-02-01 18/week @ 2024-02-08 47/week @ 2024-02-15 58/week @ 2024-02-22 24/week @ 2024-02-29 32/week @ 2024-03-07 22/week @ 2024-03-14 45/week @ 2024-03-21 32/week @ 2024-03-28

132 downloads per month
Used in nix-installer

LGPL-2.1

19KB
220 lines

nix-config-parser

A simple parser for the Nix configuration file format.

Based off of https://github.com/NixOS/nix/blob/0079d2943702a7a7fbdd88c0f9a5ad677c334aa8/src/libutil/config.cc#L80-L138.

Usage

Read from a file

use std::error::Error;

fn main() -> Result<(), Box<dyn Error>> {
    std::fs::write(
       "nix.conf",
       b"experimental-features = flakes nix-command\nwarn-dirty = false\n",
    )?;

    let nix_conf = nix_config_parser::NixConfig::parse_file(&std::path::Path::new("nix.conf"))?;

    assert_eq!(
       nix_conf.settings().get("experimental-features").unwrap(),
       "flakes nix-command"
    );
    assert_eq!(nix_conf.settings().get("warn-dirty").unwrap(), "false");

    std::fs::remove_file("nix.conf")?;

    Ok(())
}

Read from a string

use std::error::Error;

fn main() -> Result<(), Box<dyn Error>> {
    let nix_conf_string = String::from("experimental-features = flakes nix-command");
    let nix_conf = nix_config_parser::NixConfig::parse_string(nix_conf_string, None)?;

    assert_eq!(
        nix_conf.settings().get("experimental-features").unwrap(),
        "flakes nix-command"
    );

    Ok(())
}

Dependencies

~1–1.8MB
~35K SLoC