diff options
Diffstat (limited to 'usr.bin/cvs')
-rw-r--r-- | usr.bin/cvs/cvs.1 | 4 | ||||
-rw-r--r-- | usr.bin/cvs/cvs.c | 6 | ||||
-rw-r--r-- | usr.bin/cvs/diff.c | 70 |
3 files changed, 68 insertions, 12 deletions
diff --git a/usr.bin/cvs/cvs.1 b/usr.bin/cvs/cvs.1 index 099235325a4..bc088f51d36 100644 --- a/usr.bin/cvs/cvs.1 +++ b/usr.bin/cvs/cvs.1 @@ -1,4 +1,4 @@ -.\" $OpenBSD: cvs.1,v 1.23 2005/01/13 00:03:28 xsa Exp $ +.\" $OpenBSD: cvs.1,v 1.24 2005/01/13 23:39:42 jfb Exp $ .\" .\" Copyright (c) 2004 Jean-Francois Brousseau <jfb@openbsd.org> .\" All rights reserved. @@ -175,7 +175,7 @@ repository's information to reflect the changes. Aliases: .Ic ci , .Ic com . -.It Xo Ic diff Op Fl cilu +.It Xo Ic diff Op Fl cilNpu .Op Fl D Ar date .Op Fl r Ar rev .Op Ar file ... diff --git a/usr.bin/cvs/cvs.c b/usr.bin/cvs/cvs.c index 5b28ea2d86b..853cfb6a340 100644 --- a/usr.bin/cvs/cvs.c +++ b/usr.bin/cvs/cvs.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cvs.c,v 1.33 2005/01/13 18:47:31 jfb Exp $ */ +/* $OpenBSD: cvs.c,v 1.34 2005/01/13 23:39:42 jfb Exp $ */ /* * Copyright (c) 2004 Jean-Francois Brousseau <jfb@openbsd.org> * All rights reserved. @@ -131,8 +131,8 @@ static struct cvs_cmd { }, { CVS_OP_DIFF, "diff", { "di", "dif" }, cvs_diff, - "[-cilu] [-D date] [-r rev] ...", - "cD:ilur:", + "[-cilNpu] [-D date] [-r rev] ...", + "cD:ilNpr:u", "Show differences between revisions", NULL, }, diff --git a/usr.bin/cvs/diff.c b/usr.bin/cvs/diff.c index 2b0c3c940da..d69c6d87d71 100644 --- a/usr.bin/cvs/diff.c +++ b/usr.bin/cvs/diff.c @@ -1,4 +1,4 @@ -/* $OpenBSD: diff.c,v 1.16 2004/12/28 22:07:31 xsa Exp $ */ +/* $OpenBSD: diff.c,v 1.17 2005/01/13 23:39:42 jfb Exp $ */ /* * Copyright (C) Caldera International Inc. 2001-2002. * All rights reserved. @@ -239,12 +239,13 @@ static int isqrt(int); static int stone(int *, int, int *, int *); static int readhash(FILE *); static int files_differ(FILE *, FILE *); +static char *match_function(const long *, int, FILE *); static char *preadline(int, size_t, off_t); extern int cvs_client; -static int aflag, bflag, dflag, iflag, Nflag, tflag, Tflag, wflag; +static int aflag, bflag, dflag, iflag, Nflag, pflag, tflag, Tflag, wflag; static int context, status; static int format = D_NORMAL; static struct stat stb1, stb2; @@ -273,8 +274,9 @@ static struct context_vec *context_vec_end; static struct context_vec *context_vec_ptr; #define FUNCTION_CONTEXT_SIZE 41 -static int lastline; -static int lastmatchline; +static char lastbuf[FUNCTION_CONTEXT_SIZE]; +static int lastline; +static int lastmatchline; /* @@ -357,7 +359,7 @@ cvs_diff(int argc, char **argv) memset(&darg, 0, sizeof(darg)); strlcpy(diffargs, argv[0], sizeof(diffargs)); - while ((ch = getopt(argc, argv, "cD:liN:r:u")) != -1) { + while ((ch = getopt(argc, argv, "cD:liNpr:u")) != -1) { switch (ch) { case 'c': strlcat(diffargs, " -c", sizeof(diffargs)); @@ -387,6 +389,10 @@ cvs_diff(int argc, char **argv) strlcat(diffargs, " -N", sizeof(diffargs)); Nflag = 1; break; + case 'p': + strlcat(diffargs, " -p", sizeof(diffargs)); + pflag = 1; + break; case 'r': if ((darg.rev1 == NULL) && (darg.date1 == NULL)) darg.rev1 = optarg; @@ -438,6 +444,11 @@ int cvs_diff_sendflags(struct cvsroot *root, struct diff_arg *dap) { /* send the flags */ + if (Nflag && (cvs_sendarg(root, "-N", 0) < 0)) + return (-1); + if (pflag && (cvs_sendarg(root, "-p", 0) < 0)) + return (-1); + if (format == D_CONTEXT) cvs_sendarg(root, "-c", 0); else if (format == D_UNIFIED) @@ -1424,6 +1435,37 @@ asciifile(FILE *f) return (1); } +static char* +match_function(const long *f, int pos, FILE *fp) +{ + unsigned char buf[FUNCTION_CONTEXT_SIZE]; + size_t nc; + int last = lastline; + char *p; + + lastline = pos; + while (pos > last) { + fseek(fp, f[pos - 1], SEEK_SET); + nc = f[pos] - f[pos - 1]; + if (nc >= sizeof(buf)) + nc = sizeof(buf) - 1; + nc = fread(buf, 1, nc, fp); + if (nc > 0) { + buf[nc] = '\0'; + p = strchr(buf, '\n'); + if (p != NULL) + *p = '\0'; + if (isalpha(buf[0]) || buf[0] == '_' || buf[0] == '$') { + strlcpy(lastbuf, buf, sizeof lastbuf); + lastmatchline = pos; + return lastbuf; + } + } + pos--; + } + return (lastmatchline > 0) ? lastbuf : NULL; +} + /* dump accumulated "context" diff changes */ static void @@ -1432,7 +1474,7 @@ dump_context_vec(FILE *f1, FILE *f2) struct context_vec *cvp = context_vec_start; int lowa, upb, lowc, upd, do_output; int a, b, c, d; - char ch; + char ch, *f; if (context_vec_start > context_vec_ptr) return; @@ -1444,6 +1486,13 @@ dump_context_vec(FILE *f1, FILE *f2) upd = MIN(len[1], context_vec_ptr->d + context); printf("***************"); + if (pflag) { + f = match_function(ixold, lowa - 1, f1); + if (f != NULL) { + putchar(' '); + fputs(f, stdout); + } + } printf("\n*** "); range(lowa, upb, ","); printf(" ****\n"); @@ -1530,7 +1579,7 @@ dump_unified_vec(FILE *f1, FILE *f2) struct context_vec *cvp = context_vec_start; int lowa, upb, lowc, upd; int a, b, c, d; - char ch; + char ch, *f; if (context_vec_start > context_vec_ptr) return; @@ -1546,6 +1595,13 @@ dump_unified_vec(FILE *f1, FILE *f2) fputs(" +", stdout); uni_range(lowc, upd); fputs(" @@", stdout); + if (pflag) { + f = match_function(ixold, lowa - 1, f1); + if (f != NULL) { + putchar(' '); + fputs(f, stdout); + } + } putchar('\n'); /* |