pkgsrc/devel/idiff/patches/patch-aa

64 lines
1.7 KiB
Text

$NetBSD: patch-aa,v 1.2 2001/05/29 08:16:05 agc Exp $
Don't overwrite read-only strings, so they can be placed in the text
segment by a decent optimising compiler.
Honour the VISUAL and EDITOR settings in the environment before
using ed(1)
--- idiff.c.orig Wed Sep 16 20:58:16 1998
+++ idiff.c Tue May 29 09:11:44 2001
@@ -1,5 +1,7 @@
/* idiff: interactive diff */
+#include <sys/param.h>
+
#include <stdio.h>
#include <ctype.h>
char *progname;
@@ -11,6 +13,7 @@
{
FILE *fin, *fout, *f1, *f2, *efopen();
char buf[BUFSIZ], *mktemp();
+ char realdiffname[MAXPATHLEN];
char *diffout = "idiff.XXXXXX";
progname = argv[0];
@@ -21,6 +24,8 @@
f1 = efopen(argv[1], "r");
f2 = efopen(argv[2], "r");
fout = efopen("idiff.out", "w");
+ (void) strcpy(realdiffname, diffout);
+ diffout = realdiffname;
mktemp(diffout);
sprintf(buf,"diff %s %s >%s",argv[1],argv[2],diffout);
system(buf);
@@ -34,11 +39,15 @@
idiff(f1, f2, fin, fout) /* process diffs */
FILE *f1, *f2, *fin, *fout;
{
+ char realtempfile[MAXPATHLEN];
char *tempfile = "idiff.XXXXXX";
char buf[BUFSIZ], buf2[BUFSIZ], *mktemp();
FILE *ft, *efopen();
int cmd, n, from1, to1, from2, to2, nf1, nf2;
+ char *ed;
+ (void) strcpy(realtempfile, tempfile);
+ tempfile = realtempfile;
mktemp(tempfile);
nf1 = nf2 = 0;
while (fgets(buf, sizeof buf, fin) != NULL) {
@@ -76,7 +85,11 @@
fprintf(ft, "---\n");
ncopy(f2, to2+1-from2, ft);
fclose(ft);
- sprintf(buf2, "ed %s", tempfile);
+ if ((ed = getenv("VISUAL")) == NULL &&
+ (ed = getenv("EDITOR")) == NULL) {
+ ed = "/bin/ed";
+ }
+ snprintf(buf2, sizeof(buf2), "%s %s", ed, tempfile);
system(buf2);
ft = efopen(tempfile, "r");
ncopy(ft, HUGE, fout);