summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTodd C. Miller <millert@cvs.openbsd.org>2002-01-25 07:10:05 +0000
committerTodd C. Miller <millert@cvs.openbsd.org>2002-01-25 07:10:05 +0000
commit3e8b4aad709c4694a87b92ee4ac6d865c9cef4e9 (patch)
treea8e9a44e5e6fecd5fe461afee6d579d07c85795b
parent5dde3390038a7376039732dce96630661d6cd1aa (diff)
Stat source path at the top of do_move() and return an error if
this fails. Previously, "mv nonexistent file_with_no_write_perms" would prompt whether or not to overwrite the file w/o write perms even though 'nonexistent' would fail to lstat() later on.
-rw-r--r--bin/mv/mv.c15
1 files changed, 8 insertions, 7 deletions
diff --git a/bin/mv/mv.c b/bin/mv/mv.c
index 74ba10acbc5..4a1189e5f0d 100644
--- a/bin/mv/mv.c
+++ b/bin/mv/mv.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: mv.c,v 1.21 2002/01/16 18:44:21 mpech Exp $ */
+/* $OpenBSD: mv.c,v 1.22 2002/01/25 07:10:04 millert Exp $ */
/* $NetBSD: mv.c,v 1.9 1995/03/21 09:06:52 cgd Exp $ */
/*
@@ -47,7 +47,7 @@ static char copyright[] =
#if 0
static char sccsid[] = "@(#)mv.c 8.2 (Berkeley) 4/2/94";
#else
-static char rcsid[] = "$OpenBSD: mv.c,v 1.21 2002/01/16 18:44:21 mpech Exp $";
+static char rcsid[] = "$OpenBSD: mv.c,v 1.22 2002/01/25 07:10:04 millert Exp $";
#endif
#endif /* not lint */
@@ -174,6 +174,12 @@ do_move(from, to)
struct stat sb, fsb;
char modep[15];
+ /* Source path must exist (symlink is OK). */
+ if (lstat(from, &fsb)) {
+ warn("%s", from);
+ return (1);
+ }
+
/*
* (1) If the destination path exists, the -f option is not specified
* and either of the following conditions are true:
@@ -231,11 +237,6 @@ do_move(from, to)
return (1);
}
- if (lstat(from, &fsb)) {
- warn("%s", from);
- return (1);
- }
-
/* Disallow moving a mount point. */
if (S_ISDIR(fsb.st_mode)) {
struct statfs sfs;