A basic ini file parsing library that aims to be lightweight and easy to integrate. It relies only on the standard C library and uses some C99 functionality for safety.
- Read and/or write ini files.
- Easy integration, simply drop in one header and one source file, and you're set!
- No UTF8 support (ANSI only)
- Comments are limited to full line, end of line comments not supported.
- When reading and subsequently saving, any comments within the ini file are lost. (Refer to Issue #4)
- Some baffling decisions may have been made due to lack of sleep.
It's public domain under terms of the Unlicense. Refer to the bottom of the header and source files to read terms.
[test_group]
test1 = "this is a thing that can happen"
test2 = false
test4 = 3
[test_group_2]
test1 = 12.123123142
test2 = true
test3 = "This is a string that seems to go on for quite a while. Stay a while and listen, while I tell you about the majestic moose."
test4 = 0.0000123
/*
* Reading and writing a basic INI File:
*/
#include <stdio.h>
#define SBINI_IMPLEMENTATION
#include "sbini.h"
int main (int argc, char *argv[])
{
sbini_t *ini;
char string_buffer[256];
int integer;
float decimal;
int boolean;
ini = sbini_load("test.ini");
if (!ini) {
printf("Something has gone terribly wrong\n");
return -1;
}
/* No error checking for brevity, but each returns 0 on success, < 0 on error. */
sbini_get_string(ini, "test_group", "test1", string_buffer, 256);
sbini_get_int(ini, "test_group", "test4", &integer)
sbini_get_float(ini, "test_group_2", "test1", &decimal);
sbini_get_boolean(ini, "test_group_2", "test2", &boolean);
printf("String: %s\n", string_buffer);
printf("Integer: %d\n", integer);
printf("Float: %f\n", decimal);
printf("Boolean: %d\n", boolean);
sbini_set_boolean(ini, "newly_added", "testkey", 1);
sbini_set_float(ini, "newly_added", "anotherkey", 123.1234f);
sbini_set_int(ini, "newly_added", "whatisthis", 4003);
sbini_set_string(ini, "newly_added", "bass", "Rickenbacker 4003!");
sbini_save(ini, "output.ini"); // save changes
sbini_free(ini);
return 0;
}
[test_group]
test1 = "this is a thing that can happen"
test2 = false
test4 = 3
[test_group_2]
test1 = 12.123123123
test2 = true
test3 = "This is a string that seems to go on for quite a while. Stay a while and listen, while I tell you about the majestic moose."
test4 = 0.0000123
[newly_added]
testkey = true
anotherkey = 123.123398
whatisthis = 4003
bass = "Rickenbacker 4003!"
String: this is a thing that can happen
Integer: 3
Float: 12.123123
Boolean: 1