IxMilia.Config
A portable .NET library for reading and writing INI-style configuration files.
Usage
Configuration handling is implemented as a set of extension methods on string
and IDictionary<string, string>
to enable maximum portability. Key/value
pairs are reflected in the <section-name>.<key-name> = <value>
format. E.g.,
Given the following file:
[heading1]
key1 = value1
key2 = value2
[heading2]
key3 = value3
The following dictionary mappings will be produced:
"heading1.key1" => "value1"
"heading1.key2" => "value2"
"heading2.key3" => "value3"
To read a config file from disk:
using System.Collections.Generic;
using System.IO;
using IxMilia.Config;
// ...
string[] lines = File.ReadAllLines(@"C:\Path\To\File.config");
IDictionary<string, string> dict = new Dictionary<string, string>();
dict.ParseConfig(lines);
Other extension methods are provided to aid in parsing out the individual string values, such as:
<string>.TryParseValue()
<string>.TryParseAssign()
<IDictionary<string, string>>.TryParseValue()
<IDictionary<string, string>>.TryParseAssign()
When writing a file back to disk you have the option of provding the original lines from the file which will preserve as much of the original file's structure as possible.
using System.Collections.Generic;
using System.IO;
using IxMilia.Config;
// ...
IDictionary<string, string> dict = ...;
string configText;
string configFilePath = @"C:\Path\To\File.config";
if (<preserve structure>)
{
// read in the existing lines to try to copy the original file's structure
string[] existingLines = File.ReadAllLines(configFilePath);
configText = dict.WriteConfig(existingLines);
}
else
{
// don't preserve any structure
configText = dict.WriteConfig();
}
// write the new contents
File.WriteAllText(configFilePath, configText);
Building locally
To build locally, install the latest .NET Core 3.0 SDK.
Integration
All relevant code is in the src\IxMilia.Config\ConfigExtensions.cs
file so you
can either build and link against the assembly or directly include in your project
just by copying one file.