tdiff v0.2.1

CLI tool for comparing tree like structures

tdiff

Built with Crystal CI Latest release

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

  1. Fork it (https://github.com/aleandros/tdiff/fork)
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request

Contributors

Repository

tdiff

Owner
Statistic
  • 21
  • 0
  • 0
  • 0
  • 1
  • over 4 years ago
  • April 29, 2020
License

MIT License

Links
Synced at

Sat, 21 Dec 2024 10:10:05 GMT

Languages