man.bsd.lv manual page server

Manual Page Search Parameters

UNDELETE(2) System Calls Manual UNDELETE(2)

undeleteattempt to recover a deleted file

library “libc”

#include <unistd.h>

int
undelete(const char *path);

The () function attempts to recover the deleted file named by path. Currently, this works only when the named object is a whiteout in a union filesystem. The system call removes the whiteout causing any objects in a lower layer of the union stack to become visible once more.

Eventually, the () functionality may be expanded to other filesystems able to recover deleted files such as the log-structured filesystem.

The undelete() function returns the value 0 if successful; otherwise the value -1 is returned and the global variable errno is set to indicate the error.

The undelete() succeeds unless:

[]
A component of the path prefix is not a directory.
[]
A component of a pathname exceeded 255 characters, or an entire path name exceeded 1023 characters.
[]
The path does not reference a whiteout.
[]
The named whiteout does not exist.
[]
Search permission is denied for a component of the path prefix.
[]
Write permission is denied on the directory containing the name to be undeleted.
[]
Too many symbolic links were encountered in translating the pathname.
[]
The directory containing the name is marked sticky, and the containing directory is not owned by the effective user ID.
[]
An I/O error occurred while updating the directory entry.
[]
The name resides on a read-only file system.
[]
Path points outside the process's allocated address space.

unlink(2)

An undelete() function call first appeared in 4.4BSD-Lite.

October 18, 1994 DragonFly-5.6.1