tdiff v0.2.1
tdiff
A tool for comparing Tree like files, specifically JSON and YAML
Installation
Right now, simply go to the releases page and download the latest binary to your prefered directory in your path (like /usr/local/bin
). This applies for both windows and linux
Using snap on Linux
If you have snap
on your system, you can install it with
$ sudo snap install --beta tdiff # I hope to be able to consider it out of beta soon
Using Homebrew for OSX
$ brew tap aleandros/tdiff
$ brew install tdiff
Usage as a binary
Usage: tdiff [OPTION]... [SOURCE] <TARGET>
Identifies the differences between two tree-like file structures.
If <TARGET>
is not present, input is assumed to come from STDIN. At this moment, only JSON and YAML are supported.
An exit status of 1 indicates an error in the program. An exit status of 127 indicates that there are differences between source and target. An exit status of 0 indicates no changes
Example output:
$ tdiff shard.yml shard.lock
- name: tdiff
* version: changed type from string to float
- authors: ["Edgar Cabrera <edgar.cabrera@pm.me>"]
- targets: {"tdiff" => {"main" => "main.cr"}}
- crystal: 0.34.0
- license: MIT
- development_dependencies: {"ameba" => {"github" => "crystal-ameba/ameba", "version" => "~> 0.12.0"}}
+ shards: {"ameba" => {"github" => "crystal-ameba/ameba", "version" => "0.12.1"}}
Usage as a shard
Add it to your application shards:
dependencies:
tdiff:
github: aleandros/tdiff
It just requires a couple of IO objects, containing the YAML or JSON data, and returns a list of Tdiff:Core::Result
objects.
require "tdiff"
comparator = Tdiff.compare(File.open('target_1.yml'), File.open('target_2.yml'))
comparator.compare
comparator.results.each do |result|
puts "#{result.path.join(".")}: #{result.difference.reason}"
end
If any of the inputs cannot be parsed, this method will raise a Tdiff::Exception
error.
Development
This is a pretty standard crystal project. So install crystal with your prefered method.
First install dependencies with shards install
.
Remember to run:
- Tests with
crystal spec
- Format with
crystal tool format
- Ameba checks with
bin/ameba
This will be checked by CI but still save yourself some time.
Documentation
You can find the documentation here
TODO
- Compare file to STDIN
- Compare yamls
- Compare json
- Presentation layer
- Add auto-publish via github actions and installation instructions
- Add portable binaries for OSX (or homebrew package)
- Publish as snap package
- Add portable binary for Windows
- Fix file permission testing in CI
- Allow
Tdiff::Core
to be used as a library - Support more array comparison algorithms
- Allow presentation-level customizations at runtime
Contributing
- Fork it (https://github.com/aleandros/tdiff/fork)
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
Contributors
- Edgar Cabrera - creator and maintainer
tdiff
- 21
- 0
- 0
- 0
- 1
- over 4 years ago
- April 29, 2020
MIT License
Sat, 21 Dec 2024 10:10:05 GMT