<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html lang="ja"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <meta http-equiv="Content-Style-Type" content="text/css"> <link rel="up" title="FatFs" href="../00index_j.html"> <link rel="alternate" hreflang="en" title="English" href="../en/readdir.html"> <link rel="stylesheet" href="../css_j.css" type="text/css" media="screen" title="ELM Default"> <title>FatFs - f_readdir</title> </head> <body> <div class="para func"> <h2>f_readdir</h2> <p>ディレクトリ項目を読み出します。</p> <pre> FRESULT f_readdir ( DIR* <span class="arg">dp</span>, <span class="c">/* [IN] ディレクトリ ブジェクト構造体へのポインタ */</span> FILINFO* <span class="arg">fno</span> <span class="c">/* [OUT] ファイル情報構造体へのポインタ */</span> ); </pre> </div> <div class="para arg"> <h4>引数</h4> <dl class="par"> <dt>dp</dt> <dd><tt>f_opendir</tt>関数で作成された有効なディレクトリ オブジェクトへのポインタを指定します。</dd> <dt>fno</dt> <dd>読み出したディレクトリ項目を格納する<a href="sfileinfo.html">ファイル情報構造体</a>へのポインタ、またはヌル ポインタを指定します。</dd> </dl> </div> <div class="para ret"> <h4>戻り値</h4> <p> <a href="rc.html#ok">FR_OK</a>, <a href="rc.html#de">FR_DISK_ERR</a>, <a href="rc.html#ie">FR_INT_ERR</a>, <a href="rc.html#io">FR_INVALID_OBJECT</a>, <a href="rc.html#tm">FR_TIMEOUT</a>, <a href="rc.html#nc">FR_NOT_ENOUGH_CORE</a> </p> </div> <div class="para desc"> <h4>解説</h4> <p>ディレクトリの項目(ファイルおよびサブ ディレクトリ)の情報を順次読み出します。この関数を繰り返し実行することによりそのディレクトリの全ての項目を読み出すことができます。得られるファイル情報の詳細については <tt>FILINFO</tt>構造体を参照してください。全ての項目が読み出され、読み出す項目がもう無いときは、<tt>fno->fname[]</tt>にヌル文字列が返されます。<tt class="arg">fno</tt>にヌル ポインタを指定すると、そのディレクトリのリード インデックスを先頭に巻き戻します。サブ ディレクトリのドット エントリ(<tt>"."</tt>と<tt>".."</tt>)は、出力に現れません。</p> <p>LFN構成では、<tt>altname[]</tt>が新たに定義され、そのオブジェクトの短いファイル名がストアされます。次の条件のときは長いファイル名を返せないので<tt>fname[]</tt>に短いファイル名がストアされ、<tt>altname[]</tt>はヌル文字列になります。</p> <ul> <li>オブジェクトが長いファイル名を持っていない。(exFATボリュームでは該当せず)</li> <li><tt>_MAX_LFN</tt>の設定がその長いファイル名の長さに対して不十分 (<tt>_MAX_LFN == 255</tt>では該当せず)</li> <li>長いファイル名にANSI/OEMコードに無い文字が含まれている。(<tt>_LFN_UNICODE == 1</tt>では該当せず)</li> </ul> <p>exFATボリュームのディレクトリを読み出すとき、構成によっては問題が発生します。exFATでは短いファイル名がサポートされません。つまり、上記の条件のとき代わりに返すファイル名が無いということです。このような場合は<tt>fname[]</tt>に"?"が返され、そのオブジェクトにアクセスできないことを示します。この問題を避けるには、FatFsの構成を<tt>_LFN_UNICODE = 1</tt>および<tt>_MAX_LFN = 255</tt>として長いファイル名に完全対応とする必要があります。</p> </div> <div class="para comp"> <h4>対応情報</h4> <p><tt>_FS_MINIMIZE <= 1</tt>のときに使用可能です。</p> </div> <div class="para use"> <h4>使用例</h4> <pre> FATFS fs; char buff[256]; FRESULT scan_files ( char* path <span class="c">/* 開始ノード (ワークエリアとしても使用) */</span> ) { FRESULT res; DIR dir; UINT i; static FILINFO fno; res = f_opendir(&dir, path); <span class="c">/* ディレクトリを開く */</span> if (res == FR_OK) { for (;;) { res = f_readdir(&dir, &fno); <span class="c">/* ディレクトリ項目を1個読み出す */</span> if (res != FR_OK || fno.fname[0] == 0) break; <span class="c">/* エラーまたは項目無しのときは抜ける */</span> if (fno.fattrib & AM_DIR) { <span class="c">/* ディレクトリ */</span> i = strlen(path); sprintf(&path[i], "/%s", fno.fname); res = scan_files(path); <span class="c">/* 一つ下へ */</span> if (res != FR_OK) break; path[i] = 0; } else { <span class="c">/* ファイル */</span> printf("%s/%s\n", path, fno.fname); } } f_closedir(&dir) } return res; } int main (void) { FRESULT res; res = f_mount(&fs, "", 1); if (res == FR_OK) { strcpy(buff, "/"); res = scan_files(buff); } return res; } </pre> </div> <div class="para ref"> <h4>参照</h4> <p><tt><a href="opendir.html">f_opendir</a>, <a href="closedir.html">f_closedir</a>, <a href="stat.html">f_stat</a>, <a href="sfileinfo.html">FILINFO</a>, <a href="sdir.html">DIR</a></tt></p> </div> <p class="foot"><a href="../00index_j.html">戻る</a></p> </body> </html>