summaryrefslogtreecommitdiff
path: root/deps/npm/node_modules/ini/README.md
blob: 9f82a765da63bdcd00d15f5bbb547a79fed31f12 (plain)
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
An ini format parser and serializer for node.

Sections are treated as nested objects.  Items before the first heading
are saved on the object directly.

## Usage

Consider an ini-file `config.ini` that looks like this:

    ; this comment is being ignored
    scope = global

    [database]
    user = dbuser
    password = dbpassword
    database = use_this_database

    [paths.default]
    datadir = /var/lib/data

You can read, manipulate and write the ini-file like so:

    var fs = require('fs')
      , ini = require('ini')

    var config = ini.parse(fs.readFileSync('./config.ini', 'utf-8'))

    config.scope = 'local'
    config.database.database = 'use_another_database'
    config.paths.default.tmpdir = '/tmp'
    delete config.paths.default.datadir

    fs.writeFileSync('./config_modified.ini', ini.stringify(config, 'section'))

This will result in a file called `config_modified.ini` being written to the filesystem with the following content:

    [section]
    scope = local
    [section.database]
    user = dbuser
    password = dbpassword
    database = use_another_database
    [section.paths.default]
    tmpdir = /tmp

## API

### decode(inistring)
Decode the ini-style formatted `inistring` into a nested object.

### parse(inistring)
Alias for `decode(inistring)`

### encode(object, [section])
Encode the object `object` into an ini-style formatted string. If the optional parameter `section` is given, then all top-level properties of the object are put into this section and the `section`-string is prepended to all sub-sections, see the usage example above.

### stringify(object, [section])
Alias for `encode(object, [section])`

### safe(val)
Escapes the string `val` such that it is safe to be used as a key or value in an ini-file. Basically escapes quotes. For example

    ini.safe('"unsafe string"')

would result in

    "\"unsafe string\""

### unsafe(val)
Unescapes the string `val`