1 unstable release

0.1.0 Jul 13, 2024

#74 in Value formatting

MIT license

34KB
748 lines

CTOML

A command-line interface tool for reading, writing, and removing values from TOML files.

Table of Contents

Features

  • Read: Retrieve values from TOML files using dot notation and array indexing.
  • Write: Modify or add new values to TOML files, supporting nested structures and arrays.
  • Remove: Delete keys or array elements from TOML files.
  • Support for complex data structures: Handle nested tables, arrays, and mixed data types.
  • Flexible syntax: Use dot notation for nested keys and bracket notation for array indexing.

Installation

To install the TOML CLI Editor, you need to have Rust and Cargo installed on your system. If you don't have them, you can install them from rustup.rs.

Once you have Rust and Cargo set up, you can install the TOML CLI Editor using:

cargo install ctoml

Usage

The general syntax for using the TOML CLI Editor is:

ctoml <file> <key> [value]

For removing values:

ctoml -r <file> <key>

Where:

  • <file> is the path to your TOML file
  • <key> is the key you want to operate on (using dot notation for nested keys and brackets for array indexing)
  • [value] is the new value (only for writing operations)

Reading Values

To read a value from the TOML file:

ctoml <file> <key>

Writing Values

To write a value to the TOML file:

ctoml <file> <key> <value>

Removing Values

To remove a value from the TOML file:

ctoml -r <file> <key>

Examples

Assuming we have a sample.toml file with the following content:

food.snickers.taste.sweet = true

[foo]
bar = "some string"
integers = [ 1, 2, 3 ]
colors = [ "red", "yellow", "green" ]
nested_arrays_of_ints = [ [ 1, 2 ], [3, 4, 5] ]
name = { first = "Tom", last = "Preston-Werner" }

[fruits]
apples = 3
bananas = 5

[[products]]
name = "Hammer"
sku = 738594937

[[products]]
name = "Nail"
sku = 284758393

Reading Examples

ctoml sample.toml foo.bar
# Output: some string

ctoml sample.toml foo.integers
# Output: [ 1, 2, 3 ]

ctoml sample.toml foo.integers[1]
# Output: 2

ctoml sample.toml foo.nested_arrays_of_ints[0][0]
# Output: 1

ctoml sample.toml foo.name.first
# Output: Tom

ctoml sample.toml products[1].sku
# Output: 284758393

Writing Examples

ctoml sample.toml foo.bar some_value
# Writes "some_value" string to foo.bar

ctoml sample.toml foo.integers [1, 2, 3]
# Writes [1, 2, 3] array to foo.integers

ctoml sample.toml foo.integers[1] 2
# Writes 2 to the second entry of foo.integers array

ctoml sample.toml foo.integers[] 5
# Adds 5 to the end of foo.integers array

ctoml sample.toml foo.integers[] [5, 6, 8]
# Adds three elements (5, 6, 8) to the end of foo.integers array

ctoml sample.toml products[1].name Nauk
# Sets value "Nauk" to the second element of products array table for key name

Removing Examples

ctoml -r sample.toml foo.integers
# Removes integers from foo

ctoml -r sample.toml foo.integers[:2]
# Removes the last 2 elements from foo.integers array

ctoml -r sample.toml foo.integers[2:]
# Removes the first 2 elements from foo.integers array

ctoml -r sample.toml foo.integers[1]
# Removes the second element from foo.integers array

ctoml -r sample.toml foo.integers[0,2,4]
# Removes elements at indices 0, 2, and 4 from foo.integers array

ctoml -r sample.toml foo.nested_arrays_of_ints[0][:1]
# Removes the last element from the first nested array in foo.nested_arrays_of_ints

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Dependencies

~0.6–1.2MB
~24K SLoC