#include <sys/types.h> #include <sys/xattr.h> int setxattr(const char *path, const char *name, const void *value, size_t size, int flags); int lsetxattr(const char *path, const char *name, const void *value, size_t size, int flags); int fsetxattr(int fd, const char *name, const void *value, size_t size, int flags);
setxattr() は、ファイルシステム内の指定された path に対応する、名前 name の拡張属性の値 value を設定する。 value の size は必ず指定しなければならない。
lsetxattr() は setxattr() と同じだが、シンボリックリンクの場合に、リンクが参照しているファイル ではなく、リンクそのものの拡張属性を設定する点だけが異なる。
fsetxattr() は setxattr() と同じだが、 path の代わりに fd で参照されたオープン済みファイルの情報だけを設定する点が異なる (filedes は open(2) によって返される)。
拡張属性の名前 は普通のヌル終端された文字列である。 name には、名前空間を表す接頭辞 (prefix) が含まれる。 個々の inode に対して、互いに独立な名前空間が複数あってもよい。 拡張属性の値 value は、ある一定の長さの任意のテキストデータまたは バイナリデータの集合である。
操作の意味を明確にするために flags 引き数を使用することができる。 XATTR_CREATE は属性の作成だけを行うことを指定する。 指定された名前の属性がすでに存在する場合は失敗する。 XATTR_REPLACE は属性の置換だけを行うことを指定する。 指定された名前の属性がまだ存在しない場合は失敗する。 デフォルトでは (フラグを指定しない場合)、拡張属性は必要な場合は作成され、 属性がすでに存在する場合は属性値の置換を行う。
上記に加えて、 stat(2) に書かれているエラーが発生する場合もある。
[man1]
[man2]
[man3]
[man4]
[man5]
[man6]
[man7]
[man8]
[a]
[b]
[c]
[d]
[e]
[f]
[g]
[h]
[i]
[j]
[k]
[l]
[m]
[n]
[o]
[p]
[q]
[r]
[s]
[t]
[u]
[v]
[w]
[x]
[y]
[z]