blob: b5aef421ce61e254833bec8fbba643e3b6453228 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
#include "pch.h"
#include "modmanager.h"
#include "scriptsrson.h"
#include "filesystem.h"
#include "squirrel.h"
#include <sstream>
#include <fstream>
void ModManager::BuildScriptsRson()
{
spdlog::info("Building custom scripts.rson");
fs::remove(MOD_SCRIPTS_RSON_PATH);
// not really important since it doesn't affect actual functionality at all, but the rson we output is really weird
// has a shitload of newlines added, even in places where we don't modify it at all
std::string scriptsRson = ReadVPKOriginalFile("scripts/vscripts/scripts.rson");
scriptsRson += "\n\n// START MODDED SCRIPT CONTENT\n\n"; // newline before we start custom stuff
for (Mod* mod : m_loadedMods)
{
// this isn't needed at all, just nice to have imo
scriptsRson += "// MOD: ";
scriptsRson += mod->Name;
scriptsRson += ":\n\n";
for (ModScript* script : mod->Scripts)
{
/* should create something with this format for each script
When: "CONTEXT"
Scripts:
[
_coolscript.gnut
]*/
scriptsRson += "When: \"";
scriptsRson += script->RsonRunOn;
scriptsRson += "\"\n";
scriptsRson += "Scripts:\n[\n\t";
scriptsRson += script->Path;
scriptsRson += "\n]\n\n";
}
}
fs::create_directories(MOD_SCRIPTS_RSON_PATH.parent_path());
std::ofstream writeStream(MOD_SCRIPTS_RSON_PATH);
writeStream << scriptsRson;
writeStream.close();
ModOverrideFile* overrideFile = new ModOverrideFile;
overrideFile->owningMod = nullptr;
overrideFile->path = VPK_SCRIPTS_RSON_PATH;
if (m_modFiles.find(VPK_SCRIPTS_RSON_PATH) == m_modFiles.end())
m_modFiles.insert(std::make_pair(VPK_SCRIPTS_RSON_PATH, overrideFile));
else
m_modFiles[VPK_SCRIPTS_RSON_PATH] = overrideFile;
// todo: for preventing dupe scripts in scripts.rson, we could actually parse when conditions with the squirrel vm, just need a way to get a result out of squirrelmanager.ExecuteCode
// this would probably be the best way to do this, imo
}
|