summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--usr.bin/patch/backupfile.c30
-rw-r--r--usr.bin/patch/common.h42
-rw-r--r--usr.bin/patch/config.h33
-rw-r--r--usr.bin/patch/inp.c88
-rw-r--r--usr.bin/patch/inp.h7
-rw-r--r--usr.bin/patch/patch.c139
-rw-r--r--usr.bin/patch/pch.c210
-rw-r--r--usr.bin/patch/pch.h9
-rw-r--r--usr.bin/patch/util.c47
-rw-r--r--usr.bin/patch/util.h16
10 files changed, 296 insertions, 325 deletions
diff --git a/usr.bin/patch/backupfile.c b/usr.bin/patch/backupfile.c
index d418549d78d..0c925d2a555 100644
--- a/usr.bin/patch/backupfile.c
+++ b/usr.bin/patch/backupfile.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: backupfile.c,v 1.12 2003/07/21 14:32:21 deraadt Exp $ */
+/* $OpenBSD: backupfile.c,v 1.13 2003/07/22 17:18:49 otto Exp $ */
/*
* backupfile.c -- make Emacs style backup file names Copyright (C) 1990 Free
@@ -17,17 +17,22 @@
*/
#ifndef lint
-static char rcsid[] = "$OpenBSD: backupfile.c,v 1.12 2003/07/21 14:32:21 deraadt Exp $";
+static const char rcsid[] = "$OpenBSD: backupfile.c,v 1.13 2003/07/22 17:18:49 otto Exp $";
#endif /* not lint */
+#include <ctype.h>
+#include <libgen.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
-#include <ctype.h>
-#include <libgen.h>
-#include <sys/types.h>
+
#include "backupfile.h"
-#include "config.h"
+
+/*
+ * DIRHEADER: This definition indicates which directory library header to
+ * use.
+ */
+#define DIRENT
#ifdef DIRENT
#include <dirent.h>
@@ -64,7 +69,6 @@ enum backup_type backup_type = none;
char *simple_backup_suffix = "~";
static char *concat(char *, char *);
-char *find_backup_file_name(char *);
static char *make_version_name(char *, int);
static int max_backup_version(char *, char *);
static int version_number(char *, char *, int);
@@ -86,11 +90,11 @@ find_backup_file_name(char *file)
return concat(file, simple_backup_suffix);
base_versions = concat(basename(file), ".~");
if (base_versions == 0)
- return 0;
+ return NULL;
dir = dirname(file);
if (dir == 0) {
free(base_versions);
- return 0;
+ return NULL;
}
highest_backup = max_backup_version(base_versions, dir);
free(base_versions);
@@ -141,7 +145,7 @@ make_version_name(char *file, int version)
char *backup_name;
if (asprintf(&backup_name, "%s.~%d~", file, version) == -1)
- return 0;
+ return NULL;
return backup_name;
}
@@ -176,7 +180,7 @@ concat(char *str1, char *str2)
char *newstr;
if (asprintf(&newstr, "%s%s", str1, str2) == -1)
- return 0;
+ return NULL;
return newstr;
}
@@ -186,7 +190,7 @@ concat(char *str1, char *str2)
* does not match any element or -2 if it is ambiguous (is a prefix of more
* than one element).
*/
-int
+static int
argmatch(char *arg, char **optlist)
{
int i; /* Temporary index in OPTLIST. */
@@ -221,7 +225,7 @@ argmatch(char *arg, char **optlist)
* that was being matched. VALUE is the invalid value that was given. PROBLEM
* is the return value from argmatch.
*/
-void
+static void
invalid_arg(char *kind, char *value, int problem)
{
fprintf(stderr, "patch: ");
diff --git a/usr.bin/patch/common.h b/usr.bin/patch/common.h
index 24ac2d4b090..82f4b9ffeaf 100644
--- a/usr.bin/patch/common.h
+++ b/usr.bin/patch/common.h
@@ -1,26 +1,8 @@
-/* $OpenBSD: common.h,v 1.16 2003/07/21 14:32:21 deraadt Exp $ */
+/* $OpenBSD: common.h,v 1.17 2003/07/22 17:18:49 otto Exp $ */
#define DEBUGGING
-#include "config.h"
-
-/* shut lint up about the following when return value ignored */
-
#include <stdio.h>
-#include <string.h>
-#include <assert.h>
-#include <sys/types.h>
-#include <sys/file.h>
-#include <sys/stat.h>
-#include <sys/param.h>
-#include <ctype.h>
-#include <paths.h>
-#include <signal.h>
-#include <stdlib.h>
-#include <unistd.h>
-#include <stdarg.h>
-#include <libgen.h>
-#include <errno.h>
/* constants */
@@ -45,13 +27,6 @@
/* handy definitions */
-#define Null(t) ((t)0)
-#define Nullch Null(char *)
-#define Nullfp Null(FILE *)
-#define Nulline Null(LINENUM)
-
-#define Ctl(ch) ((ch) & 037)
-
#define strNE(s1,s2) (strcmp(s1, s2))
#define strEQ(s1,s2) (!strcmp(s1, s2))
#define strnNE(s1,s2,l) (strncmp(s1, s2, l))
@@ -73,8 +48,8 @@ EXT struct stat filestat; /* file statistics area */
EXT int filemode INIT(0644);
EXT char buf[MAXLINELEN];/* general purpose buffer */
-EXT FILE *ofp INIT(Nullfp); /* output file pointer */
-EXT FILE *rejfp INIT(Nullfp); /* reject file pointer */
+EXT FILE *ofp INIT(NULL); /* output file pointer */
+EXT FILE *rejfp INIT(NULL); /* reject file pointer */
EXT int myuid; /* cache getuid return value */
@@ -85,12 +60,12 @@ EXT bool out_of_mem INIT(FALSE);/* ran out of memory in plan a */
EXT int filec INIT(0); /* how many file arguments? */
EXT char *filearg[MAXFILEC];
EXT bool ok_to_create_file INIT(FALSE);
-EXT char *bestguess INIT(Nullch); /* guess at correct filename */
+EXT char *bestguess INIT(NULL); /* guess at correct filename */
-EXT char *outname INIT(Nullch);
+EXT char *outname INIT(NULL);
EXT char rejname[128];
-EXT char *origprae INIT(Nullch);
+EXT char *origprae INIT(NULL);
EXT char *TMPOUTNAME;
EXT char *TMPINNAME;
@@ -112,6 +87,9 @@ EXT bool noreverse INIT(FALSE);
EXT bool skip_rest_of_patch INIT(FALSE);
EXT int strippath INIT(957);
EXT bool canonicalize INIT(FALSE);
+/* TRUE if -C was specified on command line. */
+EXT bool check_only INIT(FALSE);
+
#define CONTEXT_DIFF 1
#define NORMAL_DIFF 2
@@ -126,4 +104,4 @@ EXT char not_defined[128]; /* #ifndef xyzzy */
EXT char else_defined[] INIT("#else\n"); /* #else */
EXT char end_defined[128]; /* #endif xyzzy */
-EXT char *revision INIT(Nullch); /* prerequisite revision, if any */
+EXT char *revision INIT(NULL); /* prerequisite revision, if any */
diff --git a/usr.bin/patch/config.h b/usr.bin/patch/config.h
deleted file mode 100644
index 7b1f7b5e86e..00000000000
--- a/usr.bin/patch/config.h
+++ /dev/null
@@ -1,33 +0,0 @@
-/* $OpenBSD: config.h,v 1.6 2003/07/21 14:32:21 deraadt Exp $ */
-
-/*
- * config.h This file was produced by running the config.h.SH script, which
- * gets its values from config.sh, which is generally produced by running
- * Configure.
- *
- * Feel free to modify any of this as the need arises. Note, however, that
- * running config.h.SH again will wipe out any changes you've made. For a
- * more permanent change edit config.sh and rerun config.h.SH.
- *
- */
-
-
-/*
- * CPPSTDIN: This symbol contains the first part of the string which will
- * invoke the C preprocessor on the standard input and produce to standard
- * output. Typical value of "cc -E" or "/lib/cpp".
- */
-/*
- * CPPMINUS: This symbol contains the second part of the string which will
- * invoke the C preprocessor on the standard input and produce to standard
- * output. This symbol will have the value "-" if CPPSTDIN needs a minus to
- * specify standard input, otherwise the value is "".
- */
-#define CPPSTDIN "/usr/bin/cpp"
-#define CPPMINUS ""
-
-/*
- * DIRHEADER: This definition indicates which directory library header to
- * use.
- */
-#define DIRENT
diff --git a/usr.bin/patch/inp.c b/usr.bin/patch/inp.c
index 9928ab6ed2e..f89c924ab9a 100644
--- a/usr.bin/patch/inp.c
+++ b/usr.bin/patch/inp.c
@@ -1,9 +1,20 @@
-/* $OpenBSD: inp.c,v 1.15 2003/07/21 21:01:45 otto Exp $ */
+/* $OpenBSD: inp.c,v 1.16 2003/07/22 17:18:49 otto Exp $ */
#ifndef lint
-static char rcsid[] = "$OpenBSD: inp.c,v 1.15 2003/07/21 21:01:45 otto Exp $";
+static const char rcsid[] = "$OpenBSD: inp.c,v 1.16 2003/07/22 17:18:49 otto Exp $";
#endif /* not lint */
+#include <sys/types.h>
+#include <sys/file.h>
+#include <sys/stat.h>
+
+#include <ctype.h>
+#include <libgen.h>
+#include <limits.h>
+#include <stdlib.h>
+#include <string.h>
+#include <unistd.h>
+
#include "EXTERN.h"
#include "common.h"
#include "util.h"
@@ -11,7 +22,6 @@ static char rcsid[] = "$OpenBSD: inp.c,v 1.15 2003/07/21 21:01:45 otto Exp $
#include "INTERN.h"
#include "inp.h"
-extern bool check_only;
/* Input-file-with-indexable-lines abstract type */
@@ -25,7 +35,9 @@ static LINENUM tiline[2] = {-1, -1}; /* 1st line in each buffer */
static LINENUM lines_per_buf; /* how many lines per buffer */
static int tireclen; /* length of records in tmp file */
-void re_input(void);
+static bool rev_in_string(char *);
+static bool plan_a(char *); /* returns false if insufficient memory */
+static void plan_b(char *);
/* New patch--prepare to edit another file. */
@@ -34,21 +46,17 @@ re_input(void)
{
if (using_plan_a) {
i_size = 0;
-#ifndef lint
- if (i_ptr != Null(char **))
- free((char *) i_ptr);
-#endif
- if (i_womp != Nullch)
- free(i_womp);
- i_womp = Nullch;
- i_ptr = Null(char **);
+ free(i_ptr);
+ free(i_womp);
+ i_womp = NULL;
+ i_ptr = NULL;
} else {
using_plan_a = TRUE; /* maybe the next one is smaller */
close(tifd);
tifd = -1;
free(tibuf[0]);
free(tibuf[1]);
- tibuf[0] = tibuf[1] = Nullch;
+ tibuf[0] = tibuf[1] = NULL;
tiline[0] = tiline[1] = -1;
tireclen = 0;
}
@@ -69,7 +77,7 @@ scan_input(char *filename)
/* Try keeping everything in memory. */
-bool
+static bool
plan_a(char *filename)
{
int ifd, statfailed;
@@ -103,7 +111,7 @@ plan_a(char *filename)
(filestat.st_mode & 0222) == 0 ||
/* I can't write to it. */
((filestat.st_mode & 0022) == 0 && filestat.st_uid != myuid)) {
- char *cs = Nullch, *filebase, *filedir;
+ char *cs = NULL, *filebase, *filedir;
struct stat cstat;
filebase = basename(filename);
@@ -170,18 +178,20 @@ plan_a(char *filename)
out_of_mem = FALSE;
return FALSE; /* force plan b because plan a bombed */
}
- i_womp = malloc(i_size + 2);
- if (i_womp == Nullch)
+ if (i_size > SIZE_MAX - 2)
+ fatal("block too large to allocate");
+ i_womp = malloc((size_t)(i_size + 2));
+ if (i_womp == NULL)
return FALSE;
if ((ifd = open(filename, O_RDONLY)) < 0)
pfatal("can't open file %s", filename);
-#ifndef lint
+
if (read(ifd, i_womp, (size_t) i_size) != i_size) {
close(ifd); /* probably means i_size > 15 or 16 bits worth */
free(i_womp); /* at this point it doesn't matter if i_womp was */
return FALSE; /* undersized. */
}
-#endif
+
close(ifd);
if (i_size && i_womp[i_size - 1] != '\n')
i_womp[i_size++] = '\n';
@@ -194,12 +204,10 @@ plan_a(char *filename)
if (*s == '\n')
iline++;
}
-#ifdef lint
- i_ptr = Null(char **);
-#else
+
i_ptr = (char **) malloc((iline + 2) * sizeof(char *));
-#endif
- if (i_ptr == Null(char **)) { /* shucks, it was a near thing */
+
+ if (i_ptr == NULL) { /* shucks, it was a near thing */
free((char *) i_womp);
return FALSE;
}
@@ -216,7 +224,7 @@ plan_a(char *filename)
/* now check for revision, if any */
- if (revision != Nullch) {
+ if (revision != NULL) {
if (!rev_in_string(i_womp)) {
if (force) {
if (verbose)
@@ -243,26 +251,26 @@ plan_a(char *filename)
/* Keep (virtually) nothing in memory. */
-void
+static void
plan_b(char *filename)
{
FILE *ifp;
int i = 0, maxlen = 1;
- bool found_revision = (revision == Nullch);
+ bool found_revision = (revision == NULL);
using_plan_a = FALSE;
- if ((ifp = fopen(filename, "r")) == Nullfp)
+ if ((ifp = fopen(filename, "r")) == NULL)
pfatal("can't open file %s", filename);
(void) unlink(TMPINNAME);
if ((tifd = open(TMPINNAME, O_EXCL | O_CREAT | O_WRONLY, 0666)) < 0)
pfatal("can't open file %s", TMPINNAME);
- while (fgets(buf, sizeof buf, ifp) != Nullch) {
- if (revision != Nullch && !found_revision && rev_in_string(buf))
+ while (fgets(buf, sizeof buf, ifp) != NULL) {
+ if (revision != NULL && !found_revision && rev_in_string(buf))
found_revision = TRUE;
if ((i = strlen(buf)) > maxlen)
maxlen = i; /* find longest line */
}
- if (revision != Nullch) {
+ if (revision != NULL) {
if (!found_revision) {
if (force) {
if (verbose)
@@ -284,21 +292,21 @@ plan_b(char *filename)
say("Good. This file appears to be the %s version.\n",
revision);
}
- fseek(ifp, 0L, 0); /* rewind file */
+ fseek(ifp, 0L, SEEK_SET); /* rewind file */
lines_per_buf = BUFFERSIZE / maxlen;
tireclen = maxlen;
tibuf[0] = malloc(BUFFERSIZE + 1);
- if (tibuf[0] == Nullch)
+ if (tibuf[0] == NULL)
fatal("out of memory\n");
tibuf[1] = malloc(BUFFERSIZE + 1);
- if (tibuf[1] == Nullch)
+ if (tibuf[1] == NULL)
fatal("out of memory\n");
for (i = 1;; i++) {
if (!(i % lines_per_buf)) /* new block */
if (write(tifd, tibuf[0], BUFFERSIZE) < BUFFERSIZE)
pfatal("can't write temp file");
if (fgets(tibuf[0] + maxlen * (i % lines_per_buf),
- maxlen + 1, ifp) == Nullch) {
+ maxlen + 1, ifp) == NULL) {
input_lines = i - 1;
if (i % lines_per_buf)
if (write(tifd, tibuf[0], BUFFERSIZE) < BUFFERSIZE)
@@ -334,10 +342,10 @@ ifetch(LINENUM line, int whichbuf)
whichbuf = 1;
else {
tiline[whichbuf] = baseline;
-#ifndef lint /* complains of long accuracy */
+
lseek(tifd, (off_t) (baseline / lines_per_buf *
- BUFFERSIZE), 0);
-#endif
+ BUFFERSIZE), SEEK_SET);
+
if (read(tifd, tibuf[whichbuf], BUFFERSIZE) < 0)
pfatal("error reading tmp file %s", TMPINNAME);
}
@@ -348,13 +356,13 @@ ifetch(LINENUM line, int whichbuf)
/*
* True if the string argument contains the revision number we want.
*/
-bool
+static bool
rev_in_string(char *string)
{
char *s;
int patlen;
- if (revision == Nullch)
+ if (revision == NULL)
return TRUE;
patlen = strlen(revision);
if (strnEQ(string, revision, patlen) && isspace(string[patlen]))
diff --git a/usr.bin/patch/inp.h b/usr.bin/patch/inp.h
index 81670d852ea..fc453297cbd 100644
--- a/usr.bin/patch/inp.h
+++ b/usr.bin/patch/inp.h
@@ -1,11 +1,10 @@
-/* $OpenBSD: inp.h,v 1.5 2003/07/21 14:32:21 deraadt Exp $ */
+/* $OpenBSD: inp.h,v 1.6 2003/07/22 17:18:49 otto Exp $ */
EXT LINENUM input_lines INIT(0); /* how long is input file in lines */
EXT LINENUM last_frozen_line INIT(0); /* how many input lines have been */
/* irretractibly output */
-bool rev_in_string(char *);
+
+void re_input(void);
void scan_input(char *);
-bool plan_a(char *); /* returns false if insufficient memory */
-void plan_b(char *);
char *ifetch(LINENUM, int);
diff --git a/usr.bin/patch/patch.c b/usr.bin/patch/patch.c
index d3a10bcb36c..348399f2c21 100644
--- a/usr.bin/patch/patch.c
+++ b/usr.bin/patch/patch.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: patch.c,v 1.22 2003/07/21 21:01:45 otto Exp $ */
+/* $OpenBSD: patch.c,v 1.23 2003/07/22 17:18:49 otto Exp $ */
/*
* patch - a program to apply diffs to original files
@@ -27,9 +27,18 @@
*/
#ifndef lint
-static char rcsid[] = "$OpenBSD: patch.c,v 1.22 2003/07/21 21:01:45 otto Exp $";
+static const char rcsid[] = "$OpenBSD: patch.c,v 1.23 2003/07/22 17:18:49 otto Exp $";
#endif /* not lint */
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <unistd.h>
+
+#include <assert.h>
+#include <ctype.h>
+#include <string.h>
+#include <stdlib.h>
+
#include "INTERN.h"
#include "common.h"
#include "EXTERN.h"
@@ -38,22 +47,21 @@ static char rcsid[] = "$OpenBSD: patch.c,v 1.22 2003/07/21 21:01:45 otto Exp $";
#include "inp.h"
#include "backupfile.h"
-void reinitialize_almost_everything(void);
-void get_some_switches(void);
-LINENUM locate_hunk(LINENUM);
-void abort_hunk(void);
-void apply_hunk(LINENUM);
-void init_output(char *);
-void init_reject(char *);
-void copy_till(LINENUM);
-void spew_output(void);
-void dump_line(LINENUM);
-bool patch_match(LINENUM, LINENUM, LINENUM);
-bool similar(char *, char *, int);
-void re_input(void);
-void my_exit(int) __attribute__((noreturn));
-int optcmp(const void *, const void *);
-char decode_long_option(char *);
+
+static void reinitialize_almost_everything(void);
+static void get_some_switches(void);
+static LINENUM locate_hunk(LINENUM);
+static void abort_hunk(void);
+static void apply_hunk(LINENUM);
+static void init_output(char *);
+static void init_reject(char *);
+static void copy_till(LINENUM);
+static void spew_output(void);
+static void dump_line(LINENUM);
+static bool patch_match(LINENUM, LINENUM, LINENUM);
+static bool similar(char *, char *, int);
+static int optcmp(const void *, const void *);
+static char decode_long_option(char *);
/* TRUE if -E was specified on command line. */
static int remove_empty_files = FALSE;
@@ -61,8 +69,8 @@ static int remove_empty_files = FALSE;
/* TRUE if -R was specified on command line. */
static int reverse_flag_specified = FALSE;
-/* TRUE if -C was specified on command line. */
-bool check_only = FALSE;
+ /* buffer for stderr */
+static char serrbuf[BUFSIZ];
/* Apply a set of diffs as appropriate. */
@@ -75,7 +83,7 @@ main(int argc, char *argv[])
setbuf(stderr, serrbuf);
for (i = 0; i < MAXFILEC; i++)
- filearg[i] = Nullch;
+ filearg[i] = NULL;
myuid = getuid();
@@ -131,7 +139,7 @@ main(int argc, char *argv[])
patch_seen = TRUE;
- if (outname == Nullch)
+ if (outname == NULL)
outname = savestr(filearg[0]);
/* for ed script just up and do it and exit */
@@ -159,24 +167,24 @@ main(int argc, char *argv[])
out_of_mem = FALSE;
while (another_hunk()) {
hunk++;
- fuzz = Nulline;
+ fuzz = NULL;
mymaxfuzz = pch_context();
if (maxfuzz < mymaxfuzz)
mymaxfuzz = maxfuzz;
if (!skip_rest_of_patch) {
do {
where = locate_hunk(fuzz);
- if (hunk == 1 && where == Nulline && !force) {
+ if (hunk == 1 && where == NULL && !force) {
/* dwim for reversed patch? */
if (!pch_swap()) {
- if (fuzz == Nulline)
+ if (fuzz == NULL)
say("Not enough memory to try swapped hunk! Assuming unswapped.\n");
continue;
}
reverse = !reverse;
/* try again */
where = locate_hunk(fuzz);
- if (where == Nulline) {
+ if (where == NULL) {
/* didn't find it swapped */
if (!pch_swap())
/* put it back to normal */
@@ -202,7 +210,7 @@ main(int argc, char *argv[])
ask("Apply anyway? [n] ");
if (*buf != 'y')
skip_rest_of_patch = TRUE;
- where = Nulline;
+ where = NULL;
reverse = !reverse;
if (!pch_swap())
/* put it back to normal */
@@ -210,12 +218,12 @@ main(int argc, char *argv[])
}
}
}
- } while (!skip_rest_of_patch && where == Nulline &&
+ } while (!skip_rest_of_patch && where == NULL &&
++fuzz <= mymaxfuzz);
if (skip_rest_of_patch) { /* just got decided */
fclose(ofp);
- ofp = Nullfp;
+ ofp = NULL;
}
}
newwhere = pch_newfirst() + last_offset;
@@ -225,7 +233,7 @@ main(int argc, char *argv[])
if (verbose)
say("Hunk #%d ignored at %ld.\n",
hunk, newwhere);
- } else if (where == Nulline) {
+ } else if (where == NULL) {
abort_hunk();
failed++;
if (verbose)
@@ -253,10 +261,10 @@ main(int argc, char *argv[])
say("\n\nRan out of memory using Plan A--trying again...\n\n");
if (ofp)
fclose(ofp);
- ofp = Nullfp;
+ ofp = NULL;
if (rejfp)
fclose(rejfp);
- rejfp = Nullfp;
+ rejfp = NULL;
continue;
}
assert(hunk);
@@ -290,7 +298,7 @@ main(int argc, char *argv[])
}
}
fclose(rejfp);
- rejfp = Nullfp;
+ rejfp = NULL;
if (failed) {
failtotal += failed;
if (!*rejname) {
@@ -321,7 +329,7 @@ main(int argc, char *argv[])
/* Prepare to find the next patch to do in the patch file. */
-void
+static void
reinitialize_almost_everything(void)
{
re_patch();
@@ -331,21 +339,21 @@ reinitialize_almost_everything(void)
last_frozen_line = 0;
filec = 0;
- if (filearg[0] != Nullch && !out_of_mem) {
+ if (filearg[0] != NULL && !out_of_mem) {
free(filearg[0]);
- filearg[0] = Nullch;
+ filearg[0] = NULL;
}
- if (outname != Nullch) {
+ if (outname != NULL) {
free(outname);
- outname = Nullch;
+ outname = NULL;
}
last_offset = 0;
diff_type = 0;
- if (revision != Nullch) {
+ if (revision != NULL) {
free(revision);
- revision = Nullch;
+ revision = NULL;
}
reverse = reverse_flag_specified;
skip_rest_of_patch = FALSE;
@@ -371,7 +379,7 @@ struct option {
char short_opt;
};
-int
+static int
optcmp(const void *v1, const void *v2)
{
const struct option *a = v1, *b = v2;
@@ -381,7 +389,7 @@ optcmp(const void *v1, const void *v2)
/* Decode Long options beginning with "--" to their short equivalents. */
-char
+static char
decode_long_option(char *opt)
{
/*
@@ -426,7 +434,7 @@ decode_long_option(char *opt)
/* Process switches and filenames up to next '+' or end of list. */
-void
+static void
get_some_switches(void)
{
char *s;
@@ -572,7 +580,7 @@ Options:\n\
/*
* Attempt to find the right place to apply this hunk of patch.
*/
-LINENUM
+static LINENUM
locate_hunk(LINENUM fuzz)
{
LINENUM first_guess = pch_first() + last_offset;
@@ -585,7 +593,7 @@ locate_hunk(LINENUM fuzz)
return first_guess;
if (max_neg_offset >= first_guess) /* do not try lines < 0 */
max_neg_offset = first_guess - 1;
- if (first_guess <= input_lines && patch_match(first_guess, Nulline, fuzz))
+ if (first_guess <= input_lines && patch_match(first_guess, NULL, fuzz))
return first_guess;
for (offset = 1; ; offset++) {
bool check_after = (offset <= max_pos_offset);
@@ -608,13 +616,13 @@ locate_hunk(LINENUM fuzz)
last_offset = -offset;
return first_guess - offset;
} else if (!check_before && !check_after)
- return Nulline;
+ return NULL;
}
}
/* We did not find the pattern, dump out the hunk so they can handle it. */
-void
+static void
abort_hunk(void)
{
LINENUM i;
@@ -668,7 +676,7 @@ abort_hunk(void)
/* We found where to apply it (we hope), so do it. */
-void
+static void
apply_hunk(LINENUM where)
{
LINENUM old = 1;
@@ -780,29 +788,29 @@ apply_hunk(LINENUM where)
/*
* Open the new file.
*/
-void
+static void
init_output(char *name)
{
ofp = fopen(name, "w");
- if (ofp == Nullfp)
+ if (ofp == NULL)
pfatal("can't create %s", name);
}
/*
* Open a file to put hunks we can't locate.
*/
-void
+static void
init_reject(char *name)
{
rejfp = fopen(name, "w");
- if (rejfp == Nullfp)
+ if (rejfp == NULL)
pfatal("can't create %s", name);
}
/*
* Copy input file to output, up to wherever hunk is to be applied.
*/
-void
+static void
copy_till(LINENUM lastline)
{
LINENUM R_last_frozen_line = last_frozen_line;
@@ -817,7 +825,7 @@ copy_till(LINENUM lastline)
/*
* Finish copying the input file to the output file.
*/
-void
+static void
spew_output(void)
{
#ifdef DEBUGGING
@@ -827,13 +835,13 @@ spew_output(void)
if (input_lines)
copy_till(input_lines); /* dump remainder of file */
fclose(ofp);
- ofp = Nullfp;
+ ofp = NULL;
}
/*
* Copy one line from input to output.
*/
-void
+static void
dump_line(LINENUM line)
{
char *s, R_newline = '\n';
@@ -846,7 +854,7 @@ dump_line(LINENUM line)
/*
* Does the patch pattern match at line base+offset?
*/
-bool
+static bool
patch_match(LINENUM base, LINENUM offset, LINENUM fuzz)
{
LINENUM pline = 1 + fuzz;
@@ -868,7 +876,7 @@ patch_match(LINENUM base, LINENUM offset, LINENUM fuzz)
/*
* Do two lines match with canonicalized white space?
*/
-bool
+static bool
similar(char *a, char *b, int len)
{
while (len) {
@@ -889,18 +897,3 @@ similar(char *a, char *b, int len)
return TRUE; /* actually, this is not reached */
/* since there is always a \n */
}
-
-/*
- * Exit with cleanup.
- */
-void
-my_exit(int status)
-{
- unlink(TMPINNAME);
- if (!toutkeep)
- unlink(TMPOUTNAME);
- if (!trejkeep)
- unlink(TMPREJNAME);
- unlink(TMPPATNAME);
- exit(status);
-}
diff --git a/usr.bin/patch/pch.c b/usr.bin/patch/pch.c
index 2a2c8fb7eaf..2761d2089ef 100644
--- a/usr.bin/patch/pch.c
+++ b/usr.bin/patch/pch.c
@@ -1,16 +1,24 @@
-/* $OpenBSD: pch.c,v 1.20 2003/07/21 14:32:21 deraadt Exp $ */
+/* $OpenBSD: pch.c,v 1.21 2003/07/22 17:18:49 otto Exp $ */
#ifndef lint
-static char rcsid[] = "$OpenBSD: pch.c,v 1.20 2003/07/21 14:32:21 deraadt Exp $";
+static const char rcsid[] = "$OpenBSD: pch.c,v 1.21 2003/07/22 17:18:49 otto Exp $";
#endif /* not lint */
+#include <sys/types.h>
+#include <sys/stat.h>
+
+#include <assert.h>
+#include <ctype.h>
+#include <stdlib.h>
+#include <string.h>
+#include <unistd.h>
+
#include "EXTERN.h"
#include "common.h"
#include "util.h"
#include "INTERN.h"
#include "pch.h"
-extern bool check_only;
/* Patch (diff listing) abstract type. */
static long p_filesize; /* size of the patch file */
@@ -22,9 +30,9 @@ static LINENUM p_end = -1; /* last line in hunk */
static LINENUM p_max; /* max allowed value of p_end */
static LINENUM p_context = 3; /* # of context lines */
static LINENUM p_input_line = 0; /* current line # from patch file */
-static char **p_line = Null(char **); /* the text of the hunk */
-static short *p_len = Null(short *); /* length of each line */
-static char *p_char = Nullch;/* +, -, and ! */
+static char **p_line = NULL; /* the text of the hunk */
+static short *p_len = NULL; /* length of each line */
+static char *p_char = NULL;/* +, -, and ! */
static int hunkmax = INITHUNKMAX; /* size of above arrays to begin with */
static int p_indent; /* indent to patch */
static LINENUM p_base; /* where to intuit this time */
@@ -35,18 +43,24 @@ static LINENUM p_hunk_beg; /* line number of current hunk */
static LINENUM p_efake = -1; /* end of faked up lines--don't free */
static LINENUM p_bfake = -1; /* beg of faked up lines */
+static void grow_hunkmax(void);
+static int intuit_diff_type(void);
+static void next_intuit_at(long, long);
+static void skip_to(long, long);
+static char *pgets(char *, int, FILE *);
+
/*
* Prepare to look for the next patch in the patch file.
*/
void
re_patch(void)
{
- p_first = Nulline;
- p_newfirst = Nulline;
- p_ptrn_lines = Nulline;
- p_repl_lines = Nulline;
+ p_first = NULL;
+ p_newfirst = NULL;
+ p_ptrn_lines = NULL;
+ p_repl_lines = NULL;
p_end = (LINENUM) - 1;
- p_max = Nulline;
+ p_max = NULL;
p_indent = 0;
}
@@ -56,17 +70,17 @@ re_patch(void)
void
open_patch_file(char *filename)
{
- if (filename == Nullch || !*filename || strEQ(filename, "-")) {
+ if (filename == NULL || !*filename || strEQ(filename, "-")) {
pfp = fopen(TMPPATNAME, "w");
- if (pfp == Nullfp)
+ if (pfp == NULL)
pfatal("can't create %s", TMPPATNAME);
- while (fgets(buf, sizeof buf, stdin) != Nullch)
+ while (fgets(buf, sizeof buf, stdin) != NULL)
fputs(buf, pfp);
fclose(pfp);
filename = TMPPATNAME;
}
pfp = fopen(filename, "r");
- if (pfp == Nullfp)
+ if (pfp == NULL)
pfatal("patch file %s not found", filename);
fstat(fileno(pfp), &filestat);
p_filesize = filestat.st_size;
@@ -80,20 +94,18 @@ open_patch_file(char *filename)
void
set_hunkmax(void)
{
-#ifndef lint
- if (p_line == Null(char **))
- p_line = (char **) malloc((size_t) hunkmax * sizeof(char *));
- if (p_len == Null(short *))
- p_len = (short *) malloc((size_t) hunkmax * sizeof(short));
-#endif
- if (p_char == Nullch)
- p_char = (char *) malloc((size_t) hunkmax * sizeof(char));
+ if (p_line == NULL)
+ p_line = malloc((size_t) hunkmax * sizeof(char *));
+ if (p_len == NULL)
+ p_len = malloc((size_t) hunkmax * sizeof(short));
+ if (p_char == NULL)
+ p_char = malloc((size_t) hunkmax * sizeof(char));
}
/*
* Enlarge the arrays containing the current hunk of patch.
*/
-void
+static void
grow_hunkmax(void)
{
hunkmax *= 2;
@@ -103,13 +115,13 @@ grow_hunkmax(void)
* since p_len can move into p_line's old space, and p_char can move into
* p_len's old space. Not on PDP-11's however. But it doesn't matter.
*/
- assert(p_line != Null(char **) &&p_len != Null(short *) &&p_char != Nullch);
-#ifndef lint
- p_line = (char **) realloc((char *) p_line, hunkmax * sizeof(char *));
- p_len = (short *) realloc((char *) p_len, hunkmax * sizeof(short));
- p_char = (char *) realloc((char *) p_char, hunkmax * sizeof(char));
-#endif
- if (p_line != Null(char **) &&p_len != Null(short *) &&p_char != Nullch)
+ assert(p_line != NULL &&p_len != NULL &&p_char != NULL);
+
+ p_line = realloc(p_line, hunkmax * sizeof(char *));
+ p_len = realloc(p_len, hunkmax * sizeof(short));
+ p_char = realloc(p_char, hunkmax * sizeof(char));
+
+ if (p_line != NULL &&p_len != NULL &&p_char != NULL)
return;
if (!using_plan_a)
fatal("out of memory\n");
@@ -150,7 +162,7 @@ there_is_another_patch(void)
say("(Patch is indented %d space%s.)\n", p_indent,
p_indent == 1 ? "" : "s");
skip_to(p_start, p_sline);
- while (filearg[0] == Nullch) {
+ while (filearg[0] == NULL) {
if (force || batch) {
say("No file to patch. Skipping...\n");
filearg[0] = savestr(bestguess);
@@ -164,7 +176,7 @@ there_is_another_patch(void)
bestguess = savestr(buf);
filearg[0] = fetchname(buf, 0, FALSE);
}
- if (filearg[0] == Nullch) {
+ if (filearg[0] == NULL) {
ask("No file found--skip this patch? [n] ");
if (*buf != 'y')
continue;
@@ -180,7 +192,7 @@ there_is_another_patch(void)
/* Determine what kind of diff is in the remaining part of the patch file. */
-int
+static int
intuit_diff_type(void)
{
long this_line = 0, previous_line;
@@ -188,17 +200,17 @@ intuit_diff_type(void)
bool last_line_was_command = FALSE, this_is_a_command = FALSE;
bool stars_last_line = FALSE, stars_this_line = FALSE;
char *s, *t;
- char *indtmp = Nullch;
- char *oldtmp = Nullch;
- char *newtmp = Nullch;
- char *indname = Nullch;
- char *oldname = Nullch;
- char *newname = Nullch;
+ char *indtmp = NULL;
+ char *oldtmp = NULL;
+ char *newtmp = NULL;
+ char *indname = NULL;
+ char *oldname = NULL;
+ char *newname = NULL;
int indent, retval;
- bool no_filearg = (filearg[0] == Nullch);
+ bool no_filearg = (filearg[0] == NULL);
ok_to_create_file = FALSE;
- fseek(pfp, p_base, 0);
+ fseek(pfp, p_base, SEEK_SET);
p_input_line = p_bline - 1;
for (;;) {
previous_line = this_line;
@@ -207,7 +219,7 @@ intuit_diff_type(void)
this_line = ftell(pfp);
indent = 0;
p_input_line++;
- if (fgets(buf, sizeof buf, pfp) == Nullch) {
+ if (fgets(buf, sizeof buf, pfp) == NULL) {
if (first_command_line >= 0L) {
/* nothing but deletes!? */
p_start = first_command_line;
@@ -254,7 +266,7 @@ intuit_diff_type(void)
*t = '\0';
if (!*revision) {
free(revision);
- revision = Nullch;
+ revision = NULL;
}
}
if ((!diff_type || diff_type == ED_DIFF) &&
@@ -305,11 +317,11 @@ intuit_diff_type(void)
}
scan_exit:
if (no_filearg) {
- if (indtmp != Nullch)
+ if (indtmp != NULL)
indname = fetchname(indtmp, strippath, ok_to_create_file);
- if (oldtmp != Nullch)
+ if (oldtmp != NULL)
oldname = fetchname(oldtmp, strippath, ok_to_create_file);
- if (newtmp != Nullch)
+ if (newtmp != NULL)
newname = fetchname(newtmp, strippath, ok_to_create_file);
if (indname)
filearg[0] = savestr(indname);
@@ -325,16 +337,16 @@ scan_exit:
}
if (bestguess) {
free(bestguess);
- bestguess = Nullch;
+ bestguess = NULL;
}
- if (filearg[0] != Nullch)
+ if (filearg[0] != NULL)
bestguess = savestr(filearg[0]);
- else if (indtmp != Nullch)
+ else if (indtmp != NULL)
bestguess = fetchname(indtmp, strippath, TRUE);
else {
- if (oldtmp != Nullch)
+ if (oldtmp != NULL)
oldname = fetchname(oldtmp, strippath, TRUE);
- if (newtmp != Nullch)
+ if (newtmp != NULL)
newname = fetchname(newtmp, strippath, TRUE);
if (oldname && newname) {
if (strlen(oldname) < strlen(newname))
@@ -346,25 +358,19 @@ scan_exit:
else if (newname)
bestguess = savestr(newname);
}
- if (indtmp != Nullch)
- free(indtmp);
- if (oldtmp != Nullch)
- free(oldtmp);
- if (newtmp != Nullch)
- free(newtmp);
- if (indname != Nullch)
- free(indname);
- if (oldname != Nullch)
- free(oldname);
- if (newname != Nullch)
- free(newname);
+ free(indtmp);
+ free(oldtmp);
+ free(newtmp);
+ free(indname);
+ free(oldname);
+ free(newname);
return retval;
}
/*
* Remember where this patch ends so we know where to start up again.
*/
-void
+static void
next_intuit_at(long file_pos, long file_line)
{
p_base = file_pos;
@@ -374,23 +380,23 @@ next_intuit_at(long file_pos, long file_line)
/*
* Basically a verbose fseek() to the actual diff listing.
*/
-void
+static void
skip_to(long file_pos, long file_line)
{
char *ret;
assert(p_base <= file_pos);
if (verbose && p_base < file_pos) {
- fseek(pfp, p_base, 0);
+ fseek(pfp, p_base, SEEK_SET);
say("The text leading up to this was:\n--------------------------\n");
while (ftell(pfp) < file_pos) {
ret = fgets(buf, sizeof buf, pfp);
- assert(ret != Nullch);
+ assert(ret != NULL);
say("|%s", buf);
}
say("--------------------------\n");
} else
- fseek(pfp, file_pos, 0);
+ fseek(pfp, file_pos, SEEK_SET);
p_input_line = file_line - 1;
}
@@ -468,7 +474,7 @@ another_hunk(void)
ret = pgets(buf, sizeof buf, pfp);
p_input_line++;
- if (ret == Nullch || strnNE(buf, "********", 8)) {
+ if (ret == NULL || strnNE(buf, "********", 8)) {
next_intuit_at(line_beginning, p_input_line);
return FALSE;
}
@@ -478,7 +484,7 @@ another_hunk(void)
line_beginning = ftell(pfp);
ret = pgets(buf, sizeof buf, pfp);
p_input_line++;
- if (ret == Nullch) {
+ if (ret == NULL) {
if (p_max - p_end < 4) {
/* assume blank lines got chopped */
strlcpy(buf, " \n", sizeof buf);
@@ -493,7 +499,7 @@ another_hunk(void)
p_end++;
assert(p_end < hunkmax);
p_char[p_end] = *buf;
- p_line[p_end] = Nullch;
+ p_line[p_end] = NULL;
switch (*buf) {
case '*':
if (strnEQ(buf, "********", 8)) {
@@ -711,7 +717,7 @@ hunk_done:
p_input_line = repl_patch_line;
for (p_end--; p_end > repl_beginning; p_end--)
free(p_line[p_end]);
- fseek(pfp, repl_backtrack_position, 0);
+ fseek(pfp, repl_backtrack_position, SEEK_SET);
/* redundant 'new' context lines were omitted - set */
/* up to fill them in from the old file context */
@@ -792,7 +798,7 @@ hunk_done:
ret = pgets(buf, sizeof buf, pfp);
p_input_line++;
- if (ret == Nullch || strnNE(buf, "@@ -", 4)) {
+ if (ret == NULL || strnNE(buf, "@@ -", 4)) {
next_intuit_at(line_beginning, p_input_line);
return FALSE;
}
@@ -856,7 +862,7 @@ hunk_done:
line_beginning = ftell(pfp);
ret = pgets(buf, sizeof buf, pfp);
p_input_line++;
- if (ret == Nullch) {
+ if (ret == NULL) {
if (p_max - filldst < 3) {
/* assume blank lines got chopped */
strlcpy(buf, " \n", sizeof buf);
@@ -954,7 +960,7 @@ hunk_done:
p_context = 0;
ret = pgets(buf, sizeof buf, pfp);
p_input_line++;
- if (ret == Nullch || !isdigit(*buf)) {
+ if (ret == NULL || !isdigit(*buf)) {
next_intuit_at(line_beginning, p_input_line);
return FALSE;
}
@@ -998,7 +1004,7 @@ hunk_done:
for (i = 1; i <= p_ptrn_lines; i++) {
ret = pgets(buf, sizeof buf, pfp);
p_input_line++;
- if (ret == Nullch)
+ if (ret == NULL)
fatal("unexpected end of file in patch at line %ld\n",
p_input_line);
if (*buf != '<')
@@ -1020,7 +1026,7 @@ hunk_done:
if (hunk_type == 'c') {
ret = pgets(buf, sizeof buf, pfp);
p_input_line++;
- if (ret == Nullch)
+ if (ret == NULL)
fatal("unexpected end of file in patch at line %ld\n",
p_input_line);
if (*buf != '-')
@@ -1037,7 +1043,7 @@ hunk_done:
for (i++; i <= p_end; i++) {
ret = pgets(buf, sizeof buf, pfp);
p_input_line++;
- if (ret == Nullch)
+ if (ret == NULL)
fatal("unexpected end of file in patch at line %ld\n",
p_input_line);
if (*buf != '>')
@@ -1084,13 +1090,13 @@ hunk_done:
/*
* Input a line from the patch file, worrying about indentation.
*/
-char *
+static char *
pgets(char *bf, int sz, FILE *fp)
{
char *s, *ret = fgets(bf, sz, fp);
int indent = 0;
- if (p_indent && ret != Nullch) {
+ if (p_indent && ret != NULL) {
for (s = buf;
indent < p_indent && (*s == ' ' || *s == '\t' || *s == 'X');
s++) {
@@ -1128,21 +1134,20 @@ pch_swap(void)
tp_line = p_line;
tp_len = p_len;
tp_char = p_char;
- p_line = Null(char **); /* force set_hunkmax to allocate again */
- p_len = Null(short *);
- p_char = Nullch;
+ p_line = NULL; /* force set_hunkmax to allocate again */
+ p_len = NULL;
+ p_char = NULL;
set_hunkmax();
- if (p_line == Null(char **) ||p_len == Null(short *) ||p_char == Nullch) {
-#ifndef lint
- if (p_line == Null(char **))
- free((char *) p_line);
+ if (p_line == NULL ||p_len == NULL ||p_char == NULL) {
+
+ if (p_line == NULL) /* XXX */
+ free(p_line);
p_line = tp_line;
- if (p_len == Null(short *))
- free((char *) p_len);
+ if (p_len == NULL) /* XXX */
+ free(p_len);
p_len = tp_len;
-#endif
- if (p_char == Nullch)
- free((char *) p_char);
+ if (p_char == NULL) /* XXX */
+ free(p_char);
p_char = tp_char;
return FALSE; /* not enough memory to swap hunk! */
}
@@ -1199,14 +1204,13 @@ pch_swap(void)
i = p_ptrn_lines;
p_ptrn_lines = p_repl_lines;
p_repl_lines = i;
-#ifndef lint
- if (tp_line == Null(char **))
- free((char *) tp_line);
- if (tp_len == Null(short *))
- free((char *) tp_len);
-#endif
- if (tp_char == Nullch)
- free((char *) tp_char);
+
+ if (tp_line == NULL) /* XXX */
+ free(tp_line);
+ if (tp_len == NULL) /* XXX */
+ free(tp_len);
+ if (tp_char == NULL) /* XXX */
+ free(tp_char);
return TRUE;
}
@@ -1322,7 +1326,7 @@ do_ed_script(void)
}
for (;;) {
beginning_of_this_line = ftell(pfp);
- if (pgets(buf, sizeof buf, pfp) == Nullch) {
+ if (pgets(buf, sizeof buf, pfp) == NULL) {
next_intuit_at(beginning_of_this_line, p_input_line);
break;
}
@@ -1335,7 +1339,7 @@ do_ed_script(void)
if (!skip_rest_of_patch)
fputs(buf, pipefp);
if (*t != 'd') {
- while (pgets(buf, sizeof buf, pfp) != Nullch) {
+ while (pgets(buf, sizeof buf, pfp) != NULL) {
p_input_line++;
if (!skip_rest_of_patch)
fputs(buf, pipefp);
diff --git a/usr.bin/patch/pch.h b/usr.bin/patch/pch.h
index 9f20d696123..9c8633f4f53 100644
--- a/usr.bin/patch/pch.h
+++ b/usr.bin/patch/pch.h
@@ -1,15 +1,11 @@
-/* $OpenBSD: pch.h,v 1.5 2003/07/21 14:32:21 deraadt Exp $ */
+/* $OpenBSD: pch.h,v 1.6 2003/07/22 17:18:49 otto Exp $ */
-EXT FILE *pfp INIT(Nullfp); /* patch file pointer */
+EXT FILE *pfp INIT(NULL); /* patch file pointer */
void re_patch(void);
void open_patch_file(char *);
void set_hunkmax(void);
-void grow_hunkmax(void);
bool there_is_another_patch(void);
-int intuit_diff_type(void);
-void next_intuit_at(long, long);
-void skip_to(long, long);
bool another_hunk(void);
bool pch_swap(void);
char *pfetch(LINENUM);
@@ -23,5 +19,4 @@ LINENUM pch_context(void);
LINENUM pch_hunk_beg(void);
char pch_char(LINENUM);
char *pfetch(LINENUM);
-char *pgets(char *, int, FILE *);
void do_ed_script(void);
diff --git a/usr.bin/patch/util.c b/usr.bin/patch/util.c
index 6340266a7a9..800097c3972 100644
--- a/usr.bin/patch/util.c
+++ b/usr.bin/patch/util.c
@@ -1,16 +1,28 @@
-/* $OpenBSD: util.c,v 1.15 2003/07/21 14:32:21 deraadt Exp $ */
+/* $OpenBSD: util.c,v 1.16 2003/07/22 17:18:49 otto Exp $ */
#ifndef lint
-static char rcsid[] = "$OpenBSD: util.c,v 1.15 2003/07/21 14:32:21 deraadt Exp $";
+static const char rcsid[] = "$OpenBSD: util.c,v 1.16 2003/07/22 17:18:49 otto Exp $";
#endif /* not lint */
+#include <sys/param.h>
+#include <sys/stat.h>
+
+#include <ctype.h>
+#include <errno.h>
+#include <fcntl.h>
+#include <libgen.h>
+#include <paths.h>
+#include <stdarg.h>
+#include <stdlib.h>
+#include <string.h>
+#include <unistd.h>
+
#include "EXTERN.h"
#include "common.h"
#include "INTERN.h"
#include "util.h"
#include "backupfile.h"
-void my_exit(int) __attribute__((noreturn));
/* Rename a file, copying it if necessary. */
@@ -31,7 +43,7 @@ move_file(char *from, char *to)
if (fromfd < 0)
pfatal("internal error, can't reopen %s", from);
while ((i = read(fromfd, buf, sizeof buf)) > 0)
- if (write(1, buf, i) != 1)
+ if (write(STDOUT_FILENO, buf, i) != i)
pfatal("write failed");
close(fromfd);
return 0;
@@ -167,7 +179,7 @@ savestr(char *s)
while (*t++)
;
rv = malloc((size_t) (t - s));
- if (rv == Nullch) {
+ if (rv == NULL) {
if (using_plan_a)
out_of_mem = TRUE;
else
@@ -275,7 +287,6 @@ ask(char *fmt, ...)
void
set_signals(int reset)
{
-#ifndef lint
static sig_t hupval, intval;
if (!reset) {
@@ -288,7 +299,6 @@ set_signals(int reset)
}
signal(SIGHUP, hupval);
signal(SIGINT, intval);
-#endif
}
/*
@@ -297,10 +307,8 @@ set_signals(int reset)
void
ignore_signals(void)
{
-#ifndef lint
signal(SIGHUP, SIG_IGN);
signal(SIGINT, SIG_IGN);
-#endif
}
/*
@@ -340,7 +348,7 @@ fetchname(char *at, int strip_leading, int assume_exists)
int sleading = strip_leading;
if (!at || *at == '\0')
- return Nullch;
+ return NULL;
while (isspace(*at))
at++;
#ifdef DEBUGGING
@@ -348,7 +356,7 @@ fetchname(char *at, int strip_leading, int assume_exists)
say("fetchname %s %d %d\n", at, strip_leading, assume_exists);
#endif
if (strnEQ(at, "/dev/null", 9)) /* so files can be created by diffing */
- return Nullch; /* against /dev/null. */
+ return NULL; /* against /dev/null. */
name = fullname = t = savestr(at);
/* Strip off up to `sleading' leading slashes and null terminate. */
@@ -387,7 +395,7 @@ fetchname(char *at, int strip_leading, int assume_exists)
try("%s/%s%s", filedir, SCCSPREFIX, filebase))
return name;
free(name);
- name = Nullch;
+ name = NULL;
}
return name;
}
@@ -398,3 +406,18 @@ version(void)
fprintf(stderr, "Patch version 2.0-12u8-OpenBSD\n");
my_exit(0);
}
+
+/*
+ * Exit with cleanup.
+ */
+void
+my_exit(int status)
+{
+ unlink(TMPINNAME);
+ if (!toutkeep)
+ unlink(TMPOUTNAME);
+ if (!trejkeep)
+ unlink(TMPREJNAME);
+ unlink(TMPPATNAME);
+ exit(status);
+}
diff --git a/usr.bin/patch/util.h b/usr.bin/patch/util.h
index 3b81cd8da68..4f0d42c10cd 100644
--- a/usr.bin/patch/util.h
+++ b/usr.bin/patch/util.h
@@ -1,18 +1,18 @@
-/* $OpenBSD: util.h,v 1.6 2003/07/21 14:32:21 deraadt Exp $ */
-
-/* and for those machine that can't handle a variable argument list */
-
-EXT char serrbuf[BUFSIZ];/* buffer for stderr */
+/* $OpenBSD: util.h,v 1.7 2003/07/22 17:18:49 otto Exp $ */
char *fetchname(char *, int, int);
int move_file(char *, char *);
void copy_file(char *, char *);
void say(char *, ...);
-void fatal(char *, ...);
-void pfatal(char *, ...);
-void ask(char *, ...);
+void fatal(char *, ...)
+ __attribute__((__format__(__printf__, 1, 2)));
+void pfatal(char *, ...)
+ __attribute__((__format__(__printf__, 1, 2)));
+void ask(char *, ...)
+ __attribute__((__format__(__printf__, 1, 2)));
char *savestr(char *);
void set_signals(int);
void ignore_signals(void);
void makedirs(char *, bool);
void version(void);
+void my_exit(int) __attribute__((noreturn));