Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/bin/mv New mv -h option.
details: https://anonhg.NetBSD.org/src/rev/451565d9781d
branches: trunk
changeset: 1011265:451565d9781d
user: riastradh <riastradh%NetBSD.org@localhost>
date: Wed Jun 24 16:58:12 2020 +0000
description:
New mv -h option.
`mv -h source target' just issues rename(source, target) without
discriminating on whether target resolves to a directory; this way
you can atomically replace a symlink to a directory.
diffstat:
bin/mv/mv.1 | 13 ++++++++++---
bin/mv/mv.c | 15 +++++++++------
2 files changed, 19 insertions(+), 9 deletions(-)
diffs (99 lines):
diff -r 253d9e8618d1 -r 451565d9781d bin/mv/mv.1
--- a/bin/mv/mv.1 Wed Jun 24 16:49:30 2020 +0000
+++ b/bin/mv/mv.1 Wed Jun 24 16:58:12 2020 +0000
@@ -1,4 +1,4 @@
-.\" $NetBSD: mv.1,v 1.30 2017/07/04 06:50:04 wiz Exp $
+.\" $NetBSD: mv.1,v 1.31 2020/06/24 16:58:12 riastradh Exp $
.\"
.\" Copyright (c) 1989, 1990, 1993
.\" The Regents of the University of California. All rights reserved.
@@ -40,7 +40,7 @@
.Nd move files
.Sh SYNOPSIS
.Nm
-.Op Fl fiv
+.Op Fl fhiv
.Ar source target
.Nm
.Op Fl fiv
@@ -54,7 +54,9 @@
.Ar target
operand.
This form is assumed when the last operand does not name an already
-existing directory.
+existing directory or when the
+.Fl h
+flag is specified.
.Pp
In its second form,
.Nm
@@ -72,6 +74,11 @@
.It Fl f
Do not prompt for confirmation before overwriting the destination
path.
+.It Fl h
+Try to rename the source to the target irrespective of whether the
+target may resolve to a directory.
+This option allows atomically replacing a symbolic link to a
+directory.
.It Fl i
Causes
.Nm
diff -r 253d9e8618d1 -r 451565d9781d bin/mv/mv.c
--- a/bin/mv/mv.c Wed Jun 24 16:49:30 2020 +0000
+++ b/bin/mv/mv.c Wed Jun 24 16:58:12 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: mv.c,v 1.45 2016/02/28 10:59:29 mrg Exp $ */
+/* $NetBSD: mv.c,v 1.46 2020/06/24 16:58:12 riastradh Exp $ */
/*
* Copyright (c) 1989, 1993, 1994
@@ -42,7 +42,7 @@
#if 0
static char sccsid[] = "@(#)mv.c 8.2 (Berkeley) 4/2/94";
#else
-__RCSID("$NetBSD: mv.c,v 1.45 2016/02/28 10:59:29 mrg Exp $");
+__RCSID("$NetBSD: mv.c,v 1.46 2020/06/24 16:58:12 riastradh Exp $");
#endif
#endif /* not lint */
@@ -65,7 +65,7 @@
#include "pathnames.h"
-static int fflg, iflg, vflg;
+static int fflg, hflg, iflg, vflg;
static int stdin_ok;
static sig_atomic_t pinfo;
@@ -93,8 +93,11 @@
setprogname(argv[0]);
(void)setlocale(LC_ALL, "");
- while ((ch = getopt(argc, argv, "ifv")) != -1)
+ while ((ch = getopt(argc, argv, "hifv")) != -1)
switch (ch) {
+ case 'h':
+ hflg = 1;
+ break;
case 'i':
fflg = 0;
iflg = 1;
@@ -123,7 +126,7 @@
* If the stat on the target fails or the target isn't a directory,
* try the move. More than 2 arguments is an error in this case.
*/
- if (stat(argv[argc - 1], &sb) || !S_ISDIR(sb.st_mode)) {
+ if (hflg || stat(argv[argc - 1], &sb) || !S_ISDIR(sb.st_mode)) {
if (argc > 2)
usage();
exit(do_move(argv[0], argv[1]));
@@ -419,7 +422,7 @@
static void
usage(void)
{
- (void)fprintf(stderr, "usage: %s [-fiv] source target\n"
+ (void)fprintf(stderr, "usage: %s [-fhiv] source target\n"
" %s [-fiv] source ... directory\n", getprogname(),
getprogname());
exit(1);
Home |
Main Index |
Thread Index |
Old Index