kpp-tool
is a utility for interacting with Krita brush presets (i.e.
KPP files) from the command line. The program can inspect/change
preset metadata or extract embedded resources such as brush tips and
patterns.
The most common pattern for invoking kpp-tool
is:
kpp-tool [FLAGS] [KPP_FILE]
where KPP_FILE
is the path to a preset file. If no path is provided,
the program will attempt to read a file from stdin
.
There are generally three kinds of command line flags:
- Mode flags select special alternative program modes like "help mode" or "dump xml mode". Only one mode can be selected for a given program invocation.
- Operation flags correspond to specific actions the program can take with a preset, such as looking up properties or changing the preset's name. These flags are executed in the order they are provided.
- Global flags configure global program settings that affect all operations, like enabling overwrite mode. The position and order of these flags does not matter - they can appear anywhere on the command line.
By default, the program doesn't save any modifications made to the
preset. Use the global -O/--overwrite
flag to modify a preset file
in-place, or the -o/--output
operation to save a preset to another
file. When input is taken from stdin
, the -O/--overwrite
option
will write the final output to stdout
.
Note that -o/--output
is an operation flag, so it should appear
after any changes you want to save on the command line. For example,
you probably don't want to run kpp-tool --output=output.kpp --set-name=foobar input.kpp
, which would write the output before
changing the name to "foobar". Instead, kpp-tool --set-name=foobar --output=output.kpp input.kpp
would change the name, then save the result.
# Print detailed information about a preset.
$ kpp-tool --info preset.kpp
# Change the name of a preset to "foobar".
$ kpp-tool -O --set-name=foobar preset.kpp
# Set the 'EraserMode' parameter to "true".
$ kpp-tool -O --set-param "EraserMode=string:true" preset.kpp
# Query the values of the 'FlowSensor' and 'FlowValue' parameters.
$ kpp-tool --get-param FlowSensor --get-param FlowValue preset.kpp
# Extract a preset's current icon image, then set a new one.
$ kpp-tool -O --get-icon=old-icon.png \
--set-icon=new-icon.png \
preset.kpp
# Create three variations of a preset with different blending modes.
$ kpp-tool --set-param CompositeOp=string:multiply \
--output preset_multiply.kpp \
--set-param CompositeOp=string:dodge \
--output preset_dodge.kpp \
--set-param CompositeOp=string:soft_light_svg \
--output preset_softlight.kpp \
preset.kpp
# Extract the raw XML settings document from a preset file.
$ kpp-tool --dump-xml preset.kpp
The full list of supported command line flags is as follows:
-h --help Display help and usage information.
-v --version Display version information.
-d PATH --dump-xml=PATH Dump a preset's XML settings to standard output.
-O --overwrite Modify a preset file in-place.
-q --quiet Supress unnecessary output.
-o PATH --output=PATH Write preset data to PATH.
If PATH is "-", data will be written to stdout.
-i --info Print a description of a preset.
-n --get-name Print a preset's metadata name.
-N STRING --set-name=STRING Change a preset's metadata name.
-S --sync-name Change a preset's metadata name to match it's filename.
For example, 'kpp-tool --sync-name foobar.kpp' will change
the preset's name to "foobar".
-l --list-params Print a table of all parameters.
-p KEY --get-param=KEY Print the value of a single parameter.
-P KEY=TYPE:VALUE --set-param=KEY=TYPE:VALUE Set the value of a parameter.
TYPE can be 'string', 'internal', or 'binary'.
For binary parameters, VALUE should be encoded in base-64.
-r --list-resources Print a table of all embedded resources.
-x KEY=VALUE[,...] --extract=KEY=VALUE[,...] Extract an embedded resource.
-X[DIR] --extract-all[=DIR] Extract all embedded resources.
If the optional directory path argument is provided,
the extracted files will be placed in DIR.
-e KEY=VALUE[,...] --embed=KEY=VALUE[,...] Insert or update a resource file.
-c PATH --get-icon=PATH Extract a preset's PNG icon image.
-C PATH --set-icon=PATH Change a preset's icon image.
FILE must be a PNG or KPP file.
kpp-tool
can be built using stack or cabal. Build dependencies
include zlib
, as well as common build tools like pkg-config
and
g++
. Depending on your platform, you may need to install development
packages for some dependencies like libc
and zlib
(e.g. zlib-dev
on Alpine).
You should be able to build the program by running stack build
in
the root directory of the repository. stack install
will copy the
executable to the local bin directory (usually $HOME/.local/bin
),
which may need to be added to PATH.
Building with Cabal is fairly similar. After obtaining the source code
and required dependencies, running cabal build
in the root directory
of the repository should build the software. Alternatively, to produce
a fully static binary, build with the --enable-executable-static
option and make sure statically linked zlib
is available.
For example, here is the full build process on Alpine Linux.
# (as root)
# For static linking, also install the zlib-static package.
apk update
apk add git cabal g++ zlib-dev
# (as regular user)
git clone https://github.com/quytelda/kpp-tool.git
cd kpp-tool
cabal update
cabal build
# Alternatively, to produce a fully static binary:
cabal build --enable-executable-static