libeuropa/io: Split pak into new subdirectory
Namespaces exist. Use them, perhaps.
This commit is contained in:
parent
087657d5c1
commit
84c537c873
15 changed files with 102 additions and 99 deletions
|
@ -18,13 +18,13 @@
|
||||||
#include <variant>
|
#include <variant>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
namespace europa::io {
|
namespace europa::io::pak {
|
||||||
|
|
||||||
struct PakReader;
|
struct Reader;
|
||||||
struct PakWriter;
|
struct Writer;
|
||||||
|
|
||||||
/// sumtype
|
/// sumtype for package file data
|
||||||
struct PakFileData {
|
struct FileData {
|
||||||
// clang-format off
|
// clang-format off
|
||||||
using Variant = std::variant<
|
using Variant = std::variant<
|
||||||
// File data
|
// File data
|
||||||
|
@ -35,14 +35,14 @@ namespace europa::io {
|
||||||
>;
|
>;
|
||||||
// clang-format on
|
// clang-format on
|
||||||
|
|
||||||
static PakFileData InitAsBuffer(std::vector<std::uint8_t>&& buffer) {
|
static FileData InitAsBuffer(std::vector<std::uint8_t>&& buffer) {
|
||||||
return PakFileData {
|
return FileData {
|
||||||
.variant_ = Variant(std::move(buffer))
|
.variant_ = Variant(std::move(buffer))
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
static PakFileData InitAsPath(const std::filesystem::path& path) {
|
static FileData InitAsPath(const std::filesystem::path& path) {
|
||||||
return PakFileData {
|
return FileData {
|
||||||
.variant_ = Variant(path)
|
.variant_ = Variant(path)
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -80,13 +80,13 @@ namespace europa::io {
|
||||||
}
|
}
|
||||||
|
|
||||||
// private:
|
// private:
|
||||||
PakFileData::Variant variant_;
|
FileData::Variant variant_;
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Repressents a package file. Can either hold a memory buffer of contents
|
/// Repressents a package file. Can either hold a memory buffer of contents
|
||||||
/// or a filesystem path (for creating packages).
|
/// or a filesystem path (for creating packages).
|
||||||
struct PakFile {
|
struct File {
|
||||||
using DataType = PakFileData;
|
using DataType = FileData;
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
void InitWithExistingTocEntry(const T& value) {
|
void InitWithExistingTocEntry(const T& value) {
|
||||||
|
@ -194,13 +194,15 @@ namespace europa::io {
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
friend PakReader;
|
// FIXME: Are these `friend`s required? I don't think so,
|
||||||
friend PakWriter;
|
// we use public APIs now.
|
||||||
|
friend Reader;
|
||||||
|
friend Writer;
|
||||||
|
|
||||||
std::optional<PakFileData> fileData;
|
std::optional<FileData> fileData;
|
||||||
structs::PakTocEntryVariant toc;
|
structs::PakTocEntryVariant toc;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace europa::io
|
} // namespace europa::io::pak
|
||||||
|
|
||||||
#endif // EUROPA_IO_PAKFILE_H
|
#endif // EUROPA_IO_PAKFILE_H
|
|
@ -9,22 +9,21 @@
|
||||||
#ifndef EUROPA_IO_PAKREADER_H
|
#ifndef EUROPA_IO_PAKREADER_H
|
||||||
#define EUROPA_IO_PAKREADER_H
|
#define EUROPA_IO_PAKREADER_H
|
||||||
|
|
||||||
#include <europa/io/PakFile.hpp>
|
#include <europa/io/pak/File.hpp>
|
||||||
#include <europa/structs/Pak.hpp>
|
#include <europa/structs/Pak.hpp>
|
||||||
#include <iosfwd>
|
#include <iosfwd>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <map>
|
|
||||||
|
|
||||||
namespace europa::io {
|
namespace europa::io::pak {
|
||||||
|
|
||||||
/// Reader for Europa package files (.pak).
|
/// Reader for Europa package files (.pak).
|
||||||
struct PakReader {
|
struct Reader {
|
||||||
using FlatType = std::pair<std::string, PakFile>;
|
using FlatType = std::pair<std::string, File>;
|
||||||
using MapType = std::vector<FlatType>;
|
using MapType = std::vector<FlatType>;
|
||||||
|
|
||||||
/// Constructor. Takes in a input stream to read pak data from.
|
/// Constructor. Takes in a input stream to read pak data from.
|
||||||
/// This stream should only be used by the PakReader, nothing else.
|
/// This stream should only be used by the PakReader, nothing else.
|
||||||
explicit PakReader(std::istream& is);
|
explicit Reader(std::istream& is);
|
||||||
|
|
||||||
/// Reads the header and the file TOC.
|
/// Reads the header and the file TOC.
|
||||||
/// This function should be called first.
|
/// This function should be called first.
|
||||||
|
@ -61,6 +60,6 @@ namespace europa::io {
|
||||||
MapType files;
|
MapType files;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace europa::io
|
} // namespace europa::io::pak
|
||||||
|
|
||||||
#endif // EUROPA_IO_PAKREADER_H
|
#endif // EUROPA_IO_PAKREADER_H
|
|
@ -9,29 +9,29 @@
|
||||||
#ifndef EUROPA_IO_PAKWRITER_H
|
#ifndef EUROPA_IO_PAKWRITER_H
|
||||||
#define EUROPA_IO_PAKWRITER_H
|
#define EUROPA_IO_PAKWRITER_H
|
||||||
|
|
||||||
#include <europa/io/PakFile.hpp>
|
#include <europa/io/pak/File.hpp>
|
||||||
#include <europa/io/PakProgressReportSink.hpp>
|
#include <europa/io/pak/WriterProgressReportSink.hpp>
|
||||||
#include <iosfwd>
|
#include <iosfwd>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
#include "europa/structs/Pak.hpp"
|
#include "europa/structs/Pak.hpp"
|
||||||
|
|
||||||
namespace europa::io {
|
namespace europa::io::pak {
|
||||||
|
|
||||||
/// A efficient writer for Europa package (.pak) files.
|
/// A efficient writer for Europa package (.pak) files.
|
||||||
struct PakWriter {
|
struct Writer {
|
||||||
/// Vocabulary type for making sector alignment stuff a bit easier to see.
|
/// Vocabulary type for making sector alignment stuff a bit easier to see.
|
||||||
enum class SectorAlignment {
|
enum class SectorAlignment {
|
||||||
DoNotAlign, /// Do not align to a sector boundary
|
DoNotAlign, /// Do not align to a sector boundary
|
||||||
Align /// Align to a sector boundary
|
Align /// Align to a sector boundary
|
||||||
};
|
};
|
||||||
|
|
||||||
using FlattenedType = std::pair<std::string, PakFile>;
|
using FlattenedType = std::pair<std::string, File>;
|
||||||
|
|
||||||
constexpr PakWriter() = default;
|
constexpr Writer() = default;
|
||||||
|
|
||||||
PakWriter(structs::PakVersion version) {
|
Writer(structs::PakVersion version) {
|
||||||
SetVersion(version);
|
SetVersion(version);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,11 +42,11 @@ namespace europa::io {
|
||||||
/// [vec] is all files which should be packaged
|
/// [vec] is all files which should be packaged
|
||||||
/// [sink] is a implementation of PakProgressReportsSink which should get events (TODO: Make this optional)
|
/// [sink] is a implementation of PakProgressReportsSink which should get events (TODO: Make this optional)
|
||||||
/// [sectorAlignment] controls sector alignment. It is ignored unless the package's version is [structs::PakVersion::Ver5].
|
/// [sectorAlignment] controls sector alignment. It is ignored unless the package's version is [structs::PakVersion::Ver5].
|
||||||
void Write(std::ostream& os, std::vector<FlattenedType>&& vec, PakProgressReportSink& sink, SectorAlignment sectorAlignment = SectorAlignment::DoNotAlign);
|
void Write(std::ostream& os, std::vector<FlattenedType>&& vec, WriterProgressReportSink& sink, SectorAlignment sectorAlignment = SectorAlignment::DoNotAlign);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
template <class T>
|
template <class T>
|
||||||
void WriteImpl(std::ostream& os, std::vector<FlattenedType>&& vec, PakProgressReportSink& sink, SectorAlignment sectorAlignment);
|
void WriteImpl(std::ostream& os, std::vector<FlattenedType>&& vec, WriterProgressReportSink& sink, SectorAlignment sectorAlignment);
|
||||||
|
|
||||||
structs::PakVersion version {};
|
structs::PakVersion version {};
|
||||||
};
|
};
|
|
@ -11,10 +11,10 @@
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
namespace europa::io {
|
namespace europa::io::pak {
|
||||||
|
|
||||||
/// Interface for [PakWriter] to output detailed progress information.
|
/// Interface for [PakWriter] to output detailed progress information.
|
||||||
struct PakProgressReportSink {
|
struct WriterProgressReportSink {
|
||||||
struct PakEvent {
|
struct PakEvent {
|
||||||
enum class EventCode {
|
enum class EventCode {
|
||||||
FillInHeader, /// Filling in header.
|
FillInHeader, /// Filling in header.
|
||||||
|
@ -35,7 +35,7 @@ namespace europa::io {
|
||||||
const std::string& targetFileName;
|
const std::string& targetFileName;
|
||||||
};
|
};
|
||||||
|
|
||||||
virtual ~PakProgressReportSink() = default;
|
virtual ~WriterProgressReportSink() = default;
|
||||||
|
|
||||||
virtual void OnEvent(const PakEvent& event) = 0;
|
virtual void OnEvent(const PakEvent& event) = 0;
|
||||||
virtual void OnEvent(const FileEvent& event) = 0;
|
virtual void OnEvent(const FileEvent& event) = 0;
|
|
@ -11,8 +11,8 @@ add_library(europa
|
||||||
io/StreamUtils.cpp
|
io/StreamUtils.cpp
|
||||||
|
|
||||||
# Pak IO
|
# Pak IO
|
||||||
io/PakReader.cpp
|
io/pak/Reader.cpp
|
||||||
io/PakWriter.cpp
|
io/pak/Writer.cpp
|
||||||
|
|
||||||
# Yatf IO
|
# Yatf IO
|
||||||
io/YatfReader.cpp
|
io/YatfReader.cpp
|
||||||
|
|
|
@ -9,21 +9,21 @@
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
#include <europa/io/PakReader.hpp>
|
#include <europa/io/pak/File.hpp>
|
||||||
|
#include <europa/io/pak/Reader.hpp>
|
||||||
#include <europa/structs/Pak.hpp>
|
#include <europa/structs/Pak.hpp>
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
|
|
||||||
#include "europa/io/PakFile.hpp"
|
#include "../StreamUtils.h"
|
||||||
#include "StreamUtils.h"
|
|
||||||
|
|
||||||
namespace europa::io {
|
namespace europa::io::pak {
|
||||||
|
|
||||||
PakReader::PakReader(std::istream& is)
|
Reader::Reader(std::istream& is)
|
||||||
: stream(is) {
|
: stream(is) {
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
void PakReader::ReadData_Impl() {
|
void Reader::ReadData_Impl() {
|
||||||
auto header_type = impl::ReadStreamType<T>(stream);
|
auto header_type = impl::ReadStreamType<T>(stream);
|
||||||
|
|
||||||
if(!header_type.Valid()) {
|
if(!header_type.Valid()) {
|
||||||
|
@ -39,7 +39,7 @@ namespace europa::io {
|
||||||
//
|
//
|
||||||
// Read this in first.
|
// Read this in first.
|
||||||
auto filename = impl::ReadPString(stream);
|
auto filename = impl::ReadPString(stream);
|
||||||
auto file = PakFile {};
|
auto file = File {};
|
||||||
if constexpr(std::is_same_v<T, structs::PakHeader_V5>) {
|
if constexpr(std::is_same_v<T, structs::PakHeader_V5>) {
|
||||||
// Version 5 supports sector aligned packages which have an additional field in them
|
// Version 5 supports sector aligned packages which have an additional field in them
|
||||||
// so we need to handle it here
|
// so we need to handle it here
|
||||||
|
@ -59,7 +59,7 @@ namespace europa::io {
|
||||||
header = header_type;
|
header = header_type;
|
||||||
}
|
}
|
||||||
|
|
||||||
void PakReader::ReadHeaderAndTOC() {
|
void Reader::ReadHeaderAndTOC() {
|
||||||
auto commonHeader = impl::ReadStreamType<structs::PakHeader_Common>(stream);
|
auto commonHeader = impl::ReadStreamType<structs::PakHeader_Common>(stream);
|
||||||
stream.seekg(0, std::istream::beg);
|
stream.seekg(0, std::istream::beg);
|
||||||
|
|
||||||
|
@ -78,13 +78,13 @@ namespace europa::io {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void PakReader::ReadFiles() {
|
void Reader::ReadFiles() {
|
||||||
for(auto& [filename, file] : files)
|
for(auto& [filename, file] : files)
|
||||||
ReadFile(filename);
|
ReadFile(filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
void PakReader::ReadFile(const std::string& file) {
|
void Reader::ReadFile(const std::string& file) {
|
||||||
auto it = std::find_if(files.begin(), files.end(), [&file](PakReader::FlatType& fl) { return fl.first == file; });
|
auto it = std::find_if(files.begin(), files.end(), [&file](Reader::FlatType& fl) { return fl.first == file; });
|
||||||
if(it == files.end())
|
if(it == files.end())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -104,16 +104,16 @@ namespace europa::io {
|
||||||
if(!stream)
|
if(!stream)
|
||||||
throw std::runtime_error("Stream went bad while trying to read file");
|
throw std::runtime_error("Stream went bad while trying to read file");
|
||||||
|
|
||||||
auto data = PakFileData::InitAsBuffer(std::move(buffer));
|
auto data = FileData::InitAsBuffer(std::move(buffer));
|
||||||
fileObject.SetData(std::move(data));
|
fileObject.SetData(std::move(data));
|
||||||
}
|
}
|
||||||
|
|
||||||
PakReader::MapType& PakReader::GetFiles() {
|
Reader::MapType& Reader::GetFiles() {
|
||||||
return files;
|
return files;
|
||||||
}
|
}
|
||||||
|
|
||||||
const PakReader::MapType& PakReader::GetFiles() const {
|
const Reader::MapType& Reader::GetFiles() const {
|
||||||
return files;
|
return files;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace europa::io
|
} // namespace europa::io::pak
|
|
@ -8,7 +8,8 @@
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <chrono>
|
#include <chrono>
|
||||||
#include <europa/io/PakWriter.hpp>
|
#include <europa/io/pak/Writer.hpp>
|
||||||
|
#include <europa/structs/Pak.hpp>
|
||||||
#include <europa/util/AlignHelpers.hpp>
|
#include <europa/util/AlignHelpers.hpp>
|
||||||
#include <europa/util/Overloaded.hpp>
|
#include <europa/util/Overloaded.hpp>
|
||||||
#include <europa/util/TupleElement.hpp>
|
#include <europa/util/TupleElement.hpp>
|
||||||
|
@ -18,17 +19,16 @@
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
|
|
||||||
#include "europa/structs/Pak.hpp"
|
#include "../StreamUtils.h"
|
||||||
#include "StreamUtils.h"
|
|
||||||
|
|
||||||
namespace europa::io {
|
namespace europa::io::pak {
|
||||||
|
|
||||||
void PakWriter::SetVersion(structs::PakVersion version) {
|
void Writer::SetVersion(structs::PakVersion version) {
|
||||||
// for now.
|
// for now.
|
||||||
this->version = version;
|
this->version = version;
|
||||||
}
|
}
|
||||||
|
|
||||||
void PakWriter::Write(std::ostream& os, std::vector<FlattenedType>&& vec, PakProgressReportSink& sink, SectorAlignment sectorAlignment) {
|
void Writer::Write(std::ostream& os, std::vector<FlattenedType>&& vec, WriterProgressReportSink& sink, SectorAlignment sectorAlignment) {
|
||||||
// Depending on the version, do a mix of runtime/compile-time dispatch to the right
|
// Depending on the version, do a mix of runtime/compile-time dispatch to the right
|
||||||
// package format version we have been told to write.
|
// package format version we have been told to write.
|
||||||
switch(version) {
|
switch(version) {
|
||||||
|
@ -47,7 +47,7 @@ namespace europa::io {
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class THeader>
|
template <class THeader>
|
||||||
void PakWriter::WriteImpl(std::ostream& os, std::vector<FlattenedType>&& vec, PakProgressReportSink& sink, SectorAlignment sectorAlignment) {
|
void Writer::WriteImpl(std::ostream& os, std::vector<FlattenedType>&& vec, WriterProgressReportSink& sink, SectorAlignment sectorAlignment) {
|
||||||
std::vector<FlattenedType> sortedFiles = std::move(vec);
|
std::vector<FlattenedType> sortedFiles = std::move(vec);
|
||||||
|
|
||||||
THeader pakHeader {};
|
THeader pakHeader {};
|
||||||
|
@ -82,7 +82,7 @@ namespace europa::io {
|
||||||
|
|
||||||
// Write all the file data
|
// Write all the file data
|
||||||
for(auto& [filename, file] : sortedFiles) {
|
for(auto& [filename, file] : sortedFiles) {
|
||||||
sink.OnEvent({ PakProgressReportSink::FileEvent::EventCode::FileWriteBegin,
|
sink.OnEvent({ WriterProgressReportSink::FileEvent::EventCode::FileWriteBegin,
|
||||||
filename });
|
filename });
|
||||||
|
|
||||||
// Update the offset to where we currently are, since we will be writing the file there
|
// Update the offset to where we currently are, since we will be writing the file there
|
||||||
|
@ -129,13 +129,13 @@ namespace europa::io {
|
||||||
os.seekp(util::AlignBy(static_cast<std::size_t>(os.tellp()), util::kCDSectorSize), std::istream::beg);
|
os.seekp(util::AlignBy(static_cast<std::size_t>(os.tellp()), util::kCDSectorSize), std::istream::beg);
|
||||||
}
|
}
|
||||||
|
|
||||||
sink.OnEvent({ PakProgressReportSink::FileEvent::EventCode::FileWriteEnd,
|
sink.OnEvent({ WriterProgressReportSink::FileEvent::EventCode::FileWriteEnd,
|
||||||
filename });
|
filename });
|
||||||
}
|
}
|
||||||
|
|
||||||
pakHeader.tocOffset = os.tellp();
|
pakHeader.tocOffset = os.tellp();
|
||||||
|
|
||||||
sink.OnEvent({ PakProgressReportSink::PakEvent::EventCode::WritingToc });
|
sink.OnEvent({ WriterProgressReportSink::PakEvent::EventCode::WritingToc });
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
// Sort for toc stuff? idk
|
// Sort for toc stuff? idk
|
||||||
|
@ -154,7 +154,7 @@ namespace europa::io {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
sink.OnEvent({ PakProgressReportSink::PakEvent::EventCode::FillInHeader });
|
sink.OnEvent({ WriterProgressReportSink::PakEvent::EventCode::FillInHeader });
|
||||||
|
|
||||||
// Fill out the rest of the header.
|
// Fill out the rest of the header.
|
||||||
pakHeader.fileCount = sortedFiles.size();
|
pakHeader.fileCount = sortedFiles.size();
|
||||||
|
@ -164,11 +164,11 @@ namespace europa::io {
|
||||||
auto now = std::chrono::system_clock::now();
|
auto now = std::chrono::system_clock::now();
|
||||||
pakHeader.creationUnixTime = static_cast<std::uint32_t>(std::chrono::time_point_cast<std::chrono::seconds>(now).time_since_epoch().count());
|
pakHeader.creationUnixTime = static_cast<std::uint32_t>(std::chrono::time_point_cast<std::chrono::seconds>(now).time_since_epoch().count());
|
||||||
|
|
||||||
sink.OnEvent({ PakProgressReportSink::PakEvent::EventCode::WritingHeader });
|
sink.OnEvent({ WriterProgressReportSink::PakEvent::EventCode::WritingHeader });
|
||||||
|
|
||||||
// As the last step, write it.
|
// As the last step, write it.
|
||||||
os.seekp(0, std::ostream::beg);
|
os.seekp(0, std::ostream::beg);
|
||||||
impl::WriteStreamType(os, pakHeader);
|
impl::WriteStreamType(os, pakHeader);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace europa::io
|
} // namespace europa::io::pak
|
|
@ -8,7 +8,9 @@
|
||||||
|
|
||||||
#include <chrono>
|
#include <chrono>
|
||||||
#include <EupakConfig.hpp>
|
#include <EupakConfig.hpp>
|
||||||
#include <europa/io/PakWriter.hpp>
|
#include <europa/io/pak/File.hpp>
|
||||||
|
#include <europa/io/pak/Writer.hpp>
|
||||||
|
#include <europa/io/pak/WriterProgressReportSink.hpp>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <indicators/cursor_control.hpp>
|
#include <indicators/cursor_control.hpp>
|
||||||
#include <indicators/progress_bar.hpp>
|
#include <indicators/progress_bar.hpp>
|
||||||
|
@ -17,15 +19,14 @@
|
||||||
#include <Utils.hpp>
|
#include <Utils.hpp>
|
||||||
|
|
||||||
#include "argparse/argparse.hpp"
|
#include "argparse/argparse.hpp"
|
||||||
#include "europa/io/PakFile.hpp"
|
|
||||||
#include "europa/structs/Pak.hpp"
|
#include "europa/structs/Pak.hpp"
|
||||||
#include "tasks/Task.hpp"
|
#include "tasks/Task.hpp"
|
||||||
|
|
||||||
namespace eupak::tasks {
|
namespace eupak::tasks {
|
||||||
|
|
||||||
struct CreateArchiveReportSink : public europa::io::PakProgressReportSink {
|
struct CreateArchiveReportSink : public eio::pak::WriterProgressReportSink {
|
||||||
CreateArchiveReportSink(int fileCount = 0)
|
CreateArchiveReportSink(int fileCount = 0)
|
||||||
: europa::io::PakProgressReportSink() {
|
: eio::pak::WriterProgressReportSink() {
|
||||||
indicators::show_console_cursor(false);
|
indicators::show_console_cursor(false);
|
||||||
progress.set_option(indicators::option::MaxProgress { fileCount });
|
progress.set_option(indicators::option::MaxProgress { fileCount });
|
||||||
}
|
}
|
||||||
|
@ -143,8 +144,8 @@ namespace eupak::tasks {
|
||||||
auto& args = currentArgs;
|
auto& args = currentArgs;
|
||||||
|
|
||||||
args.verbose = parser.get<bool>("--verbose");
|
args.verbose = parser.get<bool>("--verbose");
|
||||||
args.inputDirectory = eupak::fs::path(parser.get("--directory"));
|
args.inputDirectory = fs::path(parser.get("--directory"));
|
||||||
args.outputFile = eupak::fs::path(parser.get("output"));
|
args.outputFile = fs::path(parser.get("output"));
|
||||||
|
|
||||||
if(parser.is_used("--archive-version")) {
|
if(parser.is_used("--archive-version")) {
|
||||||
const auto& versionStr = parser.get("--archive-version");
|
const auto& versionStr = parser.get("--archive-version");
|
||||||
|
@ -156,12 +157,12 @@ namespace eupak::tasks {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
args.pakVersion = europa::structs::PakVersion::Ver4;
|
args.pakVersion = estructs::PakVersion::Ver4;
|
||||||
}
|
}
|
||||||
|
|
||||||
args.sectorAligned = parser.get<bool>("--sector-aligned");
|
args.sectorAligned = parser.get<bool>("--sector-aligned");
|
||||||
|
|
||||||
if(args.sectorAligned && args.pakVersion != eupak::estructs::PakVersion::Ver5) {
|
if(args.sectorAligned && args.pakVersion != estructs::PakVersion::Ver5) {
|
||||||
std::cout << "Error: --sector-aligned is only valid for creating a package with \"-V jedistarfighter\".\n"
|
std::cout << "Error: --sector-aligned is only valid for creating a package with \"-V jedistarfighter\".\n"
|
||||||
<< parser;
|
<< parser;
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -212,7 +213,7 @@ namespace eupak::tasks {
|
||||||
// TODO: use time to write in the header
|
// TODO: use time to write in the header
|
||||||
// also: is there any point to verbosity? could add archive written size ig
|
// also: is there any point to verbosity? could add archive written size ig
|
||||||
|
|
||||||
std::vector<europa::io::PakWriter::FlattenedType> files;
|
std::vector<eio::pak::Writer::FlattenedType> files;
|
||||||
files.reserve(fileCount);
|
files.reserve(fileCount);
|
||||||
|
|
||||||
for(auto& ent : fs::recursive_directory_iterator(args.inputDirectory)) {
|
for(auto& ent : fs::recursive_directory_iterator(args.inputDirectory)) {
|
||||||
|
@ -229,8 +230,8 @@ namespace eupak::tasks {
|
||||||
|
|
||||||
progress.set_option(indicators::option::PostfixText { relativePathName + " (" + std::to_string(currFile + 1) + '/' + std::to_string(fileCount) + ")" });
|
progress.set_option(indicators::option::PostfixText { relativePathName + " (" + std::to_string(currFile + 1) + '/' + std::to_string(fileCount) + ")" });
|
||||||
|
|
||||||
eio::PakFile file;
|
eio::pak::File file;
|
||||||
eio::PakFile::DataType pakData = eio::PakFileData::InitAsPath(ent.path());
|
eio::pak::FileData pakData = eio::pak::FileData::InitAsPath(ent.path());
|
||||||
|
|
||||||
file.InitAs(args.pakVersion, args.sectorAligned);
|
file.InitAs(args.pakVersion, args.sectorAligned);
|
||||||
|
|
||||||
|
@ -260,11 +261,11 @@ namespace eupak::tasks {
|
||||||
}
|
}
|
||||||
|
|
||||||
CreateArchiveReportSink reportSink(fileCount);
|
CreateArchiveReportSink reportSink(fileCount);
|
||||||
eio::PakWriter writer(args.pakVersion);
|
eio::pak::Writer writer(args.pakVersion);
|
||||||
|
|
||||||
using enum eio::PakWriter::SectorAlignment;
|
using enum eio::pak::Writer::SectorAlignment;
|
||||||
|
|
||||||
eio::PakWriter::SectorAlignment alignment = DoNotAlign;
|
eio::pak::Writer::SectorAlignment alignment = DoNotAlign;
|
||||||
|
|
||||||
if(args.sectorAligned)
|
if(args.sectorAligned)
|
||||||
alignment = Align;
|
alignment = Align;
|
||||||
|
|
|
@ -9,12 +9,11 @@
|
||||||
#ifndef EUROPA_EUPAK_TASKS_CREATETASK_HPP
|
#ifndef EUROPA_EUPAK_TASKS_CREATETASK_HPP
|
||||||
#define EUROPA_EUPAK_TASKS_CREATETASK_HPP
|
#define EUROPA_EUPAK_TASKS_CREATETASK_HPP
|
||||||
|
|
||||||
|
#include <argparse/argparse.hpp>
|
||||||
#include <CommonDefs.hpp>
|
#include <CommonDefs.hpp>
|
||||||
#include <europa/structs/Pak.hpp>
|
#include <europa/structs/Pak.hpp>
|
||||||
#include <tasks/Task.hpp>
|
#include <tasks/Task.hpp>
|
||||||
|
|
||||||
#include "argparse/argparse.hpp"
|
|
||||||
|
|
||||||
namespace eupak::tasks {
|
namespace eupak::tasks {
|
||||||
|
|
||||||
struct CreateTask : ITask {
|
struct CreateTask : ITask {
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
//
|
//
|
||||||
|
|
||||||
#include <EupakConfig.hpp>
|
#include <EupakConfig.hpp>
|
||||||
#include <europa/io/PakReader.hpp>
|
#include <europa/io/pak/Reader.hpp>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <indicators/cursor_control.hpp>
|
#include <indicators/cursor_control.hpp>
|
||||||
#include <indicators/progress_bar.hpp>
|
#include <indicators/progress_bar.hpp>
|
||||||
|
@ -82,7 +82,7 @@ namespace eupak::tasks {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
eio::PakReader reader(ifs);
|
eio::pak::Reader reader(ifs);
|
||||||
|
|
||||||
reader.ReadHeaderAndTOC();
|
reader.ReadHeaderAndTOC();
|
||||||
|
|
||||||
|
|
|
@ -10,8 +10,7 @@
|
||||||
#define EUROPA_EUPAK_TASKS_EXTRACTTASK_HPP
|
#define EUROPA_EUPAK_TASKS_EXTRACTTASK_HPP
|
||||||
|
|
||||||
#include <CommonDefs.hpp>
|
#include <CommonDefs.hpp>
|
||||||
|
#include <tasks/Task.hpp>
|
||||||
#include "tasks/Task.hpp"
|
|
||||||
|
|
||||||
namespace eupak::tasks {
|
namespace eupak::tasks {
|
||||||
|
|
||||||
|
|
|
@ -6,17 +6,15 @@
|
||||||
// SPDX-License-Identifier: MIT
|
// SPDX-License-Identifier: MIT
|
||||||
//
|
//
|
||||||
|
|
||||||
|
#include <argparse/argparse.hpp>
|
||||||
#include <EupakConfig.hpp>
|
#include <EupakConfig.hpp>
|
||||||
#include <europa/io/PakReader.hpp>
|
#include <europa/io/pak/Reader.hpp>
|
||||||
#include <filesystem>
|
#include <filesystem>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <tasks/InfoTask.hpp>
|
#include <tasks/InfoTask.hpp>
|
||||||
#include <Utils.hpp>
|
#include <Utils.hpp>
|
||||||
|
|
||||||
#include "argparse/argparse.hpp"
|
|
||||||
#include "europa/structs/Pak.hpp"
|
|
||||||
|
|
||||||
namespace eupak::tasks {
|
namespace eupak::tasks {
|
||||||
|
|
||||||
constexpr static auto DATE_FORMAT = "%m/%d/%Y %r";
|
constexpr static auto DATE_FORMAT = "%m/%d/%Y %r";
|
||||||
|
@ -78,7 +76,7 @@ namespace eupak::tasks {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
eio::PakReader reader(ifs);
|
eio::pak::Reader reader(ifs);
|
||||||
|
|
||||||
reader.ReadHeaderAndTOC();
|
reader.ReadHeaderAndTOC();
|
||||||
|
|
||||||
|
@ -120,7 +118,6 @@ namespace eupak::tasks {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
file.VisitTocEntry([&](auto& tocEntry) {
|
file.VisitTocEntry([&](auto& tocEntry) {
|
||||||
std::printf("%16s %10s %8s", FormatUnixTimestamp(tocEntry.creationUnixTime, DATE_FORMAT).c_str(), FormatUnit(tocEntry.size).c_str(), filename.c_str());
|
std::printf("%16s %10s %8s", FormatUnixTimestamp(tocEntry.creationUnixTime, DATE_FORMAT).c_str(), FormatUnit(tocEntry.size).c_str(), filename.c_str());
|
||||||
|
|
||||||
|
|
|
@ -10,8 +10,7 @@
|
||||||
#define EUROPA_EUPAK_TASKS_INFOTASK_HPP
|
#define EUROPA_EUPAK_TASKS_INFOTASK_HPP
|
||||||
|
|
||||||
#include <CommonDefs.hpp>
|
#include <CommonDefs.hpp>
|
||||||
|
#include <tasks/Task.hpp>
|
||||||
#include "tasks/Task.hpp"
|
|
||||||
|
|
||||||
namespace eupak::tasks {
|
namespace eupak::tasks {
|
||||||
|
|
||||||
|
|
|
@ -1,3 +1,11 @@
|
||||||
|
//
|
||||||
|
// EuropaTools
|
||||||
|
//
|
||||||
|
// (C) 2021-2025 modeco80 <lily.modeco80@protonmail.ch>
|
||||||
|
//
|
||||||
|
// SPDX-License-Identifier: MIT
|
||||||
|
//
|
||||||
|
|
||||||
#include "Task.hpp"
|
#include "Task.hpp"
|
||||||
|
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
|
|
|
@ -7,12 +7,11 @@
|
||||||
//
|
//
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
#include <argparse/argparse.hpp>
|
||||||
#include <CommonDefs.hpp>
|
#include <CommonDefs.hpp>
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
|
|
||||||
#include "argparse/argparse.hpp"
|
|
||||||
|
|
||||||
namespace eupak::tasks {
|
namespace eupak::tasks {
|
||||||
|
|
||||||
/// Base-class for all eupak tasks.
|
/// Base-class for all eupak tasks.
|
||||||
|
@ -49,7 +48,7 @@ namespace eupak::tasks {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Helper template to register into the [TaskFactory].
|
/// Helper template to register into the [TaskFactory].
|
||||||
template <class T>
|
template <class T>
|
||||||
struct TaskFactoryRegister {
|
struct TaskFactoryRegister {
|
||||||
TaskFactoryRegister(const std::string& name) {
|
TaskFactoryRegister(const std::string& name) {
|
||||||
|
@ -61,8 +60,8 @@ namespace eupak::tasks {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Registers a task. Should be put in the .cpp implementation source file of the
|
/// Registers a task. Should be put in the .cpp implementation source file of the
|
||||||
/// task object itself.
|
/// task object itself.
|
||||||
#define EUPAK_REGISTER_TASK(Name, TTask) \
|
#define EUPAK_REGISTER_TASK(Name, TTask) \
|
||||||
static ::eupak::tasks::TaskFactoryRegister<TTask> __register__##TTask(Name)
|
static ::eupak::tasks::TaskFactoryRegister<TTask> __register__##TTask(Name)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue