Skip to content

Yaml optimiser is a library and set of command-line tools written in C++. The library helps optimise large YAML configurations using aliases (anchors), references, and merge keys (overrides).

License

Notifications You must be signed in to change notification settings

Mr-S-Mirzoev/yaml-optimize

Repository files navigation

yaml-optimize

Yaml optimiser is a library and set of command-line tools written in C++. The library helps optimise large YAML configurations using aliases (anchors), references, and merge keys (overrides). It leverages the rapidyaml library for YAML parsing and manipulation.

The project aims to provide a fast and convenient way to optimise large YAML configurations.

Dependencies

  • rapidyaml: A fast YAML parser and emitter for C++.
  • Lyra: A simple-to-use, composing, header-only, command line arguments parser for C++ 11 and beyond.
  • fmt: A formatting library providing a fast and safe alternative to C stdio and C++ iostreams.

Examples

Currently library only supports optimizing fully identical nodes:

# YAML example with references and anchors

# Define an anchor for a nested sequence
- top_level:
    - nested:
        - - Apple
          - Orange
          - Banana

# Define an anchor for a nested mapping
- another_level:
    - even_deeper:
        - further:
            - key1: value1
              key2: value2

# Use the anchors in different parts of the YAML
- other_level:
    - some_key:
        - Apple
        - Orange
        - Banana
    - additional_key:
        key1: value1
        key2: value2

# Additional data
- SomeList:
    - 1
    - 2
    - 3
    - 4
- SomeValue: true

So the result would be (note that indentations and comments are currently removed):

- top_level:
    - nested:
        - &anchor_0
          - Apple
          - Orange
          - Banana
- another_level:
    - even_deeper:
        - further:
            - &anchor_1
              key1: value1
              key2: value2
- other_level:
    - some_key: *anchor_0
    - additional_key: *anchor_1
- SomeList:
    - 1
    - 2
    - 3
    - 4
- SomeValue: true

Roadmap

  • Replace identical blocks with anchors to the first one
  • Replace similar blocks with merge keys
  • Preserve the original document's comments and spacing (?). Also, preserve block/flow format.

Installation

Installation is fairly easy. First of all, clone the repo, downloading its submodules recursively:

git clone https://github.com/Mr-S-Mirzoev/yaml-optimize.git --recursive

If you only want to test the repo features, it may be a good idea to clone only the top of the repo:

git clone https://github.com/Mr-S-Mirzoev/yaml-optimize.git --recursive --depth=1

Next, in the repo directory, generate the project with CMake:

cmake -B build -DYO_BUILD_TOOLS=1 -DYO_BUILD_TESTS=1 -DCMAKE_BUILD_TYPE=Release

Here you see the flags that can be used when building the yaml-optimize library. YO_BUILD_TOOLS and YO_BUILD_TESTS are 0 by default, as I want the build to be minimal. If you tick the YO_BUILD_TOOLS option, tools yaml-optimize, and yaml-resolve are built:

USAGE:
  yaml-optimize [-?|-h|--help] [-l|--limit <optimization limit>] -i|--input <input> [-o|--output <output>] [-v|--verbose]

YAML Optimizer - A tool for optimising YAML configurations with the use of anchors, references and merge keys

OPTIONS, ARGUMENTS:
  -?, -h, --help          
  -l, --limit <optimization limit>
                          limit to when to stop optimisation
  -i, --input <input>     path to input file
  -o, --output <output>   path to output file (defaults to input filename + ".optimized")
  -v, --verbose           enable verbose mode

USAGE:
  yaml-resolve [-?|-h|--help] -i|--input <input> [-o|--output <output>] [-v|--verbose]

YAML Resolver - A tool for resolving YAML optimised configurations with anchors, references, and merge keys, substituting them to obtain the complete YAML configuration

OPTIONS, ARGUMENTS:
  -?, -h, --help          
  -i, --input <input>     path to input file
  -o, --output <output>   path to output file (defaults to input filename + ".resolved")
  -v, --verbose           enable verbose mode

Now, we can build the project:

cmake --build build -j8 --config Debug

About

Yaml optimiser is a library and set of command-line tools written in C++. The library helps optimise large YAML configurations using aliases (anchors), references, and merge keys (overrides).

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published