EuropaTools/include/europa/io/pak/Reader.hpp

63 lines
1.3 KiB
C++
Raw Normal View History

2022-09-04 17:11:14 -04:00
//
// EuropaTools
//
2025-01-07 14:17:50 -05:00
// (C) 2021-2025 modeco80 <lily.modeco80@protonmail.ch>
2022-09-04 17:11:14 -04:00
//
// SPDX-License-Identifier: MIT
2022-09-04 17:11:14 -04:00
//
#ifndef EUROPA_IO_PAKREADER_H
#define EUROPA_IO_PAKREADER_H
#include <europa/io/pak/File.hpp>
#include <europa/structs/Pak.hpp>
2022-09-04 17:11:14 -04:00
#include <iosfwd>
#include <string>
namespace europa::io::pak {
2022-09-04 17:11:14 -04:00
2025-01-07 15:13:10 -05:00
/// Reader for Europa package files (.pak).
struct Reader {
using FlatType = std::pair<std::string, File>;
using MapType = std::vector<FlatType>;
2022-09-04 17:11:14 -04:00
2025-01-07 15:13:10 -05:00
/// Constructor. Takes in a input stream to read pak data from.
/// This stream should only be used by the PakReader, nothing else.
explicit Reader(std::istream& is);
2022-09-04 17:11:14 -04:00
2025-01-12 16:15:06 -05:00
/// Reads the header and the file TOC.
/// This function should be called first.
void ReadHeaderAndTOC();
2022-09-04 17:11:14 -04:00
2025-01-12 16:15:06 -05:00
/// Reads all files in the package.
void ReadFiles();
2025-01-12 16:15:06 -05:00
/// Reads a file with the path specified as [file].
void ReadFile(const std::string& file);
2022-09-04 17:11:14 -04:00
bool Invalid() const {
return invalid;
}
MapType& GetFiles();
const MapType& GetFiles() const;
2022-09-04 17:11:14 -04:00
2025-01-07 15:13:10 -05:00
const structs::PakHeaderVariant& GetHeader() const {
return header;
}
2022-09-04 17:11:14 -04:00
private:
2025-01-07 15:13:10 -05:00
template <class T>
void ReadHeaderAndTOCImpl();
2022-09-04 17:11:14 -04:00
std::istream& stream;
bool invalid { false };
2022-09-04 17:11:14 -04:00
structs::PakHeaderVariant header {};
MapType files;
2022-09-04 17:11:14 -04:00
};
} // namespace europa::io::pak
2022-09-04 17:11:14 -04:00
#endif // EUROPA_IO_PAKREADER_H