2020-12-18 23:21:10 +01:00
|
|
|
#ifndef GAME_MWBASE_LUAMANAGER_H
|
|
|
|
#define GAME_MWBASE_LUAMANAGER_H
|
|
|
|
|
2022-07-30 19:10:36 +02:00
|
|
|
#include <map>
|
|
|
|
#include <string>
|
2021-06-26 23:10:24 +02:00
|
|
|
#include <variant>
|
2022-07-30 19:10:36 +02:00
|
|
|
|
2020-12-18 23:21:10 +01:00
|
|
|
#include <SDL_events.h>
|
|
|
|
|
2023-07-09 08:42:09 +02:00
|
|
|
#include "../mwgui/mode.hpp"
|
2022-02-21 19:49:00 +00:00
|
|
|
#include <components/sdlutil/events.hpp>
|
|
|
|
|
2020-12-18 23:21:10 +01:00
|
|
|
namespace MWWorld
|
|
|
|
{
|
2023-06-13 17:04:22 +02:00
|
|
|
class CellStore;
|
2020-12-18 23:21:10 +01:00
|
|
|
class Ptr;
|
|
|
|
}
|
|
|
|
|
2021-01-29 02:38:09 +01:00
|
|
|
namespace Loading
|
|
|
|
{
|
|
|
|
class Listener;
|
|
|
|
}
|
|
|
|
|
|
|
|
namespace ESM
|
|
|
|
{
|
|
|
|
class ESMReader;
|
|
|
|
class ESMWriter;
|
2023-06-12 21:35:00 -05:00
|
|
|
class RefId;
|
2021-04-23 02:49:12 +02:00
|
|
|
struct LuaScripts;
|
2021-01-29 02:38:09 +01:00
|
|
|
}
|
|
|
|
|
2020-12-18 23:21:10 +01:00
|
|
|
namespace MWBase
|
|
|
|
{
|
2023-03-13 22:41:28 +00:00
|
|
|
// \brief LuaManager is the central interface through which the engine invokes lua scripts.
|
|
|
|
//
|
|
|
|
// The native side invokes functions on this interface, which queues events to be handled by the
|
|
|
|
// scripts in the lua thread. Synchronous calls are not possible.
|
|
|
|
//
|
|
|
|
// The main implementation is in apps/openmw/mwlua/luamanagerimp.cpp.
|
|
|
|
// Lua logic in general lives under apps/openmw/mwlua and this interface is
|
|
|
|
// the main way for the rest of the engine to interact with the logic there.
|
2020-12-18 23:21:10 +01:00
|
|
|
class LuaManager
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual ~LuaManager() = default;
|
|
|
|
|
|
|
|
virtual void newGameStarted() = 0;
|
2021-09-25 10:46:47 +02:00
|
|
|
virtual void gameLoaded() = 0;
|
2021-04-21 04:11:11 +02:00
|
|
|
virtual void objectAddedToScene(const MWWorld::Ptr& ptr) = 0;
|
|
|
|
virtual void objectRemovedFromScene(const MWWorld::Ptr& ptr) = 0;
|
2023-06-18 21:19:34 +02:00
|
|
|
virtual void objectTeleported(const MWWorld::Ptr& ptr) = 0;
|
2022-05-12 18:03:50 +02:00
|
|
|
virtual void itemConsumed(const MWWorld::Ptr& consumable, const MWWorld::Ptr& actor) = 0;
|
2022-02-01 23:42:56 +00:00
|
|
|
virtual void objectActivated(const MWWorld::Ptr& object, const MWWorld::Ptr& actor) = 0;
|
2023-09-11 16:21:34 +02:00
|
|
|
virtual void useItem(const MWWorld::Ptr& object, const MWWorld::Ptr& actor, bool force) = 0;
|
2023-06-13 17:04:22 +02:00
|
|
|
virtual void exteriorCreated(MWWorld::CellStore& cell) = 0;
|
2023-06-12 21:35:00 -05:00
|
|
|
virtual void questUpdated(const ESM::RefId& questId, int stage) = 0;
|
2023-07-09 08:42:09 +02:00
|
|
|
|
|
|
|
// `arg` is either forwarded from MWGui::pushGuiMode or empty
|
|
|
|
virtual void uiModeChanged(const MWWorld::Ptr& arg) = 0;
|
|
|
|
|
2021-04-21 04:11:11 +02:00
|
|
|
// TODO: notify LuaManager about other events
|
|
|
|
// virtual void objectOnHit(const MWWorld::Ptr &ptr, float damage, bool ishealth, const MWWorld::Ptr &object,
|
|
|
|
// const MWWorld::Ptr &attacker, const osg::Vec3f &hitPosition, bool successful) = 0;
|
2020-12-18 23:21:10 +01:00
|
|
|
|
2021-06-26 23:10:24 +02:00
|
|
|
struct InputEvent
|
|
|
|
{
|
2022-02-21 19:49:00 +00:00
|
|
|
enum
|
|
|
|
{
|
|
|
|
KeyPressed,
|
|
|
|
KeyReleased,
|
|
|
|
ControllerPressed,
|
|
|
|
ControllerReleased,
|
|
|
|
Action,
|
|
|
|
TouchPressed,
|
|
|
|
TouchReleased,
|
|
|
|
TouchMoved,
|
|
|
|
} mType;
|
|
|
|
std::variant<SDL_Keysym, int, SDLUtil::TouchEvent> mValue;
|
2021-06-26 23:10:24 +02:00
|
|
|
};
|
|
|
|
virtual void inputEvent(const InputEvent& event) = 0;
|
|
|
|
|
2021-04-23 02:49:12 +02:00
|
|
|
struct ActorControls
|
|
|
|
{
|
2021-07-12 11:01:32 +02:00
|
|
|
bool mDisableAI = false;
|
2021-08-03 02:40:44 +03:00
|
|
|
bool mChanged = false;
|
2021-07-12 11:01:32 +02:00
|
|
|
|
|
|
|
bool mJump = false;
|
|
|
|
bool mRun = false;
|
2022-12-05 23:31:23 +01:00
|
|
|
bool mSneak = false;
|
2021-07-12 11:01:32 +02:00
|
|
|
float mMovement = 0;
|
|
|
|
float mSideMovement = 0;
|
2022-02-01 18:47:20 +00:00
|
|
|
float mPitchChange = 0;
|
|
|
|
float mYawChange = 0;
|
|
|
|
int mUse = 0;
|
2020-12-18 23:21:10 +01:00
|
|
|
};
|
|
|
|
|
2021-04-18 22:09:01 +02:00
|
|
|
virtual ActorControls* getActorControls(const MWWorld::Ptr&) const = 0;
|
2020-12-18 23:21:10 +01:00
|
|
|
|
|
|
|
virtual void clear() = 0;
|
|
|
|
virtual void setupPlayer(const MWWorld::Ptr&) = 0;
|
2021-01-29 02:38:09 +01:00
|
|
|
|
|
|
|
// Saving
|
2022-10-05 23:45:17 +02:00
|
|
|
int countSavedGameRecords() const { return 1; }
|
2021-01-29 02:38:09 +01:00
|
|
|
virtual void write(ESM::ESMWriter& writer, Loading::Listener& progress) = 0;
|
|
|
|
virtual void saveLocalScripts(const MWWorld::Ptr& ptr, ESM::LuaScripts& data) = 0;
|
|
|
|
|
2023-07-30 02:50:22 +02:00
|
|
|
// Must be called before save, otherwise the world can be saved in an inconsistent state.
|
|
|
|
virtual void applyDelayedActions() = 0;
|
|
|
|
|
2021-01-29 02:38:09 +01:00
|
|
|
// Loading from a save
|
|
|
|
virtual void readRecord(ESM::ESMReader& reader, uint32_t type) = 0;
|
|
|
|
virtual void loadLocalScripts(const MWWorld::Ptr& ptr, const ESM::LuaScripts& data) = 0;
|
|
|
|
|
|
|
|
// Should be called before loading. The map is used to fix refnums if the order of content files was changed.
|
|
|
|
virtual void setContentFileMapping(const std::map<int, int>&) = 0;
|
2021-04-12 03:15:17 +02:00
|
|
|
|
|
|
|
// Drops script cache and reloads all scripts. Calls `onSave` and `onLoad` for every script.
|
|
|
|
virtual void reloadAllScripts() = 0;
|
2022-04-09 23:07:57 +02:00
|
|
|
|
|
|
|
virtual void handleConsoleCommand(
|
|
|
|
const std::string& consoleMode, const std::string& command, const MWWorld::Ptr& selectedPtr)
|
|
|
|
= 0;
|
2022-11-26 21:25:18 +01:00
|
|
|
|
|
|
|
virtual std::string formatResourceUsageStats() const = 0;
|
2020-12-18 23:21:10 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // GAME_MWBASE_LUAMANAGER_H
|