Hauptindex | Abschnitt 2 | English | 日本語 | Optionen |
int rename(const char *oldpath, const char *newpath);
Andere Hardlinks der Datei (angelegt mit link) bleiben davon unberührt.
Wenn newpath schon existiert wird er überschrieben (für Ausnahmen siehe Abschnitt FEHLER), so daß kein anderer Prozes^ der versucht newpath zu erreichen, diesen nicht findet.
Wenn newpath schon existiert aber das Umbenennen aus irgendeinem Grund fehlschlägt, oder das System crasht, garantiert rename das newpath vorhanden erhalten bleibt.
Beim Ändern gibt es ein Zeitfenster zu dem sowohl oldpath als auch newpath auf die Datei zeigen die umbenannt werden soll.
Wenn oldpath auf einen symbolischen Link zeigt wird der Link umbenannt; wenn newpath auf einen symbolischen Link zeigt wird der Link überschrieben.
EISDIR | newpath ist ein vorhandenes Directory aber oldpath ist kein vorhandenes Directory. |
EXDEV | oldpath und newpath befinden sich nicht im gleichen Filesystem. |
ENOTEMPTY | |
newpath ist ein Directory das nicht leer ist. | |
EBUSY | newpath ist ein vorhandenes Directory und ist aktuelles Directory oder Root Directory eines Prozesses. |
EINVAL | Es wurde versucht ein Directory als Subdiretory von sich selbst zu erzeugen. |
EMLINK | oldpath hat schon die maximale Anzahl Links, oder es ist ein Directory und das Directory welches newpath enthält hat schon die maximale Anzahl Links. |
ENOTDIR | Ein Teil des Directory oldpath oder newpath ist in Wirklichkeit kein Directory. |
EFAULT | oldpath oder newpath zeigt außerhalb des Benutzer-Adressraums. |
EACCES | Die effektive uid des Prozesses hat kein Schreibrecht in dem Directory in dem oldpath oder newpath angelegt werden soll, oder eines der Directory's oldpath oder newpath verbietet das Suchen (execute permission fehlt), oder did not allow search (execute) permission, or oldpath ist ein Directory und hat keine Schreibberechtigung (wird zum Ändern des .. benötigt). |
EPERM | Das Directory welches oldpath enthält hat das Sticky Bit gesetzt und die effektive Userid des Prozesses ist ungleich der Userid der Datei die gelöscht werden soll , oder das Dateisystem welches pathname enthält erlaubt nicht das Umbenenen einer Datei. |
ENAMETOOLONG | |
oldpath oder newpath sind zu lang. | |
ENOENT | Eine Komponente des Directory's oldpath oder newpath existiert nicht oder ist ein unsicherer symbolischer Link. |
ENOMEM | Es war nicht genügend Kernel-Memory verfügbar. |
EROFS | Die Datei ist in einem nur lesbaren Dateisystem. |
ELOOP | oldpath oder newpath beinhalten einen Verweis auf einen kreisenden symbolischen Link, beziehungsweise auf einen symbolischen Link der auf sich selbst verweist. |
ENOSPC | Die Gerätedatei die die Datei enthält hat keinen Platz für einen neuen Directoryeintrag. |
Auf NFS Dateisystemen kann bei einer fehlgeschlagenen Operation nicht davon ausgegangen werden das die Datei nicht umbenannt wurde. Wenn der Server die Datei umbenennt und dann crasht, gibt der RPC einen Fehler zurück. Die Applikation muß dies berücksichtigen. Siehe link(2) für ein ähnliches Problem.
29 März 1996 | RENAME (2) | Linux |
Hauptindex | Abschnitt 2 | English | 日本語 | Optionen |
Bitte richten Sie Ihre Kommentare zu diesem Handbuch Seite Service, Ben Bullock. Privacy policy.
“ | If you have a problem and you think awk(1) is the solution, then you have two problems. | ” |
— David Tilbrook |