summaryrefslogtreecommitdiffstats
path: root/Tools/scripts
diff options
context:
space:
mode:
authorRaymond Hettinger <python@rcn.com>2003-06-08 23:04:17 (GMT)
committerRaymond Hettinger <python@rcn.com>2003-06-08 23:04:17 (GMT)
commita33d17758974e0d150cc07a22c0c60b1485d0ab4 (patch)
tree95dea4b360b09578c552da85d3a1d8c16a7bf38e /Tools/scripts
parentc24d767809ccb57fee073d87a40f29260ff01c57 (diff)
downloadcpython-a33d17758974e0d150cc07a22c0c60b1485d0ab4.zip
cpython-a33d17758974e0d150cc07a22c0c60b1485d0ab4.tar.gz
cpython-a33d17758974e0d150cc07a22c0c60b1485d0ab4.tar.bz2
Added a command line interface for difflib.py
Diffstat (limited to 'Tools/scripts')
-rw-r--r--Tools/scripts/README1
-rw-r--r--Tools/scripts/diff.py41
2 files changed, 42 insertions, 0 deletions
diff --git a/Tools/scripts/README b/Tools/scripts/README
index ca2ef93..5281804 100644
--- a/Tools/scripts/README
+++ b/Tools/scripts/README
@@ -15,6 +15,7 @@ copytime.py Copy one file's atime and mtime to another
crlf.py Change CRLF line endings to LF (Windows to Unix)
cvsfiles.py Print a list of files that are under CVS
db2pickle.py Dump a database file to a pickle
+diff.py Print file diffs in context, unified, or ndiff formats
dutree.py Format du(1) output as a tree sorted by size
eptags.py Create Emacs TAGS file for Python modules
finddiv.py A grep-like tool that looks for division operators.
diff --git a/Tools/scripts/diff.py b/Tools/scripts/diff.py
new file mode 100644
index 0000000..c943699
--- /dev/null
+++ b/Tools/scripts/diff.py
@@ -0,0 +1,41 @@
+""" Command line interface to difflib.py providing diffs in three formats:
+
+* ndiff: lists every line and highlights interline changes.
+* context: highlights clusters of changes in a before/after format
+* unified: highlights clusters of changes in an inline format.
+
+"""
+
+import sys, os, time, difflib, optparse
+
+usage = "usage: %prog [options] fromfile tofile"
+parser = optparse.OptionParser(usage)
+parser.add_option("-c", action="store_true", default=False, help='Produce a context format diff (default)')
+parser.add_option("-u", action="store_true", default=False, help='Produce a unified format diff')
+parser.add_option("-n", action="store_true", default=False, help='Produce a ndiff format diff')
+parser.add_option("-l", "--lines", type="int", default=3, help='Set number of context lines (default 3)')
+(options, args) = parser.parse_args()
+
+if len(args) == 0:
+ parser.print_help()
+ sys.exit(1)
+if len(args) != 2:
+ parser.error("need to specify both a fromfile and tofile")
+
+n = options.lines
+fromfile, tofile = args
+
+fromdate = time.ctime(os.stat(fromfile).st_mtime)
+todate = time.ctime(os.stat(tofile).st_mtime)
+fromlines = open(fromfile).readlines()
+tolines = open(tofile).readlines()
+
+if options.u:
+ diff = difflib.unified_diff(fromlines, tolines, fromfile, tofile, fromdate, todate, n=n)
+elif options.n:
+ diff = difflib.ndiff(fromlines, tolines)
+else:
+ diff = difflib.context_diff(fromlines, tolines, fromfile, tofile, fromdate, todate, n=n)
+
+sys.stdout.writelines(diff)
+