A quick and easy diff generator with support for plaintext and formatted diffs of markdown.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Mario Voigt e1a0c0f422 FIx in readme 3 months ago
dist fix minor: diff colors, readme, port logging 6 years ago
src respond to browser hash to show markdown/plaintext view 6 years ago
test format to standardjs code style with linting 6 years ago
.babelrc start test suite for dubdiff engine 6 years ago
.gitattributes initial check-in with working wdiff server-side api 8 years ago
.gitignore reset prepatory to merge version 2 6 years ago
LICENSE Initial commit 8 years ago
README.md FIx in readme 3 months ago
TODO.md debug markdown diff output edge cases 6 years ago
package.json format to standardjs code style with linting 6 years ago
webpack.config.js format to standardjs code style with linting 6 years ago



A diff viewer for markdown-formatted and plaintext documents.

These diffs are intended for use in copy-editing. The diffs are performed word-by-word, similarly to how the GNU wdiff tool works. This produces a more meaningful diff for English-language editing.

The diff may be further processed in a way that is aware of markdown formatting. The resulting output attempts to show differences of copy within the final document format (rather than differences of format).

The markdown-sensitive processing of the wdiff comparison is at ..., for the curious.

Version 2

This is a complete rewrite of Dubdiff with:

  • simpler project architecture
  • client-side diffing engine and simplified server
  • server-side rendering
  • switch to React from Angular
  • clean up of diffing engine
  • goal of implementing a HTML diff viewer

Basically I'm rewriting it for fun.

Live Server

The tool is live at http://dubdiff.com, feel free to use it there.


You'll need node & npm. Then install dependencies with

npm install

To build and launch a dev server:

npm start
npm run server

To build and launch the production server:

npm run build:prod
npm run serve:prod

Data is saved to a simple flat file db in the data folder. If this folder doesn't exist, create it.

mkdir data

Low-memory environments

On a low-memory machine, eg. a DigitalOcean 512MB instance, you will need to enable virtual memory. Use this guide:

How To Configure Virtual Memory (Swap File) on a VPS

Start on boot

To make the application start on boot, run the following:

# initialize pm2 to start on boot with the systemd boot manager
pm2 startup systemd

# start the app with pm2
pm2 start npm --name dubdiff -- run serve:prod

# save the current pm2 config so that it can be reloaded on boot
pm2 save

Digital Ocean: How To Set Up a Node.js Application for Production on Ubuntu 16.04