diff options
| author | Brian Downing <bdowning@lavos.net> | 2008-10-25 15:30:54 +0200 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2008-10-25 12:09:31 -0700 | 
| commit | ef2e62fe23173586f49a00c6ae953ebbdb0d13ab (patch) | |
| tree | 13c9c71347563800dc9dfb025ad97bfcffb804f7 | |
| parent | 9ccd0a88ac3ea13ac2df4630bfd01c02084f965e (diff) | |
| download | git-ef2e62fe23173586f49a00c6ae953ebbdb0d13ab.tar.gz | |
Allow alternate "low-level" emit function from xdl_diff
For some users (e.g. git blame), getting textual patch output is just
extra work, as they can get all the information they need from the low-
level diff structures.  Allow for an alternate low-level emit function
to be defined to allow bypassing the textual patch generation; set
xemitconf_t's emit_func member to enable this.
The (void (*)()) type is pretty ugly, but the alternative would be to
include most of the private xdiff headers in xdiff.h to get the types
required for the "proper" function prototype.  Also, a (void *) won't
work, as ANSI C doesn't allow a function pointer to be cast to an
object pointer.
Signed-off-by: Brian Downing <bdowning@lavos.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
| -rw-r--r-- | xdiff/xdiff.h | 1 | ||||
| -rw-r--r-- | xdiff/xdiffi.c | 4 | ||||
| -rw-r--r-- | xdiff/xemit.c | 3 | ||||
| -rw-r--r-- | xdiff/xemit.h | 3 | 
4 files changed, 8 insertions, 3 deletions
| diff --git a/xdiff/xdiff.h b/xdiff/xdiff.h index deebe02cd3..84fff583e2 100644 --- a/xdiff/xdiff.h +++ b/xdiff/xdiff.h @@ -87,6 +87,7 @@ typedef struct s_xdemitconf {  	unsigned long flags;  	find_func_t find_func;  	void *find_func_priv; +	void (*emit_func)();  } xdemitconf_t;  typedef struct s_bdiffparam { diff --git a/xdiff/xdiffi.c b/xdiff/xdiffi.c index 1bad8462fb..9d0324a38c 100644 --- a/xdiff/xdiffi.c +++ b/xdiff/xdiffi.c @@ -538,6 +538,8 @@ int xdl_diff(mmfile_t *mf1, mmfile_t *mf2, xpparam_t const *xpp,  	     xdemitconf_t const *xecfg, xdemitcb_t *ecb) {  	xdchange_t *xscr;  	xdfenv_t xe; +	emit_func_t ef = xecfg->emit_func ? +		(emit_func_t)xecfg->emit_func : xdl_emit_diff;  	if (xdl_do_diff(mf1, mf2, xpp, &xe) < 0) { @@ -551,7 +553,7 @@ int xdl_diff(mmfile_t *mf1, mmfile_t *mf2, xpparam_t const *xpp,  		return -1;  	}  	if (xscr) { -		if (xdl_emit_diff(&xe, xscr, ecb, xecfg) < 0) { +		if (ef(&xe, xscr, ecb, xecfg) < 0) {  			xdl_free_script(xscr);  			xdl_free_env(&xe); diff --git a/xdiff/xemit.c b/xdiff/xemit.c index d3d9c845c6..4625c1b421 100644 --- a/xdiff/xemit.c +++ b/xdiff/xemit.c @@ -27,7 +27,6 @@  static long xdl_get_rec(xdfile_t *xdf, long ri, char const **rec);  static int xdl_emit_record(xdfile_t *xdf, long ri, char const *pre, xdemitcb_t *ecb); -static xdchange_t *xdl_get_hunk(xdchange_t *xscr, xdemitconf_t const *xecfg); @@ -58,7 +57,7 @@ static int xdl_emit_record(xdfile_t *xdf, long ri, char const *pre, xdemitcb_t *   * Starting at the passed change atom, find the latest change atom to be included   * inside the differential hunk according to the specified configuration.   */ -static xdchange_t *xdl_get_hunk(xdchange_t *xscr, xdemitconf_t const *xecfg) { +xdchange_t *xdl_get_hunk(xdchange_t *xscr, xdemitconf_t const *xecfg) {  	xdchange_t *xch, *xchp;  	for (xchp = xscr, xch = xscr->next; xch; xchp = xch, xch = xch->next) diff --git a/xdiff/xemit.h b/xdiff/xemit.h index 440a7390fa..c2e2e83027 100644 --- a/xdiff/xemit.h +++ b/xdiff/xemit.h @@ -24,7 +24,10 @@  #define XEMIT_H +typedef int (*emit_func_t)(xdfenv_t *xe, xdchange_t *xscr, xdemitcb_t *ecb, +			   xdemitconf_t const *xecfg); +xdchange_t *xdl_get_hunk(xdchange_t *xscr, xdemitconf_t const *xecfg);  int xdl_emit_diff(xdfenv_t *xe, xdchange_t *xscr, xdemitcb_t *ecb,  		  xdemitconf_t const *xecfg); | 
