symlink(2) System Calls Manual symlink(2) NOME symlink, symlinkat - crea un nuovo nome per un file LIBRARY Standard C library (libc, -lc) SINTASSI #include int symlink(const char *target, const char *linkpath); #include /* Definizione delle costanti AT_* */ #include int symlinkat(const char *target, int newdirfd, const char *linkpath); Macro per test di funzionalita per glibc (vedere feature_test_macros(7)): symlink(): _XOPEN_SOURCE >= 500 || _POSIX_C_SOURCE >= 200112L || /* glibc <= 2.19: */ _BSD_SOURCE symlinkat(): A partire da glibc 2.10: _POSIX_C_SOURCE >= 200809L Prima di glibc 2.10: _ATFILE_SOURCE DESCRIZIONE symlink() crea un collegamento simbolico con nome linkpath che contiene la stringa target. I collegamenti simbolici sono interpretati all'esecuzione come se il contenuto del collegamento fosse stato sostituito nel percorso seguito per trovare un file o una directory. Un collegamento simbolico puo contenere .. come componente del percorso, che (se usato all'inizio del collegamento) fa riferimento alle directory superiori a quella nella quale risiede il collegamento. Un collegamento simbolico (conosciuto anche come soft link) puo puntare ad un file esistente o ad uno non esistente: in quest'ultimo caso e detto dangling link. The permissions of a symbolic link are irrelevant; the ownership is ignored when following the link (except when the protected_symlinks feature is enabled, as explained in proc(5)), but is checked when removal or renaming of the link is requested and the link is in a directory with the sticky bit (S_ISVTX) set. Se linkpath esiste non verra sovrascritto. symlinkat() La chiamata di sistema symlinkat() opera esattamente nello stesso modo di symlink(), tranne che per le differenze di seguito descritte. Se il nome di percorso dato in linkpath e relativo, e interpretato come relativo alla directory a cui il descrittore di file newdirfd fa riferimento (piuttosto che relativo alla directory di lavoro corrente del processo chiamante, come fa symlink() per un nome di percorso relativo). Se linkpath e relativo e newdirfd e il valore speciale AT_FDCWD, linkpath e interpretato come relativo alla directory di lavoro corrente del processo chiamante (come symlink()). Se linkpath e assoluto, newdirfd e ignorato. See openat(2) for an explanation of the need for symlinkat(). VALORE RESTITUITO In caso di successo restituisce zero. In caso di errore restituisce -1, e errno verra impostato per indicare l'errore. ERRORI EACCES Non e possibile l'accesso in scrittura alla directory contenente linkpath, o una delle directory contenute nel prefisso del percorso di linkpath non ha il permesso di ricerca. (Vedere anche path_resolution(7).) EBADF (symlinkat()) linkpath e relativo ma newdirfd non e ne AT_FDCWD ne un descrittore di file valido. EDQUOT La quota di risorse dell'utente sul filesystem e esaurita. Le risorse possono essere inode o blocchi del disco, a seconda dell'implementazione del filesystem. EEXIST linkpath esiste gia. EFAULT target o linkpath puntano fuori dallo spazio di indirizzamento accessibile. EIO Si e verificato errore I/O. ELOOP Si sono incontrati troppi collegamenti simbolici nella risoluzione di linkpath. ENAMETOOLONG target o linkpath e troppo lungo. ENOENT Una directory contenuta in linkpath non esiste o e un collegamento simbolico scollegato, o target o linkpath e una stringa vuota. ENOENT (symlinkat()) linkpath e un percorso relativo e newdirfd fa riferimento a una directory che e stata eliminata. ENOMEM Insufficiente memoria disponibile per il kernel. ENOSPC Il dispositivo contenente il file non ha spazio per la nuova directory. ENOTDIR Un elemento usato come directory in linkpath non e, in effetti, una directory. ENOTDIR (symlinkat()) linkpath e relativo e newdirfd e un descrittore di file fa riferimento a un file anziche a una directory. EPERM Il filesystem contenente linkpath non supporta la creazione di collegamenti simbolici. EROFS linkpath e contenuto in un filesystem in sola lettura. STANDARDS POSIX.1-2008. STORIA symlink() SVr4, 4.3BSD, POSIX.1-2001. symlinkat() POSIX.1-2008. Linux 2.6.16, glibc 2.4. glibc notes Su vecchi kernel dove symlinkat() non e disponibile, la funzione wrapper glibc retrocede all'uso di symlink(). Dove linkpath e un nome di percorso relativo, glibc costruisce un nome di percorso basato sul collegamento simbolico in /proc/self/fd che corrisponde all'argomento newdirfd. NOTE Non viene effettuato nessun controllo su target. La cancellazione del nome a cui fa riferimento un collegamento simbolico cancellera il file (a meno che esso non abbia altri collegamenti fisici). Se non si desidera questo comportamento usare link(2). VEDERE ANCHE ln(1), namei(1), lchown(2), link(2), lstat(2), open(2), readlink(2), rename(2), unlink(2), path_resolution(7), symlink(7) TRADUZIONE La traduzione italiana di questa pagina di manuale e stata creata da Goffredo Baroncelli , Giulio Daprela , Elisabetta Galli e Marco Curreli Questa traduzione e documentazione libera; leggere la GNU General Public License Versione 3 o successiva per le condizioni di copyright. Non ci assumiamo alcuna responsabilita. Per segnalare errori nella traduzione di questa pagina di manuale inviare un messaggio a . Linux man-pages 6.06 31 ottobre 2023 symlink(2)