Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

disparity

millermedeiros292.5kMIT3.2.0TypeScript support: included

Colorized string diff ideal for text/code that spans through multiple lines

diff, char, unified, multiline, string, color, ansi, terminal, cli, tty

readme

disparity

Colorized string diff ideal for text/code that spans through multiple lines.

This is basically just a wrapper around diff and ansi-styles + line numbers and omitting lines that don't have changes and/or that wouldn't help user identify the diff "context".

We also replace some invisible chars to make it easier to understand what really changed from one file to another:

  • \r becomes <CR>
  • \n becomes <LF>
  • \t becomes <tab>

Created mainly to be used by esformatter and other tools that might need to display a nice looking diff of source files.

API

var disparity = require('disparity');

chars(oldStr, newStr[, opts]):String

Diffs two blocks of text, comparing character by character and returns a String with ansi color codes.

var diff = disparity.chars(file1, file2);
console.log(diff);

Will return an empty string if oldStr === newStr;

// default options
var opts = {
  // how many lines to display before/after a line that contains diffs
  context: 3,
  // file paths displayed just before the diff
  paths: [disparity.removed, disparity.added]
};

screenshot char diff

unified(oldStr, newStr[, opts]):String

Returns ansi colorized unified diff.

Will return an empty string if oldStr === newStr;

var diff = disparity.unified(file1, file2, {
  paths: ['test/file1.js', 'test/file2.js']
});
console.log(diff);

screenshot unified diff

unifiedNoColor(oldStr, newStr[, opts]):String

Returns unified diff. Useful for terminals that doesn't support colors.

Will return an empty string if oldStr === newStr;

var diff = disparity.unifiedNoColor(file1, file2, {
  paths: ['test/file1.js', 'test/file2.js']
});
console.log(diff);

screenshot unified diff no color

removed:String

String used on the diff headers to say that chars/lines was removed.

// default value
disparity.removed = 'removed';

added:String

String used on the diff headers to say that chars/lines was added.

// default value
disparity.added = 'added';

colors:Object

Object containing references to all the colors used by disparity.

If you want a different output than ansi (eg. HTML) you can replace the color values:

// wrap blocks into custom tags
disparity.colors = {
  // chars diff
  charsRemoved: { open: '<bggreen>', close: '</bggreen>' },
  charsAdded: { open: '<bgred>', close: '</bgred>' },

  // unified diff
  removed: { open: '<red>', close: '</red>' },
  added: { open: '<green>', close: '</green>' },
  header: { open: '<yellow>', close: '</yellow>' },
  section: { open: '<magenta>', close: '</magenta>' }
};

CLI

disparity also have a command line interface:

disparity [OPTIONS] <file_1> <file_2>

Options:
  -c, --chars           Output char diff (default mode).
  -u, --unified         Output unified diff.
  --unified-no-color    Don't output colors.
  -v, --version         Display current version.
  -h, --help            Display this help.

PS: cli can only compare 2 external files at the moment, no stdin support.

License

Released under the MIT license.

changelog

disparity changelog

v3.2.0 (2021/01/20)

  • Add support to context opt in unified function

v3.1.0

  • Add type definitions for TypeScript support

v3.0.0 (2019/11/06)

  • BREAKING: Only supports node >= 8
  • Fixed security issue with outdated dependencies

v2.0.0 (2015/04/03)

  • change API so all methods have same signature (str1, str2, opts).
  • merge CLI options --unified --no-color into --unified-no-color.
  • better error messages on the CLI.
  • show paths on chars diff as well (if supplied) or fallback to disparity.removed and disparity.added.

v1.3.1 (2015/04/01)

  • fix line number alignment.

v1.3.0 (2015/04/01)

  • add support for custom colors.
  • update unified color scheme.
  • simplify line splitting logic.
  • improve way strings are colorized (avoids \n and \r chars).

v1.2.0 (2015/04/01)

  • add unifiedNoColor support.

v1.1.0 (2015/04/01)

  • allow override of removed and added strings.

v1.0.0 (2015/04/01)

  • initial release