1 .\" $NetBSD: rename.2,v 1.7 1995/02/27 12:36:15 cgd Exp $
3 .\" Copyright (c) 1983, 1991, 1993
4 .\" The Regents of the University of California. All rights reserved.
6 .\" Redistribution and use in source and binary forms, with or without
7 .\" modification, are permitted provided that the following conditions
9 .\" 1. Redistributions of source code must retain the above copyright
10 .\" notice, this list of conditions and the following disclaimer.
11 .\" 2. Redistributions in binary form must reproduce the above copyright
12 .\" notice, this list of conditions and the following disclaimer in the
13 .\" documentation and/or other materials provided with the distribution.
14 .\" 3. All advertising materials mentioning features or use of this software
15 .\" must display the following acknowledgement:
16 .\" This product includes software developed by the University of
17 .\" California, Berkeley and its contributors.
18 .\" 4. Neither the name of the University nor the names of its contributors
19 .\" may be used to endorse or promote products derived from this software
20 .\" without specific prior written permission.
22 .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
23 .\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24 .\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25 .\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
26 .\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27 .\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
28 .\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
29 .\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30 .\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
31 .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
34 .\" @(#)rename.2 8.1 (Berkeley) 6/4/93
41 .Nd change the name of a file
43 .Fd #include <stdio.h>
52 system call causes the link named
58 exists, it is first removed.
63 must be of the same type
64 (that is, both must be either directories or non-directories)
65 and must reside on the same file system.
69 system call guarantees that an instance of
72 even if the system should crash in the middle of the operation.
74 If the final component of
77 the symbolic link is renamed,
78 not the file or directory to which it points.
80 The system can deadlock if a loop is present in the file system graph.
81 This loop takes the form of an entry in directory
85 being a hard link to directory
95 When such a loop exists and two separate processes attempt to
97 .Ql rename a/foo b/bar
99 .Ql rename b/bar a/foo ,
101 the system may deadlock attempting to lock
102 both directories for modification.
104 Whether or not hard links to directories are supported is specific to
105 the underlying filesystem implementation.
107 It is recommended that any hard links to directories in an underlying
108 filesystem should be replaced by symbolic links by the system administrator
109 to avoid the possibility of deadlocks.
111 A 0 value is returned if the operation succeeds, otherwise
113 returns -1 and the global variable
115 indicates the reason for the failure.
119 system call will fail and neither of the argument files will be
124 A component of either path prefix denies search permission.
127 The requested operation requires writing in a directory
130 new/.., or old/..) whose modes disallow this.
133 The directory in which the entry for the new name
134 is being placed cannot be extended because the
135 user's quota of disk blocks on the file system
136 containing the directory has been exhausted.
140 points outside the process's allocated address space.
144 is a parent directory of
146 or an attempt is made to rename
152 An I/O error occurs while making or updating a directory entry.
161 Too many symbolic links are encountered in translating either pathname.
162 This is taken to be indicative of a looping symbolic link.
164 .It Bq Er ENAMETOOLONG
165 A component of a pathname exceeds
167 characters, or an entire path name exceeds
180 The directory in which the entry for the new name is being placed
181 cannot be extended because there is no space left on the file
182 system containing the directory.
185 A component of either path prefix is not a directory.
195 is a directory and is not empty.
198 The directory containing
201 and neither the containing directory nor
203 are owned by the effective user ID.
209 the directory containing
212 and neither the containing directory nor
214 are owned by the effective user ID.
217 The requested link requires writing in a directory on a read-only file
223 and the file named by
225 are on different logical devices (file systems).
226 Note that this error code will not be returned
227 if the implementation permits cross-device links.
230 The restriction on renaming a directory whose permissions disallow writing
231 is based on the fact that UFS directories contain a ".." entry.
232 If renaming a directory would move it to another parent directory,
233 this entry needs to be changed.
235 This restriction has been generalized to disallow renaming
236 of any write-disabled directory,
237 even when this would not require a change to the ".." entry.
238 For consistency, HFS+ directories emulate this behavior.