Manpages

ИМЯ

symlink − создать новое имя для файла

ОБЗОР

#include <unistd.h>

int symlink(const char *topath, const char *frompath);

ОПИСАНИЕ

symlink создает символьную ссылку, которая называется frompath и содержит строку topath.

Символьные ссылки интерпретируются "на лету", как будто бы содержимое ссылки было подставлено вместо пути, по которому идет поиск файла или каталога.

Символьные ссылки могут содержать такие компоненты пути, как .. которые, (если используются в начале ссылки), ссылаются на родительский каталог того каталога, в котором находится ссылка.

Символьная ссылка (также известная как "мягкая ссылка") может указывать как на существующий, так и на несуществующий файлы; в последнем случае такая ссылка называется "висячей".

Права доступа к символьной ссылке не используются; её владелец игнорируется при поиске по ссылке, но проверяется при удалении или переименовании ссылки, находящейся в каталоге с установленным sticky битом.

Если newpath существует, он не будет перезаписан.

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

В случае успеха возвращается ноль. При ошибке возвращается −1, а значение errno устанавливается должным образом.

ОШИБКИ

EPERM

Файловая система, содержащая pathname, не поддерживает создание символьных ссылок.

EFAULT

oldpath или newpath указывают за пределы доступного адресного пространства.

EACCES

Доступ для записи в каталог, содержащий newpath, не разрешен для эффектиного uid владельца процесса, или же один из каталогов, являющихся частью newpath, не допускает поиск.

ENAMETOOLONG

oldpath или newpath слишком длинны.

ENOENT

Одна из частей пути oldpath или newpath не существует или является "висячей" символьной ссылкой.

ENOTDIR

Компонент пути, использованный как каталог в oldpath или newpath, в действительности таковым не является.

ENOMEM

Ядру не хватило памяти.

EROFS

Файл находится на файловой системе, смонтированной только для чтения.

EEXIST

newpath уже существует.

ELOOP

newpath является зацикленной символьной ссылкой, то есть при подстановке возникает ссылка на неё саму.

ENOSPC

На устройстве, содержащем newpath, нет места для создания новой записи в каталоге. Это может произойти также, если исчерпана квота дискового пространства пользователя.

ЗАМЕЧАНИЯ

Не производится никакой проверки oldpath.

Удаление файла, на который ссылается символьная ссылка, действительно удалит файл (если только у него нет других жестких ссылок). Если такое поведение нежелательно, используйте link.

СООТВЕТСТВИЕ СТАНДАРТАМ

SVr4, SVID, POSIX, BSD 4.3. SVr4 документирует дополнительные коды ошибок EDQUOT, EIO, ENAMETOOLONG, ENOSYS.

ОШИБКИ

Смотри open(2) по поводу множества файлов с одним именем и NFS.

СМОТРИ ТАКЖЕ

link(2), unlink(2), rename(2), open(2), lstat(2), ln(1), link(8).

ПЕРЕВОД

Copyright (C) Alexey Mahotkin <alexm [AT] hsys.ru> 1999, Виктор Вислобоков <corochoone [AT] perm.ru> 2003

COMMENTS