patch: make '-V none' work in the expected way

Internally the code confuses the concept of "the user doesn't want
a backup file" and "the user hasn't defined a type of backup file".

Introduce a new "undefined" backup type to serve the purpose "none"
previously did, and make "none" not generate backup files, as expected.

http://mail-index.netbsd.org/tech-userlevel/2021/02/19/msg012901.html

XXX pullup?
This commit is contained in:
nia 2021-02-19 17:46:53 +00:00
parent 2ab3058973
commit 8b022a822c
3 changed files with 16 additions and 13 deletions

View File

@ -1,7 +1,7 @@
/* /*
* $OpenBSD: backupfile.c,v 1.19 2006/03/11 19:41:30 otto Exp $ * $OpenBSD: backupfile.c,v 1.19 2006/03/11 19:41:30 otto Exp $
* $DragonFly: src/usr.bin/patch/backupfile.c,v 1.5 2008/08/11 00:05:06 joerg Exp $ * $DragonFly: src/usr.bin/patch/backupfile.c,v 1.5 2008/08/11 00:05:06 joerg Exp $
* $NetBSD: backupfile.c,v 1.15 2014/04/11 17:30:03 christos Exp $ * $NetBSD: backupfile.c,v 1.16 2021/02/19 17:46:53 nia Exp $
*/ */
/* /*
@ -22,7 +22,7 @@
*/ */
#include <sys/cdefs.h> #include <sys/cdefs.h>
__RCSID("$NetBSD: backupfile.c,v 1.15 2014/04/11 17:30:03 christos Exp $"); __RCSID("$NetBSD: backupfile.c,v 1.16 2021/02/19 17:46:53 nia Exp $");
#include <ctype.h> #include <ctype.h>
#include <dirent.h> #include <dirent.h>
@ -38,7 +38,7 @@ __RCSID("$NetBSD: backupfile.c,v 1.15 2014/04/11 17:30:03 christos Exp $");
#define ISDIGIT(c) (isascii ((unsigned char)c) && isdigit ((unsigned char)c)) #define ISDIGIT(c) (isascii ((unsigned char)c) && isdigit ((unsigned char)c))
/* Which type of backup file names are generated. */ /* Which type of backup file names are generated. */
enum backup_type backup_type = none; enum backup_type backup_type = undefined;
/* /*
* The extension added to file names to produce a simple (as opposed to * The extension added to file names to produce a simple (as opposed to

View File

@ -1,7 +1,7 @@
/* /*
* $OpenBSD: backupfile.h,v 1.6 2003/07/28 18:35:36 otto Exp $ * $OpenBSD: backupfile.h,v 1.6 2003/07/28 18:35:36 otto Exp $
* $DragonFly: src/usr.bin/patch/backupfile.h,v 1.3 2007/09/29 23:11:10 swildner Exp $ * $DragonFly: src/usr.bin/patch/backupfile.h,v 1.3 2007/09/29 23:11:10 swildner Exp $
* $NetBSD: backupfile.h,v 1.6 2008/09/19 18:33:34 joerg Exp $ * $NetBSD: backupfile.h,v 1.7 2021/02/19 17:46:53 nia Exp $
*/ */
/* /*
@ -19,6 +19,8 @@
/* When to make backup files. */ /* When to make backup files. */
enum backup_type { enum backup_type {
undefined,
/* Never make backups. */ /* Never make backups. */
none, none,

View File

@ -1,7 +1,7 @@
/* /*
* $OpenBSD: patch.c,v 1.45 2007/04/18 21:52:24 sobrado Exp $ * $OpenBSD: patch.c,v 1.45 2007/04/18 21:52:24 sobrado Exp $
* $DragonFly: src/usr.bin/patch/patch.c,v 1.10 2008/08/10 23:39:56 joerg Exp $ * $DragonFly: src/usr.bin/patch/patch.c,v 1.10 2008/08/10 23:39:56 joerg Exp $
* $NetBSD: patch.c,v 1.29 2011/09/06 18:25:14 joerg Exp $ * $NetBSD: patch.c,v 1.30 2021/02/19 17:46:53 nia Exp $
*/ */
/* /*
@ -31,7 +31,7 @@
*/ */
#include <sys/cdefs.h> #include <sys/cdefs.h>
__RCSID("$NetBSD: patch.c,v 1.29 2011/09/06 18:25:14 joerg Exp $"); __RCSID("$NetBSD: patch.c,v 1.30 2021/02/19 17:46:53 nia Exp $");
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
@ -197,17 +197,18 @@ main(int argc, char *argv[])
else else
simple_backup_suffix = ORIGEXT; simple_backup_suffix = ORIGEXT;
if ((v = getenv("PATCH_VERSION_CONTROL")) == NULL)
v = getenv("VERSION_CONTROL");
if (v != NULL)
backup_type = get_version(v);
/* parse switches */ /* parse switches */
Argc = argc; Argc = argc;
Argv = argv; Argv = argv;
get_some_switches(); get_some_switches();
if (backup_type == none) { if (backup_type == undefined)
if ((v = getenv("PATCH_VERSION_CONTROL")) == NULL) backup_type = posix ? none : numbered_existing;
v = getenv("VERSION_CONTROL");
if (v != NULL || !posix)
backup_type = get_version(v); /* OK to pass NULL. */
}
/* make sure we clean up /tmp in case of disaster */ /* make sure we clean up /tmp in case of disaster */
set_signals(0); set_signals(0);
@ -493,7 +494,7 @@ get_some_switches(void)
while ((ch = getopt_long(Argc, Argv, options, longopts, NULL)) != -1) { while ((ch = getopt_long(Argc, Argv, options, longopts, NULL)) != -1) {
switch (ch) { switch (ch) {
case 'b': case 'b':
if (backup_type == none) if (backup_type == undefined)
backup_type = numbered_existing; backup_type = numbered_existing;
if (optarg == NULL) if (optarg == NULL)
break; break;