summaryrefslogtreecommitdiff
path: root/usr.bin/cvs/diff_internals.c
diff options
context:
space:
mode:
authorRay Lai <ray@cvs.openbsd.org>2007-05-30 02:21:21 +0000
committerRay Lai <ray@cvs.openbsd.org>2007-05-30 02:21:21 +0000
commitcc26359d8cc31fd2998b70da5c99dc6397db841f (patch)
tree060980637a812177048cb67660199587735b15bb /usr.bin/cvs/diff_internals.c
parent7a5b3674b83ceba74a1bac91b791a8742fc5b8d2 (diff)
Sync rcsdiff -> cvs diff
Surprisingly, rcsdiff has nicer code than cvs diff. Changes: 1. Include sys/param.h because we are using MIN/MAX... not sure why it hasn't complained in the past. 2. Use fstat instead of stat. 3. Remove useless casts and __inline. 4. Plug a memory leak. OK niallo@
Diffstat (limited to 'usr.bin/cvs/diff_internals.c')
-rw-r--r--usr.bin/cvs/diff_internals.c26
1 files changed, 14 insertions, 12 deletions
diff --git a/usr.bin/cvs/diff_internals.c b/usr.bin/cvs/diff_internals.c
index ad5ffe7e376..61d74f8dbc7 100644
--- a/usr.bin/cvs/diff_internals.c
+++ b/usr.bin/cvs/diff_internals.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: diff_internals.c,v 1.10 2007/05/29 08:02:59 ray Exp $ */
+/* $OpenBSD: diff_internals.c,v 1.11 2007/05/30 02:21:20 ray Exp $ */
/*
* Copyright (C) Caldera International Inc. 2001-2002.
* All rights reserved.
@@ -126,6 +126,7 @@
* 6n words for files of length n.
*/
+#include <sys/param.h>
#include <sys/stat.h>
#include <ctype.h>
@@ -318,11 +319,11 @@ cvs_diffreg(const char *file1, const char *file2, BUF *out)
goto closem;
}
- if (stat(file1, &stb1) < 0) {
+ if (fstat(fileno(f1), &stb1) < 0) {
cvs_log(LP_ERR, "%s", file1);
goto closem;
}
- if (stat(file2, &stb2) < 0) {
+ if (fstat(fileno(f2), &stb2) < 0) {
cvs_log(LP_ERR, "%s", file2);
goto closem;
}
@@ -405,8 +406,8 @@ files_differ(FILE *f1, FILE *f2)
if (stb1.st_size != stb2.st_size)
return (1);
for (;;) {
- i = fread(buf1, (size_t)1, sizeof(buf1), f1);
- j = fread(buf2, (size_t)1, sizeof(buf2), f2);
+ i = fread(buf1, 1, sizeof(buf1), f1);
+ j = fread(buf2, 1, sizeof(buf2), f2);
if (i != j)
return (1);
if (i == 0 && j == 0) {
@@ -428,7 +429,7 @@ prepare(int i, FILE *fd, off_t filesize)
rewind(fd);
- sz = ((size_t)filesize <= SIZE_MAX ? (size_t)filesize : SIZE_MAX) / 25;
+ sz = (filesize <= SIZE_MAX ? filesize : SIZE_MAX) / 25;
if (sz < 100)
sz = 100;
@@ -820,7 +821,7 @@ output(FILE *f1, FILE *f2)
}
}
-static __inline void
+static void
range(int a, int b, char *separator)
{
diff_output("%d", a > b ? b : a);
@@ -828,7 +829,7 @@ range(int a, int b, char *separator)
diff_output("%s%d", separator, b);
}
-static __inline void
+static void
uni_range(int a, int b)
{
if (a < b)
@@ -848,6 +849,7 @@ preadline(int fd, size_t rlen, off_t off)
line = xmalloc(rlen + 1);
if ((nr = pread(fd, line, rlen, off)) < 0) {
cvs_log(LP_ERR, "preadline failed");
+ xfree(line);
return (NULL);
}
line[nr] = '\0';
@@ -859,7 +861,7 @@ ignoreline(char *line)
{
int ret;
- ret = regexec(&ignore_re, line, (size_t)0, NULL, 0);
+ ret = regexec(&ignore_re, line, 0, NULL, 0);
xfree(line);
return (ret == 0); /* if it matched, it should be ignored. */
}
@@ -923,7 +925,7 @@ proceed:
/*
* Print the context/unidiff header first time through.
*/
- t = localtime(&stb1.st_mtime);
+ t = localtime(&stb1.st_mtime);
(void)strftime(buf, sizeof(buf),
"%d %b %G %H:%M:%S", t);
@@ -1144,7 +1146,7 @@ asciifile(FILE *f)
return (1);
rewind(f);
- cnt = fread(buf, (size_t)1, sizeof(buf), f);
+ cnt = fread(buf, 1, sizeof(buf), f);
for (i = 0; i < cnt; i++)
if (!isprint(buf[i]) && !isspace(buf[i]))
return (0);
@@ -1168,7 +1170,7 @@ match_function(const long *f, int pos, FILE *fp)
nc = f[pos] - f[pos - 1];
if (nc >= sizeof(buf))
nc = sizeof(buf) - 1;
- nc = fread(buf, (size_t)1, nc, fp);
+ nc = fread(buf, 1, nc, fp);
if (nc > 0) {
buf[nc] = '\0';
p = strchr((const char *)buf, '\n');