1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-16 16:59:56 +00:00
openmw/apps/openmw/mwlua
2024-07-23 10:39:58 +02:00
..
types Lua door opening api 2024-07-15 07:09:44 +00:00
animationbindings.cpp Throw on invalid bone group indices in getActiveGroup 2024-06-12 23:26:16 +03:00
animationbindings.hpp Cleanup includes 2024-03-21 11:14:01 +01:00
birthsignbindings.cpp Cleanup includes 2024-03-21 11:14:01 +01:00
birthsignbindings.hpp Remove Core from functions that aren't in openmw.core 2024-02-08 16:53:48 +01:00
camerabindings.cpp Cleanup includes 2024-03-21 11:14:01 +01:00
camerabindings.hpp Add headers for all .cpp files in mwlua; move packages initilaization from LuaManager to luabindings.cpp 2023-04-25 23:24:51 +02:00
cellbindings.cpp Expose cell ID, Add actor travel destinations to types.Actor.record.servicesOffered 2024-06-19 21:38:27 +00:00
cellbindings.hpp Add headers for all .cpp files in mwlua; move packages initilaization from LuaManager to luabindings.cpp 2023-04-25 23:24:51 +02:00
classbindings.cpp Cleanup includes 2024-03-21 11:14:01 +01:00
classbindings.hpp Remove Core from functions that aren't in openmw.core 2024-02-08 16:53:48 +01:00
context.hpp Lua Context: Replace exclusive bools with type enum 2024-07-23 10:39:58 +02:00
corebindings.cpp Move Lua index helpers to components and make owner.factiooRank match other ranks 2024-06-18 21:32:16 +02:00
corebindings.hpp Draft: add new type of Lua scripts - menu scripts 2023-10-31 10:29:24 +01:00
debugbindings.cpp Cleanup includes 2024-03-21 11:14:01 +01:00
debugbindings.hpp Support rendering for navmesh update frequency as a heatmap 2022-05-17 01:54:20 +02:00
dialoguebindings.cpp Move Lua index helpers to components and make owner.factiooRank match other ranks 2024-06-18 21:32:16 +02:00
dialoguebindings.hpp Optimize iteration over dialogue records 2024-05-10 10:38:18 +02:00
engineevents.cpp Revert "Merge branch 'were_engineers_not_salt_miners' into 'master'" 2024-06-25 20:58:31 +00:00
engineevents.hpp Revert "Merge branch 'were_engineers_not_salt_miners' into 'master'" 2024-06-25 20:58:31 +00:00
factionbindings.cpp Move Lua index helpers to components and make owner.factiooRank match other ranks 2024-06-18 21:32:16 +02:00
factionbindings.hpp Lua: Standardize record stores 2024-03-25 13:46:23 +00:00
globalscripts.hpp Revert "Merge branch 'were_engineers_not_salt_miners' into 'master'" 2024-06-25 20:58:31 +00:00
idcollectionbindings.hpp Unify the creation of RefId tables 2024-02-28 17:20:46 +01:00
inputbindings.cpp Remove hidden functions 2024-04-09 21:24:53 -05:00
inputbindings.hpp Add headers for all .cpp files in mwlua; move packages initilaization from LuaManager to luabindings.cpp 2023-04-25 23:24:51 +02:00
inputprocessor.hpp Mouse input engine handlers 2024-02-10 22:56:46 +01:00
itemdata.cpp move enchant charge and soul to itemdata 2024-07-05 23:33:55 +08:00
itemdata.hpp take2 2023-09-16 17:53:26 +08:00
localscripts.cpp AttackType -> ATTACK_TYPE 2024-06-24 01:15:43 +02:00
localscripts.hpp Add engine handler for skill levelup, to dehardcode the book/trainer case. 2024-01-30 21:25:39 +01:00
luabindings.cpp Load YAML files via Lua (feature 7590) 2024-03-14 16:29:21 +04:00
luabindings.hpp Draft: add new type of Lua scripts - menu scripts 2023-10-31 10:29:24 +01:00
luaevents.cpp Add types.Player.sendMenuEvent 2023-10-31 11:05:00 +01:00
luaevents.hpp Add types.Player.sendMenuEvent 2023-10-31 11:05:00 +01:00
luamanagerimp.cpp Lua Context: Replace exclusive bools with type enum 2024-07-23 10:39:58 +02:00
luamanagerimp.hpp Add a showInDialogue parameter to ui.showMessage and use it for level up messages 2024-06-27 17:16:49 +02:00
magicbindings.cpp Merge branch 'coverity' into 'master' 2024-06-24 07:10:28 +00:00
magicbindings.hpp Lua bindings for magic. Based on the work made by @bharbich in !2765. 2023-04-20 18:48:34 +02:00
markupbindings.cpp Do not use an inner namespace 2024-03-17 18:15:23 +04:00
markupbindings.hpp Load YAML files via Lua (feature 7590) 2024-03-14 16:29:21 +04:00
menuscripts.cpp Move Lua index helpers to components and make owner.factiooRank match other ranks 2024-06-18 21:32:16 +02:00
menuscripts.hpp Avoid making engine handler methods public 2024-01-11 00:55:29 +01:00
mwscriptbindings.cpp Revert "Merge branch 'were_engineers_not_salt_miners' into 'master'" 2024-06-25 20:58:31 +00:00
mwscriptbindings.hpp Change MWScript Lua bindings (#7142) 2023-06-30 22:26:17 +02:00
nearbybindings.cpp Move local variables 2024-02-23 17:10:55 +04:00
nearbybindings.hpp Add headers for all .cpp files in mwlua; move packages initilaization from LuaManager to luabindings.cpp 2023-04-25 23:24:51 +02:00
object.hpp Revert "Merge branch 'were_engineers_not_salt_miners' into 'master'" 2024-06-25 20:58:31 +00:00
objectbindings.cpp Move Lua index helpers to components and make owner.factiooRank match other ranks 2024-06-18 21:32:16 +02:00
objectbindings.hpp Add headers for all .cpp files in mwlua; move packages initilaization from LuaManager to luabindings.cpp 2023-04-25 23:24:51 +02:00
objectlists.cpp Cleanup includes 2024-03-21 11:14:01 +01:00
objectlists.hpp Rename MWLua::WorldView -> MWLua::ObjectLists 2023-08-08 22:57:28 +02:00
objectvariant.hpp Add missing type validation in mwlua/objectvariant.hpp 2023-04-23 20:47:24 +02:00
playerscripts.hpp Avoid making engine handler methods public 2024-01-11 00:55:29 +01:00
postprocessingbindings.cpp Move Lua index helpers to components and make owner.factiooRank match other ranks 2024-06-18 21:32:16 +02:00
postprocessingbindings.hpp Add headers for all .cpp files in mwlua; move packages initilaization from LuaManager to luabindings.cpp 2023-04-25 23:24:51 +02:00
racebindings.cpp Cleanup includes 2024-03-21 11:14:01 +01:00
racebindings.hpp Expose races to Lua 2024-02-27 21:50:57 +01:00
README.md Add a bit of high-level developer documentation about the Lua system 2023-03-13 22:41:28 +00:00
recordstore.hpp Move Lua index helpers to components and make owner.factiooRank match other ranks 2024-06-18 21:32:16 +02:00
soundbindings.cpp Do not allow Lua's "stopMusic" to interrupt MWScript's music 2024-06-02 13:18:06 +04:00
soundbindings.hpp Implement Lua bindings for sound system 2023-08-15 10:28:29 +04:00
stats.cpp Expose AI stats to Lua 2024-03-29 22:34:53 +01:00
stats.hpp Revert redundant changes 2023-11-07 11:52:53 -06:00
uibindings.cpp Lua Context: Replace exclusive bools with type enum 2024-07-23 10:39:58 +02:00
uibindings.hpp Add headers for all .cpp files in mwlua; move packages initilaization from LuaManager to luabindings.cpp 2023-04-25 23:24:51 +02:00
userdataserializer.cpp Replace const ESM::RefNum& -> ESM::RefNum 2023-09-15 19:38:09 +02:00
userdataserializer.hpp Merge MWLua::ObjectRegistry and MWWorld::WorldModel 2022-12-28 12:45:11 +01:00
vfsbindings.cpp Cleanup includes 2024-03-21 11:14:01 +01:00
vfsbindings.hpp Implement Lua API for VFS 2023-09-02 08:47:46 +04:00
worker.cpp Use correct frame and stats for lua worker 2024-04-24 21:53:59 +02:00
worker.hpp Use correct frame and stats for lua worker 2024-04-24 21:53:59 +02:00
worldbindings.cpp Expose cell ID, Add actor travel destinations to types.Actor.record.servicesOffered 2024-06-19 21:38:27 +00:00
worldbindings.hpp Draft: add new type of Lua scripts - menu scripts 2023-10-31 10:29:24 +01:00

MWLua

This folder contains the C++ implementation of the Lua scripting system.

For user-facing documentation, see OpenMW Lua scripting. The documentation is generated from /docs/source/reference/lua-scripting. You can find instructions for generating the documentation at the root of the docs folder.

The Lua API reference is generated from the specifications in /files/lua_api. They are written in the Lua Development Tool Documentation Language, and also enable autocompletion for (LDT) users. Please update them to reflect any changes you make.

MWLua::LuaManager

The Lua manager is the central interface through which information flows from the engine to the scripts and back.

Lua is executed in a separate thread by default. This thread executes update() in parallel with rendering logic (specifically with OSG Cull traversal). Because of this, Lua must not synchronously mutate anything that can directly or indirectly affect the scene graph. Instead such changes are queued to mActionQueue. They are then processed by synchronizedUpdate(), which is executed by the main thread. The Lua thread is paused while other updates of the game state take place, which means that state that doesn't affect the scene graph can be mutated immediately. There is no easy way to characterize which things affect the graph, you'll need to inspect the code.

Bindings

The bulk of the code in this folder consists of bindings that expose C++ data to Lua.

As explained in the scripting overview, there are Global and Local scripts, and they have different capabilities. A Local script has read-only access to objects other the one it is attached to. The bindings use the types MWLua::GObject, MWLua::LObject, MWLua::SelfObject to enforce this behaviour.

  • MWLua::GObject is used in global scripts
  • MWLua::LObject is used in local scripts (readonly),
  • MWLua::SelfObject is the object the local script is attached to.
  • MWLua::Object is the common base of all 3.

Functions that don't change objects are usually available in both local and global scripts so they accept MWLua::Object. Some (for example setEquipment in actor.cpp) should work only on self and because of this have argument of type SelfObject. There are also cases where a function is available in both local and global scripts, but has different effects in different cases. For example see the binding actor["inventory"] in 'MWLua::addActorBindings` in actor.cpp:

actor["inventory"] = sol::overload([](const LObject& o) { return Inventory<LObject>{ o }; },
    [](const GObject& o) { return Inventory<GObject>{ o }; });

The difference is that Inventory<LObject> is readonly and Inventory<GObject> is mutable. The read-only bindings are defined for both, but some functions are exclusive for Inventory<GObject>.

Mutations that affect the scene graph

Because of the threading issues mentioned under MWLua::LuaManager, bindings that mutate things that affect the scene graph must be implemented by queuing an action with LuaManager::addAction.

Here is an example that illustrates action queuing, along with the differences between GObject and LObject:

// We can always read the value because OSG Cull doesn't modify `RefData`.
auto isEnabled = [](const Object& o) { return o.ptr().getRefData().isEnabled(); };

// Changing the value must be queued because `World::enable`/`World::disable` aside of
// changing `RefData` also adds/removes the object to the scene graph.
auto setEnabled = [context](const Object& object, bool enable) {
    // It is important that the lambda state stores `object` and not the result of
    // `object.ptr()` because when delayed will be executed the old Ptr can potentially
    // be already invalidated.
    context.mLuaManager->addAction([object, enable] {
        if (enable)
            MWBase::Environment::get().getWorld()->enable(object.ptr());
        else
            MWBase::Environment::get().getWorld()->disable(object.ptr());
    });
};

// Local scripts can only view the value (because in multiplayer local scripts
// will be client-side and we want to avoid synchronization issues).
LObjectMetatable["enabled"] = sol::readonly_property(isEnabled);

// Global scripts can both read and modify the value.
GObjectMetatable["enabled"] = sol::property(isEnabled, setEnabled);

Please note that queueing means changes scripts make won't be visible to other scripts before the next frame. If you want to avoid that, you can implement a cache in the bindings. The first write will create the cache and queue the value to be synchronized from the cache to the engine in the next synchronization. Later writes will update the cache. Reads will read the cache if it exists. See LocalScripts::SelfObject::mStatsCache for an example.