// Copyright (C) 2003 Dolphin Project. // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, version 2.0. // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License 2.0 for more details. // A copy of the GPL 2.0 should have been included with the program. // If not, see http://www.gnu.org/licenses/ // Official Git repository and contact information can be found at // http://code.google.com/p/dolphin-emu/ #ifndef _WBFS_BLOB_H #define _WBFS_BLOB_H #include "Blob.h" #include "FileUtil.h" namespace DiscIO { struct wbfs_head_t; class WbfsFileReader : public IBlobReader { WbfsFileReader(const char* filename); ~WbfsFileReader(); bool OpenFiles(const char* filename); bool ReadHeader(); File::IOFile& SeekToCluster(u64 offset, u64* available); bool IsGood() {return m_good;} struct file_entry { File::IOFile file; u64 base_address; u64 size; }; std::vector m_files; u32 m_total_files; u64 m_size; u64 hd_sector_size; u8 hd_sector_shift; u32 hd_sector_count; u64 wbfs_sector_size; u8 wbfs_sector_shift; u64 wbfs_sector_count; u64 m_disc_info_size; u8 disc_table[500]; u16* m_wlba_table; u64 m_blocks_per_disc; bool m_good; public: static WbfsFileReader* Create(const char* filename); u64 GetDataSize() const { return m_size; } u64 GetRawSize() const { return m_size; } bool Read(u64 offset, u64 nbytes, u8* out_ptr); }; bool IsWbfsBlob(const char* filename); } // namespace #endif // _FILE_BLOB_H