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.

52 lines
1.9KB

  1. // Copyright 2011 Olivier Gillet.
  2. //
  3. // Author: Olivier Gillet (ol.gillet@gmail.com)
  4. //
  5. // This program is free software: you can redistribute it and/or modify
  6. // it under the terms of the GNU General Public License as published by
  7. // the Free Software Foundation, either version 3 of the License, or
  8. // (at your option) any later version.
  9. // This program is distributed in the hope that it will be useful,
  10. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. // GNU General Public License for more details.
  13. // You should have received a copy of the GNU General Public License
  14. // along with this program. If not, see <http://www.gnu.org/licenses/>.
  15. //
  16. // -----------------------------------------------------------------------------
  17. //
  18. // FatFS wrappers.
  19. #include "avrlib/filesystem/directory.h"
  20. namespace avrlib {
  21. FilesystemStatus Directory::Open(
  22. const char* directory_name,
  23. uint16_t retry_timeout) {
  24. FilesystemStatus s;
  25. s = static_cast<FilesystemStatus>(f_opendir(&d_, directory_name));
  26. if (s == FS_DISK_ERROR && retry_timeout) {
  27. // If an open fails because of a disk access error, try to reinitialize the
  28. // disk access layer. This might happen because a process in the background
  29. // has temporarily disabled the disk access layer (for example to access
  30. // another device). It is OK to have the disk access layer disabled between
  31. // file access "sessions" -- but it is not OK to have it disabled during a
  32. // session.
  33. Filesystem::Init(retry_timeout);
  34. s = static_cast<FilesystemStatus>(f_opendir(&d_, directory_name));
  35. }
  36. return s;
  37. }
  38. FilesystemStatus Directory::Next() {
  39. return static_cast<FilesystemStatus>(f_readdir(&d_, &f_.file_info));
  40. }
  41. FilesystemStatus Directory::Rewind() {
  42. return static_cast<FilesystemStatus>(f_readdir(&d_, NULL));
  43. }
  44. } // namespace avrlib