From 3e8b4aad709c4694a87b92ee4ac6d865c9cef4e9 Mon Sep 17 00:00:00 2001 From: "Todd C. Miller" Date: Fri, 25 Jan 2002 07:10:05 +0000 Subject: 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. --- bin/mv/mv.c | 15 ++++++++------- 1 file 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; -- cgit v1.2.3