mirror of
https://github.com/aimrebirth/tools.git
synced 2026-04-14 17:33:25 +00:00
Initial txt2script.
This commit is contained in:
parent
5c641bcc04
commit
161cd9d95e
2 changed files with 84 additions and 0 deletions
83
src/txt2script/txt2script.cpp
Normal file
83
src/txt2script/txt2script.cpp
Normal file
|
|
@ -0,0 +1,83 @@
|
||||||
|
/*
|
||||||
|
* AIM script2txt2 (simpler version)
|
||||||
|
* Copyright (C) 2024 lzwdgc
|
||||||
|
*
|
||||||
|
* 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, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* 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 for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <mmap.h>
|
||||||
|
#include <types.h>
|
||||||
|
|
||||||
|
#include <primitives/sw/main.h>
|
||||||
|
#include <primitives/sw/settings.h>
|
||||||
|
#include <primitives/sw/cl.h>
|
||||||
|
|
||||||
|
#include <fstream>
|
||||||
|
|
||||||
|
int main(int argc, char *argv[]) {
|
||||||
|
cl::opt<path> p(cl::Positional, cl::desc("<script.scr or scripts dir>"), cl::Required);
|
||||||
|
|
||||||
|
cl::ParseCommandLineOptions(argc, argv);
|
||||||
|
|
||||||
|
auto func = [](path filename) {
|
||||||
|
uint32_t sz{};
|
||||||
|
auto lines = read_lines(filename);
|
||||||
|
for (auto &&line : lines) {
|
||||||
|
sz += line.size() + 1;
|
||||||
|
}
|
||||||
|
uint32_t maxlines = lines.size();
|
||||||
|
|
||||||
|
uint32_t unk{};
|
||||||
|
auto fsz = sizeof(script) + sz + maxlines * sizeof(sz) + sizeof(unk);
|
||||||
|
|
||||||
|
primitives::templates2::mmap_file<uint8_t> f{filename.stem(), primitives::templates2::mmap_file<uint8_t>::rw{}};
|
||||||
|
f.alloc_raw(fsz);
|
||||||
|
stream s{f};
|
||||||
|
script scr{};
|
||||||
|
scr.nlines = lines.size();
|
||||||
|
scr.raw_text_size = sz;
|
||||||
|
scr.file_size = fsz - sizeof(scr.file_size);
|
||||||
|
s = scr;
|
||||||
|
|
||||||
|
for (auto &&line : lines) {
|
||||||
|
boost::to_upper(line); // can be bad?
|
||||||
|
memcpy((char *)s.p, line.c_str(), line.size() + 1);
|
||||||
|
s.skip(line.size() + 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
s = maxlines;
|
||||||
|
uint32_t offset{};
|
||||||
|
for (auto &&line : lines) {
|
||||||
|
s = offset;
|
||||||
|
offset += line.size() + 1;
|
||||||
|
}
|
||||||
|
s = offset;
|
||||||
|
};
|
||||||
|
|
||||||
|
if (fs::is_regular_file(p)) {
|
||||||
|
func(p.string());
|
||||||
|
} else if (fs::is_directory(p)) {
|
||||||
|
auto files = enumerate_files_like(p, ".*\\.scr.txt", false);
|
||||||
|
auto files2 = enumerate_files_like(p, ".*\\.QST.txt", false);
|
||||||
|
files.insert(files2.begin(), files2.end());
|
||||||
|
for (auto &f : files) {
|
||||||
|
std::cout << "processing: " << f << "\n";
|
||||||
|
func(f.string());
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
throw std::runtime_error("Bad fs object");
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
1
sw.cpp
1
sw.cpp
|
|
@ -50,6 +50,7 @@ void build(Solution &s)
|
||||||
add_exe_with_common("mpj_loader");
|
add_exe_with_common("mpj_loader");
|
||||||
add_exe_with_common("paker");
|
add_exe_with_common("paker");
|
||||||
add_exe_with_common("script2txt2");
|
add_exe_with_common("script2txt2");
|
||||||
|
add_exe_with_common("txt2script");
|
||||||
add_exe_with_common("tm_converter");
|
add_exe_with_common("tm_converter");
|
||||||
add_exe("name_generator");
|
add_exe("name_generator");
|
||||||
add_exe_with_common("save_loader");
|
add_exe_with_common("save_loader");
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue