1997-03-03 18:01:01 +00:00
|
|
|
.\" -*- nroff -*-
|
|
|
|
.\"
|
|
|
|
.\" Copyright (c) 1996 Doug Rabson
|
|
|
|
.\"
|
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" This program is free software.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
.\" IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
.\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
.\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
.\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
.\"
|
1999-08-28 00:22:10 +00:00
|
|
|
.\" $FreeBSD$
|
1997-03-03 18:01:01 +00:00
|
|
|
.\"
|
|
|
|
.Dd July 24, 1996
|
|
|
|
.Os
|
|
|
|
.Dt VOP_RENAME 9
|
|
|
|
.Sh NAME
|
|
|
|
.Nm VOP_RENAME
|
|
|
|
.Nd rename a file
|
|
|
|
.Sh SYNOPSIS
|
2001-10-01 16:09:29 +00:00
|
|
|
.In sys/param.h
|
|
|
|
.In sys/vnode.h
|
1997-03-03 18:01:01 +00:00
|
|
|
.Ft int
|
2001-07-14 19:41:16 +00:00
|
|
|
.Fn VOP_RENAME "struct vnode *fdvp" "struct vnode *fvp" "struct componentname *fcnp" "struct vnode *tdvp" "struct vnode *tvp" "struct componentname *tcnp"
|
1997-03-03 18:01:01 +00:00
|
|
|
.Sh DESCRIPTION
|
|
|
|
This renames a file and possibly changes its parent directory.
|
|
|
|
If the destination object exists, it will be removed first.
|
|
|
|
.Pp
|
|
|
|
Its arguments are:
|
|
|
|
.Bl -tag -width fdvp
|
2003-05-31 14:07:25 +00:00
|
|
|
.It Fa fdvp
|
2005-01-28 10:43:05 +00:00
|
|
|
The vnode of the old parent directory.
|
2003-05-31 14:07:25 +00:00
|
|
|
.It Fa fvp
|
2005-01-28 10:43:05 +00:00
|
|
|
The vnode of the file to be renamed.
|
2003-05-31 14:07:25 +00:00
|
|
|
.It Fa fcnp
|
2005-01-28 10:43:05 +00:00
|
|
|
Pathname information about the file's current name.
|
2003-05-31 14:07:25 +00:00
|
|
|
.It Fa tdvp
|
2005-01-28 10:43:05 +00:00
|
|
|
The vnode of the new parent directory.
|
2003-05-31 14:07:25 +00:00
|
|
|
.It Fa tvp
|
2005-01-28 10:43:05 +00:00
|
|
|
The vnode of the target file (if it exists).
|
2003-05-31 14:07:25 +00:00
|
|
|
.It Fa tcnp
|
2005-01-28 10:43:05 +00:00
|
|
|
Pathname information about the file's new name.
|
1997-03-03 18:01:01 +00:00
|
|
|
.El
|
|
|
|
.Sh LOCKS
|
1999-09-24 17:11:02 +00:00
|
|
|
The source directory and file are unlocked but are expected to have their
|
2003-10-23 02:11:14 +00:00
|
|
|
ref count bumped on entry.
|
|
|
|
The VOP routine is expected to
|
2003-10-23 03:52:07 +00:00
|
|
|
.Xr vrele 9
|
1999-09-25 17:21:21 +00:00
|
|
|
both prior
|
1999-09-24 17:11:02 +00:00
|
|
|
to returning.
|
|
|
|
.Pp
|
|
|
|
The destination directory and file are locked as well as having their ref
|
2003-10-23 02:11:14 +00:00
|
|
|
count bumped.
|
|
|
|
The VOP routine is expected to
|
2003-10-23 03:52:07 +00:00
|
|
|
.Xr vput 9
|
2001-07-14 19:41:16 +00:00
|
|
|
both prior to
|
1999-09-24 17:11:02 +00:00
|
|
|
returning.
|
1997-03-03 18:01:01 +00:00
|
|
|
.Sh ERRORS
|
1997-03-07 03:32:31 +00:00
|
|
|
.Bl -tag -width Er
|
1997-03-03 18:01:01 +00:00
|
|
|
.It Bq Er EPERM
|
2002-09-18 09:34:01 +00:00
|
|
|
The file is immutable.
|
1997-03-03 18:01:01 +00:00
|
|
|
.It Bq Er EXDEV
|
2002-09-18 22:12:43 +00:00
|
|
|
It is not possible to rename a file between different file systems.
|
1997-03-03 18:01:01 +00:00
|
|
|
.It Bq Er EINVAL
|
2002-09-18 22:12:43 +00:00
|
|
|
An attempt was made to rename
|
2002-11-29 11:39:20 +00:00
|
|
|
.Pa \&.
|
2002-09-18 22:12:43 +00:00
|
|
|
or
|
2002-11-29 11:39:20 +00:00
|
|
|
.Pa .. ,
|
|
|
|
or to perform an operation which would break the directory tree structure.
|
1997-03-03 18:01:01 +00:00
|
|
|
.It Bq Er ENOTDIR
|
2002-09-18 22:12:43 +00:00
|
|
|
An attempt was made to rename a directory to a file or vice versa.
|
1997-03-03 18:01:01 +00:00
|
|
|
.It Bq Er ENOTEMPTY
|
2002-09-18 22:12:43 +00:00
|
|
|
An attempt was made to remove a directory which is not empty.
|
1997-03-03 18:01:01 +00:00
|
|
|
.El
|
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr vnode 9
|
|
|
|
.Sh AUTHORS
|
2003-10-23 03:52:07 +00:00
|
|
|
This manual page was written by
|
1998-03-12 07:31:21 +00:00
|
|
|
.An Doug Rabson .
|