You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

2536 lines
122KB

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
  5. <meta http-equiv="X-UA-Compatible" content="IE=9"/>
  6. <meta name="generator" content="Doxygen 1.8.8"/>
  7. <title>SdFat: FatFile Class Reference</title>
  8. <link href="tabs.css" rel="stylesheet" type="text/css"/>
  9. <script type="text/javascript" src="jquery.js"></script>
  10. <script type="text/javascript" src="dynsections.js"></script>
  11. <link href="search/search.css" rel="stylesheet" type="text/css"/>
  12. <script type="text/javascript" src="search/search.js"></script>
  13. <script type="text/javascript">
  14. $(document).ready(function() { searchBox.OnSelectItem(0); });
  15. </script>
  16. <link href="doxygen.css" rel="stylesheet" type="text/css" />
  17. </head>
  18. <body>
  19. <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
  20. <div id="titlearea">
  21. <table cellspacing="0" cellpadding="0">
  22. <tbody>
  23. <tr style="height: 56px;">
  24. <td style="padding-left: 0.5em;">
  25. <div id="projectname">SdFat
  26. </div>
  27. </td>
  28. </tr>
  29. </tbody>
  30. </table>
  31. </div>
  32. <!-- end header part -->
  33. <!-- Generated by Doxygen 1.8.8 -->
  34. <script type="text/javascript">
  35. var searchBox = new SearchBox("searchBox", "search",false,'Search');
  36. </script>
  37. <div id="navrow1" class="tabs">
  38. <ul class="tablist">
  39. <li><a href="index.html"><span>Main&#160;Page</span></a></li>
  40. <li><a href="modules.html"><span>Modules</span></a></li>
  41. <li class="current"><a href="annotated.html"><span>Classes</span></a></li>
  42. <li><a href="files.html"><span>Files</span></a></li>
  43. <li>
  44. <div id="MSearchBox" class="MSearchBoxInactive">
  45. <span class="left">
  46. <img id="MSearchSelect" src="search/mag_sel.png"
  47. onmouseover="return searchBox.OnSearchSelectShow()"
  48. onmouseout="return searchBox.OnSearchSelectHide()"
  49. alt=""/>
  50. <input type="text" id="MSearchField" value="Search" accesskey="S"
  51. onfocus="searchBox.OnSearchFieldFocus(true)"
  52. onblur="searchBox.OnSearchFieldFocus(false)"
  53. onkeyup="searchBox.OnSearchFieldChange(event)"/>
  54. </span><span class="right">
  55. <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
  56. </span>
  57. </div>
  58. </li>
  59. </ul>
  60. </div>
  61. <div id="navrow2" class="tabs2">
  62. <ul class="tablist">
  63. <li><a href="annotated.html"><span>Class&#160;List</span></a></li>
  64. <li><a href="inherits.html"><span>Class&#160;Hierarchy</span></a></li>
  65. <li><a href="functions.html"><span>Class&#160;Members</span></a></li>
  66. </ul>
  67. </div>
  68. <!-- window showing the filter options -->
  69. <div id="MSearchSelectWindow"
  70. onmouseover="return searchBox.OnSearchSelectShow()"
  71. onmouseout="return searchBox.OnSearchSelectHide()"
  72. onkeydown="return searchBox.OnSearchSelectKey(event)">
  73. <a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(0)"><span class="SelectionMark">&#160;</span>All</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(1)"><span class="SelectionMark">&#160;</span>Classes</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(2)"><span class="SelectionMark">&#160;</span>Files</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(3)"><span class="SelectionMark">&#160;</span>Functions</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(4)"><span class="SelectionMark">&#160;</span>Variables</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(5)"><span class="SelectionMark">&#160;</span>Typedefs</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(6)"><span class="SelectionMark">&#160;</span>Enumerations</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(7)"><span class="SelectionMark">&#160;</span>Enumerator</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(8)"><span class="SelectionMark">&#160;</span>Macros</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(9)"><span class="SelectionMark">&#160;</span>Modules</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(10)"><span class="SelectionMark">&#160;</span>Pages</a></div>
  74. <!-- iframe showing the search results (closed by default) -->
  75. <div id="MSearchResultsWindow">
  76. <iframe src="javascript:void(0)" frameborder="0"
  77. name="MSearchResults" id="MSearchResults">
  78. </iframe>
  79. </div>
  80. </div><!-- top -->
  81. <div class="header">
  82. <div class="summary">
  83. <a href="#pub-methods">Public Member Functions</a> &#124;
  84. <a href="#pub-static-methods">Static Public Member Functions</a> &#124;
  85. <a href="class_fat_file-members.html">List of all members</a> </div>
  86. <div class="headertitle">
  87. <div class="title">FatFile Class Reference</div> </div>
  88. </div><!--header-->
  89. <div class="contents">
  90. <p>Basic file class.
  91. <a href="class_fat_file.html#details">More...</a></p>
  92. <p><code>#include &lt;FatFile.h&gt;</code></p>
  93. <div class="dynheader">
  94. Inheritance diagram for FatFile:</div>
  95. <div class="dyncontent">
  96. <div class="center"><img src="class_fat_file__inherit__graph.png" border="0" usemap="#_fat_file_inherit__map" alt="Inheritance graph"/></div>
  97. <map name="_fat_file_inherit__map" id="_fat_file_inherit__map">
  98. <area shape="rect" id="node3" href="class_fat_stream_base.html" title="Base class for C++ style streams. " alt="" coords="97,80,209,107"/> <area shape="rect" id="node11" href="class_sd_base_file.html" title="SdBaseFile base for SdFile and File. " alt="" coords="259,80,348,107"/> <area shape="rect" id="node17" href="class_stdio_stream.html" title="StdioStream implements a minimal stdio stream. " alt="" coords="373,80,467,107"/> <area shape="rect" id="node5" href="classfstream.html" title="file input/output stream. " alt="" coords="5,155,69,181"/> <area shape="rect" id="node7" href="classifstream.html" title="file input stream. " alt="" coords="94,155,161,181"/> <area shape="rect" id="node9" href="classofstream.html" title="file output stream. " alt="" coords="187,155,259,181"/> <area shape="rect" id="node13" href="class_file.html" title="Arduino SD.h style File API. " alt="" coords="283,155,325,181"/> <area shape="rect" id="node15" href="class_sd_file.html" title="SdFile SdBaseFile with Print. " alt="" coords="349,155,408,181"/> </map>
  99. <center><span class="legend">[<a href="graph_legend.html">legend</a>]</span></center></div>
  100. <table class="memberdecls">
  101. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
  102. Public Member Functions</h2></td></tr>
  103. <tr class="memitem:ac1fa779d98db7ffdb96f8019ab0060d6"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#ac1fa779d98db7ffdb96f8019ab0060d6">available</a> ()</td></tr>
  104. <tr class="separator:ac1fa779d98db7ffdb96f8019ab0060d6"><td class="memSeparator" colspan="2">&#160;</td></tr>
  105. <tr class="memitem:aeca2a2eff91e6aa55fe1b0e3860c9a05"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#aeca2a2eff91e6aa55fe1b0e3860c9a05">clearWriteError</a> ()</td></tr>
  106. <tr class="separator:aeca2a2eff91e6aa55fe1b0e3860c9a05"><td class="memSeparator" colspan="2">&#160;</td></tr>
  107. <tr class="memitem:afd16af325e0642e4bff6430b7d8bb18b"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#afd16af325e0642e4bff6430b7d8bb18b">close</a> ()</td></tr>
  108. <tr class="separator:afd16af325e0642e4bff6430b7d8bb18b"><td class="memSeparator" colspan="2">&#160;</td></tr>
  109. <tr class="memitem:aa367708bcc8bc0e0c45c0c2a812c65da"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#aa367708bcc8bc0e0c45c0c2a812c65da">contiguousRange</a> (uint32_t *bgnBlock, uint32_t *endBlock)</td></tr>
  110. <tr class="separator:aa367708bcc8bc0e0c45c0c2a812c65da"><td class="memSeparator" colspan="2">&#160;</td></tr>
  111. <tr class="memitem:a0afc2a1cffa238d1cb2049bfa2d8d199"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a0afc2a1cffa238d1cb2049bfa2d8d199">createContiguous</a> (<a class="el" href="class_fat_file.html">FatFile</a> *dirFile, const char *path, uint32_t size)</td></tr>
  112. <tr class="separator:a0afc2a1cffa238d1cb2049bfa2d8d199"><td class="memSeparator" colspan="2">&#160;</td></tr>
  113. <tr class="memitem:a4c03e2f6729526786e6ab4a623e0339b"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a4c03e2f6729526786e6ab4a623e0339b">curCluster</a> () const </td></tr>
  114. <tr class="separator:a4c03e2f6729526786e6ab4a623e0339b"><td class="memSeparator" colspan="2">&#160;</td></tr>
  115. <tr class="memitem:a20c55b134bfd1d287a00bf64eba9332e"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a20c55b134bfd1d287a00bf64eba9332e">curPosition</a> () const </td></tr>
  116. <tr class="separator:a20c55b134bfd1d287a00bf64eba9332e"><td class="memSeparator" colspan="2">&#160;</td></tr>
  117. <tr class="memitem:a6858d18c807411a071fd6d1b39d50087"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a6858d18c807411a071fd6d1b39d50087">dirEntry</a> (<a class="el" href="_fat_structs_8h.html#a803db59d4e16a0c54a647afc6a7954e3">dir_t</a> *dir)</td></tr>
  118. <tr class="separator:a6858d18c807411a071fd6d1b39d50087"><td class="memSeparator" colspan="2">&#160;</td></tr>
  119. <tr class="memitem:ae5ec24d4a94d3780384d3f2b731c7eb9"><td class="memItemLeft" align="right" valign="top">uint16_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#ae5ec24d4a94d3780384d3f2b731c7eb9">dirIndex</a> ()</td></tr>
  120. <tr class="separator:ae5ec24d4a94d3780384d3f2b731c7eb9"><td class="memSeparator" colspan="2">&#160;</td></tr>
  121. <tr class="memitem:a50242f98dea0d4488ce4039a279f2a57"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a50242f98dea0d4488ce4039a279f2a57">exists</a> (const char *path)</td></tr>
  122. <tr class="separator:a50242f98dea0d4488ce4039a279f2a57"><td class="memSeparator" colspan="2">&#160;</td></tr>
  123. <tr class="memitem:a7b591c9b92165fa8e4eae8c30c30e533"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a7b591c9b92165fa8e4eae8c30c30e533">FatFile</a> ()</td></tr>
  124. <tr class="separator:a7b591c9b92165fa8e4eae8c30c30e533"><td class="memSeparator" colspan="2">&#160;</td></tr>
  125. <tr class="memitem:a29d31067d0aa3a9a74b1a660c38775cc"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a29d31067d0aa3a9a74b1a660c38775cc">FatFile</a> (const char *path, uint8_t oflag)</td></tr>
  126. <tr class="separator:a29d31067d0aa3a9a74b1a660c38775cc"><td class="memSeparator" colspan="2">&#160;</td></tr>
  127. <tr class="memitem:a31ef26b3ee37cf5f5f4c6024c0ddab69"><td class="memItemLeft" align="right" valign="top">int16_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a31ef26b3ee37cf5f5f4c6024c0ddab69">fgets</a> (char *str, int16_t num, char *delim=0)</td></tr>
  128. <tr class="separator:a31ef26b3ee37cf5f5f4c6024c0ddab69"><td class="memSeparator" colspan="2">&#160;</td></tr>
  129. <tr class="memitem:a7e043dfb89d268bfd620bbbadacf1002"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a7e043dfb89d268bfd620bbbadacf1002">fileAttr</a> () const </td></tr>
  130. <tr class="separator:a7e043dfb89d268bfd620bbbadacf1002"><td class="memSeparator" colspan="2">&#160;</td></tr>
  131. <tr class="memitem:a02fc3b3ca36b4745f695f3de8c8ec36d"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a02fc3b3ca36b4745f695f3de8c8ec36d">fileSize</a> () const </td></tr>
  132. <tr class="separator:a02fc3b3ca36b4745f695f3de8c8ec36d"><td class="memSeparator" colspan="2">&#160;</td></tr>
  133. <tr class="memitem:a1057bc23b92a074539f661e896e79a09"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a1057bc23b92a074539f661e896e79a09">firstCluster</a> () const </td></tr>
  134. <tr class="separator:a1057bc23b92a074539f661e896e79a09"><td class="memSeparator" colspan="2">&#160;</td></tr>
  135. <tr class="memitem:ac7bcba15a3073d6a16b669dfec5dda78"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#ac7bcba15a3073d6a16b669dfec5dda78">getFilename</a> (char *name)</td></tr>
  136. <tr class="separator:ac7bcba15a3073d6a16b669dfec5dda78"><td class="memSeparator" colspan="2">&#160;</td></tr>
  137. <tr class="memitem:aaa4f9886887947815a61eaf015996932"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#aaa4f9886887947815a61eaf015996932">getpos</a> (<a class="el" href="struct_fat_pos__t.html">FatPos_t</a> *pos)</td></tr>
  138. <tr class="separator:aaa4f9886887947815a61eaf015996932"><td class="memSeparator" colspan="2">&#160;</td></tr>
  139. <tr class="memitem:a8062c0d3a118e8d77d0310418703d5f5"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a8062c0d3a118e8d77d0310418703d5f5">getWriteError</a> ()</td></tr>
  140. <tr class="separator:a8062c0d3a118e8d77d0310418703d5f5"><td class="memSeparator" colspan="2">&#160;</td></tr>
  141. <tr class="memitem:aef41d65e0f1ce753d18cc9ed691f7de4"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#aef41d65e0f1ce753d18cc9ed691f7de4">isDir</a> () const </td></tr>
  142. <tr class="separator:aef41d65e0f1ce753d18cc9ed691f7de4"><td class="memSeparator" colspan="2">&#160;</td></tr>
  143. <tr class="memitem:afcf6270ea8d4a3a5f8e89523bc684e22"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#afcf6270ea8d4a3a5f8e89523bc684e22">isFile</a> () const </td></tr>
  144. <tr class="separator:afcf6270ea8d4a3a5f8e89523bc684e22"><td class="memSeparator" colspan="2">&#160;</td></tr>
  145. <tr class="memitem:a7eefe7408f34b6326f0c6e78af7eb05f"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a7eefe7408f34b6326f0c6e78af7eb05f">isHidden</a> () const </td></tr>
  146. <tr class="separator:a7eefe7408f34b6326f0c6e78af7eb05f"><td class="memSeparator" colspan="2">&#160;</td></tr>
  147. <tr class="memitem:a4c8a07b081f04aa25839c6f56c739bdc"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a4c8a07b081f04aa25839c6f56c739bdc">isOpen</a> () const </td></tr>
  148. <tr class="separator:a4c8a07b081f04aa25839c6f56c739bdc"><td class="memSeparator" colspan="2">&#160;</td></tr>
  149. <tr class="memitem:a6872d3acb1e70f81c9c2be2495977583"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a6872d3acb1e70f81c9c2be2495977583">isReadOnly</a> () const </td></tr>
  150. <tr class="separator:a6872d3acb1e70f81c9c2be2495977583"><td class="memSeparator" colspan="2">&#160;</td></tr>
  151. <tr class="memitem:aa4a206803a4bf8243be20244c1aef4d2"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#aa4a206803a4bf8243be20244c1aef4d2">isRoot</a> () const </td></tr>
  152. <tr class="separator:aa4a206803a4bf8243be20244c1aef4d2"><td class="memSeparator" colspan="2">&#160;</td></tr>
  153. <tr class="memitem:a8215bd4b21e11ec83fa88ef226ceb06f"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a8215bd4b21e11ec83fa88ef226ceb06f">isRootFixed</a> () const </td></tr>
  154. <tr class="separator:a8215bd4b21e11ec83fa88ef226ceb06f"><td class="memSeparator" colspan="2">&#160;</td></tr>
  155. <tr class="memitem:a95b503b17442c2b364a2f53de1b2aeba"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a95b503b17442c2b364a2f53de1b2aeba">isSubDir</a> () const </td></tr>
  156. <tr class="separator:a95b503b17442c2b364a2f53de1b2aeba"><td class="memSeparator" colspan="2">&#160;</td></tr>
  157. <tr class="memitem:add932e13e5bf32ad467af6ec34824e3c"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#add932e13e5bf32ad467af6ec34824e3c">isSystem</a> () const </td></tr>
  158. <tr class="separator:add932e13e5bf32ad467af6ec34824e3c"><td class="memSeparator" colspan="2">&#160;</td></tr>
  159. <tr class="memitem:acabf31ff85e696fbf384c49428012fea"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#acabf31ff85e696fbf384c49428012fea">ls</a> (<a class="el" href="_fat_file_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *pr, uint8_t flags=0, uint8_t indent=0)</td></tr>
  160. <tr class="separator:acabf31ff85e696fbf384c49428012fea"><td class="memSeparator" colspan="2">&#160;</td></tr>
  161. <tr class="memitem:abab5b9f72cc796388dd4eed01d13d90d"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#abab5b9f72cc796388dd4eed01d13d90d">mkdir</a> (<a class="el" href="class_fat_file.html">FatFile</a> *dir, const char *path, bool pFlag=true)</td></tr>
  162. <tr class="separator:abab5b9f72cc796388dd4eed01d13d90d"><td class="memSeparator" colspan="2">&#160;</td></tr>
  163. <tr class="memitem:a5f64576d3d19177ab3cf3812b69abdfa"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a5f64576d3d19177ab3cf3812b69abdfa">open</a> (<a class="el" href="class_fat_file_system.html">FatFileSystem</a> *fs, const char *path, uint8_t oflag)</td></tr>
  164. <tr class="separator:a5f64576d3d19177ab3cf3812b69abdfa"><td class="memSeparator" colspan="2">&#160;</td></tr>
  165. <tr class="memitem:ad3fa9daaccb4e4179fb88a8ca037aa80"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#ad3fa9daaccb4e4179fb88a8ca037aa80">open</a> (<a class="el" href="class_fat_file.html">FatFile</a> *dirFile, uint16_t index, uint8_t oflag)</td></tr>
  166. <tr class="separator:ad3fa9daaccb4e4179fb88a8ca037aa80"><td class="memSeparator" colspan="2">&#160;</td></tr>
  167. <tr class="memitem:a211be757679b18708f6b6a36464e4f61"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a211be757679b18708f6b6a36464e4f61">open</a> (<a class="el" href="class_fat_file.html">FatFile</a> *dirFile, const char *path, uint8_t oflag)</td></tr>
  168. <tr class="separator:a211be757679b18708f6b6a36464e4f61"><td class="memSeparator" colspan="2">&#160;</td></tr>
  169. <tr class="memitem:ab0e7075062c89f356441f80fc64d03e6"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#ab0e7075062c89f356441f80fc64d03e6">open</a> (const char *path, uint8_t oflag=O_READ)</td></tr>
  170. <tr class="separator:ab0e7075062c89f356441f80fc64d03e6"><td class="memSeparator" colspan="2">&#160;</td></tr>
  171. <tr class="memitem:a8034c4649eb0d26715b1a8a69e73d9d0"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a8034c4649eb0d26715b1a8a69e73d9d0">openNext</a> (<a class="el" href="class_fat_file.html">FatFile</a> *dirFile, uint8_t oflag=O_READ)</td></tr>
  172. <tr class="separator:a8034c4649eb0d26715b1a8a69e73d9d0"><td class="memSeparator" colspan="2">&#160;</td></tr>
  173. <tr class="memitem:a76b34d6ecd7b343fdaa0bb1c3ec229e3"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a76b34d6ecd7b343fdaa0bb1c3ec229e3">openNextLFN</a> (<a class="el" href="class_fat_file.html">FatFile</a> *dirFile, char *name, size_t size, uint8_t oflag)</td></tr>
  174. <tr class="separator:a76b34d6ecd7b343fdaa0bb1c3ec229e3"><td class="memSeparator" colspan="2">&#160;</td></tr>
  175. <tr class="memitem:a7e0c0548fed3a69e7284b91b694439d4"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a7e0c0548fed3a69e7284b91b694439d4">openRoot</a> (<a class="el" href="class_fat_volume.html">FatVolume</a> *vol)</td></tr>
  176. <tr class="separator:a7e0c0548fed3a69e7284b91b694439d4"><td class="memSeparator" colspan="2">&#160;</td></tr>
  177. <tr class="memitem:ac05b7136b887539426856c623869aa3a"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#ac05b7136b887539426856c623869aa3a">peek</a> ()</td></tr>
  178. <tr class="separator:ac05b7136b887539426856c623869aa3a"><td class="memSeparator" colspan="2">&#160;</td></tr>
  179. <tr class="memitem:a558530f20314a8d8ee3d1a488fc7f46e"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a558530f20314a8d8ee3d1a488fc7f46e">printCreateDateTime</a> (<a class="el" href="_fat_file_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *pr)</td></tr>
  180. <tr class="separator:a558530f20314a8d8ee3d1a488fc7f46e"><td class="memSeparator" colspan="2">&#160;</td></tr>
  181. <tr class="memitem:a7478cad0f9e5079311b9e1fa558016ff"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a7478cad0f9e5079311b9e1fa558016ff">printField</a> (float value, char term, uint8_t prec=2)</td></tr>
  182. <tr class="separator:a7478cad0f9e5079311b9e1fa558016ff"><td class="memSeparator" colspan="2">&#160;</td></tr>
  183. <tr class="memitem:abd3e1747511216462b3ef98167156cbb"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#abd3e1747511216462b3ef98167156cbb">printField</a> (int16_t value, char term)</td></tr>
  184. <tr class="separator:abd3e1747511216462b3ef98167156cbb"><td class="memSeparator" colspan="2">&#160;</td></tr>
  185. <tr class="memitem:a9972c2419c293ef9c382bff666b9ae4d"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a9972c2419c293ef9c382bff666b9ae4d">printField</a> (uint16_t value, char term)</td></tr>
  186. <tr class="separator:a9972c2419c293ef9c382bff666b9ae4d"><td class="memSeparator" colspan="2">&#160;</td></tr>
  187. <tr class="memitem:a41b3b32dd8482429b74c7af3432d6cf8"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a41b3b32dd8482429b74c7af3432d6cf8">printField</a> (int32_t value, char term)</td></tr>
  188. <tr class="separator:a41b3b32dd8482429b74c7af3432d6cf8"><td class="memSeparator" colspan="2">&#160;</td></tr>
  189. <tr class="memitem:a097240f08baadeb1c64b63eab9afb088"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a097240f08baadeb1c64b63eab9afb088">printField</a> (uint32_t value, char term)</td></tr>
  190. <tr class="separator:a097240f08baadeb1c64b63eab9afb088"><td class="memSeparator" colspan="2">&#160;</td></tr>
  191. <tr class="memitem:a12a5d2de2737c201aa39ca1bd2ab9c47"><td class="memItemLeft" align="right" valign="top">size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a12a5d2de2737c201aa39ca1bd2ab9c47">printFileSize</a> (<a class="el" href="_fat_file_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *pr)</td></tr>
  192. <tr class="separator:a12a5d2de2737c201aa39ca1bd2ab9c47"><td class="memSeparator" colspan="2">&#160;</td></tr>
  193. <tr class="memitem:a05cee5df46a370bf916d3ba597c82e39"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a05cee5df46a370bf916d3ba597c82e39">printModifyDateTime</a> (<a class="el" href="_fat_file_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *pr)</td></tr>
  194. <tr class="separator:a05cee5df46a370bf916d3ba597c82e39"><td class="memSeparator" colspan="2">&#160;</td></tr>
  195. <tr class="memitem:afe18a787fb8640e2d2483370c770f82f"><td class="memItemLeft" align="right" valign="top">size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#afe18a787fb8640e2d2483370c770f82f">printName</a> (<a class="el" href="_fat_file_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *pr)</td></tr>
  196. <tr class="separator:afe18a787fb8640e2d2483370c770f82f"><td class="memSeparator" colspan="2">&#160;</td></tr>
  197. <tr class="memitem:a60ae55ff6fe158c2340071d702a363c5"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a60ae55ff6fe158c2340071d702a363c5">read</a> ()</td></tr>
  198. <tr class="separator:a60ae55ff6fe158c2340071d702a363c5"><td class="memSeparator" colspan="2">&#160;</td></tr>
  199. <tr class="memitem:a200e6e0553d5b709520c9dfac9ef77dd"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a200e6e0553d5b709520c9dfac9ef77dd">read</a> (void *buf, size_t nbyte)</td></tr>
  200. <tr class="separator:a200e6e0553d5b709520c9dfac9ef77dd"><td class="memSeparator" colspan="2">&#160;</td></tr>
  201. <tr class="memitem:a1325afe074c3efecff666678cd9f116a"><td class="memItemLeft" align="right" valign="top">int8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a1325afe074c3efecff666678cd9f116a">readDir</a> (<a class="el" href="_fat_structs_8h.html#a803db59d4e16a0c54a647afc6a7954e3">dir_t</a> *dir)</td></tr>
  202. <tr class="separator:a1325afe074c3efecff666678cd9f116a"><td class="memSeparator" colspan="2">&#160;</td></tr>
  203. <tr class="memitem:ac837a537fbcca14c7aa390c5fc9f4e7c"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#ac837a537fbcca14c7aa390c5fc9f4e7c">remove</a> ()</td></tr>
  204. <tr class="separator:ac837a537fbcca14c7aa390c5fc9f4e7c"><td class="memSeparator" colspan="2">&#160;</td></tr>
  205. <tr class="memitem:a4b42f2454ff462555c07ea094a92a1e0"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a4b42f2454ff462555c07ea094a92a1e0">rename</a> (<a class="el" href="class_fat_file.html">FatFile</a> *dirFile, const char *newPath)</td></tr>
  206. <tr class="separator:a4b42f2454ff462555c07ea094a92a1e0"><td class="memSeparator" colspan="2">&#160;</td></tr>
  207. <tr class="memitem:a5aac6e0b3cb08fc8b8668e916a8b0ca5"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a5aac6e0b3cb08fc8b8668e916a8b0ca5">rewind</a> ()</td></tr>
  208. <tr class="separator:a5aac6e0b3cb08fc8b8668e916a8b0ca5"><td class="memSeparator" colspan="2">&#160;</td></tr>
  209. <tr class="memitem:a9515bac181d33e7f0125e88fa2ccd283"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a9515bac181d33e7f0125e88fa2ccd283">rmdir</a> ()</td></tr>
  210. <tr class="separator:a9515bac181d33e7f0125e88fa2ccd283"><td class="memSeparator" colspan="2">&#160;</td></tr>
  211. <tr class="memitem:ac780a80526f86d3def701ecdc99d8bfe"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#ac780a80526f86d3def701ecdc99d8bfe">rmRfStar</a> ()</td></tr>
  212. <tr class="separator:ac780a80526f86d3def701ecdc99d8bfe"><td class="memSeparator" colspan="2">&#160;</td></tr>
  213. <tr class="memitem:a5812037ea30777cc350698ad26f2c73f"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a5812037ea30777cc350698ad26f2c73f">seekCur</a> (int32_t offset)</td></tr>
  214. <tr class="separator:a5812037ea30777cc350698ad26f2c73f"><td class="memSeparator" colspan="2">&#160;</td></tr>
  215. <tr class="memitem:a84f677f4e75ef6fa2eb632f4cdf6b486"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a84f677f4e75ef6fa2eb632f4cdf6b486">seekEnd</a> (int32_t offset=0)</td></tr>
  216. <tr class="separator:a84f677f4e75ef6fa2eb632f4cdf6b486"><td class="memSeparator" colspan="2">&#160;</td></tr>
  217. <tr class="memitem:ab067190d25733ed7e697d9890f61fd7a"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#ab067190d25733ed7e697d9890f61fd7a">seekSet</a> (uint32_t pos)</td></tr>
  218. <tr class="separator:ab067190d25733ed7e697d9890f61fd7a"><td class="memSeparator" colspan="2">&#160;</td></tr>
  219. <tr class="memitem:acf264de4e3ca36c5e8a39e56173c9044"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#acf264de4e3ca36c5e8a39e56173c9044">setpos</a> (<a class="el" href="struct_fat_pos__t.html">FatPos_t</a> *pos)</td></tr>
  220. <tr class="separator:acf264de4e3ca36c5e8a39e56173c9044"><td class="memSeparator" colspan="2">&#160;</td></tr>
  221. <tr class="memitem:a67f3dc4896c542d695e11aac927f585e"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a67f3dc4896c542d695e11aac927f585e">sync</a> ()</td></tr>
  222. <tr class="separator:a67f3dc4896c542d695e11aac927f585e"><td class="memSeparator" colspan="2">&#160;</td></tr>
  223. <tr class="memitem:aa53a8d1d2467ad9af7d61cbf8ee85243"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#aa53a8d1d2467ad9af7d61cbf8ee85243">timestamp</a> (<a class="el" href="class_fat_file.html">FatFile</a> *file)</td></tr>
  224. <tr class="separator:aa53a8d1d2467ad9af7d61cbf8ee85243"><td class="memSeparator" colspan="2">&#160;</td></tr>
  225. <tr class="memitem:a56dabdf73833b7e961c4530eb8e16d23"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a56dabdf73833b7e961c4530eb8e16d23">timestamp</a> (uint8_t flags, uint16_t year, uint8_t month, uint8_t day, uint8_t hour, uint8_t minute, uint8_t second)</td></tr>
  226. <tr class="separator:a56dabdf73833b7e961c4530eb8e16d23"><td class="memSeparator" colspan="2">&#160;</td></tr>
  227. <tr class="memitem:aa6e663098a578635d37d92e82d18d616"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#aa6e663098a578635d37d92e82d18d616">truncate</a> (uint32_t length)</td></tr>
  228. <tr class="separator:aa6e663098a578635d37d92e82d18d616"><td class="memSeparator" colspan="2">&#160;</td></tr>
  229. <tr class="memitem:a3c64bd8a9abb9a6461d4addb405614df"><td class="memItemLeft" align="right" valign="top"><a class="el" href="class_fat_volume.html">FatVolume</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a3c64bd8a9abb9a6461d4addb405614df">volume</a> () const </td></tr>
  230. <tr class="separator:a3c64bd8a9abb9a6461d4addb405614df"><td class="memSeparator" colspan="2">&#160;</td></tr>
  231. <tr class="memitem:a5524bd9f3b8f54ee163e391cba618186"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a5524bd9f3b8f54ee163e391cba618186">write</a> (uint8_t b)</td></tr>
  232. <tr class="separator:a5524bd9f3b8f54ee163e391cba618186"><td class="memSeparator" colspan="2">&#160;</td></tr>
  233. <tr class="memitem:a0ab9df44a9ee4b6eb0a78f15f1e30004"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a0ab9df44a9ee4b6eb0a78f15f1e30004">write</a> (const void *buf, size_t nbyte)</td></tr>
  234. <tr class="separator:a0ab9df44a9ee4b6eb0a78f15f1e30004"><td class="memSeparator" colspan="2">&#160;</td></tr>
  235. </table><table class="memberdecls">
  236. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-static-methods"></a>
  237. Static Public Member Functions</h2></td></tr>
  238. <tr class="memitem:a3b68e603ad8e47bad915f0547e580adb"><td class="memItemLeft" align="right" valign="top">static <a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a3b68e603ad8e47bad915f0547e580adb">cwd</a> ()</td></tr>
  239. <tr class="separator:a3b68e603ad8e47bad915f0547e580adb"><td class="memSeparator" colspan="2">&#160;</td></tr>
  240. <tr class="memitem:a29a623f50df057e8b49045ba6611ec2b"><td class="memItemLeft" align="right" valign="top">static void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a29a623f50df057e8b49045ba6611ec2b">dateTimeCallback</a> (void(*dateTime)(uint16_t *date, uint16_t *time))</td></tr>
  241. <tr class="separator:a29a623f50df057e8b49045ba6611ec2b"><td class="memSeparator" colspan="2">&#160;</td></tr>
  242. <tr class="memitem:a5df02f1d037e6091375488af25244ebc"><td class="memItemLeft" align="right" valign="top">static void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a5df02f1d037e6091375488af25244ebc">dateTimeCallbackCancel</a> ()</td></tr>
  243. <tr class="separator:a5df02f1d037e6091375488af25244ebc"><td class="memSeparator" colspan="2">&#160;</td></tr>
  244. <tr class="memitem:a648461081fe07578780f4cd3f246cb66"><td class="memItemLeft" align="right" valign="top">static uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a648461081fe07578780f4cd3f246cb66">dirName</a> (const <a class="el" href="_fat_structs_8h.html#a803db59d4e16a0c54a647afc6a7954e3">dir_t</a> *dir, char *name)</td></tr>
  245. <tr class="separator:a648461081fe07578780f4cd3f246cb66"><td class="memSeparator" colspan="2">&#160;</td></tr>
  246. <tr class="memitem:ada5364f66204b1a64afbf9d2e6cd2b0b"><td class="memItemLeft" align="right" valign="top">static void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#ada5364f66204b1a64afbf9d2e6cd2b0b">printFatDate</a> (<a class="el" href="_fat_file_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *pr, uint16_t fatDate)</td></tr>
  247. <tr class="separator:ada5364f66204b1a64afbf9d2e6cd2b0b"><td class="memSeparator" colspan="2">&#160;</td></tr>
  248. <tr class="memitem:a4e7e56ba52ca17c602af1b85684b09a9"><td class="memItemLeft" align="right" valign="top">static void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a4e7e56ba52ca17c602af1b85684b09a9">printFatTime</a> (<a class="el" href="_fat_file_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *pr, uint16_t fatTime)</td></tr>
  249. <tr class="separator:a4e7e56ba52ca17c602af1b85684b09a9"><td class="memSeparator" colspan="2">&#160;</td></tr>
  250. <tr class="memitem:afe820bbb056863e91ec482961c8dc695"><td class="memItemLeft" align="right" valign="top">static bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#afe820bbb056863e91ec482961c8dc695">remove</a> (<a class="el" href="class_fat_file.html">FatFile</a> *dirFile, const char *path)</td></tr>
  251. <tr class="separator:afe820bbb056863e91ec482961c8dc695"><td class="memSeparator" colspan="2">&#160;</td></tr>
  252. <tr class="memitem:a360ef9c05e677271bed6c0a4d663634c"><td class="memItemLeft" align="right" valign="top">static bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a360ef9c05e677271bed6c0a4d663634c">setCwd</a> (<a class="el" href="class_fat_file.html">FatFile</a> *dir)</td></tr>
  253. <tr class="separator:a360ef9c05e677271bed6c0a4d663634c"><td class="memSeparator" colspan="2">&#160;</td></tr>
  254. </table>
  255. <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
  256. <div class="textblock"><p>Basic file class. </p>
  257. </div><h2 class="groupheader">Constructor &amp; Destructor Documentation</h2>
  258. <a class="anchor" id="a7b591c9b92165fa8e4eae8c30c30e533"></a>
  259. <div class="memitem">
  260. <div class="memproto">
  261. <table class="mlabels">
  262. <tr>
  263. <td class="mlabels-left">
  264. <table class="memname">
  265. <tr>
  266. <td class="memname">FatFile::FatFile </td>
  267. <td>(</td>
  268. <td class="paramname"></td><td>)</td>
  269. <td></td>
  270. </tr>
  271. </table>
  272. </td>
  273. <td class="mlabels-right">
  274. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  275. </tr>
  276. </table>
  277. </div><div class="memdoc">
  278. <p>Create an instance. </p>
  279. </div>
  280. </div>
  281. <a class="anchor" id="a29d31067d0aa3a9a74b1a660c38775cc"></a>
  282. <div class="memitem">
  283. <div class="memproto">
  284. <table class="mlabels">
  285. <tr>
  286. <td class="mlabels-left">
  287. <table class="memname">
  288. <tr>
  289. <td class="memname">FatFile::FatFile </td>
  290. <td>(</td>
  291. <td class="paramtype">const char *&#160;</td>
  292. <td class="paramname"><em>path</em>, </td>
  293. </tr>
  294. <tr>
  295. <td class="paramkey"></td>
  296. <td></td>
  297. <td class="paramtype">uint8_t&#160;</td>
  298. <td class="paramname"><em>oflag</em>&#160;</td>
  299. </tr>
  300. <tr>
  301. <td></td>
  302. <td>)</td>
  303. <td></td><td></td>
  304. </tr>
  305. </table>
  306. </td>
  307. <td class="mlabels-right">
  308. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  309. </tr>
  310. </table>
  311. </div><div class="memdoc">
  312. <p>Create a file object and open it in the current working directory.</p>
  313. <dl class="params"><dt>Parameters</dt><dd>
  314. <table class="params">
  315. <tr><td class="paramdir">[in]</td><td class="paramname">path</td><td>A path with a valid 8.3 DOS name for a file to be opened.</td></tr>
  316. <tr><td class="paramdir">[in]</td><td class="paramname">oflag</td><td>Values for <em>oflag</em> are constructed by a bitwise-inclusive OR of open flags. see <a class="el" href="class_fat_file.html#a211be757679b18708f6b6a36464e4f61">FatFile::open(FatFile*, const char*, uint8_t)</a>. </td></tr>
  317. </table>
  318. </dd>
  319. </dl>
  320. </div>
  321. </div>
  322. <h2 class="groupheader">Member Function Documentation</h2>
  323. <a class="anchor" id="ac1fa779d98db7ffdb96f8019ab0060d6"></a>
  324. <div class="memitem">
  325. <div class="memproto">
  326. <table class="mlabels">
  327. <tr>
  328. <td class="mlabels-left">
  329. <table class="memname">
  330. <tr>
  331. <td class="memname">uint32_t FatFile::available </td>
  332. <td>(</td>
  333. <td class="paramname"></td><td>)</td>
  334. <td></td>
  335. </tr>
  336. </table>
  337. </td>
  338. <td class="mlabels-right">
  339. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  340. </tr>
  341. </table>
  342. </div><div class="memdoc">
  343. <dl class="section return"><dt>Returns</dt><dd>number of bytes available from the current position to EOF </dd></dl>
  344. </div>
  345. </div>
  346. <a class="anchor" id="aeca2a2eff91e6aa55fe1b0e3860c9a05"></a>
  347. <div class="memitem">
  348. <div class="memproto">
  349. <table class="mlabels">
  350. <tr>
  351. <td class="mlabels-left">
  352. <table class="memname">
  353. <tr>
  354. <td class="memname">void FatFile::clearWriteError </td>
  355. <td>(</td>
  356. <td class="paramname"></td><td>)</td>
  357. <td></td>
  358. </tr>
  359. </table>
  360. </td>
  361. <td class="mlabels-right">
  362. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  363. </tr>
  364. </table>
  365. </div><div class="memdoc">
  366. <p>Set writeError to zero </p>
  367. </div>
  368. </div>
  369. <a class="anchor" id="afd16af325e0642e4bff6430b7d8bb18b"></a>
  370. <div class="memitem">
  371. <div class="memproto">
  372. <table class="memname">
  373. <tr>
  374. <td class="memname">bool FatFile::close </td>
  375. <td>(</td>
  376. <td class="paramname"></td><td>)</td>
  377. <td></td>
  378. </tr>
  379. </table>
  380. </div><div class="memdoc">
  381. <p>Close a file and force cached data and directory information to be written to the storage device.</p>
  382. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. Reasons for failure include no file is open or an I/O error. </dd></dl>
  383. </div>
  384. </div>
  385. <a class="anchor" id="aa367708bcc8bc0e0c45c0c2a812c65da"></a>
  386. <div class="memitem">
  387. <div class="memproto">
  388. <table class="memname">
  389. <tr>
  390. <td class="memname">bool FatFile::contiguousRange </td>
  391. <td>(</td>
  392. <td class="paramtype">uint32_t *&#160;</td>
  393. <td class="paramname"><em>bgnBlock</em>, </td>
  394. </tr>
  395. <tr>
  396. <td class="paramkey"></td>
  397. <td></td>
  398. <td class="paramtype">uint32_t *&#160;</td>
  399. <td class="paramname"><em>endBlock</em>&#160;</td>
  400. </tr>
  401. <tr>
  402. <td></td>
  403. <td>)</td>
  404. <td></td><td></td>
  405. </tr>
  406. </table>
  407. </div><div class="memdoc">
  408. <p>Check for contiguous file and return its raw block range.</p>
  409. <dl class="params"><dt>Parameters</dt><dd>
  410. <table class="params">
  411. <tr><td class="paramdir">[out]</td><td class="paramname">bgnBlock</td><td>the first block address for the file. </td></tr>
  412. <tr><td class="paramdir">[out]</td><td class="paramname">endBlock</td><td>the last block address for the file.</td></tr>
  413. </table>
  414. </dd>
  415. </dl>
  416. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. Reasons for failure include file is not contiguous, file has zero length or an I/O error occurred. </dd></dl>
  417. </div>
  418. </div>
  419. <a class="anchor" id="a0afc2a1cffa238d1cb2049bfa2d8d199"></a>
  420. <div class="memitem">
  421. <div class="memproto">
  422. <table class="memname">
  423. <tr>
  424. <td class="memname">bool FatFile::createContiguous </td>
  425. <td>(</td>
  426. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  427. <td class="paramname"><em>dirFile</em>, </td>
  428. </tr>
  429. <tr>
  430. <td class="paramkey"></td>
  431. <td></td>
  432. <td class="paramtype">const char *&#160;</td>
  433. <td class="paramname"><em>path</em>, </td>
  434. </tr>
  435. <tr>
  436. <td class="paramkey"></td>
  437. <td></td>
  438. <td class="paramtype">uint32_t&#160;</td>
  439. <td class="paramname"><em>size</em>&#160;</td>
  440. </tr>
  441. <tr>
  442. <td></td>
  443. <td>)</td>
  444. <td></td><td></td>
  445. </tr>
  446. </table>
  447. </div><div class="memdoc">
  448. <p>Create and open a new contiguous file of a specified size.</p>
  449. <dl class="section note"><dt>Note</dt><dd>This function only supports short DOS 8.3 names. See <a class="el" href="class_fat_file.html#a5f64576d3d19177ab3cf3812b69abdfa">open()</a> for more information.</dd></dl>
  450. <dl class="params"><dt>Parameters</dt><dd>
  451. <table class="params">
  452. <tr><td class="paramdir">[in]</td><td class="paramname">dirFile</td><td>The directory where the file will be created. </td></tr>
  453. <tr><td class="paramdir">[in]</td><td class="paramname">path</td><td>A path with a valid DOS 8.3 file name. </td></tr>
  454. <tr><td class="paramdir">[in]</td><td class="paramname">size</td><td>The desired file size.</td></tr>
  455. </table>
  456. </dd>
  457. </dl>
  458. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. Reasons for failure include <em>path</em> contains an invalid DOS 8.3 file name, the FAT volume has not been initialized, a file is already open, the file already exists, the root directory is full or an I/O error. </dd></dl>
  459. </div>
  460. </div>
  461. <a class="anchor" id="a4c03e2f6729526786e6ab4a623e0339b"></a>
  462. <div class="memitem">
  463. <div class="memproto">
  464. <table class="mlabels">
  465. <tr>
  466. <td class="mlabels-left">
  467. <table class="memname">
  468. <tr>
  469. <td class="memname">uint32_t FatFile::curCluster </td>
  470. <td>(</td>
  471. <td class="paramname"></td><td>)</td>
  472. <td> const</td>
  473. </tr>
  474. </table>
  475. </td>
  476. <td class="mlabels-right">
  477. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  478. </tr>
  479. </table>
  480. </div><div class="memdoc">
  481. <dl class="section return"><dt>Returns</dt><dd>The current cluster number for a file or directory. </dd></dl>
  482. </div>
  483. </div>
  484. <a class="anchor" id="a20c55b134bfd1d287a00bf64eba9332e"></a>
  485. <div class="memitem">
  486. <div class="memproto">
  487. <table class="mlabels">
  488. <tr>
  489. <td class="mlabels-left">
  490. <table class="memname">
  491. <tr>
  492. <td class="memname">uint32_t FatFile::curPosition </td>
  493. <td>(</td>
  494. <td class="paramname"></td><td>)</td>
  495. <td> const</td>
  496. </tr>
  497. </table>
  498. </td>
  499. <td class="mlabels-right">
  500. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  501. </tr>
  502. </table>
  503. </div><div class="memdoc">
  504. <dl class="section return"><dt>Returns</dt><dd>The current position for a file or directory. </dd></dl>
  505. </div>
  506. </div>
  507. <a class="anchor" id="a3b68e603ad8e47bad915f0547e580adb"></a>
  508. <div class="memitem">
  509. <div class="memproto">
  510. <table class="mlabels">
  511. <tr>
  512. <td class="mlabels-left">
  513. <table class="memname">
  514. <tr>
  515. <td class="memname">static <a class="el" href="class_fat_file.html">FatFile</a>* FatFile::cwd </td>
  516. <td>(</td>
  517. <td class="paramname"></td><td>)</td>
  518. <td></td>
  519. </tr>
  520. </table>
  521. </td>
  522. <td class="mlabels-right">
  523. <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
  524. </tr>
  525. </table>
  526. </div><div class="memdoc">
  527. <dl class="section return"><dt>Returns</dt><dd>Current working directory </dd></dl>
  528. </div>
  529. </div>
  530. <a class="anchor" id="a29a623f50df057e8b49045ba6611ec2b"></a>
  531. <div class="memitem">
  532. <div class="memproto">
  533. <table class="mlabels">
  534. <tr>
  535. <td class="mlabels-left">
  536. <table class="memname">
  537. <tr>
  538. <td class="memname">static void FatFile::dateTimeCallback </td>
  539. <td>(</td>
  540. <td class="paramtype">void(*)(uint16_t *date, uint16_t *time)&#160;</td>
  541. <td class="paramname"><em>dateTime</em></td><td>)</td>
  542. <td></td>
  543. </tr>
  544. </table>
  545. </td>
  546. <td class="mlabels-right">
  547. <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
  548. </tr>
  549. </table>
  550. </div><div class="memdoc">
  551. <p>Set the date/time callback function</p>
  552. <dl class="params"><dt>Parameters</dt><dd>
  553. <table class="params">
  554. <tr><td class="paramdir">[in]</td><td class="paramname">dateTime</td><td>The user's call back function. The callback function is of the form:</td></tr>
  555. </table>
  556. </dd>
  557. </dl>
  558. <div class="fragment"><div class="line"><span class="keywordtype">void</span> dateTime(uint16_t* date, uint16_t* time) {</div>
  559. <div class="line"> uint16_t year;</div>
  560. <div class="line"> uint8_t month, day, hour, minute, second;</div>
  561. <div class="line"></div>
  562. <div class="line"> <span class="comment">// User gets date and time from GPS or real-time clock here</span></div>
  563. <div class="line"></div>
  564. <div class="line"> <span class="comment">// return date using FAT_DATE macro to format fields</span></div>
  565. <div class="line"> *date = <a class="code" href="_fat_structs_8h.html#a44899ad42ddf32ff1c1a73b5251b304a">FAT_DATE</a>(year, month, day);</div>
  566. <div class="line"></div>
  567. <div class="line"> <span class="comment">// return time using FAT_TIME macro to format fields</span></div>
  568. <div class="line"> *time = <a class="code" href="_fat_structs_8h.html#a375720927be5a39475d48b2d75dae29a">FAT_TIME</a>(hour, minute, second);</div>
  569. <div class="line">}</div>
  570. </div><!-- fragment --><p>Sets the function that is called when a file is created or when a file's directory entry is modified by <a class="el" href="class_fat_file.html#a67f3dc4896c542d695e11aac927f585e">sync()</a>. All timestamps, access, creation, and modify, are set when a file is created. <a class="el" href="class_fat_file.html#a67f3dc4896c542d695e11aac927f585e">sync()</a> maintains the last access date and last modify date/time.</p>
  571. <p>See the <a class="el" href="class_fat_file.html#aa53a8d1d2467ad9af7d61cbf8ee85243">timestamp()</a> function. </p>
  572. </div>
  573. </div>
  574. <a class="anchor" id="a5df02f1d037e6091375488af25244ebc"></a>
  575. <div class="memitem">
  576. <div class="memproto">
  577. <table class="mlabels">
  578. <tr>
  579. <td class="mlabels-left">
  580. <table class="memname">
  581. <tr>
  582. <td class="memname">static void FatFile::dateTimeCallbackCancel </td>
  583. <td>(</td>
  584. <td class="paramname"></td><td>)</td>
  585. <td></td>
  586. </tr>
  587. </table>
  588. </td>
  589. <td class="mlabels-right">
  590. <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
  591. </tr>
  592. </table>
  593. </div><div class="memdoc">
  594. <p>Cancel the date/time callback function. </p>
  595. </div>
  596. </div>
  597. <a class="anchor" id="a6858d18c807411a071fd6d1b39d50087"></a>
  598. <div class="memitem">
  599. <div class="memproto">
  600. <table class="memname">
  601. <tr>
  602. <td class="memname">bool FatFile::dirEntry </td>
  603. <td>(</td>
  604. <td class="paramtype"><a class="el" href="_fat_structs_8h.html#a803db59d4e16a0c54a647afc6a7954e3">dir_t</a> *&#160;</td>
  605. <td class="paramname"><em>dir</em></td><td>)</td>
  606. <td></td>
  607. </tr>
  608. </table>
  609. </div><div class="memdoc">
  610. <p>Return a file's directory entry.</p>
  611. <dl class="params"><dt>Parameters</dt><dd>
  612. <table class="params">
  613. <tr><td class="paramdir">[out]</td><td class="paramname">dir</td><td>Location for return of the file's directory entry.</td></tr>
  614. </table>
  615. </dd>
  616. </dl>
  617. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. </dd></dl>
  618. </div>
  619. </div>
  620. <a class="anchor" id="ae5ec24d4a94d3780384d3f2b731c7eb9"></a>
  621. <div class="memitem">
  622. <div class="memproto">
  623. <table class="mlabels">
  624. <tr>
  625. <td class="mlabels-left">
  626. <table class="memname">
  627. <tr>
  628. <td class="memname">uint16_t FatFile::dirIndex </td>
  629. <td>(</td>
  630. <td class="paramname"></td><td>)</td>
  631. <td></td>
  632. </tr>
  633. </table>
  634. </td>
  635. <td class="mlabels-right">
  636. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  637. </tr>
  638. </table>
  639. </div><div class="memdoc">
  640. <dl class="section return"><dt>Returns</dt><dd>The index of this file in it's directory. </dd></dl>
  641. </div>
  642. </div>
  643. <a class="anchor" id="a648461081fe07578780f4cd3f246cb66"></a>
  644. <div class="memitem">
  645. <div class="memproto">
  646. <table class="mlabels">
  647. <tr>
  648. <td class="mlabels-left">
  649. <table class="memname">
  650. <tr>
  651. <td class="memname">uint8_t FatFile::dirName </td>
  652. <td>(</td>
  653. <td class="paramtype">const <a class="el" href="_fat_structs_8h.html#a803db59d4e16a0c54a647afc6a7954e3">dir_t</a> *&#160;</td>
  654. <td class="paramname"><em>dir</em>, </td>
  655. </tr>
  656. <tr>
  657. <td class="paramkey"></td>
  658. <td></td>
  659. <td class="paramtype">char *&#160;</td>
  660. <td class="paramname"><em>name</em>&#160;</td>
  661. </tr>
  662. <tr>
  663. <td></td>
  664. <td>)</td>
  665. <td></td><td></td>
  666. </tr>
  667. </table>
  668. </td>
  669. <td class="mlabels-right">
  670. <span class="mlabels"><span class="mlabel">static</span></span> </td>
  671. </tr>
  672. </table>
  673. </div><div class="memdoc">
  674. <p>Format the name field of <em>dir</em> into the 13 byte array <em>name</em> in standard 8.3 short name format.</p>
  675. <dl class="params"><dt>Parameters</dt><dd>
  676. <table class="params">
  677. <tr><td class="paramdir">[in]</td><td class="paramname">dir</td><td>The directory structure containing the name. </td></tr>
  678. <tr><td class="paramdir">[out]</td><td class="paramname">name</td><td>A 13 byte char array for the formatted name. </td></tr>
  679. </table>
  680. </dd>
  681. </dl>
  682. <dl class="section return"><dt>Returns</dt><dd>length of the name. </dd></dl>
  683. </div>
  684. </div>
  685. <a class="anchor" id="a50242f98dea0d4488ce4039a279f2a57"></a>
  686. <div class="memitem">
  687. <div class="memproto">
  688. <table class="mlabels">
  689. <tr>
  690. <td class="mlabels-left">
  691. <table class="memname">
  692. <tr>
  693. <td class="memname">bool FatFile::exists </td>
  694. <td>(</td>
  695. <td class="paramtype">const char *&#160;</td>
  696. <td class="paramname"><em>path</em></td><td>)</td>
  697. <td></td>
  698. </tr>
  699. </table>
  700. </td>
  701. <td class="mlabels-right">
  702. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  703. </tr>
  704. </table>
  705. </div><div class="memdoc">
  706. <p>Test for the existence of a file in a directory</p>
  707. <dl class="params"><dt>Parameters</dt><dd>
  708. <table class="params">
  709. <tr><td class="paramdir">[in]</td><td class="paramname">path</td><td>Path of the file to be tested for.</td></tr>
  710. </table>
  711. </dd>
  712. </dl>
  713. <p>The calling instance must be an open directory file.</p>
  714. <p>dirFile.exists("TOFIND.TXT") searches for "TOFIND.TXT" in the directory dirFile.</p>
  715. <dl class="section return"><dt>Returns</dt><dd>true if the file exists else false. </dd></dl>
  716. </div>
  717. </div>
  718. <a class="anchor" id="a31ef26b3ee37cf5f5f4c6024c0ddab69"></a>
  719. <div class="memitem">
  720. <div class="memproto">
  721. <table class="memname">
  722. <tr>
  723. <td class="memname">int16_t FatFile::fgets </td>
  724. <td>(</td>
  725. <td class="paramtype">char *&#160;</td>
  726. <td class="paramname"><em>str</em>, </td>
  727. </tr>
  728. <tr>
  729. <td class="paramkey"></td>
  730. <td></td>
  731. <td class="paramtype">int16_t&#160;</td>
  732. <td class="paramname"><em>num</em>, </td>
  733. </tr>
  734. <tr>
  735. <td class="paramkey"></td>
  736. <td></td>
  737. <td class="paramtype">char *&#160;</td>
  738. <td class="paramname"><em>delim</em> = <code>0</code>&#160;</td>
  739. </tr>
  740. <tr>
  741. <td></td>
  742. <td>)</td>
  743. <td></td><td></td>
  744. </tr>
  745. </table>
  746. </div><div class="memdoc">
  747. <p>Get a string from a file.</p>
  748. <p><a class="el" href="class_fat_file.html#a31ef26b3ee37cf5f5f4c6024c0ddab69">fgets()</a> reads bytes from a file into the array pointed to by <em>str</em>, until <em>num</em> - 1 bytes are read, or a delimiter is read and transferred to <em>str</em>, or end-of-file is encountered. The string is then terminated with a null byte.</p>
  749. <p><a class="el" href="class_fat_file.html#a31ef26b3ee37cf5f5f4c6024c0ddab69">fgets()</a> deletes CR, '\r', from the string. This insures only a '\n' terminates the string for Windows text files which use CRLF for newline.</p>
  750. <dl class="params"><dt>Parameters</dt><dd>
  751. <table class="params">
  752. <tr><td class="paramdir">[out]</td><td class="paramname">str</td><td>Pointer to the array where the string is stored. </td></tr>
  753. <tr><td class="paramdir">[in]</td><td class="paramname">num</td><td>Maximum number of characters to be read (including the final null byte). Usually the length of the array <em>str</em> is used. </td></tr>
  754. <tr><td class="paramdir">[in]</td><td class="paramname">delim</td><td>Optional set of delimiters. The default is "\n".</td></tr>
  755. </table>
  756. </dd>
  757. </dl>
  758. <dl class="section return"><dt>Returns</dt><dd>For success <a class="el" href="class_fat_file.html#a31ef26b3ee37cf5f5f4c6024c0ddab69">fgets()</a> returns the length of the string in <em>str</em>. If no data is read, <a class="el" href="class_fat_file.html#a31ef26b3ee37cf5f5f4c6024c0ddab69">fgets()</a> returns zero for EOF or -1 if an error occurred. </dd></dl>
  759. </div>
  760. </div>
  761. <a class="anchor" id="a7e043dfb89d268bfd620bbbadacf1002"></a>
  762. <div class="memitem">
  763. <div class="memproto">
  764. <table class="mlabels">
  765. <tr>
  766. <td class="mlabels-left">
  767. <table class="memname">
  768. <tr>
  769. <td class="memname">uint8_t FatFile::fileAttr </td>
  770. <td>(</td>
  771. <td class="paramname"></td><td>)</td>
  772. <td> const</td>
  773. </tr>
  774. </table>
  775. </td>
  776. <td class="mlabels-right">
  777. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  778. </tr>
  779. </table>
  780. </div><div class="memdoc">
  781. <p>Type of file. You should use <a class="el" href="class_fat_file.html#afcf6270ea8d4a3a5f8e89523bc684e22">isFile()</a> or <a class="el" href="class_fat_file.html#aef41d65e0f1ce753d18cc9ed691f7de4">isDir()</a> instead of fileType() if possible.</p>
  782. <dl class="section return"><dt>Returns</dt><dd>The file or directory type. </dd></dl>
  783. </div>
  784. </div>
  785. <a class="anchor" id="a02fc3b3ca36b4745f695f3de8c8ec36d"></a>
  786. <div class="memitem">
  787. <div class="memproto">
  788. <table class="mlabels">
  789. <tr>
  790. <td class="mlabels-left">
  791. <table class="memname">
  792. <tr>
  793. <td class="memname">uint32_t FatFile::fileSize </td>
  794. <td>(</td>
  795. <td class="paramname"></td><td>)</td>
  796. <td> const</td>
  797. </tr>
  798. </table>
  799. </td>
  800. <td class="mlabels-right">
  801. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  802. </tr>
  803. </table>
  804. </div><div class="memdoc">
  805. <dl class="section return"><dt>Returns</dt><dd>The total number of bytes in a file or directory. </dd></dl>
  806. </div>
  807. </div>
  808. <a class="anchor" id="a1057bc23b92a074539f661e896e79a09"></a>
  809. <div class="memitem">
  810. <div class="memproto">
  811. <table class="mlabels">
  812. <tr>
  813. <td class="mlabels-left">
  814. <table class="memname">
  815. <tr>
  816. <td class="memname">uint32_t FatFile::firstCluster </td>
  817. <td>(</td>
  818. <td class="paramname"></td><td>)</td>
  819. <td> const</td>
  820. </tr>
  821. </table>
  822. </td>
  823. <td class="mlabels-right">
  824. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  825. </tr>
  826. </table>
  827. </div><div class="memdoc">
  828. <dl class="section return"><dt>Returns</dt><dd>The first cluster number for a file or directory. </dd></dl>
  829. </div>
  830. </div>
  831. <a class="anchor" id="ac7bcba15a3073d6a16b669dfec5dda78"></a>
  832. <div class="memitem">
  833. <div class="memproto">
  834. <table class="memname">
  835. <tr>
  836. <td class="memname">bool FatFile::getFilename </td>
  837. <td>(</td>
  838. <td class="paramtype">char *&#160;</td>
  839. <td class="paramname"><em>name</em></td><td>)</td>
  840. <td></td>
  841. </tr>
  842. </table>
  843. </div><div class="memdoc">
  844. <p>Get a file's name</p>
  845. <dl class="params"><dt>Parameters</dt><dd>
  846. <table class="params">
  847. <tr><td class="paramdir">[out]</td><td class="paramname">name</td><td>An array of 13 characters for the file's name.</td></tr>
  848. </table>
  849. </dd>
  850. </dl>
  851. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. </dd></dl>
  852. </div>
  853. </div>
  854. <a class="anchor" id="aaa4f9886887947815a61eaf015996932"></a>
  855. <div class="memitem">
  856. <div class="memproto">
  857. <table class="memname">
  858. <tr>
  859. <td class="memname">void FatFile::getpos </td>
  860. <td>(</td>
  861. <td class="paramtype"><a class="el" href="struct_fat_pos__t.html">FatPos_t</a> *&#160;</td>
  862. <td class="paramname"><em>pos</em></td><td>)</td>
  863. <td></td>
  864. </tr>
  865. </table>
  866. </div><div class="memdoc">
  867. <p>get position for streams </p><dl class="params"><dt>Parameters</dt><dd>
  868. <table class="params">
  869. <tr><td class="paramdir">[out]</td><td class="paramname">pos</td><td>struct to receive position </td></tr>
  870. </table>
  871. </dd>
  872. </dl>
  873. </div>
  874. </div>
  875. <a class="anchor" id="a8062c0d3a118e8d77d0310418703d5f5"></a>
  876. <div class="memitem">
  877. <div class="memproto">
  878. <table class="mlabels">
  879. <tr>
  880. <td class="mlabels-left">
  881. <table class="memname">
  882. <tr>
  883. <td class="memname">bool FatFile::getWriteError </td>
  884. <td>(</td>
  885. <td class="paramname"></td><td>)</td>
  886. <td></td>
  887. </tr>
  888. </table>
  889. </td>
  890. <td class="mlabels-right">
  891. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  892. </tr>
  893. </table>
  894. </div><div class="memdoc">
  895. <dl class="section return"><dt>Returns</dt><dd>value of writeError </dd></dl>
  896. </div>
  897. </div>
  898. <a class="anchor" id="aef41d65e0f1ce753d18cc9ed691f7de4"></a>
  899. <div class="memitem">
  900. <div class="memproto">
  901. <table class="mlabels">
  902. <tr>
  903. <td class="mlabels-left">
  904. <table class="memname">
  905. <tr>
  906. <td class="memname">bool FatFile::isDir </td>
  907. <td>(</td>
  908. <td class="paramname"></td><td>)</td>
  909. <td> const</td>
  910. </tr>
  911. </table>
  912. </td>
  913. <td class="mlabels-right">
  914. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  915. </tr>
  916. </table>
  917. </div><div class="memdoc">
  918. <dl class="section return"><dt>Returns</dt><dd>True if this is a directory else false. </dd></dl>
  919. </div>
  920. </div>
  921. <a class="anchor" id="afcf6270ea8d4a3a5f8e89523bc684e22"></a>
  922. <div class="memitem">
  923. <div class="memproto">
  924. <table class="mlabels">
  925. <tr>
  926. <td class="mlabels-left">
  927. <table class="memname">
  928. <tr>
  929. <td class="memname">bool FatFile::isFile </td>
  930. <td>(</td>
  931. <td class="paramname"></td><td>)</td>
  932. <td> const</td>
  933. </tr>
  934. </table>
  935. </td>
  936. <td class="mlabels-right">
  937. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  938. </tr>
  939. </table>
  940. </div><div class="memdoc">
  941. <dl class="section return"><dt>Returns</dt><dd>True if this is a normal file else false. </dd></dl>
  942. </div>
  943. </div>
  944. <a class="anchor" id="a7eefe7408f34b6326f0c6e78af7eb05f"></a>
  945. <div class="memitem">
  946. <div class="memproto">
  947. <table class="mlabels">
  948. <tr>
  949. <td class="mlabels-left">
  950. <table class="memname">
  951. <tr>
  952. <td class="memname">bool FatFile::isHidden </td>
  953. <td>(</td>
  954. <td class="paramname"></td><td>)</td>
  955. <td> const</td>
  956. </tr>
  957. </table>
  958. </td>
  959. <td class="mlabels-right">
  960. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  961. </tr>
  962. </table>
  963. </div><div class="memdoc">
  964. <dl class="section return"><dt>Returns</dt><dd>True if this is a hidden file else false. </dd></dl>
  965. </div>
  966. </div>
  967. <a class="anchor" id="a4c8a07b081f04aa25839c6f56c739bdc"></a>
  968. <div class="memitem">
  969. <div class="memproto">
  970. <table class="mlabels">
  971. <tr>
  972. <td class="mlabels-left">
  973. <table class="memname">
  974. <tr>
  975. <td class="memname">bool FatFile::isOpen </td>
  976. <td>(</td>
  977. <td class="paramname"></td><td>)</td>
  978. <td> const</td>
  979. </tr>
  980. </table>
  981. </td>
  982. <td class="mlabels-right">
  983. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  984. </tr>
  985. </table>
  986. </div><div class="memdoc">
  987. <dl class="section return"><dt>Returns</dt><dd>True if this is an open file/directory else false. </dd></dl>
  988. </div>
  989. </div>
  990. <a class="anchor" id="a6872d3acb1e70f81c9c2be2495977583"></a>
  991. <div class="memitem">
  992. <div class="memproto">
  993. <table class="mlabels">
  994. <tr>
  995. <td class="mlabels-left">
  996. <table class="memname">
  997. <tr>
  998. <td class="memname">bool FatFile::isReadOnly </td>
  999. <td>(</td>
  1000. <td class="paramname"></td><td>)</td>
  1001. <td> const</td>
  1002. </tr>
  1003. </table>
  1004. </td>
  1005. <td class="mlabels-right">
  1006. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1007. </tr>
  1008. </table>
  1009. </div><div class="memdoc">
  1010. <dl class="section return"><dt>Returns</dt><dd>True if file is read-only </dd></dl>
  1011. </div>
  1012. </div>
  1013. <a class="anchor" id="aa4a206803a4bf8243be20244c1aef4d2"></a>
  1014. <div class="memitem">
  1015. <div class="memproto">
  1016. <table class="mlabels">
  1017. <tr>
  1018. <td class="mlabels-left">
  1019. <table class="memname">
  1020. <tr>
  1021. <td class="memname">bool FatFile::isRoot </td>
  1022. <td>(</td>
  1023. <td class="paramname"></td><td>)</td>
  1024. <td> const</td>
  1025. </tr>
  1026. </table>
  1027. </td>
  1028. <td class="mlabels-right">
  1029. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1030. </tr>
  1031. </table>
  1032. </div><div class="memdoc">
  1033. <dl class="section return"><dt>Returns</dt><dd>True if this is the root directory. </dd></dl>
  1034. </div>
  1035. </div>
  1036. <a class="anchor" id="a8215bd4b21e11ec83fa88ef226ceb06f"></a>
  1037. <div class="memitem">
  1038. <div class="memproto">
  1039. <table class="mlabels">
  1040. <tr>
  1041. <td class="mlabels-left">
  1042. <table class="memname">
  1043. <tr>
  1044. <td class="memname">bool FatFile::isRootFixed </td>
  1045. <td>(</td>
  1046. <td class="paramname"></td><td>)</td>
  1047. <td> const</td>
  1048. </tr>
  1049. </table>
  1050. </td>
  1051. <td class="mlabels-right">
  1052. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1053. </tr>
  1054. </table>
  1055. </div><div class="memdoc">
  1056. <dl class="section return"><dt>Returns</dt><dd>True if this is the FAT12 of FAT16 root directory. </dd></dl>
  1057. </div>
  1058. </div>
  1059. <a class="anchor" id="a95b503b17442c2b364a2f53de1b2aeba"></a>
  1060. <div class="memitem">
  1061. <div class="memproto">
  1062. <table class="mlabels">
  1063. <tr>
  1064. <td class="mlabels-left">
  1065. <table class="memname">
  1066. <tr>
  1067. <td class="memname">bool FatFile::isSubDir </td>
  1068. <td>(</td>
  1069. <td class="paramname"></td><td>)</td>
  1070. <td> const</td>
  1071. </tr>
  1072. </table>
  1073. </td>
  1074. <td class="mlabels-right">
  1075. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1076. </tr>
  1077. </table>
  1078. </div><div class="memdoc">
  1079. <dl class="section return"><dt>Returns</dt><dd>True if this is a subdirectory else false. </dd></dl>
  1080. </div>
  1081. </div>
  1082. <a class="anchor" id="add932e13e5bf32ad467af6ec34824e3c"></a>
  1083. <div class="memitem">
  1084. <div class="memproto">
  1085. <table class="mlabels">
  1086. <tr>
  1087. <td class="mlabels-left">
  1088. <table class="memname">
  1089. <tr>
  1090. <td class="memname">bool FatFile::isSystem </td>
  1091. <td>(</td>
  1092. <td class="paramname"></td><td>)</td>
  1093. <td> const</td>
  1094. </tr>
  1095. </table>
  1096. </td>
  1097. <td class="mlabels-right">
  1098. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1099. </tr>
  1100. </table>
  1101. </div><div class="memdoc">
  1102. <dl class="section return"><dt>Returns</dt><dd>True if this is a system file else false. </dd></dl>
  1103. </div>
  1104. </div>
  1105. <a class="anchor" id="acabf31ff85e696fbf384c49428012fea"></a>
  1106. <div class="memitem">
  1107. <div class="memproto">
  1108. <table class="memname">
  1109. <tr>
  1110. <td class="memname">void FatFile::ls </td>
  1111. <td>(</td>
  1112. <td class="paramtype"><a class="el" href="_fat_file_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *&#160;</td>
  1113. <td class="paramname"><em>pr</em>, </td>
  1114. </tr>
  1115. <tr>
  1116. <td class="paramkey"></td>
  1117. <td></td>
  1118. <td class="paramtype">uint8_t&#160;</td>
  1119. <td class="paramname"><em>flags</em> = <code>0</code>, </td>
  1120. </tr>
  1121. <tr>
  1122. <td class="paramkey"></td>
  1123. <td></td>
  1124. <td class="paramtype">uint8_t&#160;</td>
  1125. <td class="paramname"><em>indent</em> = <code>0</code>&#160;</td>
  1126. </tr>
  1127. <tr>
  1128. <td></td>
  1129. <td>)</td>
  1130. <td></td><td></td>
  1131. </tr>
  1132. </table>
  1133. </div><div class="memdoc">
  1134. <p>List directory contents.</p>
  1135. <dl class="params"><dt>Parameters</dt><dd>
  1136. <table class="params">
  1137. <tr><td class="paramdir">[in]</td><td class="paramname">pr</td><td>Print stream for list.</td></tr>
  1138. <tr><td class="paramdir">[in]</td><td class="paramname">flags</td><td>The inclusive OR of</td></tr>
  1139. </table>
  1140. </dd>
  1141. </dl>
  1142. <p>LS_DATE - Print file modification date</p>
  1143. <p>LS_SIZE - Print file size.</p>
  1144. <p>LS_R - Recursive list of subdirectories.</p>
  1145. <dl class="params"><dt>Parameters</dt><dd>
  1146. <table class="params">
  1147. <tr><td class="paramdir">[in]</td><td class="paramname">indent</td><td>Amount of space before file name. Used for recursive list to indicate subdirectory level. </td></tr>
  1148. </table>
  1149. </dd>
  1150. </dl>
  1151. </div>
  1152. </div>
  1153. <a class="anchor" id="abab5b9f72cc796388dd4eed01d13d90d"></a>
  1154. <div class="memitem">
  1155. <div class="memproto">
  1156. <table class="memname">
  1157. <tr>
  1158. <td class="memname">bool FatFile::mkdir </td>
  1159. <td>(</td>
  1160. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  1161. <td class="paramname"><em>dir</em>, </td>
  1162. </tr>
  1163. <tr>
  1164. <td class="paramkey"></td>
  1165. <td></td>
  1166. <td class="paramtype">const char *&#160;</td>
  1167. <td class="paramname"><em>path</em>, </td>
  1168. </tr>
  1169. <tr>
  1170. <td class="paramkey"></td>
  1171. <td></td>
  1172. <td class="paramtype">bool&#160;</td>
  1173. <td class="paramname"><em>pFlag</em> = <code>true</code>&#160;</td>
  1174. </tr>
  1175. <tr>
  1176. <td></td>
  1177. <td>)</td>
  1178. <td></td><td></td>
  1179. </tr>
  1180. </table>
  1181. </div><div class="memdoc">
  1182. <p>Make a new directory.</p>
  1183. <dl class="params"><dt>Parameters</dt><dd>
  1184. <table class="params">
  1185. <tr><td class="paramdir">[in]</td><td class="paramname">dir</td><td>An open <a class="el" href="class_fat_file.html" title="Basic file class. ">FatFile</a> instance for the directory that will contain the new directory.</td></tr>
  1186. <tr><td class="paramdir">[in]</td><td class="paramname">path</td><td>A path with a valid 8.3 DOS name for the new directory.</td></tr>
  1187. <tr><td class="paramdir">[in]</td><td class="paramname">pFlag</td><td>Create missing parent directories if true.</td></tr>
  1188. </table>
  1189. </dd>
  1190. </dl>
  1191. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. Reasons for failure include this file is already open, <em>parent</em> is not a directory, <em>path</em> is invalid or already exists in <em>parent</em>. </dd></dl>
  1192. </div>
  1193. </div>
  1194. <a class="anchor" id="a5f64576d3d19177ab3cf3812b69abdfa"></a>
  1195. <div class="memitem">
  1196. <div class="memproto">
  1197. <table class="memname">
  1198. <tr>
  1199. <td class="memname">bool FatFile::open </td>
  1200. <td>(</td>
  1201. <td class="paramtype"><a class="el" href="class_fat_file_system.html">FatFileSystem</a> *&#160;</td>
  1202. <td class="paramname"><em>fs</em>, </td>
  1203. </tr>
  1204. <tr>
  1205. <td class="paramkey"></td>
  1206. <td></td>
  1207. <td class="paramtype">const char *&#160;</td>
  1208. <td class="paramname"><em>path</em>, </td>
  1209. </tr>
  1210. <tr>
  1211. <td class="paramkey"></td>
  1212. <td></td>
  1213. <td class="paramtype">uint8_t&#160;</td>
  1214. <td class="paramname"><em>oflag</em>&#160;</td>
  1215. </tr>
  1216. <tr>
  1217. <td></td>
  1218. <td>)</td>
  1219. <td></td><td></td>
  1220. </tr>
  1221. </table>
  1222. </div><div class="memdoc">
  1223. <p>Open a file in the volume working directory of a <a class="el" href="class_fat_file_system.html" title="Integration class for the FatLib library. ">FatFileSystem</a>.</p>
  1224. <dl class="params"><dt>Parameters</dt><dd>
  1225. <table class="params">
  1226. <tr><td class="paramdir">[in]</td><td class="paramname">fs</td><td><a class="el" href="class_file.html" title="Arduino SD.h style File API. ">File</a> System where the file is located.</td></tr>
  1227. <tr><td class="paramdir">[in]</td><td class="paramname">path</td><td>with a valid 8.3 DOS name for a file to be opened.</td></tr>
  1228. <tr><td class="paramdir">[in]</td><td class="paramname">oflag</td><td>bitwise-inclusive OR of open mode flags. See see <a class="el" href="class_fat_file.html#a211be757679b18708f6b6a36464e4f61">FatFile::open(FatFile*, const char*, uint8_t)</a>.</td></tr>
  1229. </table>
  1230. </dd>
  1231. </dl>
  1232. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. </dd></dl>
  1233. </div>
  1234. </div>
  1235. <a class="anchor" id="ad3fa9daaccb4e4179fb88a8ca037aa80"></a>
  1236. <div class="memitem">
  1237. <div class="memproto">
  1238. <table class="memname">
  1239. <tr>
  1240. <td class="memname">bool FatFile::open </td>
  1241. <td>(</td>
  1242. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  1243. <td class="paramname"><em>dirFile</em>, </td>
  1244. </tr>
  1245. <tr>
  1246. <td class="paramkey"></td>
  1247. <td></td>
  1248. <td class="paramtype">uint16_t&#160;</td>
  1249. <td class="paramname"><em>index</em>, </td>
  1250. </tr>
  1251. <tr>
  1252. <td class="paramkey"></td>
  1253. <td></td>
  1254. <td class="paramtype">uint8_t&#160;</td>
  1255. <td class="paramname"><em>oflag</em>&#160;</td>
  1256. </tr>
  1257. <tr>
  1258. <td></td>
  1259. <td>)</td>
  1260. <td></td><td></td>
  1261. </tr>
  1262. </table>
  1263. </div><div class="memdoc">
  1264. <p>Open a file by index.</p>
  1265. <dl class="params"><dt>Parameters</dt><dd>
  1266. <table class="params">
  1267. <tr><td class="paramdir">[in]</td><td class="paramname">dirFile</td><td>An open <a class="el" href="class_fat_file.html" title="Basic file class. ">FatFile</a> instance for the directory.</td></tr>
  1268. <tr><td class="paramdir">[in]</td><td class="paramname">index</td><td>The <em>index</em> of the directory entry for the file to be opened. The value for <em>index</em> is (directory file position)/32.</td></tr>
  1269. <tr><td class="paramdir">[in]</td><td class="paramname">oflag</td><td>bitwise-inclusive OR of open mode flags. See see <a class="el" href="class_fat_file.html#a211be757679b18708f6b6a36464e4f61">FatFile::open(FatFile*, const char*, uint8_t)</a>.</td></tr>
  1270. </table>
  1271. </dd>
  1272. </dl>
  1273. <p>See <a class="el" href="class_fat_file.html#a5f64576d3d19177ab3cf3812b69abdfa">open()</a> by path for definition of flags. </p><dl class="section return"><dt>Returns</dt><dd>true for success or false for failure. </dd></dl>
  1274. </div>
  1275. </div>
  1276. <a class="anchor" id="a211be757679b18708f6b6a36464e4f61"></a>
  1277. <div class="memitem">
  1278. <div class="memproto">
  1279. <table class="memname">
  1280. <tr>
  1281. <td class="memname">bool FatFile::open </td>
  1282. <td>(</td>
  1283. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  1284. <td class="paramname"><em>dirFile</em>, </td>
  1285. </tr>
  1286. <tr>
  1287. <td class="paramkey"></td>
  1288. <td></td>
  1289. <td class="paramtype">const char *&#160;</td>
  1290. <td class="paramname"><em>path</em>, </td>
  1291. </tr>
  1292. <tr>
  1293. <td class="paramkey"></td>
  1294. <td></td>
  1295. <td class="paramtype">uint8_t&#160;</td>
  1296. <td class="paramname"><em>oflag</em>&#160;</td>
  1297. </tr>
  1298. <tr>
  1299. <td></td>
  1300. <td>)</td>
  1301. <td></td><td></td>
  1302. </tr>
  1303. </table>
  1304. </div><div class="memdoc">
  1305. <p>Open a file or directory by name.</p>
  1306. <dl class="params"><dt>Parameters</dt><dd>
  1307. <table class="params">
  1308. <tr><td class="paramdir">[in]</td><td class="paramname">dirFile</td><td>An open <a class="el" href="class_fat_file.html" title="Basic file class. ">FatFile</a> instance for the directory containing the file to be opened.</td></tr>
  1309. <tr><td class="paramdir">[in]</td><td class="paramname">path</td><td>A path with a valid 8.3 DOS name for a file to be opened.</td></tr>
  1310. <tr><td class="paramdir">[in]</td><td class="paramname">oflag</td><td>Values for <em>oflag</em> are constructed by a bitwise-inclusive OR of flags from the following list</td></tr>
  1311. </table>
  1312. </dd>
  1313. </dl>
  1314. <p>O_READ - Open for reading.</p>
  1315. <p>O_RDONLY - Same as O_READ.</p>
  1316. <p>O_WRITE - Open for writing.</p>
  1317. <p>O_WRONLY - Same as O_WRITE.</p>
  1318. <p>O_RDWR - Open for reading and writing.</p>
  1319. <p>O_APPEND - If set, the file offset shall be set to the end of the file prior to each write.</p>
  1320. <p>O_AT_END - Set the initial position at the end of the file.</p>
  1321. <p>O_CREAT - If the file exists, this flag has no effect except as noted under O_EXCL below. Otherwise, the file shall be created</p>
  1322. <p>O_EXCL - If O_CREAT and O_EXCL are set, <a class="el" href="class_fat_file.html#a5f64576d3d19177ab3cf3812b69abdfa">open()</a> shall fail if the file exists.</p>
  1323. <p>O_SYNC - Call <a class="el" href="class_fat_file.html#a67f3dc4896c542d695e11aac927f585e">sync()</a> after each write. This flag should not be used with <a class="el" href="class_fat_file.html#a5524bd9f3b8f54ee163e391cba618186">write(uint8_t)</a> or any functions do character at a time writes since <a class="el" href="class_fat_file.html#a67f3dc4896c542d695e11aac927f585e">sync()</a> will be called after each byte.</p>
  1324. <p>O_TRUNC - If the file exists and is a regular file, and the file is successfully opened and is not read only, its length shall be truncated to 0.</p>
  1325. <p>WARNING: A given file must not be opened by more than one <a class="el" href="class_fat_file.html" title="Basic file class. ">FatFile</a> object or file corruption may occur.</p>
  1326. <dl class="section note"><dt>Note</dt><dd>Directory files must be opened read only. Write and truncation is not allowed for directory files.</dd></dl>
  1327. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. Reasons for failure include this file is already open, <em>dirFile</em> is not a directory, <em>path</em> is invalid, the file does not exist or can't be opened in the access mode specified by oflag. </dd></dl>
  1328. </div>
  1329. </div>
  1330. <a class="anchor" id="ab0e7075062c89f356441f80fc64d03e6"></a>
  1331. <div class="memitem">
  1332. <div class="memproto">
  1333. <table class="mlabels">
  1334. <tr>
  1335. <td class="mlabels-left">
  1336. <table class="memname">
  1337. <tr>
  1338. <td class="memname">bool FatFile::open </td>
  1339. <td>(</td>
  1340. <td class="paramtype">const char *&#160;</td>
  1341. <td class="paramname"><em>path</em>, </td>
  1342. </tr>
  1343. <tr>
  1344. <td class="paramkey"></td>
  1345. <td></td>
  1346. <td class="paramtype">uint8_t&#160;</td>
  1347. <td class="paramname"><em>oflag</em> = <code>O_READ</code>&#160;</td>
  1348. </tr>
  1349. <tr>
  1350. <td></td>
  1351. <td>)</td>
  1352. <td></td><td></td>
  1353. </tr>
  1354. </table>
  1355. </td>
  1356. <td class="mlabels-right">
  1357. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1358. </tr>
  1359. </table>
  1360. </div><div class="memdoc">
  1361. <p>Open a file in the current working directory.</p>
  1362. <dl class="params"><dt>Parameters</dt><dd>
  1363. <table class="params">
  1364. <tr><td class="paramdir">[in]</td><td class="paramname">path</td><td>A path with a valid 8.3 DOS name for a file to be opened.</td></tr>
  1365. <tr><td class="paramdir">[in]</td><td class="paramname">oflag</td><td>bitwise-inclusive OR of open mode flags. See see <a class="el" href="class_fat_file.html#a211be757679b18708f6b6a36464e4f61">FatFile::open(FatFile*, const char*, uint8_t)</a>.</td></tr>
  1366. </table>
  1367. </dd>
  1368. </dl>
  1369. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. </dd></dl>
  1370. </div>
  1371. </div>
  1372. <a class="anchor" id="a8034c4649eb0d26715b1a8a69e73d9d0"></a>
  1373. <div class="memitem">
  1374. <div class="memproto">
  1375. <table class="memname">
  1376. <tr>
  1377. <td class="memname">bool FatFile::openNext </td>
  1378. <td>(</td>
  1379. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  1380. <td class="paramname"><em>dirFile</em>, </td>
  1381. </tr>
  1382. <tr>
  1383. <td class="paramkey"></td>
  1384. <td></td>
  1385. <td class="paramtype">uint8_t&#160;</td>
  1386. <td class="paramname"><em>oflag</em> = <code>O_READ</code>&#160;</td>
  1387. </tr>
  1388. <tr>
  1389. <td></td>
  1390. <td>)</td>
  1391. <td></td><td></td>
  1392. </tr>
  1393. </table>
  1394. </div><div class="memdoc">
  1395. <p>Open the next file or subdirectory in a directory.</p>
  1396. <dl class="params"><dt>Parameters</dt><dd>
  1397. <table class="params">
  1398. <tr><td class="paramdir">[in]</td><td class="paramname">dirFile</td><td>An open <a class="el" href="class_fat_file.html" title="Basic file class. ">FatFile</a> instance for the directory containing the file to be opened.</td></tr>
  1399. <tr><td class="paramdir">[in]</td><td class="paramname">oflag</td><td>bitwise-inclusive OR of open mode flags. See see <a class="el" href="class_fat_file.html#a211be757679b18708f6b6a36464e4f61">FatFile::open(FatFile*, const char*, uint8_t)</a>.</td></tr>
  1400. </table>
  1401. </dd>
  1402. </dl>
  1403. <dl class="section return"><dt>Returns</dt><dd>true for success or false for failure. </dd></dl>
  1404. </div>
  1405. </div>
  1406. <a class="anchor" id="a76b34d6ecd7b343fdaa0bb1c3ec229e3"></a>
  1407. <div class="memitem">
  1408. <div class="memproto">
  1409. <table class="memname">
  1410. <tr>
  1411. <td class="memname">int FatFile::openNextLFN </td>
  1412. <td>(</td>
  1413. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  1414. <td class="paramname"><em>dirFile</em>, </td>
  1415. </tr>
  1416. <tr>
  1417. <td class="paramkey"></td>
  1418. <td></td>
  1419. <td class="paramtype">char *&#160;</td>
  1420. <td class="paramname"><em>name</em>, </td>
  1421. </tr>
  1422. <tr>
  1423. <td class="paramkey"></td>
  1424. <td></td>
  1425. <td class="paramtype">size_t&#160;</td>
  1426. <td class="paramname"><em>size</em>, </td>
  1427. </tr>
  1428. <tr>
  1429. <td class="paramkey"></td>
  1430. <td></td>
  1431. <td class="paramtype">uint8_t&#160;</td>
  1432. <td class="paramname"><em>oflag</em>&#160;</td>
  1433. </tr>
  1434. <tr>
  1435. <td></td>
  1436. <td>)</td>
  1437. <td></td><td></td>
  1438. </tr>
  1439. </table>
  1440. </div><div class="memdoc">
  1441. <p>Open the next file or subdirectory in a directory and return the file name. The Long File Name, LFN, is returned if present otherwise the 8.3 short name will be returned.</p>
  1442. <dl class="params"><dt>Parameters</dt><dd>
  1443. <table class="params">
  1444. <tr><td class="paramdir">[in]</td><td class="paramname">dirFile</td><td>An open <a class="el" href="class_fat_file.html" title="Basic file class. ">FatFile</a> instance for the directory containing the file to be opened.</td></tr>
  1445. <tr><td class="paramdir">[out]</td><td class="paramname">name</td><td>Location that will receive the name.</td></tr>
  1446. <tr><td class="paramdir">[in]</td><td class="paramname">size</td><td>The size of the name array.</td></tr>
  1447. <tr><td class="paramdir">[in]</td><td class="paramname">oflag</td><td>bitwise-inclusive OR of open mode flags. See see <a class="el" href="class_fat_file.html#a211be757679b18708f6b6a36464e4f61">FatFile::open(FatFile*, const char*, uint8_t)</a>.</td></tr>
  1448. </table>
  1449. </dd>
  1450. </dl>
  1451. <dl class="section return"><dt>Returns</dt><dd>For success, the length of the returned name. The name will be truncated to size - 1 bytes followed by a zero byte. For EOF, zero will be returned. If an error occurs, -1 is returned. </dd></dl>
  1452. </div>
  1453. </div>
  1454. <a class="anchor" id="a7e0c0548fed3a69e7284b91b694439d4"></a>
  1455. <div class="memitem">
  1456. <div class="memproto">
  1457. <table class="memname">
  1458. <tr>
  1459. <td class="memname">bool FatFile::openRoot </td>
  1460. <td>(</td>
  1461. <td class="paramtype"><a class="el" href="class_fat_volume.html">FatVolume</a> *&#160;</td>
  1462. <td class="paramname"><em>vol</em></td><td>)</td>
  1463. <td></td>
  1464. </tr>
  1465. </table>
  1466. </div><div class="memdoc">
  1467. <p>Open a volume's root directory.</p>
  1468. <dl class="params"><dt>Parameters</dt><dd>
  1469. <table class="params">
  1470. <tr><td class="paramdir">[in]</td><td class="paramname">vol</td><td>The FAT volume containing the root directory to be opened.</td></tr>
  1471. </table>
  1472. </dd>
  1473. </dl>
  1474. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. Reasons for failure include the file is already open, the FAT volume has not been initialized or it a FAT12 volume. </dd></dl>
  1475. </div>
  1476. </div>
  1477. <a class="anchor" id="ac05b7136b887539426856c623869aa3a"></a>
  1478. <div class="memitem">
  1479. <div class="memproto">
  1480. <table class="memname">
  1481. <tr>
  1482. <td class="memname">int FatFile::peek </td>
  1483. <td>(</td>
  1484. <td class="paramname"></td><td>)</td>
  1485. <td></td>
  1486. </tr>
  1487. </table>
  1488. </div><div class="memdoc">
  1489. <p>Return the next available byte without consuming it.</p>
  1490. <dl class="section return"><dt>Returns</dt><dd>The byte if no error and not at eof else -1; </dd></dl>
  1491. </div>
  1492. </div>
  1493. <a class="anchor" id="a558530f20314a8d8ee3d1a488fc7f46e"></a>
  1494. <div class="memitem">
  1495. <div class="memproto">
  1496. <table class="memname">
  1497. <tr>
  1498. <td class="memname">bool FatFile::printCreateDateTime </td>
  1499. <td>(</td>
  1500. <td class="paramtype"><a class="el" href="_fat_file_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *&#160;</td>
  1501. <td class="paramname"><em>pr</em></td><td>)</td>
  1502. <td></td>
  1503. </tr>
  1504. </table>
  1505. </div><div class="memdoc">
  1506. <p>Print a file's creation date and time</p>
  1507. <dl class="params"><dt>Parameters</dt><dd>
  1508. <table class="params">
  1509. <tr><td class="paramdir">[in]</td><td class="paramname">pr</td><td>Print stream for output.</td></tr>
  1510. </table>
  1511. </dd>
  1512. </dl>
  1513. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. </dd></dl>
  1514. </div>
  1515. </div>
  1516. <a class="anchor" id="ada5364f66204b1a64afbf9d2e6cd2b0b"></a>
  1517. <div class="memitem">
  1518. <div class="memproto">
  1519. <table class="mlabels">
  1520. <tr>
  1521. <td class="mlabels-left">
  1522. <table class="memname">
  1523. <tr>
  1524. <td class="memname">void FatFile::printFatDate </td>
  1525. <td>(</td>
  1526. <td class="paramtype"><a class="el" href="_fat_file_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *&#160;</td>
  1527. <td class="paramname"><em>pr</em>, </td>
  1528. </tr>
  1529. <tr>
  1530. <td class="paramkey"></td>
  1531. <td></td>
  1532. <td class="paramtype">uint16_t&#160;</td>
  1533. <td class="paramname"><em>fatDate</em>&#160;</td>
  1534. </tr>
  1535. <tr>
  1536. <td></td>
  1537. <td>)</td>
  1538. <td></td><td></td>
  1539. </tr>
  1540. </table>
  1541. </td>
  1542. <td class="mlabels-right">
  1543. <span class="mlabels"><span class="mlabel">static</span></span> </td>
  1544. </tr>
  1545. </table>
  1546. </div><div class="memdoc">
  1547. <p>Print a directory date field.</p>
  1548. <p>Format is yyyy-mm-dd.</p>
  1549. <dl class="params"><dt>Parameters</dt><dd>
  1550. <table class="params">
  1551. <tr><td class="paramdir">[in]</td><td class="paramname">pr</td><td>Print stream for output. </td></tr>
  1552. <tr><td class="paramdir">[in]</td><td class="paramname">fatDate</td><td>The date field from a directory entry. </td></tr>
  1553. </table>
  1554. </dd>
  1555. </dl>
  1556. </div>
  1557. </div>
  1558. <a class="anchor" id="a4e7e56ba52ca17c602af1b85684b09a9"></a>
  1559. <div class="memitem">
  1560. <div class="memproto">
  1561. <table class="mlabels">
  1562. <tr>
  1563. <td class="mlabels-left">
  1564. <table class="memname">
  1565. <tr>
  1566. <td class="memname">void FatFile::printFatTime </td>
  1567. <td>(</td>
  1568. <td class="paramtype"><a class="el" href="_fat_file_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *&#160;</td>
  1569. <td class="paramname"><em>pr</em>, </td>
  1570. </tr>
  1571. <tr>
  1572. <td class="paramkey"></td>
  1573. <td></td>
  1574. <td class="paramtype">uint16_t&#160;</td>
  1575. <td class="paramname"><em>fatTime</em>&#160;</td>
  1576. </tr>
  1577. <tr>
  1578. <td></td>
  1579. <td>)</td>
  1580. <td></td><td></td>
  1581. </tr>
  1582. </table>
  1583. </td>
  1584. <td class="mlabels-right">
  1585. <span class="mlabels"><span class="mlabel">static</span></span> </td>
  1586. </tr>
  1587. </table>
  1588. </div><div class="memdoc">
  1589. <p>Print a directory time field.</p>
  1590. <p>Format is hh:mm:ss.</p>
  1591. <dl class="params"><dt>Parameters</dt><dd>
  1592. <table class="params">
  1593. <tr><td class="paramdir">[in]</td><td class="paramname">pr</td><td>Print stream for output. </td></tr>
  1594. <tr><td class="paramdir">[in]</td><td class="paramname">fatTime</td><td>The time field from a directory entry. </td></tr>
  1595. </table>
  1596. </dd>
  1597. </dl>
  1598. </div>
  1599. </div>
  1600. <a class="anchor" id="a7478cad0f9e5079311b9e1fa558016ff"></a>
  1601. <div class="memitem">
  1602. <div class="memproto">
  1603. <table class="memname">
  1604. <tr>
  1605. <td class="memname">int FatFile::printField </td>
  1606. <td>(</td>
  1607. <td class="paramtype">float&#160;</td>
  1608. <td class="paramname"><em>value</em>, </td>
  1609. </tr>
  1610. <tr>
  1611. <td class="paramkey"></td>
  1612. <td></td>
  1613. <td class="paramtype">char&#160;</td>
  1614. <td class="paramname"><em>term</em>, </td>
  1615. </tr>
  1616. <tr>
  1617. <td class="paramkey"></td>
  1618. <td></td>
  1619. <td class="paramtype">uint8_t&#160;</td>
  1620. <td class="paramname"><em>prec</em> = <code>2</code>&#160;</td>
  1621. </tr>
  1622. <tr>
  1623. <td></td>
  1624. <td>)</td>
  1625. <td></td><td></td>
  1626. </tr>
  1627. </table>
  1628. </div><div class="memdoc">
  1629. <p>Print a number followed by a field terminator. </p><dl class="params"><dt>Parameters</dt><dd>
  1630. <table class="params">
  1631. <tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>The number to be printed. </td></tr>
  1632. <tr><td class="paramdir">[in]</td><td class="paramname">term</td><td>The field terminator. Use '\n' for CR LF. </td></tr>
  1633. <tr><td class="paramdir">[in]</td><td class="paramname">prec</td><td>Number of digits after decimal point. </td></tr>
  1634. </table>
  1635. </dd>
  1636. </dl>
  1637. <dl class="section return"><dt>Returns</dt><dd>The number of bytes written or -1 if an error occurs. </dd></dl>
  1638. </div>
  1639. </div>
  1640. <a class="anchor" id="abd3e1747511216462b3ef98167156cbb"></a>
  1641. <div class="memitem">
  1642. <div class="memproto">
  1643. <table class="memname">
  1644. <tr>
  1645. <td class="memname">int FatFile::printField </td>
  1646. <td>(</td>
  1647. <td class="paramtype">int16_t&#160;</td>
  1648. <td class="paramname"><em>value</em>, </td>
  1649. </tr>
  1650. <tr>
  1651. <td class="paramkey"></td>
  1652. <td></td>
  1653. <td class="paramtype">char&#160;</td>
  1654. <td class="paramname"><em>term</em>&#160;</td>
  1655. </tr>
  1656. <tr>
  1657. <td></td>
  1658. <td>)</td>
  1659. <td></td><td></td>
  1660. </tr>
  1661. </table>
  1662. </div><div class="memdoc">
  1663. <p>Print a number followed by a field terminator. </p><dl class="params"><dt>Parameters</dt><dd>
  1664. <table class="params">
  1665. <tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>The number to be printed. </td></tr>
  1666. <tr><td class="paramdir">[in]</td><td class="paramname">term</td><td>The field terminator. Use '\n' for CR LF. </td></tr>
  1667. </table>
  1668. </dd>
  1669. </dl>
  1670. <dl class="section return"><dt>Returns</dt><dd>The number of bytes written or -1 if an error occurs. </dd></dl>
  1671. </div>
  1672. </div>
  1673. <a class="anchor" id="a9972c2419c293ef9c382bff666b9ae4d"></a>
  1674. <div class="memitem">
  1675. <div class="memproto">
  1676. <table class="memname">
  1677. <tr>
  1678. <td class="memname">int FatFile::printField </td>
  1679. <td>(</td>
  1680. <td class="paramtype">uint16_t&#160;</td>
  1681. <td class="paramname"><em>value</em>, </td>
  1682. </tr>
  1683. <tr>
  1684. <td class="paramkey"></td>
  1685. <td></td>
  1686. <td class="paramtype">char&#160;</td>
  1687. <td class="paramname"><em>term</em>&#160;</td>
  1688. </tr>
  1689. <tr>
  1690. <td></td>
  1691. <td>)</td>
  1692. <td></td><td></td>
  1693. </tr>
  1694. </table>
  1695. </div><div class="memdoc">
  1696. <p>Print a number followed by a field terminator. </p><dl class="params"><dt>Parameters</dt><dd>
  1697. <table class="params">
  1698. <tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>The number to be printed. </td></tr>
  1699. <tr><td class="paramdir">[in]</td><td class="paramname">term</td><td>The field terminator. Use '\n' for CR LF. </td></tr>
  1700. </table>
  1701. </dd>
  1702. </dl>
  1703. <dl class="section return"><dt>Returns</dt><dd>The number of bytes written or -1 if an error occurs. </dd></dl>
  1704. </div>
  1705. </div>
  1706. <a class="anchor" id="a41b3b32dd8482429b74c7af3432d6cf8"></a>
  1707. <div class="memitem">
  1708. <div class="memproto">
  1709. <table class="memname">
  1710. <tr>
  1711. <td class="memname">int FatFile::printField </td>
  1712. <td>(</td>
  1713. <td class="paramtype">int32_t&#160;</td>
  1714. <td class="paramname"><em>value</em>, </td>
  1715. </tr>
  1716. <tr>
  1717. <td class="paramkey"></td>
  1718. <td></td>
  1719. <td class="paramtype">char&#160;</td>
  1720. <td class="paramname"><em>term</em>&#160;</td>
  1721. </tr>
  1722. <tr>
  1723. <td></td>
  1724. <td>)</td>
  1725. <td></td><td></td>
  1726. </tr>
  1727. </table>
  1728. </div><div class="memdoc">
  1729. <p>Print a number followed by a field terminator. </p><dl class="params"><dt>Parameters</dt><dd>
  1730. <table class="params">
  1731. <tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>The number to be printed. </td></tr>
  1732. <tr><td class="paramdir">[in]</td><td class="paramname">term</td><td>The field terminator. Use '\n' for CR LF. </td></tr>
  1733. </table>
  1734. </dd>
  1735. </dl>
  1736. <dl class="section return"><dt>Returns</dt><dd>The number of bytes written or -1 if an error occurs. </dd></dl>
  1737. </div>
  1738. </div>
  1739. <a class="anchor" id="a097240f08baadeb1c64b63eab9afb088"></a>
  1740. <div class="memitem">
  1741. <div class="memproto">
  1742. <table class="memname">
  1743. <tr>
  1744. <td class="memname">int FatFile::printField </td>
  1745. <td>(</td>
  1746. <td class="paramtype">uint32_t&#160;</td>
  1747. <td class="paramname"><em>value</em>, </td>
  1748. </tr>
  1749. <tr>
  1750. <td class="paramkey"></td>
  1751. <td></td>
  1752. <td class="paramtype">char&#160;</td>
  1753. <td class="paramname"><em>term</em>&#160;</td>
  1754. </tr>
  1755. <tr>
  1756. <td></td>
  1757. <td>)</td>
  1758. <td></td><td></td>
  1759. </tr>
  1760. </table>
  1761. </div><div class="memdoc">
  1762. <p>Print a number followed by a field terminator. </p><dl class="params"><dt>Parameters</dt><dd>
  1763. <table class="params">
  1764. <tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>The number to be printed. </td></tr>
  1765. <tr><td class="paramdir">[in]</td><td class="paramname">term</td><td>The field terminator. Use '\n' for CR LF. </td></tr>
  1766. </table>
  1767. </dd>
  1768. </dl>
  1769. <dl class="section return"><dt>Returns</dt><dd>The number of bytes written or -1 if an error occurs. </dd></dl>
  1770. </div>
  1771. </div>
  1772. <a class="anchor" id="a12a5d2de2737c201aa39ca1bd2ab9c47"></a>
  1773. <div class="memitem">
  1774. <div class="memproto">
  1775. <table class="memname">
  1776. <tr>
  1777. <td class="memname">size_t FatFile::printFileSize </td>
  1778. <td>(</td>
  1779. <td class="paramtype"><a class="el" href="_fat_file_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *&#160;</td>
  1780. <td class="paramname"><em>pr</em></td><td>)</td>
  1781. <td></td>
  1782. </tr>
  1783. </table>
  1784. </div><div class="memdoc">
  1785. <p>Print a file's size.</p>
  1786. <dl class="params"><dt>Parameters</dt><dd>
  1787. <table class="params">
  1788. <tr><td class="paramdir">[in]</td><td class="paramname">pr</td><td>Print stream for output.</td></tr>
  1789. </table>
  1790. </dd>
  1791. </dl>
  1792. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. </dd></dl>
  1793. </div>
  1794. </div>
  1795. <a class="anchor" id="a05cee5df46a370bf916d3ba597c82e39"></a>
  1796. <div class="memitem">
  1797. <div class="memproto">
  1798. <table class="memname">
  1799. <tr>
  1800. <td class="memname">bool FatFile::printModifyDateTime </td>
  1801. <td>(</td>
  1802. <td class="paramtype"><a class="el" href="_fat_file_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *&#160;</td>
  1803. <td class="paramname"><em>pr</em></td><td>)</td>
  1804. <td></td>
  1805. </tr>
  1806. </table>
  1807. </div><div class="memdoc">
  1808. <p>Print a file's modify date and time</p>
  1809. <dl class="params"><dt>Parameters</dt><dd>
  1810. <table class="params">
  1811. <tr><td class="paramdir">[in]</td><td class="paramname">pr</td><td>Print stream for output.</td></tr>
  1812. </table>
  1813. </dd>
  1814. </dl>
  1815. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. </dd></dl>
  1816. </div>
  1817. </div>
  1818. <a class="anchor" id="afe18a787fb8640e2d2483370c770f82f"></a>
  1819. <div class="memitem">
  1820. <div class="memproto">
  1821. <table class="memname">
  1822. <tr>
  1823. <td class="memname">size_t FatFile::printName </td>
  1824. <td>(</td>
  1825. <td class="paramtype"><a class="el" href="_fat_file_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *&#160;</td>
  1826. <td class="paramname"><em>pr</em></td><td>)</td>
  1827. <td></td>
  1828. </tr>
  1829. </table>
  1830. </div><div class="memdoc">
  1831. <p>Print a file's name</p>
  1832. <dl class="params"><dt>Parameters</dt><dd>
  1833. <table class="params">
  1834. <tr><td class="paramdir">[in]</td><td class="paramname">pr</td><td>Print stream for output.</td></tr>
  1835. </table>
  1836. </dd>
  1837. </dl>
  1838. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. </dd></dl>
  1839. </div>
  1840. </div>
  1841. <a class="anchor" id="a60ae55ff6fe158c2340071d702a363c5"></a>
  1842. <div class="memitem">
  1843. <div class="memproto">
  1844. <table class="mlabels">
  1845. <tr>
  1846. <td class="mlabels-left">
  1847. <table class="memname">
  1848. <tr>
  1849. <td class="memname">int FatFile::read </td>
  1850. <td>(</td>
  1851. <td class="paramname"></td><td>)</td>
  1852. <td></td>
  1853. </tr>
  1854. </table>
  1855. </td>
  1856. <td class="mlabels-right">
  1857. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1858. </tr>
  1859. </table>
  1860. </div><div class="memdoc">
  1861. <p>Read the next byte from a file.</p>
  1862. <dl class="section return"><dt>Returns</dt><dd>For success read returns the next byte in the file as an int. If an error occurs or end of file is reached -1 is returned. </dd></dl>
  1863. </div>
  1864. </div>
  1865. <a class="anchor" id="a200e6e0553d5b709520c9dfac9ef77dd"></a>
  1866. <div class="memitem">
  1867. <div class="memproto">
  1868. <table class="memname">
  1869. <tr>
  1870. <td class="memname">int FatFile::read </td>
  1871. <td>(</td>
  1872. <td class="paramtype">void *&#160;</td>
  1873. <td class="paramname"><em>buf</em>, </td>
  1874. </tr>
  1875. <tr>
  1876. <td class="paramkey"></td>
  1877. <td></td>
  1878. <td class="paramtype">size_t&#160;</td>
  1879. <td class="paramname"><em>nbyte</em>&#160;</td>
  1880. </tr>
  1881. <tr>
  1882. <td></td>
  1883. <td>)</td>
  1884. <td></td><td></td>
  1885. </tr>
  1886. </table>
  1887. </div><div class="memdoc">
  1888. <p>Read data from a file starting at the current position.</p>
  1889. <dl class="params"><dt>Parameters</dt><dd>
  1890. <table class="params">
  1891. <tr><td class="paramdir">[out]</td><td class="paramname">buf</td><td>Pointer to the location that will receive the data.</td></tr>
  1892. <tr><td class="paramdir">[in]</td><td class="paramname">nbyte</td><td>Maximum number of bytes to read.</td></tr>
  1893. </table>
  1894. </dd>
  1895. </dl>
  1896. <dl class="section return"><dt>Returns</dt><dd>For success <a class="el" href="class_fat_file.html#a60ae55ff6fe158c2340071d702a363c5">read()</a> returns the number of bytes read. A value less than <em>nbyte</em>, including zero, will be returned if end of file is reached. If an error occurs, <a class="el" href="class_fat_file.html#a60ae55ff6fe158c2340071d702a363c5">read()</a> returns -1. Possible errors include <a class="el" href="class_fat_file.html#a60ae55ff6fe158c2340071d702a363c5">read()</a> called before a file has been opened, corrupt file system or an I/O error occurred. </dd></dl>
  1897. </div>
  1898. </div>
  1899. <a class="anchor" id="a1325afe074c3efecff666678cd9f116a"></a>
  1900. <div class="memitem">
  1901. <div class="memproto">
  1902. <table class="memname">
  1903. <tr>
  1904. <td class="memname">int8_t FatFile::readDir </td>
  1905. <td>(</td>
  1906. <td class="paramtype"><a class="el" href="_fat_structs_8h.html#a803db59d4e16a0c54a647afc6a7954e3">dir_t</a> *&#160;</td>
  1907. <td class="paramname"><em>dir</em></td><td>)</td>
  1908. <td></td>
  1909. </tr>
  1910. </table>
  1911. </div><div class="memdoc">
  1912. <p>Read the next directory entry from a directory file.</p>
  1913. <dl class="params"><dt>Parameters</dt><dd>
  1914. <table class="params">
  1915. <tr><td class="paramdir">[out]</td><td class="paramname">dir</td><td>The dir_t struct that will receive the data.</td></tr>
  1916. </table>
  1917. </dd>
  1918. </dl>
  1919. <dl class="section return"><dt>Returns</dt><dd>For success <a class="el" href="class_fat_file.html#a1325afe074c3efecff666678cd9f116a">readDir()</a> returns the number of bytes read. A value of zero will be returned if end of file is reached. If an error occurs, <a class="el" href="class_fat_file.html#a1325afe074c3efecff666678cd9f116a">readDir()</a> returns -1. Possible errors include <a class="el" href="class_fat_file.html#a1325afe074c3efecff666678cd9f116a">readDir()</a> called before a directory has been opened, this is not a directory file or an I/O error occurred. </dd></dl>
  1920. </div>
  1921. </div>
  1922. <a class="anchor" id="ac837a537fbcca14c7aa390c5fc9f4e7c"></a>
  1923. <div class="memitem">
  1924. <div class="memproto">
  1925. <table class="memname">
  1926. <tr>
  1927. <td class="memname">bool FatFile::remove </td>
  1928. <td>(</td>
  1929. <td class="paramname"></td><td>)</td>
  1930. <td></td>
  1931. </tr>
  1932. </table>
  1933. </div><div class="memdoc">
  1934. <p>Remove a file.</p>
  1935. <p>The directory entry and all data for the file are deleted.</p>
  1936. <dl class="section note"><dt>Note</dt><dd>This function should not be used to delete the 8.3 version of a file that has a long name. For example if a file has the long name "New Text Document.txt" you should not delete the 8.3 name "NEWTEX~1.TXT".</dd></dl>
  1937. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. Reasons for failure include the file read-only, is a directory, or an I/O error occurred. </dd></dl>
  1938. </div>
  1939. </div>
  1940. <a class="anchor" id="afe820bbb056863e91ec482961c8dc695"></a>
  1941. <div class="memitem">
  1942. <div class="memproto">
  1943. <table class="mlabels">
  1944. <tr>
  1945. <td class="mlabels-left">
  1946. <table class="memname">
  1947. <tr>
  1948. <td class="memname">bool FatFile::remove </td>
  1949. <td>(</td>
  1950. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  1951. <td class="paramname"><em>dirFile</em>, </td>
  1952. </tr>
  1953. <tr>
  1954. <td class="paramkey"></td>
  1955. <td></td>
  1956. <td class="paramtype">const char *&#160;</td>
  1957. <td class="paramname"><em>path</em>&#160;</td>
  1958. </tr>
  1959. <tr>
  1960. <td></td>
  1961. <td>)</td>
  1962. <td></td><td></td>
  1963. </tr>
  1964. </table>
  1965. </td>
  1966. <td class="mlabels-right">
  1967. <span class="mlabels"><span class="mlabel">static</span></span> </td>
  1968. </tr>
  1969. </table>
  1970. </div><div class="memdoc">
  1971. <p>Remove a file.</p>
  1972. <p>The directory entry and all data for the file are deleted.</p>
  1973. <dl class="params"><dt>Parameters</dt><dd>
  1974. <table class="params">
  1975. <tr><td class="paramdir">[in]</td><td class="paramname">dirFile</td><td>The directory that contains the file. </td></tr>
  1976. <tr><td class="paramdir">[in]</td><td class="paramname">path</td><td>Path for the file to be removed.</td></tr>
  1977. </table>
  1978. </dd>
  1979. </dl>
  1980. <dl class="section note"><dt>Note</dt><dd>This function should not be used to delete the 8.3 version of a file that has a long name. For example if a file has the long name "New Text Document.txt" you should not delete the 8.3 name "NEWTEX~1.TXT".</dd></dl>
  1981. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. Reasons for failure include the file is a directory, is read only, <em>dirFile</em> is not a directory, <em>path</em> is not found or an I/O error occurred. </dd></dl>
  1982. </div>
  1983. </div>
  1984. <a class="anchor" id="a4b42f2454ff462555c07ea094a92a1e0"></a>
  1985. <div class="memitem">
  1986. <div class="memproto">
  1987. <table class="memname">
  1988. <tr>
  1989. <td class="memname">bool FatFile::rename </td>
  1990. <td>(</td>
  1991. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  1992. <td class="paramname"><em>dirFile</em>, </td>
  1993. </tr>
  1994. <tr>
  1995. <td class="paramkey"></td>
  1996. <td></td>
  1997. <td class="paramtype">const char *&#160;</td>
  1998. <td class="paramname"><em>newPath</em>&#160;</td>
  1999. </tr>
  2000. <tr>
  2001. <td></td>
  2002. <td>)</td>
  2003. <td></td><td></td>
  2004. </tr>
  2005. </table>
  2006. </div><div class="memdoc">
  2007. <p>Rename a file or subdirectory.</p>
  2008. <dl class="params"><dt>Parameters</dt><dd>
  2009. <table class="params">
  2010. <tr><td class="paramdir">[in]</td><td class="paramname">dirFile</td><td>Directory for the new path. </td></tr>
  2011. <tr><td class="paramdir">[in]</td><td class="paramname">newPath</td><td>New path name for the file/directory.</td></tr>
  2012. </table>
  2013. </dd>
  2014. </dl>
  2015. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. Reasons for failure include <em>dirFile</em> is not open or is not a directory file, newPath is invalid or already exists, or an I/O error occurs. </dd></dl>
  2016. </div>
  2017. </div>
  2018. <a class="anchor" id="a5aac6e0b3cb08fc8b8668e916a8b0ca5"></a>
  2019. <div class="memitem">
  2020. <div class="memproto">
  2021. <table class="mlabels">
  2022. <tr>
  2023. <td class="mlabels-left">
  2024. <table class="memname">
  2025. <tr>
  2026. <td class="memname">void FatFile::rewind </td>
  2027. <td>(</td>
  2028. <td class="paramname"></td><td>)</td>
  2029. <td></td>
  2030. </tr>
  2031. </table>
  2032. </td>
  2033. <td class="mlabels-right">
  2034. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  2035. </tr>
  2036. </table>
  2037. </div><div class="memdoc">
  2038. <p>Set the file's current position to zero. </p>
  2039. </div>
  2040. </div>
  2041. <a class="anchor" id="a9515bac181d33e7f0125e88fa2ccd283"></a>
  2042. <div class="memitem">
  2043. <div class="memproto">
  2044. <table class="memname">
  2045. <tr>
  2046. <td class="memname">bool FatFile::rmdir </td>
  2047. <td>(</td>
  2048. <td class="paramname"></td><td>)</td>
  2049. <td></td>
  2050. </tr>
  2051. </table>
  2052. </div><div class="memdoc">
  2053. <p>Remove a directory file.</p>
  2054. <p>The directory file will be removed only if it is empty and is not the root directory. <a class="el" href="class_fat_file.html#a9515bac181d33e7f0125e88fa2ccd283">rmdir()</a> follows DOS and Windows and ignores the read-only attribute for the directory.</p>
  2055. <dl class="section note"><dt>Note</dt><dd>This function should not be used to delete the 8.3 version of a directory that has a long name. For example if a directory has the long name "New folder" you should not delete the 8.3 name "NEWFOL~1".</dd></dl>
  2056. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. Reasons for failure include the file is not a directory, is the root directory, is not empty, or an I/O error occurred. </dd></dl>
  2057. </div>
  2058. </div>
  2059. <a class="anchor" id="ac780a80526f86d3def701ecdc99d8bfe"></a>
  2060. <div class="memitem">
  2061. <div class="memproto">
  2062. <table class="memname">
  2063. <tr>
  2064. <td class="memname">bool FatFile::rmRfStar </td>
  2065. <td>(</td>
  2066. <td class="paramname"></td><td>)</td>
  2067. <td></td>
  2068. </tr>
  2069. </table>
  2070. </div><div class="memdoc">
  2071. <p>Recursively delete a directory and all contained files.</p>
  2072. <p>This is like the Unix/Linux 'rm -rf *' if called with the root directory hence the name.</p>
  2073. <p>Warning - This will remove all contents of the directory including subdirectories. The directory will then be removed if it is not root. The read-only attribute for files will be ignored.</p>
  2074. <dl class="section note"><dt>Note</dt><dd>This function should not be used to delete the 8.3 version of a directory that has a long name. See <a class="el" href="class_fat_file.html#ac837a537fbcca14c7aa390c5fc9f4e7c">remove()</a> and <a class="el" href="class_fat_file.html#a9515bac181d33e7f0125e88fa2ccd283">rmdir()</a>.</dd></dl>
  2075. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. </dd></dl>
  2076. </div>
  2077. </div>
  2078. <a class="anchor" id="a5812037ea30777cc350698ad26f2c73f"></a>
  2079. <div class="memitem">
  2080. <div class="memproto">
  2081. <table class="mlabels">
  2082. <tr>
  2083. <td class="mlabels-left">
  2084. <table class="memname">
  2085. <tr>
  2086. <td class="memname">bool FatFile::seekCur </td>
  2087. <td>(</td>
  2088. <td class="paramtype">int32_t&#160;</td>
  2089. <td class="paramname"><em>offset</em></td><td>)</td>
  2090. <td></td>
  2091. </tr>
  2092. </table>
  2093. </td>
  2094. <td class="mlabels-right">
  2095. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  2096. </tr>
  2097. </table>
  2098. </div><div class="memdoc">
  2099. <p>Set the files position to current position + <em>pos</em>. See <a class="el" href="class_fat_file.html#ab067190d25733ed7e697d9890f61fd7a">seekSet()</a>. </p><dl class="params"><dt>Parameters</dt><dd>
  2100. <table class="params">
  2101. <tr><td class="paramdir">[in]</td><td class="paramname">offset</td><td>The new position in bytes from the current position. </td></tr>
  2102. </table>
  2103. </dd>
  2104. </dl>
  2105. <dl class="section return"><dt>Returns</dt><dd>true for success or false for failure. </dd></dl>
  2106. </div>
  2107. </div>
  2108. <a class="anchor" id="a84f677f4e75ef6fa2eb632f4cdf6b486"></a>
  2109. <div class="memitem">
  2110. <div class="memproto">
  2111. <table class="mlabels">
  2112. <tr>
  2113. <td class="mlabels-left">
  2114. <table class="memname">
  2115. <tr>
  2116. <td class="memname">bool FatFile::seekEnd </td>
  2117. <td>(</td>
  2118. <td class="paramtype">int32_t&#160;</td>
  2119. <td class="paramname"><em>offset</em> = <code>0</code></td><td>)</td>
  2120. <td></td>
  2121. </tr>
  2122. </table>
  2123. </td>
  2124. <td class="mlabels-right">
  2125. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  2126. </tr>
  2127. </table>
  2128. </div><div class="memdoc">
  2129. <p>Set the files position to end-of-file + <em>offset</em>. See <a class="el" href="class_fat_file.html#ab067190d25733ed7e697d9890f61fd7a">seekSet()</a>. </p><dl class="params"><dt>Parameters</dt><dd>
  2130. <table class="params">
  2131. <tr><td class="paramdir">[in]</td><td class="paramname">offset</td><td>The new position in bytes from end-of-file. </td></tr>
  2132. </table>
  2133. </dd>
  2134. </dl>
  2135. <dl class="section return"><dt>Returns</dt><dd>true for success or false for failure. </dd></dl>
  2136. </div>
  2137. </div>
  2138. <a class="anchor" id="ab067190d25733ed7e697d9890f61fd7a"></a>
  2139. <div class="memitem">
  2140. <div class="memproto">
  2141. <table class="memname">
  2142. <tr>
  2143. <td class="memname">bool FatFile::seekSet </td>
  2144. <td>(</td>
  2145. <td class="paramtype">uint32_t&#160;</td>
  2146. <td class="paramname"><em>pos</em></td><td>)</td>
  2147. <td></td>
  2148. </tr>
  2149. </table>
  2150. </div><div class="memdoc">
  2151. <p>Sets a file's position.</p>
  2152. <dl class="params"><dt>Parameters</dt><dd>
  2153. <table class="params">
  2154. <tr><td class="paramdir">[in]</td><td class="paramname">pos</td><td>The new position in bytes from the beginning of the file.</td></tr>
  2155. </table>
  2156. </dd>
  2157. </dl>
  2158. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. </dd></dl>
  2159. </div>
  2160. </div>
  2161. <a class="anchor" id="a360ef9c05e677271bed6c0a4d663634c"></a>
  2162. <div class="memitem">
  2163. <div class="memproto">
  2164. <table class="mlabels">
  2165. <tr>
  2166. <td class="mlabels-left">
  2167. <table class="memname">
  2168. <tr>
  2169. <td class="memname">static bool FatFile::setCwd </td>
  2170. <td>(</td>
  2171. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  2172. <td class="paramname"><em>dir</em></td><td>)</td>
  2173. <td></td>
  2174. </tr>
  2175. </table>
  2176. </td>
  2177. <td class="mlabels-right">
  2178. <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
  2179. </tr>
  2180. </table>
  2181. </div><div class="memdoc">
  2182. <p>Set the current working directory.</p>
  2183. <dl class="params"><dt>Parameters</dt><dd>
  2184. <table class="params">
  2185. <tr><td class="paramdir">[in]</td><td class="paramname">dir</td><td>New current working directory.</td></tr>
  2186. </table>
  2187. </dd>
  2188. </dl>
  2189. <dl class="section return"><dt>Returns</dt><dd>true for success else false. </dd></dl>
  2190. </div>
  2191. </div>
  2192. <a class="anchor" id="acf264de4e3ca36c5e8a39e56173c9044"></a>
  2193. <div class="memitem">
  2194. <div class="memproto">
  2195. <table class="memname">
  2196. <tr>
  2197. <td class="memname">void FatFile::setpos </td>
  2198. <td>(</td>
  2199. <td class="paramtype"><a class="el" href="struct_fat_pos__t.html">FatPos_t</a> *&#160;</td>
  2200. <td class="paramname"><em>pos</em></td><td>)</td>
  2201. <td></td>
  2202. </tr>
  2203. </table>
  2204. </div><div class="memdoc">
  2205. <p>set position for streams </p><dl class="params"><dt>Parameters</dt><dd>
  2206. <table class="params">
  2207. <tr><td class="paramdir">[out]</td><td class="paramname">pos</td><td>struct with value for new position </td></tr>
  2208. </table>
  2209. </dd>
  2210. </dl>
  2211. </div>
  2212. </div>
  2213. <a class="anchor" id="a67f3dc4896c542d695e11aac927f585e"></a>
  2214. <div class="memitem">
  2215. <div class="memproto">
  2216. <table class="memname">
  2217. <tr>
  2218. <td class="memname">bool FatFile::sync </td>
  2219. <td>(</td>
  2220. <td class="paramname"></td><td>)</td>
  2221. <td></td>
  2222. </tr>
  2223. </table>
  2224. </div><div class="memdoc">
  2225. <p>The <a class="el" href="class_fat_file.html#a67f3dc4896c542d695e11aac927f585e">sync()</a> call causes all modified data and directory fields to be written to the storage device.</p>
  2226. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. Reasons for failure include a call to <a class="el" href="class_fat_file.html#a67f3dc4896c542d695e11aac927f585e">sync()</a> before a file has been opened or an I/O error. </dd></dl>
  2227. </div>
  2228. </div>
  2229. <a class="anchor" id="aa53a8d1d2467ad9af7d61cbf8ee85243"></a>
  2230. <div class="memitem">
  2231. <div class="memproto">
  2232. <table class="memname">
  2233. <tr>
  2234. <td class="memname">bool FatFile::timestamp </td>
  2235. <td>(</td>
  2236. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  2237. <td class="paramname"><em>file</em></td><td>)</td>
  2238. <td></td>
  2239. </tr>
  2240. </table>
  2241. </div><div class="memdoc">
  2242. <p>Copy a file's timestamps</p>
  2243. <dl class="params"><dt>Parameters</dt><dd>
  2244. <table class="params">
  2245. <tr><td class="paramdir">[in]</td><td class="paramname">file</td><td><a class="el" href="class_file.html" title="Arduino SD.h style File API. ">File</a> to copy timestamps from.</td></tr>
  2246. </table>
  2247. </dd>
  2248. </dl>
  2249. <dl class="section note"><dt>Note</dt><dd>Modify and access timestamps may be overwritten if a date time callback function has been set by <a class="el" href="class_fat_file.html#a29a623f50df057e8b49045ba6611ec2b">dateTimeCallback()</a>.</dd></dl>
  2250. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. </dd></dl>
  2251. </div>
  2252. </div>
  2253. <a class="anchor" id="a56dabdf73833b7e961c4530eb8e16d23"></a>
  2254. <div class="memitem">
  2255. <div class="memproto">
  2256. <table class="memname">
  2257. <tr>
  2258. <td class="memname">bool FatFile::timestamp </td>
  2259. <td>(</td>
  2260. <td class="paramtype">uint8_t&#160;</td>
  2261. <td class="paramname"><em>flags</em>, </td>
  2262. </tr>
  2263. <tr>
  2264. <td class="paramkey"></td>
  2265. <td></td>
  2266. <td class="paramtype">uint16_t&#160;</td>
  2267. <td class="paramname"><em>year</em>, </td>
  2268. </tr>
  2269. <tr>
  2270. <td class="paramkey"></td>
  2271. <td></td>
  2272. <td class="paramtype">uint8_t&#160;</td>
  2273. <td class="paramname"><em>month</em>, </td>
  2274. </tr>
  2275. <tr>
  2276. <td class="paramkey"></td>
  2277. <td></td>
  2278. <td class="paramtype">uint8_t&#160;</td>
  2279. <td class="paramname"><em>day</em>, </td>
  2280. </tr>
  2281. <tr>
  2282. <td class="paramkey"></td>
  2283. <td></td>
  2284. <td class="paramtype">uint8_t&#160;</td>
  2285. <td class="paramname"><em>hour</em>, </td>
  2286. </tr>
  2287. <tr>
  2288. <td class="paramkey"></td>
  2289. <td></td>
  2290. <td class="paramtype">uint8_t&#160;</td>
  2291. <td class="paramname"><em>minute</em>, </td>
  2292. </tr>
  2293. <tr>
  2294. <td class="paramkey"></td>
  2295. <td></td>
  2296. <td class="paramtype">uint8_t&#160;</td>
  2297. <td class="paramname"><em>second</em>&#160;</td>
  2298. </tr>
  2299. <tr>
  2300. <td></td>
  2301. <td>)</td>
  2302. <td></td><td></td>
  2303. </tr>
  2304. </table>
  2305. </div><div class="memdoc">
  2306. <p>Set a file's timestamps in its directory entry.</p>
  2307. <dl class="params"><dt>Parameters</dt><dd>
  2308. <table class="params">
  2309. <tr><td class="paramdir">[in]</td><td class="paramname">flags</td><td>Values for <em>flags</em> are constructed by a bitwise-inclusive OR of flags from the following list</td></tr>
  2310. </table>
  2311. </dd>
  2312. </dl>
  2313. <p>T_ACCESS - Set the file's last access date.</p>
  2314. <p>T_CREATE - Set the file's creation date and time.</p>
  2315. <p>T_WRITE - Set the file's last write/modification date and time.</p>
  2316. <dl class="params"><dt>Parameters</dt><dd>
  2317. <table class="params">
  2318. <tr><td class="paramdir">[in]</td><td class="paramname">year</td><td>Valid range 1980 - 2107 inclusive.</td></tr>
  2319. <tr><td class="paramdir">[in]</td><td class="paramname">month</td><td>Valid range 1 - 12 inclusive.</td></tr>
  2320. <tr><td class="paramdir">[in]</td><td class="paramname">day</td><td>Valid range 1 - 31 inclusive.</td></tr>
  2321. <tr><td class="paramdir">[in]</td><td class="paramname">hour</td><td>Valid range 0 - 23 inclusive.</td></tr>
  2322. <tr><td class="paramdir">[in]</td><td class="paramname">minute</td><td>Valid range 0 - 59 inclusive.</td></tr>
  2323. <tr><td class="paramdir">[in]</td><td class="paramname">second</td><td>Valid range 0 - 59 inclusive</td></tr>
  2324. </table>
  2325. </dd>
  2326. </dl>
  2327. <dl class="section note"><dt>Note</dt><dd>It is possible to set an invalid date since there is no check for the number of days in a month.</dd>
  2328. <dd>
  2329. Modify and access timestamps may be overwritten if a date time callback function has been set by <a class="el" href="class_fat_file.html#a29a623f50df057e8b49045ba6611ec2b">dateTimeCallback()</a>.</dd></dl>
  2330. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. </dd></dl>
  2331. </div>
  2332. </div>
  2333. <a class="anchor" id="aa6e663098a578635d37d92e82d18d616"></a>
  2334. <div class="memitem">
  2335. <div class="memproto">
  2336. <table class="memname">
  2337. <tr>
  2338. <td class="memname">bool FatFile::truncate </td>
  2339. <td>(</td>
  2340. <td class="paramtype">uint32_t&#160;</td>
  2341. <td class="paramname"><em>length</em></td><td>)</td>
  2342. <td></td>
  2343. </tr>
  2344. </table>
  2345. </div><div class="memdoc">
  2346. <p>Truncate a file to a specified length. The current file position will be maintained if it is less than or equal to <em>length</em> otherwise it will be set to end of file.</p>
  2347. <dl class="params"><dt>Parameters</dt><dd>
  2348. <table class="params">
  2349. <tr><td class="paramdir">[in]</td><td class="paramname">length</td><td>The desired length for the file.</td></tr>
  2350. </table>
  2351. </dd>
  2352. </dl>
  2353. <dl class="section return"><dt>Returns</dt><dd>The value one, true, is returned for success and the value zero, false, is returned for failure. Reasons for failure include file is read only, file is a directory, <em>length</em> is greater than the current file size or an I/O error occurs. </dd></dl>
  2354. </div>
  2355. </div>
  2356. <a class="anchor" id="a3c64bd8a9abb9a6461d4addb405614df"></a>
  2357. <div class="memitem">
  2358. <div class="memproto">
  2359. <table class="mlabels">
  2360. <tr>
  2361. <td class="mlabels-left">
  2362. <table class="memname">
  2363. <tr>
  2364. <td class="memname"><a class="el" href="class_fat_volume.html">FatVolume</a>* FatFile::volume </td>
  2365. <td>(</td>
  2366. <td class="paramname"></td><td>)</td>
  2367. <td> const</td>
  2368. </tr>
  2369. </table>
  2370. </td>
  2371. <td class="mlabels-right">
  2372. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  2373. </tr>
  2374. </table>
  2375. </div><div class="memdoc">
  2376. <dl class="section return"><dt>Returns</dt><dd><a class="el" href="class_fat_volume.html" title="Access FAT16 and FAT32 volumes on raw file devices. ">FatVolume</a> that contains this file. </dd></dl>
  2377. </div>
  2378. </div>
  2379. <a class="anchor" id="a5524bd9f3b8f54ee163e391cba618186"></a>
  2380. <div class="memitem">
  2381. <div class="memproto">
  2382. <table class="mlabels">
  2383. <tr>
  2384. <td class="mlabels-left">
  2385. <table class="memname">
  2386. <tr>
  2387. <td class="memname">int FatFile::write </td>
  2388. <td>(</td>
  2389. <td class="paramtype">uint8_t&#160;</td>
  2390. <td class="paramname"><em>b</em></td><td>)</td>
  2391. <td></td>
  2392. </tr>
  2393. </table>
  2394. </td>
  2395. <td class="mlabels-right">
  2396. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  2397. </tr>
  2398. </table>
  2399. </div><div class="memdoc">
  2400. <p>Write a single byte. </p><dl class="params"><dt>Parameters</dt><dd>
  2401. <table class="params">
  2402. <tr><td class="paramdir">[in]</td><td class="paramname">b</td><td>The byte to be written. </td></tr>
  2403. </table>
  2404. </dd>
  2405. </dl>
  2406. <dl class="section return"><dt>Returns</dt><dd>+1 for success or -1 for failure. </dd></dl>
  2407. </div>
  2408. </div>
  2409. <a class="anchor" id="a0ab9df44a9ee4b6eb0a78f15f1e30004"></a>
  2410. <div class="memitem">
  2411. <div class="memproto">
  2412. <table class="memname">
  2413. <tr>
  2414. <td class="memname">int FatFile::write </td>
  2415. <td>(</td>
  2416. <td class="paramtype">const void *&#160;</td>
  2417. <td class="paramname"><em>buf</em>, </td>
  2418. </tr>
  2419. <tr>
  2420. <td class="paramkey"></td>
  2421. <td></td>
  2422. <td class="paramtype">size_t&#160;</td>
  2423. <td class="paramname"><em>nbyte</em>&#160;</td>
  2424. </tr>
  2425. <tr>
  2426. <td></td>
  2427. <td>)</td>
  2428. <td></td><td></td>
  2429. </tr>
  2430. </table>
  2431. </div><div class="memdoc">
  2432. <p>Write data to an open file.</p>
  2433. <dl class="section note"><dt>Note</dt><dd>Data is moved to the cache but may not be written to the storage device until <a class="el" href="class_fat_file.html#a67f3dc4896c542d695e11aac927f585e">sync()</a> is called.</dd></dl>
  2434. <dl class="params"><dt>Parameters</dt><dd>
  2435. <table class="params">
  2436. <tr><td class="paramdir">[in]</td><td class="paramname">buf</td><td>Pointer to the location of the data to be written.</td></tr>
  2437. <tr><td class="paramdir">[in]</td><td class="paramname">nbyte</td><td>Number of bytes to write.</td></tr>
  2438. </table>
  2439. </dd>
  2440. </dl>
  2441. <dl class="section return"><dt>Returns</dt><dd>For success <a class="el" href="class_fat_file.html#a5524bd9f3b8f54ee163e391cba618186">write()</a> returns the number of bytes written, always <em>nbyte</em>. If an error occurs, <a class="el" href="class_fat_file.html#a5524bd9f3b8f54ee163e391cba618186">write()</a> returns -1. Possible errors include <a class="el" href="class_fat_file.html#a5524bd9f3b8f54ee163e391cba618186">write()</a> is called before a file has been opened, write is called for a read-only file, device is full, a corrupt file system or an I/O error. </dd></dl>
  2442. </div>
  2443. </div>
  2444. <hr/>The documentation for this class was generated from the following files:<ul>
  2445. <li>Arduino/libraries/SdFat/utility/<a class="el" href="_fat_file_8h.html">FatFile.h</a></li>
  2446. <li>Arduino/libraries/SdFat/utility/FatFile.cpp</li>
  2447. <li>Arduino/libraries/SdFat/utility/FatFilePrint.cpp</li>
  2448. </ul>
  2449. </div><!-- contents -->
  2450. <!-- start footer part -->
  2451. <hr class="footer"/><address class="footer"><small>
  2452. Generated on Sat Nov 15 2014 10:05:35 for SdFat by &#160;<a href="http://www.doxygen.org/index.html">
  2453. <img class="footer" src="doxygen.png" alt="doxygen"/>
  2454. </a> 1.8.8
  2455. </small></address>
  2456. </body>
  2457. </html>