 9cb92c390c
			
		
	
	9cb92c390c
	
	
	
		
			
			When diffing binary files, it is sometimes nice to see the differences of a canonical text form rather than either a binary patch or simply "binary files differ." Until now, the only option for doing this was to define an external diff command to perform the diff. This was a lot of work, since the external command needed to take care of doing the diff itself (including mode changes), and lost the benefit of git's colorization and other options. This patch adds a text conversion option, which converts a file to its canonical format before performing the diff. This is less flexible than an arbitrary external diff, but is much less work to set up. For example: $ echo '*.jpg diff=exif' >>.gitattributes $ git config diff.exif.textconv exiftool $ git config diff.exif.binary false allows one to see jpg diffs represented by the text output of exiftool. Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
		
			
				
	
	
		
			23 lines
		
	
	
		
			519 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			23 lines
		
	
	
		
			519 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef USERDIFF_H
 | |
| #define USERDIFF_H
 | |
| 
 | |
| struct userdiff_funcname {
 | |
| 	const char *pattern;
 | |
| 	int cflags;
 | |
| };
 | |
| 
 | |
| struct userdiff_driver {
 | |
| 	const char *name;
 | |
| 	const char *external;
 | |
| 	int binary;
 | |
| 	struct userdiff_funcname funcname;
 | |
| 	const char *textconv;
 | |
| };
 | |
| 
 | |
| int userdiff_config_basic(const char *k, const char *v);
 | |
| int userdiff_config_porcelain(const char *k, const char *v);
 | |
| struct userdiff_driver *userdiff_find_by_name(const char *name);
 | |
| struct userdiff_driver *userdiff_find_by_path(const char *path);
 | |
| 
 | |
| #endif /* USERDIFF */
 |