#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

#1857 in Parser implementations

Download history 16/week @ 2024-01-15 25/week @ 2024-01-22 25/week @ 2024-01-29 11/week @ 2024-02-05 38/week @ 2024-02-12 53/week @ 2024-02-19 43/week @ 2024-02-26 23/week @ 2024-03-04 26/week @ 2024-03-11 34/week @ 2024-03-18 15/week @ 2024-03-25 84/week @ 2024-04-01 34/week @ 2024-04-08 25/week @ 2024-04-15 14/week @ 2024-04-22 55/week @ 2024-04-29

130 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
~34K SLoC