diff options
Diffstat (limited to 'src/FATStorage.cpp')
| -rw-r--r-- | src/FATStorage.cpp | 97 | 
1 files changed, 39 insertions, 58 deletions
| diff --git a/src/FATStorage.cpp b/src/FATStorage.cpp index 07cf491..d882f8d 100644 --- a/src/FATStorage.cpp +++ b/src/FATStorage.cpp @@ -25,17 +25,7 @@  #include "Platform.h"  namespace fs = std::filesystem; - - -// really, Windows? -#ifdef __WIN32__ -    #define melon_fseek _fseeki64 -    #define melon_ftell _ftelli64 -#else -    #define melon_fseek fseek -    #define melon_ftell ftell -#endif // __WIN32__ - +using namespace Platform;  FATStorage::FATStorage(const std::string& filename, u64 size, bool readonly, const std::string& sourcedir)  { @@ -53,7 +43,7 @@ FATStorage::~FATStorage()  bool FATStorage::Open()  { -    File = Platform::OpenLocalFile(FilePath.c_str(), "r+b"); +    File = Platform::OpenLocalFile(FilePath, FileMode::ReadWriteExisting);      if (!File)      {          return false; @@ -64,7 +54,7 @@ bool FATStorage::Open()  void FATStorage::Close()  { -    if (File) fclose(File); +    if (File) CloseFile(File);      File = nullptr;  } @@ -124,7 +114,7 @@ u32 FATStorage::WriteSectors(u32 start, u32 num, u8* data)  } -FILE* FATStorage::FF_File; +FileHandle* FATStorage::FF_File;  u64 FATStorage::FF_FileSize;  UINT FATStorage::FF_ReadStorage(BYTE* buf, LBA_t sector, UINT num) @@ -138,7 +128,7 @@ UINT FATStorage::FF_WriteStorage(BYTE* buf, LBA_t sector, UINT num)  } -u32 FATStorage::ReadSectorsInternal(FILE* file, u64 filelen, u32 start, u32 num, u8* data) +u32 FATStorage::ReadSectorsInternal(FileHandle* file, u64 filelen, u32 start, u32 num, u8* data)  {      if (!file) return 0; @@ -152,12 +142,12 @@ u32 FATStorage::ReadSectorsInternal(FILE* file, u64 filelen, u32 start, u32 num,          num = len >> 9;      } -    melon_fseek(file, addr, SEEK_SET); +    FileSeek(file, addr, FileSeekOrigin::Start); -    u32 res = fread(data, 0x200, num, file); +    u32 res = FileRead(data, 0x200, num, file);      if (res < num)      { -        if (feof(file)) +        if (IsEndOfFile(file))          {              memset(&data[0x200*res], 0, 0x200*(num-res));              return num; @@ -167,7 +157,7 @@ u32 FATStorage::ReadSectorsInternal(FILE* file, u64 filelen, u32 start, u32 num,      return res;  } -u32 FATStorage::WriteSectorsInternal(FILE* file, u64 filelen, u32 start, u32 num, u8* data) +u32 FATStorage::WriteSectorsInternal(FileHandle* file, u64 filelen, u32 start, u32 num, u8* data)  {      if (!file) return 0; @@ -181,9 +171,9 @@ u32 FATStorage::WriteSectorsInternal(FILE* file, u64 filelen, u32 start, u32 num          num = len >> 9;      } -    melon_fseek(file, addr, SEEK_SET); +    FileSeek(file, addr, FileSeekOrigin::Start); -    u32 res = fwrite(data, 0x200, num, file); +    u32 res = Platform::FileWrite(data, 0x200, num, file);      return res;  } @@ -193,13 +183,13 @@ void FATStorage::LoadIndex()      DirIndex.clear();      FileIndex.clear(); -    FILE* f = Platform::OpenLocalFile(IndexPath.c_str(), "r"); +    FileHandle* f = OpenLocalFile(IndexPath, FileMode::ReadText);      if (!f) return;      char linebuf[1536]; -    while (!feof(f)) +    while (!IsEndOfFile(f))      { -        if (fgets(linebuf, 1536, f) == nullptr) +        if (!FileReadLine(linebuf, 1536, f))              break;          if (linebuf[0] == 'S') @@ -258,7 +248,7 @@ void FATStorage::LoadIndex()          }      } -    fclose(f); +    CloseFile(f);      // ensure the indexes are sane @@ -325,31 +315,31 @@ void FATStorage::LoadIndex()  void FATStorage::SaveIndex()  { -    FILE* f = Platform::OpenLocalFile(IndexPath.c_str(), "w"); +    FileHandle* f = OpenLocalFile(IndexPath, FileMode::WriteText);      if (!f) return; -    fprintf(f, "SIZE %" PRIu64 "\r\n", FileSize); +    FileWriteFormatted(f, "SIZE %" PRIu64 "\r\n", FileSize);      for (const auto& [key, val] : DirIndex)      { -        fprintf(f, "DIR %u %s\r\n", +        FileWriteFormatted(f, "DIR %u %s\r\n",                  val.IsReadOnly?1:0, val.Path.c_str());      }      for (const auto& [key, val] : FileIndex)      { -        fprintf(f, "FILE %u %" PRIu64 " %" PRId64 " %u %s\r\n", +        FileWriteFormatted(f, "FILE %u %" PRIu64 " %" PRId64 " %u %s\r\n",                  val.IsReadOnly?1:0, val.Size, val.LastModified, val.LastModifiedInternal, val.Path.c_str());      } -    fclose(f); +    CloseFile(f);  }  bool FATStorage::ExportFile(const std::string& path, fs::path out)  {      FF_FIL file; -    FILE* fout; +    FileHandle* fout;      FRESULT res;      res = f_open(&file, path.c_str(), FA_OPEN_EXISTING | FA_READ); @@ -367,7 +357,7 @@ bool FATStorage::ExportFile(const std::string& path, fs::path out)                          err);      } -    fout = Platform::OpenFile(out.u8string().c_str(), "wb"); +    fout = OpenFile(out.u8string(), FileMode::Write);      if (!fout)      {          f_close(&file); @@ -385,10 +375,10 @@ bool FATStorage::ExportFile(const std::string& path, fs::path out)          u32 nread;          f_read(&file, buf, blocklen, &nread); -        fwrite(buf, blocklen, 1, fout); +        FileWrite(buf, blocklen, 1, fout);      } -    fclose(fout); +    CloseFile(fout);      f_close(&file);      return true; @@ -782,27 +772,25 @@ void FATStorage::CleanupDirectory(const std::string& sourcedir, const std::strin  bool FATStorage::ImportFile(const std::string& path, fs::path in)  {      FF_FIL file; -    FILE* fin; +    FileHandle* fin;      FRESULT res; -    fin = Platform::OpenFile(in.u8string().c_str(), "rb"); +    fin = Platform::OpenFile(in.u8string(), FileMode::Read);      if (!fin)          return false; -    fseek(fin, 0, SEEK_END); -    u32 len = (u32)ftell(fin); -    fseek(fin, 0, SEEK_SET); +    u32 len = FileLength(fin);      if (!CanFitFile(len))      { -        fclose(fin); +        CloseFile(fin);          return false;      }      res = f_open(&file, path.c_str(), FA_CREATE_ALWAYS | FA_WRITE);      if (res != FR_OK)      { -        fclose(fin); +        CloseFile(fin);          return false;      } @@ -816,11 +804,11 @@ bool FATStorage::ImportFile(const std::string& path, fs::path in)              blocklen = 0x1000;          u32 nwrite; -        fread(buf, blocklen, 1, fin); +        FileRead(buf, blocklen, 1, fin);          f_write(&file, buf, blocklen, &nwrite);      } -    fclose(fin); +    CloseFile(fin);      f_close(&file);      return true; @@ -961,16 +949,10 @@ bool FATStorage::Load(const std::string& filename, u64 size, const std::string&      // * if no image: if sourcing from a directory, size is calculated from that      //   with a minimum 128MB extra, otherwise size is defaulted to 512MB -    bool isnew = false; -    FF_File = Platform::OpenLocalFile(filename.c_str(), "r+b"); +    bool isnew = !Platform::LocalFileExists(filename); +    FF_File = Platform::OpenLocalFile(filename, static_cast<FileMode>(FileMode::ReadWrite | FileMode::Preserve));      if (!FF_File) -    { -        FF_File = Platform::OpenLocalFile(filename.c_str(), "w+b"); -        if (!FF_File) -            return false; - -        isnew = true; -    } +        return false;      IndexPath = FilePath + ".idx";      if (isnew) @@ -985,8 +967,7 @@ bool FATStorage::Load(const std::string& filename, u64 size, const std::string&          if (FileSize == 0)          { -            melon_fseek(FF_File, 0, SEEK_END); -            FileSize = melon_ftell(FF_File); +            FileSize = FileLength(FF_File);          }      } @@ -1076,7 +1057,7 @@ bool FATStorage::Load(const std::string& filename, u64 size, const std::string&      f_unmount("0:");      ff_disk_close(); -    fclose(FF_File); +    CloseFile(FF_File);      FF_File = nullptr;      return true; @@ -1089,7 +1070,7 @@ bool FATStorage::Save()          return true;      } -    FF_File = Platform::OpenLocalFile(FilePath.c_str(), "r+b"); +    FF_File = Platform::OpenLocalFile(FilePath, FileMode::ReadWriteExisting);      if (!FF_File)      {          return false; @@ -1105,7 +1086,7 @@ bool FATStorage::Save()      if (res != FR_OK)      {          ff_disk_close(); -        fclose(FF_File); +        CloseFile(FF_File);          FF_File = nullptr;          return false;      } @@ -1117,7 +1098,7 @@ bool FATStorage::Save()      f_unmount("0:");      ff_disk_close(); -    fclose(FF_File); +    CloseFile(FF_File);      FF_File = nullptr;      return true; |