k2v(key-to-value) is a very very simple config file format.
It's simple, rigid, without super cow power, and maybe stupid.
It only designed for one purpose:
- Get the
value
of thekey
.
* We will always use a (char *)key to get the value.
* The comment line starts with `#`.
* All the value should be wrapped by `"`, and do not use `'`.
* Don't nest `""` within the value, you can use `''` if you really need.
* You can also use '\"', but the output will also contain the '\', as '\"'.
* And use '\\' for '\', because the first '\' will be removed after parsing.
* '\n', '\t' and '\r' will be kept.
* The key should not be wrapped.
* The end of a line is '\n', and will not contain `;` or `,`.
* The array is wrapped by `[]`,and each value should be separated by `,`.
* The value in array should not be `""` (the array should not contain NULL value).
* It does not support multi-line, so use single line for one key/value pair.
* Use ASCII only, unicode including "\0" is not allowed as strlen() cannot recognize it.
# Bool value.
bool_val="true"
# String.
char_val="string"
# Int.
int_val="114514"
# float.
float_val="19.19810"
# Int array.
int_array_val=["1","2","3"]
# float array.
float_array_val=["1.0","2.0","3.0"]
# Char array.
char_array_val=["string1","string2","string3"]
test/hello.conf:
string="Hello world!"
test/hello.c:
#include "../src/include/k2v.h"
int main(void)
{
// Get buffer size.
size_t filesize = k2v_get_filesize("./test/hello.conf");
// Read the config to memory.
char *buf = k2v_open_file("./test/hello.conf", filesize);
// Get the value of `string`.
char *str = key_get_char("string", buf);
// Print the value.
printf("%s\n", str);
// libk2v will automatically allocate memory.
// Do not forget to free(2) the memory after using it.
free(buf);
free(str);
}
Compile, and run:
~/libk2v # cc -lk2v test/hello.c
~/libk2v # ./a.out
Hello world!
~/libk2v #
You can just simply include the k2v.c and k2v.h files in your project.
ruri/src/rurienv.c ruri/src/config.c
char *key_get_char(const char *_Nonnull key, const char *_Nonnull buf);
int key_get_int(const char *_Nonnull key, const char *_Nonnull buf);
float key_get_float(const char *_Nonnull key, const char *_Nonnull buf);
bool key_get_bool(const char *_Nonnull key, const char *_Nonnull buf);
int key_get_int_array(const char *_Nonnull key, const char *_Nonnull buf, int *_Nonnull array, int limit);
int key_get_char_array(const char *_Nonnull key, const char *_Nonnull buf, char *_Nonnull array[], int limit);
int key_get_float_array(const char *_Nonnull key, const char *_Nonnull buf, float *_Nonnull array, int limit);
bool have_key(const char *_Nonnull key, const char *_Nonnull buf);
char *k2v_open_file(const char *_Nonnull path, size_t bufsize);
char *char_to_k2v(const char *_Nonnull key, const char *val);
char *int_to_k2v(const char *_Nonnull key, int val);
char *bool_to_k2v(const char *_Nonnull key, bool val);
char *float_to_k2v(const char *_Nonnull key, float val);
char *char_array_to_k2v(const char *_Nonnull key, char *const *_Nonnull val, int len);
char *int_array_to_k2v(const char *_Nonnull key, int *_Nonnull val, int len);
char *float_array_to_k2v(const char *_Nonnull key, float *_Nonnull val, int len);
size_t k2v_get_filesize(const char *_Nonnull path);
char *k2v_add_comment(char *_Nullable buf, char *_Nonnull comment);
char *k2v_add_newline(char *_Nonnull buf);
// This is a macro.
k2v_get_key(type, ...);
// This is a macro and it need GNU C.
char * k2v_add_config(type, __k2v_buf, ...);
For usage, see test/test.c.
// Exit when the config file have unrecognized lines.
// Default: false
extern bool k2v_stop_at_warning;
// Show warning when the config file have unrecognized lines.
// Default: true.
extern bool k2v_show_warning;
K2V is designed only for small config files, it need not to be very fast for large config files.
This is testk2v program with 46 lines of confing.
0.02s user 0.04s system 70% cpu 0.086 total