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.

2747 lines
129KB

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