1<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> 2<html lang="en"> 3<head> 4<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 5<meta http-equiv="Content-Style-Type" content="text/css"> 6<link rel="up" title="FatFs" href="../00index_e.html"> 7<link rel="alternate" hreflang="ja" title="Japanese" href="../ja/stat.html"> 8<link rel="stylesheet" href="../css_e.css" type="text/css" media="screen" title="ELM Default"> 9<title>FatFs - f_stat</title> 10</head> 11 12<body> 13 14<div class="para func"> 15<h2>f_stat</h2> 16<p>The f_stat function checks the existence of a file or sub-directory.</p> 17<pre> 18FRESULT f_stat ( 19 const TCHAR* <span class="arg">path</span>, <span class="c">/* [IN] Object name */</span> 20 FILINFO* <span class="arg">fno</span> <span class="c">/* [OUT] FILINFO structure */</span> 21); 22</pre> 23</div> 24 25<div class="para arg"> 26<h4>Parameters</h4> 27<dl class="par"> 28<dt>path</dt> 29<dd>Pointer to the null-terminated string that specifies the <a href="filename.html">object</a> to get its information. The object must not be the root direcotry.</dd> 30<dt>fno</dt> 31<dd>Pointer to the blank <tt>FILINFO</tt> structure to store the information of the object. Set null pointer if this information is not needed.</dd> 32</dl> 33</div> 34 35 36<div class="para ret"> 37<h4>Return Values</h4> 38<p> 39<a href="rc.html#ok">FR_OK</a>, 40<a href="rc.html#de">FR_DISK_ERR</a>, 41<a href="rc.html#ie">FR_INT_ERR</a>, 42<a href="rc.html#nr">FR_NOT_READY</a>, 43<a href="rc.html#ok">FR_NO_FILE</a>, 44<a href="rc.html#np">FR_NO_PATH</a>, 45<a href="rc.html#in">FR_INVALID_NAME</a>, 46<a href="rc.html#id">FR_INVALID_DRIVE</a>, 47<a href="rc.html#ne">FR_NOT_ENABLED</a>, 48<a href="rc.html#ns">FR_NO_FILESYSTEM</a>, 49<a href="rc.html#tm">FR_TIMEOUT</a>, 50<a href="rc.html#nc">FR_NOT_ENOUGH_CORE</a> 51</p> 52</div> 53 54 55<div class="para desc"> 56<h4>Description</h4> 57<p>The <tt>f_stat</tt> function checks the existence of a file or sub-directory in the directory. If it is not exist, the function returns with <tt>FR_NO_FILE</tt>. If it is exist, the function returns with <tt>FR_OK</tt> and the informations about the object, size, timestamp and attribute, is stored to the file information structure. For details of the file information, refer to the <tt>FILINFO</tt> structure and <a href="readdir.html"><tt>f_readdir</tt></a> function.</p> 58<p>Note that the file information comes from the meta data in the directory. If the file has been opend and modified, the file will need to be synched or closed in order to obtain the latest file information.</p> 59</div> 60 61 62<div class="para comp"> 63<h4>QuickInfo</h4> 64<p>Available when <tt><a href="config.html#fs_minimize">FF_FS_MINIMIZE</a> == 0</tt>.</p> 65</div> 66 67 68<div class="para use"> 69<h4>Example</h4> 70<pre> 71 FRESULT fr; 72 FILINFO fno; 73 const char *fname = "file.txt"; 74 75 76 printf("Test for \"%s\"...\n", fname); 77 78 fr = <em>f_stat</em>(fname, &fno); 79 switch (fr) { 80 81 case FR_OK: 82 printf("Size: %lu\n", fno.fsize); 83 printf("Timestamp: %u-%02u-%02u, %02u:%02u\n", 84 (fno.fdate >> 9) + 1980, fno.fdate >> 5 & 15, fno.fdate & 31, 85 fno.ftime >> 11, fno.ftime >> 5 & 63); 86 printf("Attributes: %c%c%c%c%c\n", 87 (fno.fattrib & AM_DIR) ? 'D' : '-', 88 (fno.fattrib & AM_RDO) ? 'R' : '-', 89 (fno.fattrib & AM_HID) ? 'H' : '-', 90 (fno.fattrib & AM_SYS) ? 'S' : '-', 91 (fno.fattrib & AM_ARC) ? 'A' : '-'); 92 break; 93 94 case FR_NO_FILE: 95 printf("\"%s\" is not exist.\n", fname); 96 break; 97 98 default: 99 printf("An error occured. (%d)\n", fr); 100 } 101</pre> 102</div> 103 104 105<div class="para ref"> 106<h4>References</h4> 107<p><tt><a href="opendir.html">f_opendir</a>, <a href="readdir.html">f_readdir</a>, <a href="sfileinfo.html">FILINFO</a></tt></p> 108</div> 109 110<p class="foot"><a href="../00index_e.html">Return</a></p> 111</body> 112</html> 113