libeuropa/io: Split pak into new subdirectory

Namespaces exist. Use them, perhaps.
This commit is contained in:
Lily Tsuru 2025-01-15 21:50:34 -05:00
parent 087657d5c1
commit 84c537c873
15 changed files with 102 additions and 99 deletions

View file

@ -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

View file

@ -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

View file

@ -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 {};
}; };

View file

@ -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;

View file

@ -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

View file

@ -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

View file

@ -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

View file

@ -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;

View file

@ -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 {

View file

@ -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();

View file

@ -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 {

View file

@ -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());

View file

@ -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 {

View file

@ -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>

View file

@ -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.