1
0
Fork 0
mirror of https://github.com/AquariaOSE/Aquaria.git synced 2025-01-24 17:26:41 +00:00

make dmon optional at compile time, and a dedicated runtime option

it's still experimental and might cause problems,
so only enable this if specifically requested,
since it's not needed for regular gameplay
This commit is contained in:
fgenesis 2024-06-27 23:42:45 +02:00
parent 5895703ac4
commit f71c7f5d40
8 changed files with 82 additions and 7 deletions

View file

@ -150,7 +150,8 @@ void Mod::load(const std::string &p)
}
}
dsq->setExtraTexturePath((path + "graphics/").c_str(), dsq->isDeveloperKeys());
bool hotReload = dsq->user.system.hotreload;
dsq->setExtraTexturePath((path + "graphics/").c_str(), hotReload);
dsq->sound->audioPath2 = path + "audio/";
dsq->sound->setVoicePath2(path + "audio/");

View file

@ -69,6 +69,12 @@ void UserSettings::save()
xml_grabInp->SetAttribute("on", system.grabInput);
}
xml_system->InsertEndChild(xml_grabInp);
XMLElement *xml_hotreload = doc.NewElement("HotReloadModGraphics");
{
xml_hotreload->SetAttribute("on", system.hotreload);
}
xml_system->InsertEndChild(xml_hotreload);
}
doc.InsertEndChild(xml_system);
@ -385,6 +391,12 @@ bool UserSettings::load(bool doApply, const std::string &overrideFile)
{
system.grabInput = xml_grabInp->IntAttribute("on");
}
XMLElement *xml_hotreload = xml_system->FirstChildElement("HotReloadModGraphics");
if (xml_hotreload)
{
system.hotreload = xml_hotreload->IntAttribute("on");
}
}
XMLElement *xml_audio = doc.FirstChildElement("Audio");

View file

@ -37,12 +37,13 @@ class UserSettings
public:
struct System
{
System() { debugLogOn = 0; devModeOn = 0; allowDangerousScriptFunctions = 0; grabInput=1; }
System() { debugLogOn = 0; devModeOn = 0; allowDangerousScriptFunctions = 0; grabInput=1; hotreload=0; }
int debugLogOn;
std::string locale;
int devModeOn;
int allowDangerousScriptFunctions;
int grabInput;
int hotreload;
} system;
struct Audio

View file

@ -260,6 +260,25 @@ bool exists(const std::string &f, bool makeFatal, bool skipVFS)
return e;
}
bool dirExistsOnDisk(const std::string &f)
{
#ifdef BBGE_BUILD_VFS
return ttvfs::IsDirectory(f.c_str());
#elif _WIN32
DWORD dwFileAttr = GetFileAttributesA(s);
if(dwFileAttr == INVALID_FILE_ATTRIBUTES)
return false;
return !!(dwFileAttr & FILE_ATTRIBUTE_DIRECTORY);
#else
if (!access(s, 0))
{
struct stat status;
stat( s, &status );
return status.st_mode & S_IFDIR;
}
return false;
#endif
}
std::string getPathInfoStr()

View file

@ -138,6 +138,7 @@ void stringToLower(std::string &s);
void stringToLowerUserData(std::string &s);
float sqr(float x);
bool exists(const std::string &f, bool makeFatal = false, bool skipVFS = false);
bool dirExistsOnDisk(const std::string &f);
void errorLog(const std::string &s);
void debugLog(const std::string &s);

View file

@ -1,15 +1,27 @@
#include "DirWatcher.h"
#include <string>
#include <assert.h>
#include <sstream>
#ifdef AQUARIA_ENABLE_DIR_WATCH
#include <SDL_mutex.h>
#define DMON_IMPL
#define DMON_SLEEP_INTERVAL 250
#define DMON_LOG_DEBUG(s) debugLog(s)
#define DMON_LOG_ERROR(s) debugLog(s) // no, dmon, you're not allowed to abort() when a directory doesn't exist. grrr.
#include "dmon.h"
namespace DirWatcher {
#endif
namespace DirWatcher {
#ifdef AQUARIA_ENABLE_DIR_WATCH
struct WatchEntry
{
@ -32,15 +44,25 @@ static std::vector<WatchEntry> s_watches;
static std::vector<Pending> s_pending, s_processing;
static SDL_mutex *s_mtx;
#endif
bool Init()
{
#ifdef AQUARIA_ENABLE_DIR_WATCH
debugLog("DirWatcher: Init");
assert(!s_mtx);
s_mtx = SDL_CreateMutex();
dmon_init();
return true;
#else
debugLog("DirWatcher: Not enabled at compile time. Function not available.");
return false;
#endif
}
void Shutdown()
{
#ifdef AQUARIA_ENABLE_DIR_WATCH
if(!s_mtx)
return;
for(size_t i = 0; i < s_watches.size(); ++i)
@ -51,10 +73,12 @@ void Shutdown()
dmon_deinit();
SDL_DestroyMutex(s_mtx);
s_mtx = NULL;
#endif
}
void Pump()
{
#ifdef AQUARIA_ENABLE_DIR_WATCH
if(!s_mtx)
return;
@ -103,6 +127,7 @@ void Pump()
s_processing.clear();
debugLog("... callbacks done.");
#endif
}
static void _watch_cb(dmon_watch_id watch_id, dmon_action action,
@ -135,6 +160,13 @@ static void _watch_cb(dmon_watch_id watch_id, dmon_action action,
size_t AddWatch(const char* path, Flags flags, Callback cb, void* ud)
{
#ifdef AQUARIA_ENABLE_DIR_WATCH
if(!dirExistsOnDisk(path))
{
debugLog(std::string("DirWatcher: Path does not exist, ignoring: ") + path);
return 0;
}
const size_t N = s_watches.size();
if(!N && !s_mtx)
if(!Init())
@ -160,6 +192,8 @@ size_t AddWatch(const char* path, Flags flags, Callback cb, void* ud)
if(flags & RECURSIVE)
flg = DMON_WATCHFLAGS_RECURSIVE;
debugLog(std::string("DirWatcher: Add watch: ") + path);
s_watches[idx].watch = dmon_watch(path, _watch_cb, (dmon_watch_flags_t)flg, (void*)(uintptr_t)idx);
if(!s_watches[idx].watch.id)
{
@ -170,17 +204,22 @@ size_t AddWatch(const char* path, Flags flags, Callback cb, void* ud)
}
s_watches[idx].valid = true;
return idx + 1;
#endif
}
void RemoveWatch(size_t idx)
{
#ifdef AQUARIA_ENABLE_DIR_WATCH
if(!idx)
return;
--idx;
assert(s_watches[idx].valid);
debugLog("DirWatcher: Remove watch: " + s_watches[idx].path);
dmon_unwatch(s_watches[idx].watch);
s_watches[idx].valid = false;
#endif
}

View file

@ -82,6 +82,8 @@ OPTION(AQUARIA_USE_GLM "Use GLM for matrix math" TRUE)
OPTION(AQUARIA_DEBUG_SHOW_PATHS "Show important paths upon game start to aid in finding path problems" FALSE)
mark_as_advanced(AQUARIA_DEBUG_SHOW_PATHS)
OPTION(AQUARIA_ENABLE_DIR_WATCH "Enable directory watcher component to hot-reload textures in mods. Must be enabled in the game config to be active." TRUE)
#add_compile_options(-fsanitize=address)
#add_link_options(-fsanitize=address)
@ -136,6 +138,10 @@ if(AQUARIA_DEBUG_SHOW_PATHS)
ADD_DEFINITIONS(-DAQUARIA_DEBUG_SHOW_PATHS)
endif(AQUARIA_DEBUG_SHOW_PATHS)
if(AQUARIA_ENABLE_DIR_WATCH)
ADD_DEFINITIONS(-DAQUARIA_ENABLE_DIR_WATCH)
endif(AQUARIA_ENABLE_DIR_WATCH)
# Without #define VFS_ENABLE_C_API this is just stubbed out
include_directories(ttvfs_cfileapi)
if(AQUARIA_USE_VFS)

View file

@ -37,7 +37,3 @@ static unsigned char * miniz_stbi_compress(unsigned char *data, int data_len, in
#define QOI_IMPLEMENTATION
#define QOI_NO_STDIO
#include "qoi.h"
#define DMON_IMPL
#define DMON_SLEEP_INTERVAL 250
#include "dmon.h"