ini-merge

Crates.ioini-merge
lib.rsini-merge
version0.6.0
sourcesrc
created_at2023-04-07 13:15:44.396861
updated_at2024-09-06 20:11:00.468337
descriptionLibrary to merge ini files subject to configuration.
homepage
repositoryhttps://github.com/VorpalBlade/ini-merge
max_upload_size
id832921
size72,313
Arvid Norlander (VorpalBlade)

documentation

README

Library to merge INI files subject to configuration

[ crates.io ] [ lib.rs ] [ docs.rs ]

This library forms the backend to chezmoi_modify_manager. You probably want that tool instead.

This library provides processing of INI files. In particular:

  • Merging of a source INI file with a target INI file. The merging is asymmetric: The values of the source are preferred unless specific rules have been provided for those sections and/or keys. Formatting is preserved.
  • Filtering of an INI file based on a rule set

The use case of this is configuration management for user settings file where the program writes a mix of settings and state to the same file. This gets messy if we want to track the settings part in git using a tool like chezmoi.

A typical example of this is KDE settings files. These contain (apart from settings) state like recently opened files and positions of windows and dialog boxes. Other programs (such as PrusaSlicer) also do the same thing.

This library can be used as a backend to implement a tool to smartly merge such INI files. Such a tool is already available: chezmoi_modify_manager.

MSRV

Current minimum supported Rust version is 1.75.0. This may be updated as needed. MSRV bump is not considered a semver breaking change.

Commit count: 117

cargo fmt