View colored, incremental diff in a workspace or from stdin, with side by side and auto pager support


Keywords
colored, incremental, side-by-side, diff
License
BSD-1-Clause
Install
pip install cdiff==1.0

Documentation

Ydiff

Tests status

Term based tool to view colored, incremental diff in a version controlled workspace (supports Git, Mercurial, Perforce and Svn so far) or from stdin, with side by side (similar to diff -y) and auto pager support. Requires python (>= 2.6.0) and less.

default

side by side

Ydiff only supports diff in Unified Format. This is default in most version control system except Perforce, which needs an environment variable P4DIFF="diff -u" to output unified diff.

Installation

Ydiff only depends on Python built-in libraries, so you can just download the source and run without worrying about any installation.

Git tagged releases will be packaged and uploaded to PyPI timely, however, packages hosted elsewhere are not (please note they are not managed by the author @ymattw).

Download directly

Just save ydiff.py to whatever directory which is in your $PATH, for example, $HOME/bin is in my $PATH, so I save the script there and name as ydiff.

Install with pip

Ydiff is already listed on PyPI, you can install with pip if you have the tool.

Install with setup.py

You can also run the setup.py from the source if you don't have pip.

Install with Homebrew

You can also install with Homebrew on Mac. (Thanks to @josa42, @bfontaine, @hivehand and @nijikon for contributing to the Homebrew Formula).

Install on Fedora

On Fedora, you can install ydiff with dnf.

Install on FreeBSD

On FreeBSD, you can install ydiff with pkg.

Usage

Type ydiff -h to show usage:

$ ydiff -h
Usage: ydiff [options] [file|dir ...]

View colored, incremental diff in a workspace or from stdin, with side by side
and auto pager support

Options:
  --version            show program's version number and exit
  -h, --help           show this help message and exit
  -s, --side-by-side   enable side-by-side mode
  -w N, --width=N      set text width for side-by-side mode, 0 for auto
                       detection, default is 80
  -l, --log            show log with changes from revision control
  -c M, --color=M      colorize mode 'auto' (default), 'always', or 'never'
  -t N, --tab-width=N  convert tab characters to this many spaces (default: 8)
  --wrap               wrap long lines in side-by-side view
  -p M, --pager=M      pager application, suggested values are 'less' or 'cat'
  -o M, --pager-options=M
                       options to supply to pager application

  Note:
    Option parser will stop on first unknown option and pass them down to
    underneath revision control. Environment variable YDIFF_OPTIONS may be
    used to specify default options that will be placed at the beginning
    of the argument list.

Read diff from local modification in a Git/Mercurial/Perforce/Svn workspace (output from e.g. git diff, svn diff):

Read log with changes in a Git/Mercurial/Svn workspace (output from e.g. git log -p, svn log --diff), note --diff option is new in svn 1.7.0:

Utilize a specific pager application:

Pipe in a diff:

Redirect output to another patch file is safe:

Environment variable

Environment variable YDIFF_OPTIONS may be used to specify default options that will be placed at the beginning of the argument list, for example:

Note the default pager less takes options from the environment variable LESS.

Notes

If you feel more comfortable with a command such as git ydiff to trigger the ydiff command, you may symlink the executable to one named git-ydiff as follows:

Known issues

Ydiff has following known issues:

  • Side by side mode has alignment problem for wide chars
  • Terminal might be in a mess on exception (type reset can fix it)

Pull requests are very welcome, please make sure your changes can pass unit tests and regression tests by run make docker-test.