2024-02-25 15:46:47 +01:00
|
|
|
#pragma once
|
2023-06-20 14:33:09 +10:00
|
|
|
|
|
|
|
#include "StarThread.hpp"
|
|
|
|
#include "StarLua.hpp"
|
|
|
|
#include "StarRoot.hpp"
|
|
|
|
|
|
|
|
namespace Star {
|
|
|
|
|
|
|
|
STAR_CLASS(LuaRoot);
|
|
|
|
|
|
|
|
// Loads and caches lua scripts from assets. Automatically clears cache on
|
|
|
|
// root reload. Uses an internal LuaEngine, so this and all contexts are meant
|
|
|
|
// for single threaded access and have no locking.
|
|
|
|
class LuaRoot {
|
|
|
|
public:
|
|
|
|
LuaRoot();
|
|
|
|
~LuaRoot();
|
|
|
|
|
|
|
|
void loadScript(String const& assetPath);
|
|
|
|
bool scriptLoaded(String const& assetPath) const;
|
|
|
|
void unloadScript(String const& assetPath);
|
|
|
|
|
2023-07-04 19:27:16 +10:00
|
|
|
void restart();
|
|
|
|
void shutdown();
|
|
|
|
|
2023-06-20 14:33:09 +10:00
|
|
|
// A script context can be created from the combination of several scripts,
|
|
|
|
// the functions / data in each script will be loaded in order, so that later
|
|
|
|
// specified scripts will overwrite previous ones.
|
|
|
|
//
|
|
|
|
// The LuaContext that is returned will have its 'require' function
|
|
|
|
// overloaded to take absolute asset paths and load that asset path as a lua
|
|
|
|
// module, with protection from duplicate loading.
|
|
|
|
LuaContext createContext(String const& script);
|
|
|
|
LuaContext createContext(StringList const& scriptPaths = {});
|
|
|
|
|
|
|
|
void collectGarbage(Maybe<unsigned> steps = {});
|
|
|
|
void setAutoGarbageCollection(bool autoGarbageColleciton);
|
|
|
|
void tuneAutoGarbageCollection(float pause, float stepMultiplier);
|
|
|
|
size_t luaMemoryUsage() const;
|
|
|
|
|
|
|
|
size_t scriptCacheMemoryUsage() const;
|
|
|
|
void clearScriptCache() const;
|
|
|
|
|
2023-07-04 19:27:16 +10:00
|
|
|
void addCallbacks(String const& groupName, LuaCallbacks const& callbacks);
|
2023-06-20 14:33:09 +10:00
|
|
|
|
2023-07-04 19:27:16 +10:00
|
|
|
LuaEngine& luaEngine() const;
|
2023-06-20 14:33:09 +10:00
|
|
|
private:
|
|
|
|
class ScriptCache {
|
|
|
|
public:
|
|
|
|
void loadScript(LuaEngine& engine, String const& assetPath);
|
|
|
|
bool scriptLoaded(String const& assetPath) const;
|
|
|
|
void unloadScript(String const& assetPath);
|
|
|
|
void clear();
|
|
|
|
void loadContextScript(LuaContext& context, String const& assetPath);
|
|
|
|
size_t memoryUsage() const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
mutable RecursiveMutex mutex;
|
|
|
|
StringMap<ByteArray> scripts;
|
|
|
|
};
|
|
|
|
|
|
|
|
LuaEnginePtr m_luaEngine;
|
2023-07-04 19:27:16 +10:00
|
|
|
StringMap<LuaCallbacks> m_luaCallbacks;
|
2023-06-20 14:33:09 +10:00
|
|
|
shared_ptr<ScriptCache> m_scriptCache;
|
2023-07-04 19:27:16 +10:00
|
|
|
|
2023-06-20 14:33:09 +10:00
|
|
|
ListenerPtr m_rootReloadListener;
|
|
|
|
|
|
|
|
String m_storageDirectory;
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|