DIRECTORY

Section: C Library Functions (3)
索引 jman

BSD mandoc
 

索引

名称

opendir readdir readdir_r telldir seekdir rewinddir closedir dirfd - ディレクトリ操作  

索引

ライブラリ

Lb libc  

索引

書式

In sys/types.h In dirent.h Ft DIR * Fn opendir const char *filename Ft struct dirent * Fn readdir DIR *dirp Ft int Fn readdir_r DIR *dirp struct dirent *entry struct dirent **result Ft long Fn telldir DIR *dirp Ft void Fn seekdir DIR *dirp long loc Ft void Fn rewinddir DIR *dirp Ft int Fn closedir DIR *dirp Ft int Fn dirfd DIR *dirp  

索引

解説

Fn opendir 関数は、 Fa filename で指定されたディレクトリを開き、 ディレクトリストリーム をそれに対応させ、後続の操作で ディレクトリストリーム を識別するのに使用するポインタを返します。 Fa filename にアクセスできない場合、またはすべてのものを保持するのに十分なメモリを malloc(3) できない場合は、ポインタ NULL が返されます。

Fn readdir 関数は、次のディレクトリエントリを指すポインタを返します。 この関数は、ディレクトリの末尾に到達するか、または無効な Fn seekdir 操作を検出すると NULL を返します。

Fn readdir_r は、 Fn readdir と同様の機能を提供しますが、 呼び出し元は結果を格納するためのディレクトリ Fa entry バッファを提供しなければなりません。 読み込みが成功すると Fa result は Fa entry を指し、ディレクトリの末尾に達すると Fa result は NULL に設定されます。 Fn readdir_r は、成功した場合 0 を返し、そうでなければ失敗を示すエラーナンバを返します。

Fn telldir 関数は、指定された ディレクトリストリーム に関連付けられている現在の位置を返します。 Fn telldir が返す値が有効なのは、その値が引き出された元の DIR ポインタ Fa dirp が生きている間だけです。 ディレクトリが閉じられ再び開かれると、 Fn telldir が返した以前の値はもはや有効ではありません。

Fn seekdir 関数は、その ディレクトリストリーム に対する次の Fn readdir 操作の位置を設定します。 新しい位置は、その ディレクトリストリーム と関連付けられているもので、 Fn telldir 操作が実行されたときに返されるものです。

Fn rewinddir 関数は、指定された ディレクトリストリーム の位置をそのディレクトリの先頭に戻します。

Fn closedir 関数は、指定された ディレクトリストリーム を閉じ、 Fa dirp ポインタに関連付けられた構造体を解放します。 処理が成功した場合は 0 を返します。 処理が失敗すると -1 が返され、エラーを示ためにグローバル変数 errno が設定されます。

Fn dirfd 関数は、指定された ディレクトリストリーム に関連付けられた整数のファイル記述子を返します。 open(2) を参照してください。

ディレクトリでエントリ ``name'' を検索するサンプルコードは次のとおりです。

len = strlen(name);
dirp = opendir(".");
while ((dp = readdir(dirp)) != NULL)
        if (dp->d_namlen == len && !strcmp(dp->d_name, name)) {
                (void)closedir(dirp);
                return FOUND;
        }
(void)closedir(dirp);
return NOT_FOUND;

 

索引

関連項目

close(2), lseek(2), open(2), read(2), dir(5)

 

索引

歴史

Fn opendir , Fn readdir , Fn telldir , Fn seekdir , Fn rewinddir , Fn closedir および Fn dirfd の各関数は BSD 4.2 で登場しました。


 

索引

Index

名称
ライブラリ
書式
解説
関連項目
歴史

jman



Time: 07:07:04 GMT, January 12, 2009