mirror of
				https://github.com/python/cpython.git
				synced 2025-10-26 03:04:41 +00:00 
			
		
		
		
	Added a command line interface for difflib.py
This commit is contained in:
		
							parent
							
								
									c24d767809
								
							
						
					
					
						commit
						a33d177589
					
				
					 2 changed files with 42 additions and 0 deletions
				
			
		|  | @ -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) | crlf.py			Change CRLF line endings to LF (Windows to Unix) | ||||||
| cvsfiles.py		Print a list of files that are under CVS | cvsfiles.py		Print a list of files that are under CVS | ||||||
| db2pickle.py		Dump a database file to a pickle | 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 | dutree.py		Format du(1) output as a tree sorted by size | ||||||
| eptags.py		Create Emacs TAGS file for Python modules | eptags.py		Create Emacs TAGS file for Python modules | ||||||
| finddiv.py		A grep-like tool that looks for division operators. | finddiv.py		A grep-like tool that looks for division operators. | ||||||
|  |  | ||||||
							
								
								
									
										41
									
								
								Tools/scripts/diff.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								Tools/scripts/diff.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -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) | ||||||
|  | 
 | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Raymond Hettinger
						Raymond Hettinger