2.1 KiB
initial - INI parser for the D programming language
My attempt at making a sane and high-quality INI parsing library for D.
[section]
key = value
The contents of an INI file is stored in an INIUnit structure. This
contains an associative array of INISections that you can read or set
yourself.
initial also provides serialisation facilities that can turn INIUnits
and INISections back into an INI document. Handy for if your program
has some sort of GUI configuration interface or if you're passing around
INI through a network connection.
initial.d is licensed under the Boost Software License, version 1.0. See COPYING for the full licence text.
Demo
INIUnit ini;
/* write INI data to an INIUnit */
ini["section"]["key"] = "value";
ini["section"]["num"] = "4.8";
/* read INI data */
readINI(ini, `
[section]
num = 5.3
`);
assert(ini["section"]["key"] == "value");
assert(ini["section"]["num"] == "5.3");
/* read INI from file */
readINIFile(ini, "config.ini");
/* write INI to file */
import std.file : write;
write("config.ini", ini.serialise());
Usage
Copy initial.d to somewhere in your import path, then compile it alongside your program and link it in. Or you can do it all at once by using -i.
dmd program.d initial.d
dmd -i program.d
Documentation can be found by reading the documentation comments in the code.
Progress
Finished
- Keys
- Sections
- Default section
- Comments
Unimplemented
- Key referencing
Currently initial.d does all I need it to, and I consider it complete.
However if you have any questions, feel free to send an email to my
public inbox or directly to my address (jeremy@baxters.nz). Patches
are also welcome which you can generate with git format-patch and attach
to an email or just copy into the body of an email (git send-email
can do this automatically).