Scroll to navigation

CRUDINI(1) User Commands CRUDINI(1)

NAME

crudini - manipulate ini files

SYNOPSIS

crudini --set [OPTION]... config_file section [param] [value]
crudini --get [OPTION]... config_file [section] [param]
crudini --del [OPTION]... config_file section [param] [list value]
crudini --merge [OPTION]... config_file [section]

DESCRIPTION

crudini - A utility for manipulating ini files

SECTION can be empty ("") or "DEFAULT" in which case, params not in a section, i.e. global parameters are operated on. If 'DEFAULT' is used with --set, an explicit [DEFAULT] section is added.

Multiple --set|--del|--get operations for a config_file can be specified.

OPTIONS

For --set, --del and --merge, fail if item is missing, where WHAT is 'file', 'section', or 'param', or if WHAT not specified; all specified items.
For --get, select the output FMT. Formats are 'sh','ini','lines'
Set options for handling ini files. Options are: 'nospace': use format name=value not name = value 'ignoreindent': ignore leading whitespace
Lock and write files in place. This is not atomic but has less restrictions than the default replacement method.
For --set and --del, update a list (set) of values
Delimit list values with "STR" instead of " ,". An empty STR means any whitespace is a delimiter.
Write output to FILE instead. '-' means stdout
Indicate on stderr if changes were made
Write this help to stdout
Write version to stdout

EXAMPLES

# Add/Update a var

crudini --set config_file section parameter value

# Add/Update a var in the root or global area. # I.e. that's not under a [section].

crudini --set config_file "" parameter value

# Update an existing var

crudini --set --existing config_file section parameter value

# Add/Update/Delete multiple variables atomically

crudini --set config_file section parameter1 value \

--set config_file section parameter2 value \

--del config_file section parameter3

# Get multiple items from stdin

env | crudini --get - '' USER --get - '' SHELL

# Add/Append a value to a comma separated list # Note any whitespace around commas is ignored

crudini --set --list config_file section parameter a_value

# Add/Append a value to a whitespace separated list # Note multiline lists are supported (as newline is whitespace)

crudini --set --list --list-sep= config_file section parameter a_value

# Delete a var

crudini --del config_file section parameter

# Delete a section

crudini --del config_file section

# output a value

crudini --get config_file section parameter

# output a global value not in a section

crudini --get config_file "" parameter

# output a section

crudini --get config_file section

# output a section, parseable by shell

eval "$(crudini --get --format=sh config_file section)"

# update an ini file from shell variable(s)

echo name="$name" | crudini --merge config_file section

# merge an ini file from another ini

crudini --merge config_file < another.ini

# compare two ini files using standard UNIX text processing

diff <(crudini --get --format=lines file1.ini|sort) \
<(crudini --get --format=lines file2.ini|sort)

# Rewrite ini file to use name=value format rather than name = value

crudini --ini-options=nospace --set config_file ""

# Add/Update a var, ensuring complete file in name=value format

crudini --ini-options=nospace --set config_file section parameter value

# Read indented ini file, like .gitconfig

crudini --ini-options=ignoreindent --format=lines --get ~/.gitconfig
October 2023 crudini 0.9.5