-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathREADME
105 lines (69 loc) · 3.03 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
Parse INI files directly by shell
=================================
In the shini (from "shell ini") we pay attention to those aspects:
1. **Portability**
The library code is expected to be written in portable shell, so you should be
able to parse code of this library in reasonable implementation (bash, dash,
ksh, and many more..).
2. **Performance**
Shini library is also optimized for performance, so it tries to (as long as
reasonably possible) stay "in-shell" and avoid fork() calls. If your INI
files aren't really fancy (spaces in keywords or special characters), there
are no forks at all (in future, it would be allowed to add O(1) fork calls
for portability detection - to allow per-shell-implementation optimizations).
3. **Minimal requirements**
To use this library, everything you need is your shell, and in some cases
'sha256sum' or 'sed' binaries (GNU sed && GNU coreutils). Those external
binaries are called when section names or keywords contain special characters
or white-spaces respectively. Leading/trailing spaces in statements' values
might lead to 'sed' usage.
The 'GNU sed' and 'GNU coreutils' are almost everywhere nowadays, though if
you can't use them -- avoid spaces and special characters in your INI files
and you should be fine. Use $SHINI_KW_SUMTOOL and $SHINI_SED variables to
respecify 'sha256sum' and 'sed' location.
4. **Allow C&P re-usability (bundling)**
You always should be able to just take the `shini.sh` file, and insert it
into any project (shini is LGPLv2+).
API
---
- `shini.sh` file to be sourced (or C&P'ed)
- call `shini_*` methods
- `$shini_*` variables are set as an output from API methods
- `SHINI_*` variables are configuration options
There's non-small symbol pollution after sourcing the code, and especially after
parsing some INI file. Those symbols should always be prefixed with `_*`, or
`__*`.
Example use-case
----------------
$ cat program.sh
. ./shini.sh
shini_parse your_file.ini
shini_get -s section_name keyword
echo "$shini_value"
$ cat your_file.ini
[section_name]
keyword=value
$ sh program.sh
value
Testing
-------
$ git clone --recursive https://github.com/praiskup/shini
$ cd shini
$ make check
RFEs
----
- Read-write access. So far shini supports read only access to ini files.
- Escaping. Statements like `var="value"` stay "as-is", so including double
quotes.
- namespacing, each parsed ini file should go to separate namespace at least
Patches are welcome!
Alternatives
------------
crudini - powerful command line reader/editor of INI files, written in Python
(much more features, though goes against our aspects 1.-4.). Link:
https://github.com/pixelb/crudini
bash_ini_parser - Similar functionality to shini, Bash only though. Link:
https://github.com/rudimeier/bash_ini_parser
bash-ini-parser - Similar functionality, different API, Bash only, a bit more
features (quoting). link: https://github.com/albfan/bash-ini-parser
Let me know if you know about something worth mentioning here. Thanks!