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.

2911 lines
136KB

  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="71,80,184,107"/> <area shape="rect" id="node11" href="class_file.html" title="Arduino SD.h style File API. " alt="" coords="209,80,252,107"/> <area shape="rect" id="node13" href="class_print_file.html" title="FatFile with Print. " alt="" coords="277,80,347,107"/> <area shape="rect" id="node17" href="class_sd_base_file.html" title="Class for backward compatibility. " alt="" coords="371,80,460,107"/> <area shape="rect" id="node19" href="class_stdio_stream.html" title="StdioStream implements a minimal stdio stream. " alt="" coords="485,80,579,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="node15" href="class_sd_file.html" title="Class for backward compatibility. " alt="" coords="283,155,341,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:a052e2c15a39b322a5307b693b8835b22"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a052e2c15a39b322a5307b693b8835b22">clearError</a> ()</td></tr>
  106. <tr class="separator:a052e2c15a39b322a5307b693b8835b22"><td class="memSeparator" colspan="2">&#160;</td></tr>
  107. <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>
  108. <tr class="separator:aeca2a2eff91e6aa55fe1b0e3860c9a05"><td class="memSeparator" colspan="2">&#160;</td></tr>
  109. <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>
  110. <tr class="separator:afd16af325e0642e4bff6430b7d8bb18b"><td class="memSeparator" colspan="2">&#160;</td></tr>
  111. <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>
  112. <tr class="separator:aa367708bcc8bc0e0c45c0c2a812c65da"><td class="memSeparator" colspan="2">&#160;</td></tr>
  113. <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>
  114. <tr class="separator:a0afc2a1cffa238d1cb2049bfa2d8d199"><td class="memSeparator" colspan="2">&#160;</td></tr>
  115. <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>
  116. <tr class="separator:a4c03e2f6729526786e6ab4a623e0339b"><td class="memSeparator" colspan="2">&#160;</td></tr>
  117. <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>
  118. <tr class="separator:a20c55b134bfd1d287a00bf64eba9332e"><td class="memSeparator" colspan="2">&#160;</td></tr>
  119. <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>
  120. <tr class="separator:a6858d18c807411a071fd6d1b39d50087"><td class="memSeparator" colspan="2">&#160;</td></tr>
  121. <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>
  122. <tr class="separator:ae5ec24d4a94d3780384d3f2b731c7eb9"><td class="memSeparator" colspan="2">&#160;</td></tr>
  123. <tr class="memitem:ae2ed15f05c9ccbce355e7a8d3ce8382d"><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#ae2ed15f05c9ccbce355e7a8d3ce8382d">dirSize</a> ()</td></tr>
  124. <tr class="separator:ae2ed15f05c9ccbce355e7a8d3ce8382d"><td class="memSeparator" colspan="2">&#160;</td></tr>
  125. <tr class="memitem:a4f01d27954ae49aeb6888ac7302f55d9"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a4f01d27954ae49aeb6888ac7302f55d9">dmpFile</a> (<a class="el" href="_fat_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *pr, uint32_t pos, size_t n)</td></tr>
  126. <tr class="separator:a4f01d27954ae49aeb6888ac7302f55d9"><td class="memSeparator" colspan="2">&#160;</td></tr>
  127. <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>
  128. <tr class="separator:a50242f98dea0d4488ce4039a279f2a57"><td class="memSeparator" colspan="2">&#160;</td></tr>
  129. <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>
  130. <tr class="separator:a7b591c9b92165fa8e4eae8c30c30e533"><td class="memSeparator" colspan="2">&#160;</td></tr>
  131. <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>
  132. <tr class="separator:a29d31067d0aa3a9a74b1a660c38775cc"><td class="memSeparator" colspan="2">&#160;</td></tr>
  133. <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>
  134. <tr class="separator:a31ef26b3ee37cf5f5f4c6024c0ddab69"><td class="memSeparator" colspan="2">&#160;</td></tr>
  135. <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>
  136. <tr class="separator:a7e043dfb89d268bfd620bbbadacf1002"><td class="memSeparator" colspan="2">&#160;</td></tr>
  137. <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>
  138. <tr class="separator:a02fc3b3ca36b4745f695f3de8c8ec36d"><td class="memSeparator" colspan="2">&#160;</td></tr>
  139. <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>
  140. <tr class="separator:a1057bc23b92a074539f661e896e79a09"><td class="memSeparator" colspan="2">&#160;</td></tr>
  141. <tr class="memitem:ad0dbbd083180f44c7a3ce7124d4ce19c"><td class="memItemLeft" align="right" valign="top">uint8_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#ad0dbbd083180f44c7a3ce7124d4ce19c">getError</a> ()</td></tr>
  142. <tr class="separator:ad0dbbd083180f44c7a3ce7124d4ce19c"><td class="memSeparator" colspan="2">&#160;</td></tr>
  143. <tr class="memitem:aafa565e286440aab612cdb430fc01da5"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#aafa565e286440aab612cdb430fc01da5">getName</a> (char *name, size_t size)</td></tr>
  144. <tr class="separator:aafa565e286440aab612cdb430fc01da5"><td class="memSeparator" colspan="2">&#160;</td></tr>
  145. <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>
  146. <tr class="separator:aaa4f9886887947815a61eaf015996932"><td class="memSeparator" colspan="2">&#160;</td></tr>
  147. <tr class="memitem:aba30e92a66f8e0d2f815c85662772a58"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#aba30e92a66f8e0d2f815c85662772a58">getSFN</a> (char *name)</td></tr>
  148. <tr class="separator:aba30e92a66f8e0d2f815c85662772a58"><td class="memSeparator" colspan="2">&#160;</td></tr>
  149. <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>
  150. <tr class="separator:a8062c0d3a118e8d77d0310418703d5f5"><td class="memSeparator" colspan="2">&#160;</td></tr>
  151. <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>
  152. <tr class="separator:aef41d65e0f1ce753d18cc9ed691f7de4"><td class="memSeparator" colspan="2">&#160;</td></tr>
  153. <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>
  154. <tr class="separator:afcf6270ea8d4a3a5f8e89523bc684e22"><td class="memSeparator" colspan="2">&#160;</td></tr>
  155. <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>
  156. <tr class="separator:a7eefe7408f34b6326f0c6e78af7eb05f"><td class="memSeparator" colspan="2">&#160;</td></tr>
  157. <tr class="memitem:aed36d17f8fde597b6ed9446faec1f7e3"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#aed36d17f8fde597b6ed9446faec1f7e3">isLFN</a> () const </td></tr>
  158. <tr class="separator:aed36d17f8fde597b6ed9446faec1f7e3"><td class="memSeparator" colspan="2">&#160;</td></tr>
  159. <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>
  160. <tr class="separator:a4c8a07b081f04aa25839c6f56c739bdc"><td class="memSeparator" colspan="2">&#160;</td></tr>
  161. <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>
  162. <tr class="separator:a6872d3acb1e70f81c9c2be2495977583"><td class="memSeparator" colspan="2">&#160;</td></tr>
  163. <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>
  164. <tr class="separator:aa4a206803a4bf8243be20244c1aef4d2"><td class="memSeparator" colspan="2">&#160;</td></tr>
  165. <tr class="memitem:a1449b294e3a838396c62e47674ca8cf0"><td class="memItemLeft" align="right" valign="top">bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a1449b294e3a838396c62e47674ca8cf0">isRoot32</a> () const </td></tr>
  166. <tr class="separator:a1449b294e3a838396c62e47674ca8cf0"><td class="memSeparator" colspan="2">&#160;</td></tr>
  167. <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>
  168. <tr class="separator:a8215bd4b21e11ec83fa88ef226ceb06f"><td class="memSeparator" colspan="2">&#160;</td></tr>
  169. <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>
  170. <tr class="separator:a95b503b17442c2b364a2f53de1b2aeba"><td class="memSeparator" colspan="2">&#160;</td></tr>
  171. <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>
  172. <tr class="separator:add932e13e5bf32ad467af6ec34824e3c"><td class="memSeparator" colspan="2">&#160;</td></tr>
  173. <tr class="memitem:ad49f688a494b351ccbb0102dcfafb925"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#ad49f688a494b351ccbb0102dcfafb925">ls</a> (uint8_t flags=0)</td></tr>
  174. <tr class="separator:ad49f688a494b351ccbb0102dcfafb925"><td class="memSeparator" colspan="2">&#160;</td></tr>
  175. <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_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *pr, uint8_t flags=0, uint8_t indent=0)</td></tr>
  176. <tr class="separator:acabf31ff85e696fbf384c49428012fea"><td class="memSeparator" colspan="2">&#160;</td></tr>
  177. <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>
  178. <tr class="separator:abab5b9f72cc796388dd4eed01d13d90d"><td class="memSeparator" colspan="2">&#160;</td></tr>
  179. <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>
  180. <tr class="separator:a5f64576d3d19177ab3cf3812b69abdfa"><td class="memSeparator" colspan="2">&#160;</td></tr>
  181. <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>
  182. <tr class="separator:ad3fa9daaccb4e4179fb88a8ca037aa80"><td class="memSeparator" colspan="2">&#160;</td></tr>
  183. <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>
  184. <tr class="separator:a211be757679b18708f6b6a36464e4f61"><td class="memSeparator" colspan="2">&#160;</td></tr>
  185. <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>
  186. <tr class="separator:ab0e7075062c89f356441f80fc64d03e6"><td class="memSeparator" colspan="2">&#160;</td></tr>
  187. <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>
  188. <tr class="separator:a8034c4649eb0d26715b1a8a69e73d9d0"><td class="memSeparator" colspan="2">&#160;</td></tr>
  189. <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>
  190. <tr class="separator:a7e0c0548fed3a69e7284b91b694439d4"><td class="memSeparator" colspan="2">&#160;</td></tr>
  191. <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>
  192. <tr class="separator:ac05b7136b887539426856c623869aa3a"><td class="memSeparator" colspan="2">&#160;</td></tr>
  193. <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_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *pr)</td></tr>
  194. <tr class="separator:a558530f20314a8d8ee3d1a488fc7f46e"><td class="memSeparator" colspan="2">&#160;</td></tr>
  195. <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>
  196. <tr class="separator:a7478cad0f9e5079311b9e1fa558016ff"><td class="memSeparator" colspan="2">&#160;</td></tr>
  197. <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>
  198. <tr class="separator:abd3e1747511216462b3ef98167156cbb"><td class="memSeparator" colspan="2">&#160;</td></tr>
  199. <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>
  200. <tr class="separator:a9972c2419c293ef9c382bff666b9ae4d"><td class="memSeparator" colspan="2">&#160;</td></tr>
  201. <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>
  202. <tr class="separator:a41b3b32dd8482429b74c7af3432d6cf8"><td class="memSeparator" colspan="2">&#160;</td></tr>
  203. <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>
  204. <tr class="separator:a097240f08baadeb1c64b63eab9afb088"><td class="memSeparator" colspan="2">&#160;</td></tr>
  205. <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_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *pr)</td></tr>
  206. <tr class="separator:a12a5d2de2737c201aa39ca1bd2ab9c47"><td class="memSeparator" colspan="2">&#160;</td></tr>
  207. <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_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *pr)</td></tr>
  208. <tr class="separator:a05cee5df46a370bf916d3ba597c82e39"><td class="memSeparator" colspan="2">&#160;</td></tr>
  209. <tr class="memitem:ad1cbc3aeb0f5193b7a26595966da9621"><td class="memItemLeft" align="right" valign="top">size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#ad1cbc3aeb0f5193b7a26595966da9621">printName</a> ()</td></tr>
  210. <tr class="separator:ad1cbc3aeb0f5193b7a26595966da9621"><td class="memSeparator" colspan="2">&#160;</td></tr>
  211. <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_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *pr)</td></tr>
  212. <tr class="separator:afe18a787fb8640e2d2483370c770f82f"><td class="memSeparator" colspan="2">&#160;</td></tr>
  213. <tr class="memitem:a791cd7aade71f609aab62ec018aea3c0"><td class="memItemLeft" align="right" valign="top">size_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a791cd7aade71f609aab62ec018aea3c0">printSFN</a> (<a class="el" href="_fat_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *pr)</td></tr>
  214. <tr class="separator:a791cd7aade71f609aab62ec018aea3c0"><td class="memSeparator" colspan="2">&#160;</td></tr>
  215. <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>
  216. <tr class="separator:a60ae55ff6fe158c2340071d702a363c5"><td class="memSeparator" colspan="2">&#160;</td></tr>
  217. <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>
  218. <tr class="separator:a200e6e0553d5b709520c9dfac9ef77dd"><td class="memSeparator" colspan="2">&#160;</td></tr>
  219. <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>
  220. <tr class="separator:a1325afe074c3efecff666678cd9f116a"><td class="memSeparator" colspan="2">&#160;</td></tr>
  221. <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>
  222. <tr class="separator:ac837a537fbcca14c7aa390c5fc9f4e7c"><td class="memSeparator" colspan="2">&#160;</td></tr>
  223. <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>
  224. <tr class="separator:a4b42f2454ff462555c07ea094a92a1e0"><td class="memSeparator" colspan="2">&#160;</td></tr>
  225. <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>
  226. <tr class="separator:a5aac6e0b3cb08fc8b8668e916a8b0ca5"><td class="memSeparator" colspan="2">&#160;</td></tr>
  227. <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>
  228. <tr class="separator:a9515bac181d33e7f0125e88fa2ccd283"><td class="memSeparator" colspan="2">&#160;</td></tr>
  229. <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>
  230. <tr class="separator:ac780a80526f86d3def701ecdc99d8bfe"><td class="memSeparator" colspan="2">&#160;</td></tr>
  231. <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>
  232. <tr class="separator:a5812037ea30777cc350698ad26f2c73f"><td class="memSeparator" colspan="2">&#160;</td></tr>
  233. <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>
  234. <tr class="separator:a84f677f4e75ef6fa2eb632f4cdf6b486"><td class="memSeparator" colspan="2">&#160;</td></tr>
  235. <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>
  236. <tr class="separator:ab067190d25733ed7e697d9890f61fd7a"><td class="memSeparator" colspan="2">&#160;</td></tr>
  237. <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>
  238. <tr class="separator:acf264de4e3ca36c5e8a39e56173c9044"><td class="memSeparator" colspan="2">&#160;</td></tr>
  239. <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>
  240. <tr class="separator:a67f3dc4896c542d695e11aac927f585e"><td class="memSeparator" colspan="2">&#160;</td></tr>
  241. <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>
  242. <tr class="separator:aa53a8d1d2467ad9af7d61cbf8ee85243"><td class="memSeparator" colspan="2">&#160;</td></tr>
  243. <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>
  244. <tr class="separator:a56dabdf73833b7e961c4530eb8e16d23"><td class="memSeparator" colspan="2">&#160;</td></tr>
  245. <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>
  246. <tr class="separator:aa6e663098a578635d37d92e82d18d616"><td class="memSeparator" colspan="2">&#160;</td></tr>
  247. <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>
  248. <tr class="separator:a3c64bd8a9abb9a6461d4addb405614df"><td class="memSeparator" colspan="2">&#160;</td></tr>
  249. <tr class="memitem:aa4a5b81161994cea07938702cdfce49f"><td class="memItemLeft" align="right" valign="top">int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#aa4a5b81161994cea07938702cdfce49f">write</a> (const char *str)</td></tr>
  250. <tr class="separator:aa4a5b81161994cea07938702cdfce49f"><td class="memSeparator" colspan="2">&#160;</td></tr>
  251. <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>
  252. <tr class="separator:a5524bd9f3b8f54ee163e391cba618186"><td class="memSeparator" colspan="2">&#160;</td></tr>
  253. <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>
  254. <tr class="separator:a0ab9df44a9ee4b6eb0a78f15f1e30004"><td class="memSeparator" colspan="2">&#160;</td></tr>
  255. </table><table class="memberdecls">
  256. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-static-methods"></a>
  257. Static Public Member Functions</h2></td></tr>
  258. <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>
  259. <tr class="separator:a3b68e603ad8e47bad915f0547e580adb"><td class="memSeparator" colspan="2">&#160;</td></tr>
  260. <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>
  261. <tr class="separator:a29a623f50df057e8b49045ba6611ec2b"><td class="memSeparator" colspan="2">&#160;</td></tr>
  262. <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>
  263. <tr class="separator:a5df02f1d037e6091375488af25244ebc"><td class="memSeparator" colspan="2">&#160;</td></tr>
  264. <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>
  265. <tr class="separator:a648461081fe07578780f4cd3f246cb66"><td class="memSeparator" colspan="2">&#160;</td></tr>
  266. <tr class="memitem:a94df8090f16e9666cdc53ca20f6aff90"><td class="memItemLeft" align="right" valign="top">static bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a94df8090f16e9666cdc53ca20f6aff90">legal83Char</a> (uint8_t c)</td></tr>
  267. <tr class="separator:a94df8090f16e9666cdc53ca20f6aff90"><td class="memSeparator" colspan="2">&#160;</td></tr>
  268. <tr class="memitem:a8fdb038aafdf3a17ac80b53c063aa73b"><td class="memItemLeft" align="right" valign="top">static void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a8fdb038aafdf3a17ac80b53c063aa73b">printFatDate</a> (uint16_t fatDate)</td></tr>
  269. <tr class="separator:a8fdb038aafdf3a17ac80b53c063aa73b"><td class="memSeparator" colspan="2">&#160;</td></tr>
  270. <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_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *pr, uint16_t fatDate)</td></tr>
  271. <tr class="separator:ada5364f66204b1a64afbf9d2e6cd2b0b"><td class="memSeparator" colspan="2">&#160;</td></tr>
  272. <tr class="memitem:a7740731f08ef97de7dfbc9b075c4c7d1"><td class="memItemLeft" align="right" valign="top">static void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="class_fat_file.html#a7740731f08ef97de7dfbc9b075c4c7d1">printFatTime</a> (uint16_t fatTime)</td></tr>
  273. <tr class="separator:a7740731f08ef97de7dfbc9b075c4c7d1"><td class="memSeparator" colspan="2">&#160;</td></tr>
  274. <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_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *pr, uint16_t fatTime)</td></tr>
  275. <tr class="separator:a4e7e56ba52ca17c602af1b85684b09a9"><td class="memSeparator" colspan="2">&#160;</td></tr>
  276. <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>
  277. <tr class="separator:afe820bbb056863e91ec482961c8dc695"><td class="memSeparator" colspan="2">&#160;</td></tr>
  278. <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>
  279. <tr class="separator:a360ef9c05e677271bed6c0a4d663634c"><td class="memSeparator" colspan="2">&#160;</td></tr>
  280. </table>
  281. <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
  282. <div class="textblock"><p>Basic file class. </p>
  283. </div><h2 class="groupheader">Constructor &amp; Destructor Documentation</h2>
  284. <a class="anchor" id="a7b591c9b92165fa8e4eae8c30c30e533"></a>
  285. <div class="memitem">
  286. <div class="memproto">
  287. <table class="mlabels">
  288. <tr>
  289. <td class="mlabels-left">
  290. <table class="memname">
  291. <tr>
  292. <td class="memname">FatFile::FatFile </td>
  293. <td>(</td>
  294. <td class="paramname"></td><td>)</td>
  295. <td></td>
  296. </tr>
  297. </table>
  298. </td>
  299. <td class="mlabels-right">
  300. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  301. </tr>
  302. </table>
  303. </div><div class="memdoc">
  304. <p>Create an instance. </p>
  305. </div>
  306. </div>
  307. <a class="anchor" id="a29d31067d0aa3a9a74b1a660c38775cc"></a>
  308. <div class="memitem">
  309. <div class="memproto">
  310. <table class="mlabels">
  311. <tr>
  312. <td class="mlabels-left">
  313. <table class="memname">
  314. <tr>
  315. <td class="memname">FatFile::FatFile </td>
  316. <td>(</td>
  317. <td class="paramtype">const char *&#160;</td>
  318. <td class="paramname"><em>path</em>, </td>
  319. </tr>
  320. <tr>
  321. <td class="paramkey"></td>
  322. <td></td>
  323. <td class="paramtype">uint8_t&#160;</td>
  324. <td class="paramname"><em>oflag</em>&#160;</td>
  325. </tr>
  326. <tr>
  327. <td></td>
  328. <td>)</td>
  329. <td></td><td></td>
  330. </tr>
  331. </table>
  332. </td>
  333. <td class="mlabels-right">
  334. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  335. </tr>
  336. </table>
  337. </div><div class="memdoc">
  338. <p>Create a file object and open it in the current working directory.</p>
  339. <dl class="params"><dt>Parameters</dt><dd>
  340. <table class="params">
  341. <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>
  342. <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>
  343. </table>
  344. </dd>
  345. </dl>
  346. </div>
  347. </div>
  348. <h2 class="groupheader">Member Function Documentation</h2>
  349. <a class="anchor" id="ac1fa779d98db7ffdb96f8019ab0060d6"></a>
  350. <div class="memitem">
  351. <div class="memproto">
  352. <table class="mlabels">
  353. <tr>
  354. <td class="mlabels-left">
  355. <table class="memname">
  356. <tr>
  357. <td class="memname">uint32_t FatFile::available </td>
  358. <td>(</td>
  359. <td class="paramname"></td><td>)</td>
  360. <td></td>
  361. </tr>
  362. </table>
  363. </td>
  364. <td class="mlabels-right">
  365. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  366. </tr>
  367. </table>
  368. </div><div class="memdoc">
  369. <dl class="section return"><dt>Returns</dt><dd>The number of bytes available from the current position to EOF for normal files. Zero is returned for directory files. </dd></dl>
  370. </div>
  371. </div>
  372. <a class="anchor" id="a052e2c15a39b322a5307b693b8835b22"></a>
  373. <div class="memitem">
  374. <div class="memproto">
  375. <table class="mlabels">
  376. <tr>
  377. <td class="mlabels-left">
  378. <table class="memname">
  379. <tr>
  380. <td class="memname">void FatFile::clearError </td>
  381. <td>(</td>
  382. <td class="paramname"></td><td>)</td>
  383. <td></td>
  384. </tr>
  385. </table>
  386. </td>
  387. <td class="mlabels-right">
  388. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  389. </tr>
  390. </table>
  391. </div><div class="memdoc">
  392. <p>Clear all error bits. </p>
  393. </div>
  394. </div>
  395. <a class="anchor" id="aeca2a2eff91e6aa55fe1b0e3860c9a05"></a>
  396. <div class="memitem">
  397. <div class="memproto">
  398. <table class="mlabels">
  399. <tr>
  400. <td class="mlabels-left">
  401. <table class="memname">
  402. <tr>
  403. <td class="memname">void FatFile::clearWriteError </td>
  404. <td>(</td>
  405. <td class="paramname"></td><td>)</td>
  406. <td></td>
  407. </tr>
  408. </table>
  409. </td>
  410. <td class="mlabels-right">
  411. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  412. </tr>
  413. </table>
  414. </div><div class="memdoc">
  415. <p>Set writeError to zero </p>
  416. </div>
  417. </div>
  418. <a class="anchor" id="afd16af325e0642e4bff6430b7d8bb18b"></a>
  419. <div class="memitem">
  420. <div class="memproto">
  421. <table class="memname">
  422. <tr>
  423. <td class="memname">bool FatFile::close </td>
  424. <td>(</td>
  425. <td class="paramname"></td><td>)</td>
  426. <td></td>
  427. </tr>
  428. </table>
  429. </div><div class="memdoc">
  430. <p>Close a file and force cached data and directory information to be written to the storage device.</p>
  431. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  432. </div>
  433. </div>
  434. <a class="anchor" id="aa367708bcc8bc0e0c45c0c2a812c65da"></a>
  435. <div class="memitem">
  436. <div class="memproto">
  437. <table class="memname">
  438. <tr>
  439. <td class="memname">bool FatFile::contiguousRange </td>
  440. <td>(</td>
  441. <td class="paramtype">uint32_t *&#160;</td>
  442. <td class="paramname"><em>bgnBlock</em>, </td>
  443. </tr>
  444. <tr>
  445. <td class="paramkey"></td>
  446. <td></td>
  447. <td class="paramtype">uint32_t *&#160;</td>
  448. <td class="paramname"><em>endBlock</em>&#160;</td>
  449. </tr>
  450. <tr>
  451. <td></td>
  452. <td>)</td>
  453. <td></td><td></td>
  454. </tr>
  455. </table>
  456. </div><div class="memdoc">
  457. <p>Check for contiguous file and return its raw block range.</p>
  458. <dl class="params"><dt>Parameters</dt><dd>
  459. <table class="params">
  460. <tr><td class="paramdir">[out]</td><td class="paramname">bgnBlock</td><td>the first block address for the file. </td></tr>
  461. <tr><td class="paramdir">[out]</td><td class="paramname">endBlock</td><td>the last block address for the file.</td></tr>
  462. </table>
  463. </dd>
  464. </dl>
  465. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  466. </div>
  467. </div>
  468. <a class="anchor" id="a0afc2a1cffa238d1cb2049bfa2d8d199"></a>
  469. <div class="memitem">
  470. <div class="memproto">
  471. <table class="memname">
  472. <tr>
  473. <td class="memname">bool FatFile::createContiguous </td>
  474. <td>(</td>
  475. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  476. <td class="paramname"><em>dirFile</em>, </td>
  477. </tr>
  478. <tr>
  479. <td class="paramkey"></td>
  480. <td></td>
  481. <td class="paramtype">const char *&#160;</td>
  482. <td class="paramname"><em>path</em>, </td>
  483. </tr>
  484. <tr>
  485. <td class="paramkey"></td>
  486. <td></td>
  487. <td class="paramtype">uint32_t&#160;</td>
  488. <td class="paramname"><em>size</em>&#160;</td>
  489. </tr>
  490. <tr>
  491. <td></td>
  492. <td>)</td>
  493. <td></td><td></td>
  494. </tr>
  495. </table>
  496. </div><div class="memdoc">
  497. <p>Create and open a new contiguous file of a specified size.</p>
  498. <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>
  499. <dl class="params"><dt>Parameters</dt><dd>
  500. <table class="params">
  501. <tr><td class="paramdir">[in]</td><td class="paramname">dirFile</td><td>The directory where the file will be created. </td></tr>
  502. <tr><td class="paramdir">[in]</td><td class="paramname">path</td><td>A path with a valid DOS 8.3 file name. </td></tr>
  503. <tr><td class="paramdir">[in]</td><td class="paramname">size</td><td>The desired file size.</td></tr>
  504. </table>
  505. </dd>
  506. </dl>
  507. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false, is returned for failure. </dd></dl>
  508. </div>
  509. </div>
  510. <a class="anchor" id="a4c03e2f6729526786e6ab4a623e0339b"></a>
  511. <div class="memitem">
  512. <div class="memproto">
  513. <table class="mlabels">
  514. <tr>
  515. <td class="mlabels-left">
  516. <table class="memname">
  517. <tr>
  518. <td class="memname">uint32_t FatFile::curCluster </td>
  519. <td>(</td>
  520. <td class="paramname"></td><td>)</td>
  521. <td> const</td>
  522. </tr>
  523. </table>
  524. </td>
  525. <td class="mlabels-right">
  526. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  527. </tr>
  528. </table>
  529. </div><div class="memdoc">
  530. <dl class="section return"><dt>Returns</dt><dd>The current cluster number for a file or directory. </dd></dl>
  531. </div>
  532. </div>
  533. <a class="anchor" id="a20c55b134bfd1d287a00bf64eba9332e"></a>
  534. <div class="memitem">
  535. <div class="memproto">
  536. <table class="mlabels">
  537. <tr>
  538. <td class="mlabels-left">
  539. <table class="memname">
  540. <tr>
  541. <td class="memname">uint32_t FatFile::curPosition </td>
  542. <td>(</td>
  543. <td class="paramname"></td><td>)</td>
  544. <td> const</td>
  545. </tr>
  546. </table>
  547. </td>
  548. <td class="mlabels-right">
  549. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  550. </tr>
  551. </table>
  552. </div><div class="memdoc">
  553. <dl class="section return"><dt>Returns</dt><dd>The current position for a file or directory. </dd></dl>
  554. </div>
  555. </div>
  556. <a class="anchor" id="a3b68e603ad8e47bad915f0547e580adb"></a>
  557. <div class="memitem">
  558. <div class="memproto">
  559. <table class="mlabels">
  560. <tr>
  561. <td class="mlabels-left">
  562. <table class="memname">
  563. <tr>
  564. <td class="memname">static <a class="el" href="class_fat_file.html">FatFile</a>* FatFile::cwd </td>
  565. <td>(</td>
  566. <td class="paramname"></td><td>)</td>
  567. <td></td>
  568. </tr>
  569. </table>
  570. </td>
  571. <td class="mlabels-right">
  572. <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
  573. </tr>
  574. </table>
  575. </div><div class="memdoc">
  576. <dl class="section return"><dt>Returns</dt><dd>Current working directory </dd></dl>
  577. </div>
  578. </div>
  579. <a class="anchor" id="a29a623f50df057e8b49045ba6611ec2b"></a>
  580. <div class="memitem">
  581. <div class="memproto">
  582. <table class="mlabels">
  583. <tr>
  584. <td class="mlabels-left">
  585. <table class="memname">
  586. <tr>
  587. <td class="memname">static void FatFile::dateTimeCallback </td>
  588. <td>(</td>
  589. <td class="paramtype">void(*)(uint16_t *date, uint16_t *time)&#160;</td>
  590. <td class="paramname"><em>dateTime</em></td><td>)</td>
  591. <td></td>
  592. </tr>
  593. </table>
  594. </td>
  595. <td class="mlabels-right">
  596. <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
  597. </tr>
  598. </table>
  599. </div><div class="memdoc">
  600. <p>Set the date/time callback function</p>
  601. <dl class="params"><dt>Parameters</dt><dd>
  602. <table class="params">
  603. <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>
  604. </table>
  605. </dd>
  606. </dl>
  607. <div class="fragment"><div class="line"><span class="keywordtype">void</span> dateTime(uint16_t* date, uint16_t* time) {</div>
  608. <div class="line"> uint16_t year;</div>
  609. <div class="line"> uint8_t month, day, hour, minute, second;</div>
  610. <div class="line"></div>
  611. <div class="line"> <span class="comment">// User gets date and time from GPS or real-time clock here</span></div>
  612. <div class="line"></div>
  613. <div class="line"> <span class="comment">// return date using FAT_DATE macro to format fields</span></div>
  614. <div class="line"> *date = <a class="code" href="_fat_structs_8h.html#a44899ad42ddf32ff1c1a73b5251b304a">FAT_DATE</a>(year, month, day);</div>
  615. <div class="line"></div>
  616. <div class="line"> <span class="comment">// return time using FAT_TIME macro to format fields</span></div>
  617. <div class="line"> *time = <a class="code" href="_fat_structs_8h.html#a375720927be5a39475d48b2d75dae29a">FAT_TIME</a>(hour, minute, second);</div>
  618. <div class="line">}</div>
  619. </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>
  620. <p>See the <a class="el" href="class_fat_file.html#aa53a8d1d2467ad9af7d61cbf8ee85243">timestamp()</a> function. </p>
  621. </div>
  622. </div>
  623. <a class="anchor" id="a5df02f1d037e6091375488af25244ebc"></a>
  624. <div class="memitem">
  625. <div class="memproto">
  626. <table class="mlabels">
  627. <tr>
  628. <td class="mlabels-left">
  629. <table class="memname">
  630. <tr>
  631. <td class="memname">static void FatFile::dateTimeCallbackCancel </td>
  632. <td>(</td>
  633. <td class="paramname"></td><td>)</td>
  634. <td></td>
  635. </tr>
  636. </table>
  637. </td>
  638. <td class="mlabels-right">
  639. <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
  640. </tr>
  641. </table>
  642. </div><div class="memdoc">
  643. <p>Cancel the date/time callback function. </p>
  644. </div>
  645. </div>
  646. <a class="anchor" id="a6858d18c807411a071fd6d1b39d50087"></a>
  647. <div class="memitem">
  648. <div class="memproto">
  649. <table class="memname">
  650. <tr>
  651. <td class="memname">bool FatFile::dirEntry </td>
  652. <td>(</td>
  653. <td class="paramtype"><a class="el" href="_fat_structs_8h.html#a803db59d4e16a0c54a647afc6a7954e3">dir_t</a> *&#160;</td>
  654. <td class="paramname"><em>dir</em></td><td>)</td>
  655. <td></td>
  656. </tr>
  657. </table>
  658. </div><div class="memdoc">
  659. <p>Return a file's directory entry.</p>
  660. <dl class="params"><dt>Parameters</dt><dd>
  661. <table class="params">
  662. <tr><td class="paramdir">[out]</td><td class="paramname">dir</td><td>Location for return of the file's directory entry.</td></tr>
  663. </table>
  664. </dd>
  665. </dl>
  666. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  667. </div>
  668. </div>
  669. <a class="anchor" id="ae5ec24d4a94d3780384d3f2b731c7eb9"></a>
  670. <div class="memitem">
  671. <div class="memproto">
  672. <table class="mlabels">
  673. <tr>
  674. <td class="mlabels-left">
  675. <table class="memname">
  676. <tr>
  677. <td class="memname">uint16_t FatFile::dirIndex </td>
  678. <td>(</td>
  679. <td class="paramname"></td><td>)</td>
  680. <td></td>
  681. </tr>
  682. </table>
  683. </td>
  684. <td class="mlabels-right">
  685. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  686. </tr>
  687. </table>
  688. </div><div class="memdoc">
  689. <dl class="section return"><dt>Returns</dt><dd>The index of this file in it's directory. </dd></dl>
  690. </div>
  691. </div>
  692. <a class="anchor" id="a648461081fe07578780f4cd3f246cb66"></a>
  693. <div class="memitem">
  694. <div class="memproto">
  695. <table class="mlabels">
  696. <tr>
  697. <td class="mlabels-left">
  698. <table class="memname">
  699. <tr>
  700. <td class="memname">uint8_t FatFile::dirName </td>
  701. <td>(</td>
  702. <td class="paramtype">const <a class="el" href="_fat_structs_8h.html#a803db59d4e16a0c54a647afc6a7954e3">dir_t</a> *&#160;</td>
  703. <td class="paramname"><em>dir</em>, </td>
  704. </tr>
  705. <tr>
  706. <td class="paramkey"></td>
  707. <td></td>
  708. <td class="paramtype">char *&#160;</td>
  709. <td class="paramname"><em>name</em>&#160;</td>
  710. </tr>
  711. <tr>
  712. <td></td>
  713. <td>)</td>
  714. <td></td><td></td>
  715. </tr>
  716. </table>
  717. </td>
  718. <td class="mlabels-right">
  719. <span class="mlabels"><span class="mlabel">static</span></span> </td>
  720. </tr>
  721. </table>
  722. </div><div class="memdoc">
  723. <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>
  724. <dl class="params"><dt>Parameters</dt><dd>
  725. <table class="params">
  726. <tr><td class="paramdir">[in]</td><td class="paramname">dir</td><td>The directory structure containing the name. </td></tr>
  727. <tr><td class="paramdir">[out]</td><td class="paramname">name</td><td>A 13 byte char array for the formatted name. </td></tr>
  728. </table>
  729. </dd>
  730. </dl>
  731. <dl class="section return"><dt>Returns</dt><dd>length of the name. </dd></dl>
  732. </div>
  733. </div>
  734. <a class="anchor" id="ae2ed15f05c9ccbce355e7a8d3ce8382d"></a>
  735. <div class="memitem">
  736. <div class="memproto">
  737. <table class="memname">
  738. <tr>
  739. <td class="memname">uint32_t FatFile::dirSize </td>
  740. <td>(</td>
  741. <td class="paramname"></td><td>)</td>
  742. <td></td>
  743. </tr>
  744. </table>
  745. </div><div class="memdoc">
  746. <dl class="section return"><dt>Returns</dt><dd>The number of bytes allocated to a directory or zero if an error occurs. </dd></dl>
  747. </div>
  748. </div>
  749. <a class="anchor" id="a4f01d27954ae49aeb6888ac7302f55d9"></a>
  750. <div class="memitem">
  751. <div class="memproto">
  752. <table class="memname">
  753. <tr>
  754. <td class="memname">void FatFile::dmpFile </td>
  755. <td>(</td>
  756. <td class="paramtype"><a class="el" href="_fat_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *&#160;</td>
  757. <td class="paramname"><em>pr</em>, </td>
  758. </tr>
  759. <tr>
  760. <td class="paramkey"></td>
  761. <td></td>
  762. <td class="paramtype">uint32_t&#160;</td>
  763. <td class="paramname"><em>pos</em>, </td>
  764. </tr>
  765. <tr>
  766. <td class="paramkey"></td>
  767. <td></td>
  768. <td class="paramtype">size_t&#160;</td>
  769. <td class="paramname"><em>n</em>&#160;</td>
  770. </tr>
  771. <tr>
  772. <td></td>
  773. <td>)</td>
  774. <td></td><td></td>
  775. </tr>
  776. </table>
  777. </div><div class="memdoc">
  778. <p>Dump file in Hex </p><dl class="params"><dt>Parameters</dt><dd>
  779. <table class="params">
  780. <tr><td class="paramdir">[in]</td><td class="paramname">pr</td><td>Print stream for list. </td></tr>
  781. <tr><td class="paramdir">[in]</td><td class="paramname">pos</td><td>Start position in file. </td></tr>
  782. <tr><td class="paramdir">[in]</td><td class="paramname">n</td><td>number of locations to dump. </td></tr>
  783. </table>
  784. </dd>
  785. </dl>
  786. </div>
  787. </div>
  788. <a class="anchor" id="a50242f98dea0d4488ce4039a279f2a57"></a>
  789. <div class="memitem">
  790. <div class="memproto">
  791. <table class="mlabels">
  792. <tr>
  793. <td class="mlabels-left">
  794. <table class="memname">
  795. <tr>
  796. <td class="memname">bool FatFile::exists </td>
  797. <td>(</td>
  798. <td class="paramtype">const char *&#160;</td>
  799. <td class="paramname"><em>path</em></td><td>)</td>
  800. <td></td>
  801. </tr>
  802. </table>
  803. </td>
  804. <td class="mlabels-right">
  805. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  806. </tr>
  807. </table>
  808. </div><div class="memdoc">
  809. <p>Test for the existence of a file in a directory</p>
  810. <dl class="params"><dt>Parameters</dt><dd>
  811. <table class="params">
  812. <tr><td class="paramdir">[in]</td><td class="paramname">path</td><td>Path of the file to be tested for.</td></tr>
  813. </table>
  814. </dd>
  815. </dl>
  816. <p>The calling instance must be an open directory file.</p>
  817. <p>dirFile.exists("TOFIND.TXT") searches for "TOFIND.TXT" in the directory dirFile.</p>
  818. <dl class="section return"><dt>Returns</dt><dd>true if the file exists else false. </dd></dl>
  819. </div>
  820. </div>
  821. <a class="anchor" id="a31ef26b3ee37cf5f5f4c6024c0ddab69"></a>
  822. <div class="memitem">
  823. <div class="memproto">
  824. <table class="memname">
  825. <tr>
  826. <td class="memname">int16_t FatFile::fgets </td>
  827. <td>(</td>
  828. <td class="paramtype">char *&#160;</td>
  829. <td class="paramname"><em>str</em>, </td>
  830. </tr>
  831. <tr>
  832. <td class="paramkey"></td>
  833. <td></td>
  834. <td class="paramtype">int16_t&#160;</td>
  835. <td class="paramname"><em>num</em>, </td>
  836. </tr>
  837. <tr>
  838. <td class="paramkey"></td>
  839. <td></td>
  840. <td class="paramtype">char *&#160;</td>
  841. <td class="paramname"><em>delim</em> = <code>0</code>&#160;</td>
  842. </tr>
  843. <tr>
  844. <td></td>
  845. <td>)</td>
  846. <td></td><td></td>
  847. </tr>
  848. </table>
  849. </div><div class="memdoc">
  850. <p>Get a string from a file.</p>
  851. <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>
  852. <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>
  853. <dl class="params"><dt>Parameters</dt><dd>
  854. <table class="params">
  855. <tr><td class="paramdir">[out]</td><td class="paramname">str</td><td>Pointer to the array where the string is stored. </td></tr>
  856. <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>
  857. <tr><td class="paramdir">[in]</td><td class="paramname">delim</td><td>Optional set of delimiters. The default is "\n".</td></tr>
  858. </table>
  859. </dd>
  860. </dl>
  861. <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>
  862. </div>
  863. </div>
  864. <a class="anchor" id="a7e043dfb89d268bfd620bbbadacf1002"></a>
  865. <div class="memitem">
  866. <div class="memproto">
  867. <table class="mlabels">
  868. <tr>
  869. <td class="mlabels-left">
  870. <table class="memname">
  871. <tr>
  872. <td class="memname">uint8_t FatFile::fileAttr </td>
  873. <td>(</td>
  874. <td class="paramname"></td><td>)</td>
  875. <td> const</td>
  876. </tr>
  877. </table>
  878. </td>
  879. <td class="mlabels-right">
  880. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  881. </tr>
  882. </table>
  883. </div><div class="memdoc">
  884. <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>
  885. <dl class="section return"><dt>Returns</dt><dd>The file or directory type. </dd></dl>
  886. </div>
  887. </div>
  888. <a class="anchor" id="a02fc3b3ca36b4745f695f3de8c8ec36d"></a>
  889. <div class="memitem">
  890. <div class="memproto">
  891. <table class="mlabels">
  892. <tr>
  893. <td class="mlabels-left">
  894. <table class="memname">
  895. <tr>
  896. <td class="memname">uint32_t FatFile::fileSize </td>
  897. <td>(</td>
  898. <td class="paramname"></td><td>)</td>
  899. <td> const</td>
  900. </tr>
  901. </table>
  902. </td>
  903. <td class="mlabels-right">
  904. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  905. </tr>
  906. </table>
  907. </div><div class="memdoc">
  908. <dl class="section return"><dt>Returns</dt><dd>The total number of bytes in a file. </dd></dl>
  909. </div>
  910. </div>
  911. <a class="anchor" id="a1057bc23b92a074539f661e896e79a09"></a>
  912. <div class="memitem">
  913. <div class="memproto">
  914. <table class="mlabels">
  915. <tr>
  916. <td class="mlabels-left">
  917. <table class="memname">
  918. <tr>
  919. <td class="memname">uint32_t FatFile::firstCluster </td>
  920. <td>(</td>
  921. <td class="paramname"></td><td>)</td>
  922. <td> const</td>
  923. </tr>
  924. </table>
  925. </td>
  926. <td class="mlabels-right">
  927. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  928. </tr>
  929. </table>
  930. </div><div class="memdoc">
  931. <dl class="section return"><dt>Returns</dt><dd>The first cluster number for a file or directory. </dd></dl>
  932. </div>
  933. </div>
  934. <a class="anchor" id="ad0dbbd083180f44c7a3ce7124d4ce19c"></a>
  935. <div class="memitem">
  936. <div class="memproto">
  937. <table class="mlabels">
  938. <tr>
  939. <td class="mlabels-left">
  940. <table class="memname">
  941. <tr>
  942. <td class="memname">uint8_t FatFile::getError </td>
  943. <td>(</td>
  944. <td class="paramname"></td><td>)</td>
  945. <td></td>
  946. </tr>
  947. </table>
  948. </td>
  949. <td class="mlabels-right">
  950. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  951. </tr>
  952. </table>
  953. </div><div class="memdoc">
  954. <dl class="section return"><dt>Returns</dt><dd>All error bits. </dd></dl>
  955. </div>
  956. </div>
  957. <a class="anchor" id="aafa565e286440aab612cdb430fc01da5"></a>
  958. <div class="memitem">
  959. <div class="memproto">
  960. <table class="memname">
  961. <tr>
  962. <td class="memname">bool FatFile::getName </td>
  963. <td>(</td>
  964. <td class="paramtype">char *&#160;</td>
  965. <td class="paramname"><em>name</em>, </td>
  966. </tr>
  967. <tr>
  968. <td class="paramkey"></td>
  969. <td></td>
  970. <td class="paramtype">size_t&#160;</td>
  971. <td class="paramname"><em>size</em>&#160;</td>
  972. </tr>
  973. <tr>
  974. <td></td>
  975. <td>)</td>
  976. <td></td><td></td>
  977. </tr>
  978. </table>
  979. </div><div class="memdoc">
  980. <p>Get a file's name followed by a zero byte.</p>
  981. <dl class="params"><dt>Parameters</dt><dd>
  982. <table class="params">
  983. <tr><td class="paramdir">[out]</td><td class="paramname">name</td><td>An array of characters for the file's name. </td></tr>
  984. <tr><td class="paramdir">[in]</td><td class="paramname">size</td><td>The size of the array in bytes. The array must be at least 13 bytes long. The file's name will be truncated if the file's name is too long. </td></tr>
  985. </table>
  986. </dd>
  987. </dl>
  988. <dl class="section return"><dt>Returns</dt><dd>The value true, is returned for success and the value false, is returned for failure. </dd></dl>
  989. </div>
  990. </div>
  991. <a class="anchor" id="aaa4f9886887947815a61eaf015996932"></a>
  992. <div class="memitem">
  993. <div class="memproto">
  994. <table class="memname">
  995. <tr>
  996. <td class="memname">void FatFile::getpos </td>
  997. <td>(</td>
  998. <td class="paramtype"><a class="el" href="struct_fat_pos__t.html">FatPos_t</a> *&#160;</td>
  999. <td class="paramname"><em>pos</em></td><td>)</td>
  1000. <td></td>
  1001. </tr>
  1002. </table>
  1003. </div><div class="memdoc">
  1004. <p>get position for streams </p><dl class="params"><dt>Parameters</dt><dd>
  1005. <table class="params">
  1006. <tr><td class="paramdir">[out]</td><td class="paramname">pos</td><td>struct to receive position </td></tr>
  1007. </table>
  1008. </dd>
  1009. </dl>
  1010. </div>
  1011. </div>
  1012. <a class="anchor" id="aba30e92a66f8e0d2f815c85662772a58"></a>
  1013. <div class="memitem">
  1014. <div class="memproto">
  1015. <table class="memname">
  1016. <tr>
  1017. <td class="memname">bool FatFile::getSFN </td>
  1018. <td>(</td>
  1019. <td class="paramtype">char *&#160;</td>
  1020. <td class="paramname"><em>name</em></td><td>)</td>
  1021. <td></td>
  1022. </tr>
  1023. </table>
  1024. </div><div class="memdoc">
  1025. <p>Get a file's Short <a class="el" href="class_file.html" title="Arduino SD.h style File API. ">File</a> Name followed by a zero byte.</p>
  1026. <dl class="params"><dt>Parameters</dt><dd>
  1027. <table class="params">
  1028. <tr><td class="paramdir">[out]</td><td class="paramname">name</td><td>An array of characters for the file's name. The array must be at least 13 bytes long. </td></tr>
  1029. </table>
  1030. </dd>
  1031. </dl>
  1032. <dl class="section return"><dt>Returns</dt><dd>The value true, is returned for success and the value false, is returned for failure. </dd></dl>
  1033. </div>
  1034. </div>
  1035. <a class="anchor" id="a8062c0d3a118e8d77d0310418703d5f5"></a>
  1036. <div class="memitem">
  1037. <div class="memproto">
  1038. <table class="mlabels">
  1039. <tr>
  1040. <td class="mlabels-left">
  1041. <table class="memname">
  1042. <tr>
  1043. <td class="memname">bool FatFile::getWriteError </td>
  1044. <td>(</td>
  1045. <td class="paramname"></td><td>)</td>
  1046. <td></td>
  1047. </tr>
  1048. </table>
  1049. </td>
  1050. <td class="mlabels-right">
  1051. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1052. </tr>
  1053. </table>
  1054. </div><div class="memdoc">
  1055. <dl class="section return"><dt>Returns</dt><dd>value of writeError </dd></dl>
  1056. </div>
  1057. </div>
  1058. <a class="anchor" id="aef41d65e0f1ce753d18cc9ed691f7de4"></a>
  1059. <div class="memitem">
  1060. <div class="memproto">
  1061. <table class="mlabels">
  1062. <tr>
  1063. <td class="mlabels-left">
  1064. <table class="memname">
  1065. <tr>
  1066. <td class="memname">bool FatFile::isDir </td>
  1067. <td>(</td>
  1068. <td class="paramname"></td><td>)</td>
  1069. <td> const</td>
  1070. </tr>
  1071. </table>
  1072. </td>
  1073. <td class="mlabels-right">
  1074. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1075. </tr>
  1076. </table>
  1077. </div><div class="memdoc">
  1078. <dl class="section return"><dt>Returns</dt><dd>True if this is a directory else false. </dd></dl>
  1079. </div>
  1080. </div>
  1081. <a class="anchor" id="afcf6270ea8d4a3a5f8e89523bc684e22"></a>
  1082. <div class="memitem">
  1083. <div class="memproto">
  1084. <table class="mlabels">
  1085. <tr>
  1086. <td class="mlabels-left">
  1087. <table class="memname">
  1088. <tr>
  1089. <td class="memname">bool FatFile::isFile </td>
  1090. <td>(</td>
  1091. <td class="paramname"></td><td>)</td>
  1092. <td> const</td>
  1093. </tr>
  1094. </table>
  1095. </td>
  1096. <td class="mlabels-right">
  1097. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1098. </tr>
  1099. </table>
  1100. </div><div class="memdoc">
  1101. <dl class="section return"><dt>Returns</dt><dd>True if this is a normal file else false. </dd></dl>
  1102. </div>
  1103. </div>
  1104. <a class="anchor" id="a7eefe7408f34b6326f0c6e78af7eb05f"></a>
  1105. <div class="memitem">
  1106. <div class="memproto">
  1107. <table class="mlabels">
  1108. <tr>
  1109. <td class="mlabels-left">
  1110. <table class="memname">
  1111. <tr>
  1112. <td class="memname">bool FatFile::isHidden </td>
  1113. <td>(</td>
  1114. <td class="paramname"></td><td>)</td>
  1115. <td> const</td>
  1116. </tr>
  1117. </table>
  1118. </td>
  1119. <td class="mlabels-right">
  1120. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1121. </tr>
  1122. </table>
  1123. </div><div class="memdoc">
  1124. <dl class="section return"><dt>Returns</dt><dd>True if this is a hidden file else false. </dd></dl>
  1125. </div>
  1126. </div>
  1127. <a class="anchor" id="aed36d17f8fde597b6ed9446faec1f7e3"></a>
  1128. <div class="memitem">
  1129. <div class="memproto">
  1130. <table class="mlabels">
  1131. <tr>
  1132. <td class="mlabels-left">
  1133. <table class="memname">
  1134. <tr>
  1135. <td class="memname">bool FatFile::isLFN </td>
  1136. <td>(</td>
  1137. <td class="paramname"></td><td>)</td>
  1138. <td> const</td>
  1139. </tr>
  1140. </table>
  1141. </td>
  1142. <td class="mlabels-right">
  1143. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1144. </tr>
  1145. </table>
  1146. </div><div class="memdoc">
  1147. <dl class="section return"><dt>Returns</dt><dd>true if this file has a Long <a class="el" href="class_file.html" title="Arduino SD.h style File API. ">File</a> Name. </dd></dl>
  1148. </div>
  1149. </div>
  1150. <a class="anchor" id="a4c8a07b081f04aa25839c6f56c739bdc"></a>
  1151. <div class="memitem">
  1152. <div class="memproto">
  1153. <table class="mlabels">
  1154. <tr>
  1155. <td class="mlabels-left">
  1156. <table class="memname">
  1157. <tr>
  1158. <td class="memname">bool FatFile::isOpen </td>
  1159. <td>(</td>
  1160. <td class="paramname"></td><td>)</td>
  1161. <td> const</td>
  1162. </tr>
  1163. </table>
  1164. </td>
  1165. <td class="mlabels-right">
  1166. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1167. </tr>
  1168. </table>
  1169. </div><div class="memdoc">
  1170. <dl class="section return"><dt>Returns</dt><dd>True if this is an open file/directory else false. </dd></dl>
  1171. </div>
  1172. </div>
  1173. <a class="anchor" id="a6872d3acb1e70f81c9c2be2495977583"></a>
  1174. <div class="memitem">
  1175. <div class="memproto">
  1176. <table class="mlabels">
  1177. <tr>
  1178. <td class="mlabels-left">
  1179. <table class="memname">
  1180. <tr>
  1181. <td class="memname">bool FatFile::isReadOnly </td>
  1182. <td>(</td>
  1183. <td class="paramname"></td><td>)</td>
  1184. <td> const</td>
  1185. </tr>
  1186. </table>
  1187. </td>
  1188. <td class="mlabels-right">
  1189. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1190. </tr>
  1191. </table>
  1192. </div><div class="memdoc">
  1193. <dl class="section return"><dt>Returns</dt><dd>True if file is read-only </dd></dl>
  1194. </div>
  1195. </div>
  1196. <a class="anchor" id="aa4a206803a4bf8243be20244c1aef4d2"></a>
  1197. <div class="memitem">
  1198. <div class="memproto">
  1199. <table class="mlabels">
  1200. <tr>
  1201. <td class="mlabels-left">
  1202. <table class="memname">
  1203. <tr>
  1204. <td class="memname">bool FatFile::isRoot </td>
  1205. <td>(</td>
  1206. <td class="paramname"></td><td>)</td>
  1207. <td> const</td>
  1208. </tr>
  1209. </table>
  1210. </td>
  1211. <td class="mlabels-right">
  1212. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1213. </tr>
  1214. </table>
  1215. </div><div class="memdoc">
  1216. <dl class="section return"><dt>Returns</dt><dd>True if this is the root directory. </dd></dl>
  1217. </div>
  1218. </div>
  1219. <a class="anchor" id="a1449b294e3a838396c62e47674ca8cf0"></a>
  1220. <div class="memitem">
  1221. <div class="memproto">
  1222. <table class="mlabels">
  1223. <tr>
  1224. <td class="mlabels-left">
  1225. <table class="memname">
  1226. <tr>
  1227. <td class="memname">bool FatFile::isRoot32 </td>
  1228. <td>(</td>
  1229. <td class="paramname"></td><td>)</td>
  1230. <td> const</td>
  1231. </tr>
  1232. </table>
  1233. </td>
  1234. <td class="mlabels-right">
  1235. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1236. </tr>
  1237. </table>
  1238. </div><div class="memdoc">
  1239. <dl class="section return"><dt>Returns</dt><dd>True if this is the FAT32 root directory. </dd></dl>
  1240. </div>
  1241. </div>
  1242. <a class="anchor" id="a8215bd4b21e11ec83fa88ef226ceb06f"></a>
  1243. <div class="memitem">
  1244. <div class="memproto">
  1245. <table class="mlabels">
  1246. <tr>
  1247. <td class="mlabels-left">
  1248. <table class="memname">
  1249. <tr>
  1250. <td class="memname">bool FatFile::isRootFixed </td>
  1251. <td>(</td>
  1252. <td class="paramname"></td><td>)</td>
  1253. <td> const</td>
  1254. </tr>
  1255. </table>
  1256. </td>
  1257. <td class="mlabels-right">
  1258. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1259. </tr>
  1260. </table>
  1261. </div><div class="memdoc">
  1262. <dl class="section return"><dt>Returns</dt><dd>True if this is the FAT12 of FAT16 root directory. </dd></dl>
  1263. </div>
  1264. </div>
  1265. <a class="anchor" id="a95b503b17442c2b364a2f53de1b2aeba"></a>
  1266. <div class="memitem">
  1267. <div class="memproto">
  1268. <table class="mlabels">
  1269. <tr>
  1270. <td class="mlabels-left">
  1271. <table class="memname">
  1272. <tr>
  1273. <td class="memname">bool FatFile::isSubDir </td>
  1274. <td>(</td>
  1275. <td class="paramname"></td><td>)</td>
  1276. <td> const</td>
  1277. </tr>
  1278. </table>
  1279. </td>
  1280. <td class="mlabels-right">
  1281. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1282. </tr>
  1283. </table>
  1284. </div><div class="memdoc">
  1285. <dl class="section return"><dt>Returns</dt><dd>True if this is a subdirectory else false. </dd></dl>
  1286. </div>
  1287. </div>
  1288. <a class="anchor" id="add932e13e5bf32ad467af6ec34824e3c"></a>
  1289. <div class="memitem">
  1290. <div class="memproto">
  1291. <table class="mlabels">
  1292. <tr>
  1293. <td class="mlabels-left">
  1294. <table class="memname">
  1295. <tr>
  1296. <td class="memname">bool FatFile::isSystem </td>
  1297. <td>(</td>
  1298. <td class="paramname"></td><td>)</td>
  1299. <td> const</td>
  1300. </tr>
  1301. </table>
  1302. </td>
  1303. <td class="mlabels-right">
  1304. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1305. </tr>
  1306. </table>
  1307. </div><div class="memdoc">
  1308. <dl class="section return"><dt>Returns</dt><dd>True if this is a system file else false. </dd></dl>
  1309. </div>
  1310. </div>
  1311. <a class="anchor" id="a94df8090f16e9666cdc53ca20f6aff90"></a>
  1312. <div class="memitem">
  1313. <div class="memproto">
  1314. <table class="mlabels">
  1315. <tr>
  1316. <td class="mlabels-left">
  1317. <table class="memname">
  1318. <tr>
  1319. <td class="memname">static bool FatFile::legal83Char </td>
  1320. <td>(</td>
  1321. <td class="paramtype">uint8_t&#160;</td>
  1322. <td class="paramname"><em>c</em></td><td>)</td>
  1323. <td></td>
  1324. </tr>
  1325. </table>
  1326. </td>
  1327. <td class="mlabels-right">
  1328. <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
  1329. </tr>
  1330. </table>
  1331. </div><div class="memdoc">
  1332. <p>Check for a legal 8.3 character. </p><dl class="params"><dt>Parameters</dt><dd>
  1333. <table class="params">
  1334. <tr><td class="paramdir">[in]</td><td class="paramname">c</td><td>Character to be checked. </td></tr>
  1335. </table>
  1336. </dd>
  1337. </dl>
  1338. <dl class="section return"><dt>Returns</dt><dd>true for a legal 8.3 character else false. </dd></dl>
  1339. </div>
  1340. </div>
  1341. <a class="anchor" id="ad49f688a494b351ccbb0102dcfafb925"></a>
  1342. <div class="memitem">
  1343. <div class="memproto">
  1344. <table class="mlabels">
  1345. <tr>
  1346. <td class="mlabels-left">
  1347. <table class="memname">
  1348. <tr>
  1349. <td class="memname">void FatFile::ls </td>
  1350. <td>(</td>
  1351. <td class="paramtype">uint8_t&#160;</td>
  1352. <td class="paramname"><em>flags</em> = <code>0</code></td><td>)</td>
  1353. <td></td>
  1354. </tr>
  1355. </table>
  1356. </td>
  1357. <td class="mlabels-right">
  1358. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1359. </tr>
  1360. </table>
  1361. </div><div class="memdoc">
  1362. <p>List directory contents.</p>
  1363. <dl class="params"><dt>Parameters</dt><dd>
  1364. <table class="params">
  1365. <tr><td class="paramdir">[in]</td><td class="paramname">flags</td><td>The inclusive OR of</td></tr>
  1366. </table>
  1367. </dd>
  1368. </dl>
  1369. <p>LS_DATE - Print file modification date</p>
  1370. <p>LS_SIZE - Print file size.</p>
  1371. <p>LS_R - Recursive list of subdirectories. </p>
  1372. </div>
  1373. </div>
  1374. <a class="anchor" id="acabf31ff85e696fbf384c49428012fea"></a>
  1375. <div class="memitem">
  1376. <div class="memproto">
  1377. <table class="memname">
  1378. <tr>
  1379. <td class="memname">void FatFile::ls </td>
  1380. <td>(</td>
  1381. <td class="paramtype"><a class="el" href="_fat_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *&#160;</td>
  1382. <td class="paramname"><em>pr</em>, </td>
  1383. </tr>
  1384. <tr>
  1385. <td class="paramkey"></td>
  1386. <td></td>
  1387. <td class="paramtype">uint8_t&#160;</td>
  1388. <td class="paramname"><em>flags</em> = <code>0</code>, </td>
  1389. </tr>
  1390. <tr>
  1391. <td class="paramkey"></td>
  1392. <td></td>
  1393. <td class="paramtype">uint8_t&#160;</td>
  1394. <td class="paramname"><em>indent</em> = <code>0</code>&#160;</td>
  1395. </tr>
  1396. <tr>
  1397. <td></td>
  1398. <td>)</td>
  1399. <td></td><td></td>
  1400. </tr>
  1401. </table>
  1402. </div><div class="memdoc">
  1403. <p>List directory contents.</p>
  1404. <dl class="params"><dt>Parameters</dt><dd>
  1405. <table class="params">
  1406. <tr><td class="paramdir">[in]</td><td class="paramname">pr</td><td>Print stream for list.</td></tr>
  1407. <tr><td class="paramdir">[in]</td><td class="paramname">flags</td><td>The inclusive OR of</td></tr>
  1408. </table>
  1409. </dd>
  1410. </dl>
  1411. <p>LS_DATE - Print file modification date</p>
  1412. <p>LS_SIZE - Print file size.</p>
  1413. <p>LS_R - Recursive list of subdirectories.</p>
  1414. <dl class="params"><dt>Parameters</dt><dd>
  1415. <table class="params">
  1416. <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>
  1417. </table>
  1418. </dd>
  1419. </dl>
  1420. </div>
  1421. </div>
  1422. <a class="anchor" id="abab5b9f72cc796388dd4eed01d13d90d"></a>
  1423. <div class="memitem">
  1424. <div class="memproto">
  1425. <table class="memname">
  1426. <tr>
  1427. <td class="memname">bool FatFile::mkdir </td>
  1428. <td>(</td>
  1429. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  1430. <td class="paramname"><em>dir</em>, </td>
  1431. </tr>
  1432. <tr>
  1433. <td class="paramkey"></td>
  1434. <td></td>
  1435. <td class="paramtype">const char *&#160;</td>
  1436. <td class="paramname"><em>path</em>, </td>
  1437. </tr>
  1438. <tr>
  1439. <td class="paramkey"></td>
  1440. <td></td>
  1441. <td class="paramtype">bool&#160;</td>
  1442. <td class="paramname"><em>pFlag</em> = <code>true</code>&#160;</td>
  1443. </tr>
  1444. <tr>
  1445. <td></td>
  1446. <td>)</td>
  1447. <td></td><td></td>
  1448. </tr>
  1449. </table>
  1450. </div><div class="memdoc">
  1451. <p>Make a new directory.</p>
  1452. <dl class="params"><dt>Parameters</dt><dd>
  1453. <table class="params">
  1454. <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>
  1455. <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>
  1456. <tr><td class="paramdir">[in]</td><td class="paramname">pFlag</td><td>Create missing parent directories if true.</td></tr>
  1457. </table>
  1458. </dd>
  1459. </dl>
  1460. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  1461. </div>
  1462. </div>
  1463. <a class="anchor" id="a5f64576d3d19177ab3cf3812b69abdfa"></a>
  1464. <div class="memitem">
  1465. <div class="memproto">
  1466. <table class="memname">
  1467. <tr>
  1468. <td class="memname">bool FatFile::open </td>
  1469. <td>(</td>
  1470. <td class="paramtype"><a class="el" href="class_fat_file_system.html">FatFileSystem</a> *&#160;</td>
  1471. <td class="paramname"><em>fs</em>, </td>
  1472. </tr>
  1473. <tr>
  1474. <td class="paramkey"></td>
  1475. <td></td>
  1476. <td class="paramtype">const char *&#160;</td>
  1477. <td class="paramname"><em>path</em>, </td>
  1478. </tr>
  1479. <tr>
  1480. <td class="paramkey"></td>
  1481. <td></td>
  1482. <td class="paramtype">uint8_t&#160;</td>
  1483. <td class="paramname"><em>oflag</em>&#160;</td>
  1484. </tr>
  1485. <tr>
  1486. <td></td>
  1487. <td>)</td>
  1488. <td></td><td></td>
  1489. </tr>
  1490. </table>
  1491. </div><div class="memdoc">
  1492. <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>
  1493. <dl class="params"><dt>Parameters</dt><dd>
  1494. <table class="params">
  1495. <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>
  1496. <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>
  1497. <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>
  1498. </table>
  1499. </dd>
  1500. </dl>
  1501. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  1502. </div>
  1503. </div>
  1504. <a class="anchor" id="ad3fa9daaccb4e4179fb88a8ca037aa80"></a>
  1505. <div class="memitem">
  1506. <div class="memproto">
  1507. <table class="memname">
  1508. <tr>
  1509. <td class="memname">bool FatFile::open </td>
  1510. <td>(</td>
  1511. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  1512. <td class="paramname"><em>dirFile</em>, </td>
  1513. </tr>
  1514. <tr>
  1515. <td class="paramkey"></td>
  1516. <td></td>
  1517. <td class="paramtype">uint16_t&#160;</td>
  1518. <td class="paramname"><em>index</em>, </td>
  1519. </tr>
  1520. <tr>
  1521. <td class="paramkey"></td>
  1522. <td></td>
  1523. <td class="paramtype">uint8_t&#160;</td>
  1524. <td class="paramname"><em>oflag</em>&#160;</td>
  1525. </tr>
  1526. <tr>
  1527. <td></td>
  1528. <td>)</td>
  1529. <td></td><td></td>
  1530. </tr>
  1531. </table>
  1532. </div><div class="memdoc">
  1533. <p>Open a file by index.</p>
  1534. <dl class="params"><dt>Parameters</dt><dd>
  1535. <table class="params">
  1536. <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>
  1537. <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>
  1538. <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>
  1539. </table>
  1540. </dd>
  1541. </dl>
  1542. <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>
  1543. </div>
  1544. </div>
  1545. <a class="anchor" id="a211be757679b18708f6b6a36464e4f61"></a>
  1546. <div class="memitem">
  1547. <div class="memproto">
  1548. <table class="memname">
  1549. <tr>
  1550. <td class="memname">bool FatFile::open </td>
  1551. <td>(</td>
  1552. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  1553. <td class="paramname"><em>dirFile</em>, </td>
  1554. </tr>
  1555. <tr>
  1556. <td class="paramkey"></td>
  1557. <td></td>
  1558. <td class="paramtype">const char *&#160;</td>
  1559. <td class="paramname"><em>path</em>, </td>
  1560. </tr>
  1561. <tr>
  1562. <td class="paramkey"></td>
  1563. <td></td>
  1564. <td class="paramtype">uint8_t&#160;</td>
  1565. <td class="paramname"><em>oflag</em>&#160;</td>
  1566. </tr>
  1567. <tr>
  1568. <td></td>
  1569. <td>)</td>
  1570. <td></td><td></td>
  1571. </tr>
  1572. </table>
  1573. </div><div class="memdoc">
  1574. <p>Open a file or directory by name.</p>
  1575. <dl class="params"><dt>Parameters</dt><dd>
  1576. <table class="params">
  1577. <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>
  1578. <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>
  1579. <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>
  1580. </table>
  1581. </dd>
  1582. </dl>
  1583. <p>O_READ - Open for reading.</p>
  1584. <p>O_RDONLY - Same as O_READ.</p>
  1585. <p>O_WRITE - Open for writing.</p>
  1586. <p>O_WRONLY - Same as O_WRITE.</p>
  1587. <p>O_RDWR - Open for reading and writing.</p>
  1588. <p>O_APPEND - If set, the file offset shall be set to the end of the file prior to each write.</p>
  1589. <p>O_AT_END - Set the initial position at the end of the file.</p>
  1590. <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>
  1591. <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>
  1592. <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>
  1593. <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>
  1594. <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>
  1595. <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>
  1596. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  1597. </div>
  1598. </div>
  1599. <a class="anchor" id="ab0e7075062c89f356441f80fc64d03e6"></a>
  1600. <div class="memitem">
  1601. <div class="memproto">
  1602. <table class="mlabels">
  1603. <tr>
  1604. <td class="mlabels-left">
  1605. <table class="memname">
  1606. <tr>
  1607. <td class="memname">bool FatFile::open </td>
  1608. <td>(</td>
  1609. <td class="paramtype">const char *&#160;</td>
  1610. <td class="paramname"><em>path</em>, </td>
  1611. </tr>
  1612. <tr>
  1613. <td class="paramkey"></td>
  1614. <td></td>
  1615. <td class="paramtype">uint8_t&#160;</td>
  1616. <td class="paramname"><em>oflag</em> = <code>O_READ</code>&#160;</td>
  1617. </tr>
  1618. <tr>
  1619. <td></td>
  1620. <td>)</td>
  1621. <td></td><td></td>
  1622. </tr>
  1623. </table>
  1624. </td>
  1625. <td class="mlabels-right">
  1626. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  1627. </tr>
  1628. </table>
  1629. </div><div class="memdoc">
  1630. <p>Open a file in the current working directory.</p>
  1631. <dl class="params"><dt>Parameters</dt><dd>
  1632. <table class="params">
  1633. <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>
  1634. <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>
  1635. </table>
  1636. </dd>
  1637. </dl>
  1638. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  1639. </div>
  1640. </div>
  1641. <a class="anchor" id="a8034c4649eb0d26715b1a8a69e73d9d0"></a>
  1642. <div class="memitem">
  1643. <div class="memproto">
  1644. <table class="memname">
  1645. <tr>
  1646. <td class="memname">bool FatFile::openNext </td>
  1647. <td>(</td>
  1648. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  1649. <td class="paramname"><em>dirFile</em>, </td>
  1650. </tr>
  1651. <tr>
  1652. <td class="paramkey"></td>
  1653. <td></td>
  1654. <td class="paramtype">uint8_t&#160;</td>
  1655. <td class="paramname"><em>oflag</em> = <code>O_READ</code>&#160;</td>
  1656. </tr>
  1657. <tr>
  1658. <td></td>
  1659. <td>)</td>
  1660. <td></td><td></td>
  1661. </tr>
  1662. </table>
  1663. </div><div class="memdoc">
  1664. <p>Open the next file or subdirectory in a directory.</p>
  1665. <dl class="params"><dt>Parameters</dt><dd>
  1666. <table class="params">
  1667. <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>
  1668. <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>
  1669. </table>
  1670. </dd>
  1671. </dl>
  1672. <dl class="section return"><dt>Returns</dt><dd>true for success or false for failure. </dd></dl>
  1673. </div>
  1674. </div>
  1675. <a class="anchor" id="a7e0c0548fed3a69e7284b91b694439d4"></a>
  1676. <div class="memitem">
  1677. <div class="memproto">
  1678. <table class="memname">
  1679. <tr>
  1680. <td class="memname">bool FatFile::openRoot </td>
  1681. <td>(</td>
  1682. <td class="paramtype"><a class="el" href="class_fat_volume.html">FatVolume</a> *&#160;</td>
  1683. <td class="paramname"><em>vol</em></td><td>)</td>
  1684. <td></td>
  1685. </tr>
  1686. </table>
  1687. </div><div class="memdoc">
  1688. <p>Open a volume's root directory.</p>
  1689. <dl class="params"><dt>Parameters</dt><dd>
  1690. <table class="params">
  1691. <tr><td class="paramdir">[in]</td><td class="paramname">vol</td><td>The FAT volume containing the root directory to be opened.</td></tr>
  1692. </table>
  1693. </dd>
  1694. </dl>
  1695. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  1696. </div>
  1697. </div>
  1698. <a class="anchor" id="ac05b7136b887539426856c623869aa3a"></a>
  1699. <div class="memitem">
  1700. <div class="memproto">
  1701. <table class="memname">
  1702. <tr>
  1703. <td class="memname">int FatFile::peek </td>
  1704. <td>(</td>
  1705. <td class="paramname"></td><td>)</td>
  1706. <td></td>
  1707. </tr>
  1708. </table>
  1709. </div><div class="memdoc">
  1710. <p>Return the next available byte without consuming it.</p>
  1711. <dl class="section return"><dt>Returns</dt><dd>The byte if no error and not at eof else -1; </dd></dl>
  1712. </div>
  1713. </div>
  1714. <a class="anchor" id="a558530f20314a8d8ee3d1a488fc7f46e"></a>
  1715. <div class="memitem">
  1716. <div class="memproto">
  1717. <table class="memname">
  1718. <tr>
  1719. <td class="memname">bool FatFile::printCreateDateTime </td>
  1720. <td>(</td>
  1721. <td class="paramtype"><a class="el" href="_fat_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *&#160;</td>
  1722. <td class="paramname"><em>pr</em></td><td>)</td>
  1723. <td></td>
  1724. </tr>
  1725. </table>
  1726. </div><div class="memdoc">
  1727. <p>Print a file's creation date and time</p>
  1728. <dl class="params"><dt>Parameters</dt><dd>
  1729. <table class="params">
  1730. <tr><td class="paramdir">[in]</td><td class="paramname">pr</td><td>Print stream for output.</td></tr>
  1731. </table>
  1732. </dd>
  1733. </dl>
  1734. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  1735. </div>
  1736. </div>
  1737. <a class="anchor" id="a8fdb038aafdf3a17ac80b53c063aa73b"></a>
  1738. <div class="memitem">
  1739. <div class="memproto">
  1740. <table class="mlabels">
  1741. <tr>
  1742. <td class="mlabels-left">
  1743. <table class="memname">
  1744. <tr>
  1745. <td class="memname">static void FatFile::printFatDate </td>
  1746. <td>(</td>
  1747. <td class="paramtype">uint16_t&#160;</td>
  1748. <td class="paramname"><em>fatDate</em></td><td>)</td>
  1749. <td></td>
  1750. </tr>
  1751. </table>
  1752. </td>
  1753. <td class="mlabels-right">
  1754. <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
  1755. </tr>
  1756. </table>
  1757. </div><div class="memdoc">
  1758. <p>Print a directory date field.</p>
  1759. <p>Format is yyyy-mm-dd.</p>
  1760. <dl class="params"><dt>Parameters</dt><dd>
  1761. <table class="params">
  1762. <tr><td class="paramdir">[in]</td><td class="paramname">fatDate</td><td>The date field from a directory entry. </td></tr>
  1763. </table>
  1764. </dd>
  1765. </dl>
  1766. </div>
  1767. </div>
  1768. <a class="anchor" id="ada5364f66204b1a64afbf9d2e6cd2b0b"></a>
  1769. <div class="memitem">
  1770. <div class="memproto">
  1771. <table class="mlabels">
  1772. <tr>
  1773. <td class="mlabels-left">
  1774. <table class="memname">
  1775. <tr>
  1776. <td class="memname">void FatFile::printFatDate </td>
  1777. <td>(</td>
  1778. <td class="paramtype"><a class="el" href="_fat_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *&#160;</td>
  1779. <td class="paramname"><em>pr</em>, </td>
  1780. </tr>
  1781. <tr>
  1782. <td class="paramkey"></td>
  1783. <td></td>
  1784. <td class="paramtype">uint16_t&#160;</td>
  1785. <td class="paramname"><em>fatDate</em>&#160;</td>
  1786. </tr>
  1787. <tr>
  1788. <td></td>
  1789. <td>)</td>
  1790. <td></td><td></td>
  1791. </tr>
  1792. </table>
  1793. </td>
  1794. <td class="mlabels-right">
  1795. <span class="mlabels"><span class="mlabel">static</span></span> </td>
  1796. </tr>
  1797. </table>
  1798. </div><div class="memdoc">
  1799. <p>Print a directory date field.</p>
  1800. <p>Format is yyyy-mm-dd.</p>
  1801. <dl class="params"><dt>Parameters</dt><dd>
  1802. <table class="params">
  1803. <tr><td class="paramdir">[in]</td><td class="paramname">pr</td><td>Print stream for output. </td></tr>
  1804. <tr><td class="paramdir">[in]</td><td class="paramname">fatDate</td><td>The date field from a directory entry. </td></tr>
  1805. </table>
  1806. </dd>
  1807. </dl>
  1808. </div>
  1809. </div>
  1810. <a class="anchor" id="a7740731f08ef97de7dfbc9b075c4c7d1"></a>
  1811. <div class="memitem">
  1812. <div class="memproto">
  1813. <table class="mlabels">
  1814. <tr>
  1815. <td class="mlabels-left">
  1816. <table class="memname">
  1817. <tr>
  1818. <td class="memname">static void FatFile::printFatTime </td>
  1819. <td>(</td>
  1820. <td class="paramtype">uint16_t&#160;</td>
  1821. <td class="paramname"><em>fatTime</em></td><td>)</td>
  1822. <td></td>
  1823. </tr>
  1824. </table>
  1825. </td>
  1826. <td class="mlabels-right">
  1827. <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
  1828. </tr>
  1829. </table>
  1830. </div><div class="memdoc">
  1831. <p>Print a directory time field.</p>
  1832. <p>Format is hh:mm:ss.</p>
  1833. <dl class="params"><dt>Parameters</dt><dd>
  1834. <table class="params">
  1835. <tr><td class="paramdir">[in]</td><td class="paramname">fatTime</td><td>The time field from a directory entry. </td></tr>
  1836. </table>
  1837. </dd>
  1838. </dl>
  1839. </div>
  1840. </div>
  1841. <a class="anchor" id="a4e7e56ba52ca17c602af1b85684b09a9"></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">void FatFile::printFatTime </td>
  1850. <td>(</td>
  1851. <td class="paramtype"><a class="el" href="_fat_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *&#160;</td>
  1852. <td class="paramname"><em>pr</em>, </td>
  1853. </tr>
  1854. <tr>
  1855. <td class="paramkey"></td>
  1856. <td></td>
  1857. <td class="paramtype">uint16_t&#160;</td>
  1858. <td class="paramname"><em>fatTime</em>&#160;</td>
  1859. </tr>
  1860. <tr>
  1861. <td></td>
  1862. <td>)</td>
  1863. <td></td><td></td>
  1864. </tr>
  1865. </table>
  1866. </td>
  1867. <td class="mlabels-right">
  1868. <span class="mlabels"><span class="mlabel">static</span></span> </td>
  1869. </tr>
  1870. </table>
  1871. </div><div class="memdoc">
  1872. <p>Print a directory time field.</p>
  1873. <p>Format is hh:mm:ss.</p>
  1874. <dl class="params"><dt>Parameters</dt><dd>
  1875. <table class="params">
  1876. <tr><td class="paramdir">[in]</td><td class="paramname">pr</td><td>Print stream for output. </td></tr>
  1877. <tr><td class="paramdir">[in]</td><td class="paramname">fatTime</td><td>The time field from a directory entry. </td></tr>
  1878. </table>
  1879. </dd>
  1880. </dl>
  1881. </div>
  1882. </div>
  1883. <a class="anchor" id="a7478cad0f9e5079311b9e1fa558016ff"></a>
  1884. <div class="memitem">
  1885. <div class="memproto">
  1886. <table class="memname">
  1887. <tr>
  1888. <td class="memname">int FatFile::printField </td>
  1889. <td>(</td>
  1890. <td class="paramtype">float&#160;</td>
  1891. <td class="paramname"><em>value</em>, </td>
  1892. </tr>
  1893. <tr>
  1894. <td class="paramkey"></td>
  1895. <td></td>
  1896. <td class="paramtype">char&#160;</td>
  1897. <td class="paramname"><em>term</em>, </td>
  1898. </tr>
  1899. <tr>
  1900. <td class="paramkey"></td>
  1901. <td></td>
  1902. <td class="paramtype">uint8_t&#160;</td>
  1903. <td class="paramname"><em>prec</em> = <code>2</code>&#160;</td>
  1904. </tr>
  1905. <tr>
  1906. <td></td>
  1907. <td>)</td>
  1908. <td></td><td></td>
  1909. </tr>
  1910. </table>
  1911. </div><div class="memdoc">
  1912. <p>Print a number followed by a field terminator. </p><dl class="params"><dt>Parameters</dt><dd>
  1913. <table class="params">
  1914. <tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>The number to be printed. </td></tr>
  1915. <tr><td class="paramdir">[in]</td><td class="paramname">term</td><td>The field terminator. Use '\n' for CR LF. </td></tr>
  1916. <tr><td class="paramdir">[in]</td><td class="paramname">prec</td><td>Number of digits after decimal point. </td></tr>
  1917. </table>
  1918. </dd>
  1919. </dl>
  1920. <dl class="section return"><dt>Returns</dt><dd>The number of bytes written or -1 if an error occurs. </dd></dl>
  1921. </div>
  1922. </div>
  1923. <a class="anchor" id="abd3e1747511216462b3ef98167156cbb"></a>
  1924. <div class="memitem">
  1925. <div class="memproto">
  1926. <table class="memname">
  1927. <tr>
  1928. <td class="memname">int FatFile::printField </td>
  1929. <td>(</td>
  1930. <td class="paramtype">int16_t&#160;</td>
  1931. <td class="paramname"><em>value</em>, </td>
  1932. </tr>
  1933. <tr>
  1934. <td class="paramkey"></td>
  1935. <td></td>
  1936. <td class="paramtype">char&#160;</td>
  1937. <td class="paramname"><em>term</em>&#160;</td>
  1938. </tr>
  1939. <tr>
  1940. <td></td>
  1941. <td>)</td>
  1942. <td></td><td></td>
  1943. </tr>
  1944. </table>
  1945. </div><div class="memdoc">
  1946. <p>Print a number followed by a field terminator. </p><dl class="params"><dt>Parameters</dt><dd>
  1947. <table class="params">
  1948. <tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>The number to be printed. </td></tr>
  1949. <tr><td class="paramdir">[in]</td><td class="paramname">term</td><td>The field terminator. Use '\n' for CR LF. </td></tr>
  1950. </table>
  1951. </dd>
  1952. </dl>
  1953. <dl class="section return"><dt>Returns</dt><dd>The number of bytes written or -1 if an error occurs. </dd></dl>
  1954. </div>
  1955. </div>
  1956. <a class="anchor" id="a9972c2419c293ef9c382bff666b9ae4d"></a>
  1957. <div class="memitem">
  1958. <div class="memproto">
  1959. <table class="memname">
  1960. <tr>
  1961. <td class="memname">int FatFile::printField </td>
  1962. <td>(</td>
  1963. <td class="paramtype">uint16_t&#160;</td>
  1964. <td class="paramname"><em>value</em>, </td>
  1965. </tr>
  1966. <tr>
  1967. <td class="paramkey"></td>
  1968. <td></td>
  1969. <td class="paramtype">char&#160;</td>
  1970. <td class="paramname"><em>term</em>&#160;</td>
  1971. </tr>
  1972. <tr>
  1973. <td></td>
  1974. <td>)</td>
  1975. <td></td><td></td>
  1976. </tr>
  1977. </table>
  1978. </div><div class="memdoc">
  1979. <p>Print a number followed by a field terminator. </p><dl class="params"><dt>Parameters</dt><dd>
  1980. <table class="params">
  1981. <tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>The number to be printed. </td></tr>
  1982. <tr><td class="paramdir">[in]</td><td class="paramname">term</td><td>The field terminator. Use '\n' for CR LF. </td></tr>
  1983. </table>
  1984. </dd>
  1985. </dl>
  1986. <dl class="section return"><dt>Returns</dt><dd>The number of bytes written or -1 if an error occurs. </dd></dl>
  1987. </div>
  1988. </div>
  1989. <a class="anchor" id="a41b3b32dd8482429b74c7af3432d6cf8"></a>
  1990. <div class="memitem">
  1991. <div class="memproto">
  1992. <table class="memname">
  1993. <tr>
  1994. <td class="memname">int FatFile::printField </td>
  1995. <td>(</td>
  1996. <td class="paramtype">int32_t&#160;</td>
  1997. <td class="paramname"><em>value</em>, </td>
  1998. </tr>
  1999. <tr>
  2000. <td class="paramkey"></td>
  2001. <td></td>
  2002. <td class="paramtype">char&#160;</td>
  2003. <td class="paramname"><em>term</em>&#160;</td>
  2004. </tr>
  2005. <tr>
  2006. <td></td>
  2007. <td>)</td>
  2008. <td></td><td></td>
  2009. </tr>
  2010. </table>
  2011. </div><div class="memdoc">
  2012. <p>Print a number followed by a field terminator. </p><dl class="params"><dt>Parameters</dt><dd>
  2013. <table class="params">
  2014. <tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>The number to be printed. </td></tr>
  2015. <tr><td class="paramdir">[in]</td><td class="paramname">term</td><td>The field terminator. Use '\n' for CR LF. </td></tr>
  2016. </table>
  2017. </dd>
  2018. </dl>
  2019. <dl class="section return"><dt>Returns</dt><dd>The number of bytes written or -1 if an error occurs. </dd></dl>
  2020. </div>
  2021. </div>
  2022. <a class="anchor" id="a097240f08baadeb1c64b63eab9afb088"></a>
  2023. <div class="memitem">
  2024. <div class="memproto">
  2025. <table class="memname">
  2026. <tr>
  2027. <td class="memname">int FatFile::printField </td>
  2028. <td>(</td>
  2029. <td class="paramtype">uint32_t&#160;</td>
  2030. <td class="paramname"><em>value</em>, </td>
  2031. </tr>
  2032. <tr>
  2033. <td class="paramkey"></td>
  2034. <td></td>
  2035. <td class="paramtype">char&#160;</td>
  2036. <td class="paramname"><em>term</em>&#160;</td>
  2037. </tr>
  2038. <tr>
  2039. <td></td>
  2040. <td>)</td>
  2041. <td></td><td></td>
  2042. </tr>
  2043. </table>
  2044. </div><div class="memdoc">
  2045. <p>Print a number followed by a field terminator. </p><dl class="params"><dt>Parameters</dt><dd>
  2046. <table class="params">
  2047. <tr><td class="paramdir">[in]</td><td class="paramname">value</td><td>The number to be printed. </td></tr>
  2048. <tr><td class="paramdir">[in]</td><td class="paramname">term</td><td>The field terminator. Use '\n' for CR LF. </td></tr>
  2049. </table>
  2050. </dd>
  2051. </dl>
  2052. <dl class="section return"><dt>Returns</dt><dd>The number of bytes written or -1 if an error occurs. </dd></dl>
  2053. </div>
  2054. </div>
  2055. <a class="anchor" id="a12a5d2de2737c201aa39ca1bd2ab9c47"></a>
  2056. <div class="memitem">
  2057. <div class="memproto">
  2058. <table class="memname">
  2059. <tr>
  2060. <td class="memname">size_t FatFile::printFileSize </td>
  2061. <td>(</td>
  2062. <td class="paramtype"><a class="el" href="_fat_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *&#160;</td>
  2063. <td class="paramname"><em>pr</em></td><td>)</td>
  2064. <td></td>
  2065. </tr>
  2066. </table>
  2067. </div><div class="memdoc">
  2068. <p>Print a file's size.</p>
  2069. <dl class="params"><dt>Parameters</dt><dd>
  2070. <table class="params">
  2071. <tr><td class="paramdir">[in]</td><td class="paramname">pr</td><td>Print stream for output.</td></tr>
  2072. </table>
  2073. </dd>
  2074. </dl>
  2075. <dl class="section return"><dt>Returns</dt><dd>The number of characters printed is returned for success and zero is returned for failure. </dd></dl>
  2076. </div>
  2077. </div>
  2078. <a class="anchor" id="a05cee5df46a370bf916d3ba597c82e39"></a>
  2079. <div class="memitem">
  2080. <div class="memproto">
  2081. <table class="memname">
  2082. <tr>
  2083. <td class="memname">bool FatFile::printModifyDateTime </td>
  2084. <td>(</td>
  2085. <td class="paramtype"><a class="el" href="_fat_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *&#160;</td>
  2086. <td class="paramname"><em>pr</em></td><td>)</td>
  2087. <td></td>
  2088. </tr>
  2089. </table>
  2090. </div><div class="memdoc">
  2091. <p>Print a file's modify date and time</p>
  2092. <dl class="params"><dt>Parameters</dt><dd>
  2093. <table class="params">
  2094. <tr><td class="paramdir">[in]</td><td class="paramname">pr</td><td>Print stream for output.</td></tr>
  2095. </table>
  2096. </dd>
  2097. </dl>
  2098. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  2099. </div>
  2100. </div>
  2101. <a class="anchor" id="ad1cbc3aeb0f5193b7a26595966da9621"></a>
  2102. <div class="memitem">
  2103. <div class="memproto">
  2104. <table class="mlabels">
  2105. <tr>
  2106. <td class="mlabels-left">
  2107. <table class="memname">
  2108. <tr>
  2109. <td class="memname">size_t FatFile::printName </td>
  2110. <td>(</td>
  2111. <td class="paramname"></td><td>)</td>
  2112. <td></td>
  2113. </tr>
  2114. </table>
  2115. </td>
  2116. <td class="mlabels-right">
  2117. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  2118. </tr>
  2119. </table>
  2120. </div><div class="memdoc">
  2121. <p>Print a file's name.</p>
  2122. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  2123. </div>
  2124. </div>
  2125. <a class="anchor" id="afe18a787fb8640e2d2483370c770f82f"></a>
  2126. <div class="memitem">
  2127. <div class="memproto">
  2128. <table class="memname">
  2129. <tr>
  2130. <td class="memname">size_t FatFile::printName </td>
  2131. <td>(</td>
  2132. <td class="paramtype"><a class="el" href="_fat_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *&#160;</td>
  2133. <td class="paramname"><em>pr</em></td><td>)</td>
  2134. <td></td>
  2135. </tr>
  2136. </table>
  2137. </div><div class="memdoc">
  2138. <p>Print a file's name</p>
  2139. <dl class="params"><dt>Parameters</dt><dd>
  2140. <table class="params">
  2141. <tr><td class="paramdir">[in]</td><td class="paramname">pr</td><td>Print stream for output.</td></tr>
  2142. </table>
  2143. </dd>
  2144. </dl>
  2145. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  2146. </div>
  2147. </div>
  2148. <a class="anchor" id="a791cd7aade71f609aab62ec018aea3c0"></a>
  2149. <div class="memitem">
  2150. <div class="memproto">
  2151. <table class="memname">
  2152. <tr>
  2153. <td class="memname">size_t FatFile::printSFN </td>
  2154. <td>(</td>
  2155. <td class="paramtype"><a class="el" href="_fat_volume_8h.html#ac62f6449331cfe1a71f29be30efe7890">print_t</a> *&#160;</td>
  2156. <td class="paramname"><em>pr</em></td><td>)</td>
  2157. <td></td>
  2158. </tr>
  2159. </table>
  2160. </div><div class="memdoc">
  2161. <p>Print a file's Short <a class="el" href="class_file.html" title="Arduino SD.h style File API. ">File</a> Name.</p>
  2162. <dl class="params"><dt>Parameters</dt><dd>
  2163. <table class="params">
  2164. <tr><td class="paramdir">[in]</td><td class="paramname">pr</td><td>Print stream for output.</td></tr>
  2165. </table>
  2166. </dd>
  2167. </dl>
  2168. <dl class="section return"><dt>Returns</dt><dd>The number of characters printed is returned for success and zero is returned for failure. </dd></dl>
  2169. </div>
  2170. </div>
  2171. <a class="anchor" id="a60ae55ff6fe158c2340071d702a363c5"></a>
  2172. <div class="memitem">
  2173. <div class="memproto">
  2174. <table class="mlabels">
  2175. <tr>
  2176. <td class="mlabels-left">
  2177. <table class="memname">
  2178. <tr>
  2179. <td class="memname">int FatFile::read </td>
  2180. <td>(</td>
  2181. <td class="paramname"></td><td>)</td>
  2182. <td></td>
  2183. </tr>
  2184. </table>
  2185. </td>
  2186. <td class="mlabels-right">
  2187. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  2188. </tr>
  2189. </table>
  2190. </div><div class="memdoc">
  2191. <p>Read the next byte from a file.</p>
  2192. <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>
  2193. </div>
  2194. </div>
  2195. <a class="anchor" id="a200e6e0553d5b709520c9dfac9ef77dd"></a>
  2196. <div class="memitem">
  2197. <div class="memproto">
  2198. <table class="memname">
  2199. <tr>
  2200. <td class="memname">int FatFile::read </td>
  2201. <td>(</td>
  2202. <td class="paramtype">void *&#160;</td>
  2203. <td class="paramname"><em>buf</em>, </td>
  2204. </tr>
  2205. <tr>
  2206. <td class="paramkey"></td>
  2207. <td></td>
  2208. <td class="paramtype">size_t&#160;</td>
  2209. <td class="paramname"><em>nbyte</em>&#160;</td>
  2210. </tr>
  2211. <tr>
  2212. <td></td>
  2213. <td>)</td>
  2214. <td></td><td></td>
  2215. </tr>
  2216. </table>
  2217. </div><div class="memdoc">
  2218. <p>Read data from a file starting at the current position.</p>
  2219. <dl class="params"><dt>Parameters</dt><dd>
  2220. <table class="params">
  2221. <tr><td class="paramdir">[out]</td><td class="paramname">buf</td><td>Pointer to the location that will receive the data.</td></tr>
  2222. <tr><td class="paramdir">[in]</td><td class="paramname">nbyte</td><td>Maximum number of bytes to read.</td></tr>
  2223. </table>
  2224. </dd>
  2225. </dl>
  2226. <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>
  2227. </div>
  2228. </div>
  2229. <a class="anchor" id="a1325afe074c3efecff666678cd9f116a"></a>
  2230. <div class="memitem">
  2231. <div class="memproto">
  2232. <table class="memname">
  2233. <tr>
  2234. <td class="memname">int8_t FatFile::readDir </td>
  2235. <td>(</td>
  2236. <td class="paramtype"><a class="el" href="_fat_structs_8h.html#a803db59d4e16a0c54a647afc6a7954e3">dir_t</a> *&#160;</td>
  2237. <td class="paramname"><em>dir</em></td><td>)</td>
  2238. <td></td>
  2239. </tr>
  2240. </table>
  2241. </div><div class="memdoc">
  2242. <p>Read the next directory entry from a directory file.</p>
  2243. <dl class="params"><dt>Parameters</dt><dd>
  2244. <table class="params">
  2245. <tr><td class="paramdir">[out]</td><td class="paramname">dir</td><td>The dir_t struct that will receive the data.</td></tr>
  2246. </table>
  2247. </dd>
  2248. </dl>
  2249. <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>
  2250. </div>
  2251. </div>
  2252. <a class="anchor" id="ac837a537fbcca14c7aa390c5fc9f4e7c"></a>
  2253. <div class="memitem">
  2254. <div class="memproto">
  2255. <table class="memname">
  2256. <tr>
  2257. <td class="memname">bool FatFile::remove </td>
  2258. <td>(</td>
  2259. <td class="paramname"></td><td>)</td>
  2260. <td></td>
  2261. </tr>
  2262. </table>
  2263. </div><div class="memdoc">
  2264. <p>Remove a file.</p>
  2265. <p>The directory entry and all data for the file are deleted.</p>
  2266. <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>
  2267. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  2268. </div>
  2269. </div>
  2270. <a class="anchor" id="afe820bbb056863e91ec482961c8dc695"></a>
  2271. <div class="memitem">
  2272. <div class="memproto">
  2273. <table class="mlabels">
  2274. <tr>
  2275. <td class="mlabels-left">
  2276. <table class="memname">
  2277. <tr>
  2278. <td class="memname">bool FatFile::remove </td>
  2279. <td>(</td>
  2280. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  2281. <td class="paramname"><em>dirFile</em>, </td>
  2282. </tr>
  2283. <tr>
  2284. <td class="paramkey"></td>
  2285. <td></td>
  2286. <td class="paramtype">const char *&#160;</td>
  2287. <td class="paramname"><em>path</em>&#160;</td>
  2288. </tr>
  2289. <tr>
  2290. <td></td>
  2291. <td>)</td>
  2292. <td></td><td></td>
  2293. </tr>
  2294. </table>
  2295. </td>
  2296. <td class="mlabels-right">
  2297. <span class="mlabels"><span class="mlabel">static</span></span> </td>
  2298. </tr>
  2299. </table>
  2300. </div><div class="memdoc">
  2301. <p>Remove a file.</p>
  2302. <p>The directory entry and all data for the file are deleted.</p>
  2303. <dl class="params"><dt>Parameters</dt><dd>
  2304. <table class="params">
  2305. <tr><td class="paramdir">[in]</td><td class="paramname">dirFile</td><td>The directory that contains the file. </td></tr>
  2306. <tr><td class="paramdir">[in]</td><td class="paramname">path</td><td>Path for the file to be removed.</td></tr>
  2307. </table>
  2308. </dd>
  2309. </dl>
  2310. <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>
  2311. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  2312. </div>
  2313. </div>
  2314. <a class="anchor" id="a4b42f2454ff462555c07ea094a92a1e0"></a>
  2315. <div class="memitem">
  2316. <div class="memproto">
  2317. <table class="memname">
  2318. <tr>
  2319. <td class="memname">bool FatFile::rename </td>
  2320. <td>(</td>
  2321. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  2322. <td class="paramname"><em>dirFile</em>, </td>
  2323. </tr>
  2324. <tr>
  2325. <td class="paramkey"></td>
  2326. <td></td>
  2327. <td class="paramtype">const char *&#160;</td>
  2328. <td class="paramname"><em>newPath</em>&#160;</td>
  2329. </tr>
  2330. <tr>
  2331. <td></td>
  2332. <td>)</td>
  2333. <td></td><td></td>
  2334. </tr>
  2335. </table>
  2336. </div><div class="memdoc">
  2337. <p>Rename a file or subdirectory.</p>
  2338. <dl class="params"><dt>Parameters</dt><dd>
  2339. <table class="params">
  2340. <tr><td class="paramdir">[in]</td><td class="paramname">dirFile</td><td>Directory for the new path. </td></tr>
  2341. <tr><td class="paramdir">[in]</td><td class="paramname">newPath</td><td>New path name for the file/directory.</td></tr>
  2342. </table>
  2343. </dd>
  2344. </dl>
  2345. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  2346. </div>
  2347. </div>
  2348. <a class="anchor" id="a5aac6e0b3cb08fc8b8668e916a8b0ca5"></a>
  2349. <div class="memitem">
  2350. <div class="memproto">
  2351. <table class="mlabels">
  2352. <tr>
  2353. <td class="mlabels-left">
  2354. <table class="memname">
  2355. <tr>
  2356. <td class="memname">void FatFile::rewind </td>
  2357. <td>(</td>
  2358. <td class="paramname"></td><td>)</td>
  2359. <td></td>
  2360. </tr>
  2361. </table>
  2362. </td>
  2363. <td class="mlabels-right">
  2364. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  2365. </tr>
  2366. </table>
  2367. </div><div class="memdoc">
  2368. <p>Set the file's current position to zero. </p>
  2369. </div>
  2370. </div>
  2371. <a class="anchor" id="a9515bac181d33e7f0125e88fa2ccd283"></a>
  2372. <div class="memitem">
  2373. <div class="memproto">
  2374. <table class="memname">
  2375. <tr>
  2376. <td class="memname">bool FatFile::rmdir </td>
  2377. <td>(</td>
  2378. <td class="paramname"></td><td>)</td>
  2379. <td></td>
  2380. </tr>
  2381. </table>
  2382. </div><div class="memdoc">
  2383. <p>Remove a directory file.</p>
  2384. <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>
  2385. <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>
  2386. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  2387. </div>
  2388. </div>
  2389. <a class="anchor" id="ac780a80526f86d3def701ecdc99d8bfe"></a>
  2390. <div class="memitem">
  2391. <div class="memproto">
  2392. <table class="memname">
  2393. <tr>
  2394. <td class="memname">bool FatFile::rmRfStar </td>
  2395. <td>(</td>
  2396. <td class="paramname"></td><td>)</td>
  2397. <td></td>
  2398. </tr>
  2399. </table>
  2400. </div><div class="memdoc">
  2401. <p>Recursively delete a directory and all contained files.</p>
  2402. <p>This is like the Unix/Linux 'rm -rf *' if called with the root directory hence the name.</p>
  2403. <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>
  2404. <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>
  2405. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  2406. </div>
  2407. </div>
  2408. <a class="anchor" id="a5812037ea30777cc350698ad26f2c73f"></a>
  2409. <div class="memitem">
  2410. <div class="memproto">
  2411. <table class="mlabels">
  2412. <tr>
  2413. <td class="mlabels-left">
  2414. <table class="memname">
  2415. <tr>
  2416. <td class="memname">bool FatFile::seekCur </td>
  2417. <td>(</td>
  2418. <td class="paramtype">int32_t&#160;</td>
  2419. <td class="paramname"><em>offset</em></td><td>)</td>
  2420. <td></td>
  2421. </tr>
  2422. </table>
  2423. </td>
  2424. <td class="mlabels-right">
  2425. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  2426. </tr>
  2427. </table>
  2428. </div><div class="memdoc">
  2429. <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>
  2430. <table class="params">
  2431. <tr><td class="paramdir">[in]</td><td class="paramname">offset</td><td>The new position in bytes from the current position. </td></tr>
  2432. </table>
  2433. </dd>
  2434. </dl>
  2435. <dl class="section return"><dt>Returns</dt><dd>true for success or false for failure. </dd></dl>
  2436. </div>
  2437. </div>
  2438. <a class="anchor" id="a84f677f4e75ef6fa2eb632f4cdf6b486"></a>
  2439. <div class="memitem">
  2440. <div class="memproto">
  2441. <table class="mlabels">
  2442. <tr>
  2443. <td class="mlabels-left">
  2444. <table class="memname">
  2445. <tr>
  2446. <td class="memname">bool FatFile::seekEnd </td>
  2447. <td>(</td>
  2448. <td class="paramtype">int32_t&#160;</td>
  2449. <td class="paramname"><em>offset</em> = <code>0</code></td><td>)</td>
  2450. <td></td>
  2451. </tr>
  2452. </table>
  2453. </td>
  2454. <td class="mlabels-right">
  2455. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  2456. </tr>
  2457. </table>
  2458. </div><div class="memdoc">
  2459. <p>Set the files position to end-of-file + <em>offset</em>. See <a class="el" href="class_fat_file.html#ab067190d25733ed7e697d9890f61fd7a">seekSet()</a>. Can't be used for directory files since file size is not defined. </p><dl class="params"><dt>Parameters</dt><dd>
  2460. <table class="params">
  2461. <tr><td class="paramdir">[in]</td><td class="paramname">offset</td><td>The new position in bytes from end-of-file. </td></tr>
  2462. </table>
  2463. </dd>
  2464. </dl>
  2465. <dl class="section return"><dt>Returns</dt><dd>true for success or false for failure. </dd></dl>
  2466. </div>
  2467. </div>
  2468. <a class="anchor" id="ab067190d25733ed7e697d9890f61fd7a"></a>
  2469. <div class="memitem">
  2470. <div class="memproto">
  2471. <table class="memname">
  2472. <tr>
  2473. <td class="memname">bool FatFile::seekSet </td>
  2474. <td>(</td>
  2475. <td class="paramtype">uint32_t&#160;</td>
  2476. <td class="paramname"><em>pos</em></td><td>)</td>
  2477. <td></td>
  2478. </tr>
  2479. </table>
  2480. </div><div class="memdoc">
  2481. <p>Sets a file's position.</p>
  2482. <dl class="params"><dt>Parameters</dt><dd>
  2483. <table class="params">
  2484. <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>
  2485. </table>
  2486. </dd>
  2487. </dl>
  2488. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  2489. </div>
  2490. </div>
  2491. <a class="anchor" id="a360ef9c05e677271bed6c0a4d663634c"></a>
  2492. <div class="memitem">
  2493. <div class="memproto">
  2494. <table class="mlabels">
  2495. <tr>
  2496. <td class="mlabels-left">
  2497. <table class="memname">
  2498. <tr>
  2499. <td class="memname">static bool FatFile::setCwd </td>
  2500. <td>(</td>
  2501. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  2502. <td class="paramname"><em>dir</em></td><td>)</td>
  2503. <td></td>
  2504. </tr>
  2505. </table>
  2506. </td>
  2507. <td class="mlabels-right">
  2508. <span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">static</span></span> </td>
  2509. </tr>
  2510. </table>
  2511. </div><div class="memdoc">
  2512. <p>Set the current working directory.</p>
  2513. <dl class="params"><dt>Parameters</dt><dd>
  2514. <table class="params">
  2515. <tr><td class="paramdir">[in]</td><td class="paramname">dir</td><td>New current working directory.</td></tr>
  2516. </table>
  2517. </dd>
  2518. </dl>
  2519. <dl class="section return"><dt>Returns</dt><dd>true for success else false. </dd></dl>
  2520. </div>
  2521. </div>
  2522. <a class="anchor" id="acf264de4e3ca36c5e8a39e56173c9044"></a>
  2523. <div class="memitem">
  2524. <div class="memproto">
  2525. <table class="memname">
  2526. <tr>
  2527. <td class="memname">void FatFile::setpos </td>
  2528. <td>(</td>
  2529. <td class="paramtype"><a class="el" href="struct_fat_pos__t.html">FatPos_t</a> *&#160;</td>
  2530. <td class="paramname"><em>pos</em></td><td>)</td>
  2531. <td></td>
  2532. </tr>
  2533. </table>
  2534. </div><div class="memdoc">
  2535. <p>set position for streams </p><dl class="params"><dt>Parameters</dt><dd>
  2536. <table class="params">
  2537. <tr><td class="paramdir">[out]</td><td class="paramname">pos</td><td>struct with value for new position </td></tr>
  2538. </table>
  2539. </dd>
  2540. </dl>
  2541. </div>
  2542. </div>
  2543. <a class="anchor" id="a67f3dc4896c542d695e11aac927f585e"></a>
  2544. <div class="memitem">
  2545. <div class="memproto">
  2546. <table class="memname">
  2547. <tr>
  2548. <td class="memname">bool FatFile::sync </td>
  2549. <td>(</td>
  2550. <td class="paramname"></td><td>)</td>
  2551. <td></td>
  2552. </tr>
  2553. </table>
  2554. </div><div class="memdoc">
  2555. <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>
  2556. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  2557. </div>
  2558. </div>
  2559. <a class="anchor" id="aa53a8d1d2467ad9af7d61cbf8ee85243"></a>
  2560. <div class="memitem">
  2561. <div class="memproto">
  2562. <table class="memname">
  2563. <tr>
  2564. <td class="memname">bool FatFile::timestamp </td>
  2565. <td>(</td>
  2566. <td class="paramtype"><a class="el" href="class_fat_file.html">FatFile</a> *&#160;</td>
  2567. <td class="paramname"><em>file</em></td><td>)</td>
  2568. <td></td>
  2569. </tr>
  2570. </table>
  2571. </div><div class="memdoc">
  2572. <p>Copy a file's timestamps</p>
  2573. <dl class="params"><dt>Parameters</dt><dd>
  2574. <table class="params">
  2575. <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>
  2576. </table>
  2577. </dd>
  2578. </dl>
  2579. <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>
  2580. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  2581. </div>
  2582. </div>
  2583. <a class="anchor" id="a56dabdf73833b7e961c4530eb8e16d23"></a>
  2584. <div class="memitem">
  2585. <div class="memproto">
  2586. <table class="memname">
  2587. <tr>
  2588. <td class="memname">bool FatFile::timestamp </td>
  2589. <td>(</td>
  2590. <td class="paramtype">uint8_t&#160;</td>
  2591. <td class="paramname"><em>flags</em>, </td>
  2592. </tr>
  2593. <tr>
  2594. <td class="paramkey"></td>
  2595. <td></td>
  2596. <td class="paramtype">uint16_t&#160;</td>
  2597. <td class="paramname"><em>year</em>, </td>
  2598. </tr>
  2599. <tr>
  2600. <td class="paramkey"></td>
  2601. <td></td>
  2602. <td class="paramtype">uint8_t&#160;</td>
  2603. <td class="paramname"><em>month</em>, </td>
  2604. </tr>
  2605. <tr>
  2606. <td class="paramkey"></td>
  2607. <td></td>
  2608. <td class="paramtype">uint8_t&#160;</td>
  2609. <td class="paramname"><em>day</em>, </td>
  2610. </tr>
  2611. <tr>
  2612. <td class="paramkey"></td>
  2613. <td></td>
  2614. <td class="paramtype">uint8_t&#160;</td>
  2615. <td class="paramname"><em>hour</em>, </td>
  2616. </tr>
  2617. <tr>
  2618. <td class="paramkey"></td>
  2619. <td></td>
  2620. <td class="paramtype">uint8_t&#160;</td>
  2621. <td class="paramname"><em>minute</em>, </td>
  2622. </tr>
  2623. <tr>
  2624. <td class="paramkey"></td>
  2625. <td></td>
  2626. <td class="paramtype">uint8_t&#160;</td>
  2627. <td class="paramname"><em>second</em>&#160;</td>
  2628. </tr>
  2629. <tr>
  2630. <td></td>
  2631. <td>)</td>
  2632. <td></td><td></td>
  2633. </tr>
  2634. </table>
  2635. </div><div class="memdoc">
  2636. <p>Set a file's timestamps in its directory entry.</p>
  2637. <dl class="params"><dt>Parameters</dt><dd>
  2638. <table class="params">
  2639. <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>
  2640. </table>
  2641. </dd>
  2642. </dl>
  2643. <p>T_ACCESS - Set the file's last access date.</p>
  2644. <p>T_CREATE - Set the file's creation date and time.</p>
  2645. <p>T_WRITE - Set the file's last write/modification date and time.</p>
  2646. <dl class="params"><dt>Parameters</dt><dd>
  2647. <table class="params">
  2648. <tr><td class="paramdir">[in]</td><td class="paramname">year</td><td>Valid range 1980 - 2107 inclusive.</td></tr>
  2649. <tr><td class="paramdir">[in]</td><td class="paramname">month</td><td>Valid range 1 - 12 inclusive.</td></tr>
  2650. <tr><td class="paramdir">[in]</td><td class="paramname">day</td><td>Valid range 1 - 31 inclusive.</td></tr>
  2651. <tr><td class="paramdir">[in]</td><td class="paramname">hour</td><td>Valid range 0 - 23 inclusive.</td></tr>
  2652. <tr><td class="paramdir">[in]</td><td class="paramname">minute</td><td>Valid range 0 - 59 inclusive.</td></tr>
  2653. <tr><td class="paramdir">[in]</td><td class="paramname">second</td><td>Valid range 0 - 59 inclusive</td></tr>
  2654. </table>
  2655. </dd>
  2656. </dl>
  2657. <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>
  2658. <dd>
  2659. 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>
  2660. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  2661. </div>
  2662. </div>
  2663. <a class="anchor" id="aa6e663098a578635d37d92e82d18d616"></a>
  2664. <div class="memitem">
  2665. <div class="memproto">
  2666. <table class="memname">
  2667. <tr>
  2668. <td class="memname">bool FatFile::truncate </td>
  2669. <td>(</td>
  2670. <td class="paramtype">uint32_t&#160;</td>
  2671. <td class="paramname"><em>length</em></td><td>)</td>
  2672. <td></td>
  2673. </tr>
  2674. </table>
  2675. </div><div class="memdoc">
  2676. <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>
  2677. <dl class="params"><dt>Parameters</dt><dd>
  2678. <table class="params">
  2679. <tr><td class="paramdir">[in]</td><td class="paramname">length</td><td>The desired length for the file.</td></tr>
  2680. </table>
  2681. </dd>
  2682. </dl>
  2683. <dl class="section return"><dt>Returns</dt><dd>The value true is returned for success and the value false is returned for failure. </dd></dl>
  2684. </div>
  2685. </div>
  2686. <a class="anchor" id="a3c64bd8a9abb9a6461d4addb405614df"></a>
  2687. <div class="memitem">
  2688. <div class="memproto">
  2689. <table class="mlabels">
  2690. <tr>
  2691. <td class="mlabels-left">
  2692. <table class="memname">
  2693. <tr>
  2694. <td class="memname"><a class="el" href="class_fat_volume.html">FatVolume</a>* FatFile::volume </td>
  2695. <td>(</td>
  2696. <td class="paramname"></td><td>)</td>
  2697. <td> const</td>
  2698. </tr>
  2699. </table>
  2700. </td>
  2701. <td class="mlabels-right">
  2702. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  2703. </tr>
  2704. </table>
  2705. </div><div class="memdoc">
  2706. <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>
  2707. </div>
  2708. </div>
  2709. <a class="anchor" id="aa4a5b81161994cea07938702cdfce49f"></a>
  2710. <div class="memitem">
  2711. <div class="memproto">
  2712. <table class="mlabels">
  2713. <tr>
  2714. <td class="mlabels-left">
  2715. <table class="memname">
  2716. <tr>
  2717. <td class="memname">int FatFile::write </td>
  2718. <td>(</td>
  2719. <td class="paramtype">const char *&#160;</td>
  2720. <td class="paramname"><em>str</em></td><td>)</td>
  2721. <td></td>
  2722. </tr>
  2723. </table>
  2724. </td>
  2725. <td class="mlabels-right">
  2726. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  2727. </tr>
  2728. </table>
  2729. </div><div class="memdoc">
  2730. <p>Write a string to a file. Used by the Arduino Print class. </p><dl class="params"><dt>Parameters</dt><dd>
  2731. <table class="params">
  2732. <tr><td class="paramdir">[in]</td><td class="paramname">str</td><td>Pointer to the string. Use getWriteError to check for errors. </td></tr>
  2733. </table>
  2734. </dd>
  2735. </dl>
  2736. <dl class="section return"><dt>Returns</dt><dd>count of characters written for success or -1 for failure. </dd></dl>
  2737. </div>
  2738. </div>
  2739. <a class="anchor" id="a5524bd9f3b8f54ee163e391cba618186"></a>
  2740. <div class="memitem">
  2741. <div class="memproto">
  2742. <table class="mlabels">
  2743. <tr>
  2744. <td class="mlabels-left">
  2745. <table class="memname">
  2746. <tr>
  2747. <td class="memname">int FatFile::write </td>
  2748. <td>(</td>
  2749. <td class="paramtype">uint8_t&#160;</td>
  2750. <td class="paramname"><em>b</em></td><td>)</td>
  2751. <td></td>
  2752. </tr>
  2753. </table>
  2754. </td>
  2755. <td class="mlabels-right">
  2756. <span class="mlabels"><span class="mlabel">inline</span></span> </td>
  2757. </tr>
  2758. </table>
  2759. </div><div class="memdoc">
  2760. <p>Write a single byte. </p><dl class="params"><dt>Parameters</dt><dd>
  2761. <table class="params">
  2762. <tr><td class="paramdir">[in]</td><td class="paramname">b</td><td>The byte to be written. </td></tr>
  2763. </table>
  2764. </dd>
  2765. </dl>
  2766. <dl class="section return"><dt>Returns</dt><dd>+1 for success or -1 for failure. </dd></dl>
  2767. </div>
  2768. </div>
  2769. <a class="anchor" id="a0ab9df44a9ee4b6eb0a78f15f1e30004"></a>
  2770. <div class="memitem">
  2771. <div class="memproto">
  2772. <table class="memname">
  2773. <tr>
  2774. <td class="memname">int FatFile::write </td>
  2775. <td>(</td>
  2776. <td class="paramtype">const void *&#160;</td>
  2777. <td class="paramname"><em>buf</em>, </td>
  2778. </tr>
  2779. <tr>
  2780. <td class="paramkey"></td>
  2781. <td></td>
  2782. <td class="paramtype">size_t&#160;</td>
  2783. <td class="paramname"><em>nbyte</em>&#160;</td>
  2784. </tr>
  2785. <tr>
  2786. <td></td>
  2787. <td>)</td>
  2788. <td></td><td></td>
  2789. </tr>
  2790. </table>
  2791. </div><div class="memdoc">
  2792. <p>Write data to an open file.</p>
  2793. <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>
  2794. <dl class="params"><dt>Parameters</dt><dd>
  2795. <table class="params">
  2796. <tr><td class="paramdir">[in]</td><td class="paramname">buf</td><td>Pointer to the location of the data to be written.</td></tr>
  2797. <tr><td class="paramdir">[in]</td><td class="paramname">nbyte</td><td>Number of bytes to write.</td></tr>
  2798. </table>
  2799. </dd>
  2800. </dl>
  2801. <dl class="section return"><dt>Returns</dt><dd>For success <a class="el" href="class_fat_file.html#aa4a5b81161994cea07938702cdfce49f">write()</a> returns the number of bytes written, always <em>nbyte</em>. If an error occurs, <a class="el" href="class_fat_file.html#aa4a5b81161994cea07938702cdfce49f">write()</a> returns -1. Possible errors include <a class="el" href="class_fat_file.html#aa4a5b81161994cea07938702cdfce49f">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>
  2802. </div>
  2803. </div>
  2804. <hr/>The documentation for this class was generated from the following files:<ul>
  2805. <li>Arduino/libraries/SdFat/src/FatLib/<a class="el" href="_fat_file_8h.html">FatFile.h</a></li>
  2806. <li>Arduino/libraries/SdFat/src/FatLib/FatFile.cpp</li>
  2807. <li>Arduino/libraries/SdFat/src/FatLib/FatFileLFN.cpp</li>
  2808. <li>Arduino/libraries/SdFat/src/FatLib/FatFilePrint.cpp</li>
  2809. <li>Arduino/libraries/SdFat/src/FatLib/FatFileSFN.cpp</li>
  2810. </ul>
  2811. </div><!-- contents -->
  2812. <!-- start footer part -->
  2813. <hr class="footer"/><address class="footer"><small>
  2814. Generated on Sun Jul 19 2015 10:15:53 for SdFat by &#160;<a href="http://www.doxygen.org/index.html">
  2815. <img class="footer" src="doxygen.png" alt="doxygen"/>
  2816. </a> 1.8.8
  2817. </small></address>
  2818. </body>
  2819. </html>