diff options
Diffstat (limited to 'source/game/scripting')
-rwxr-xr-x | source/game/scripting/StarPlayerLuaBindings.cpp | 3 | ||||
-rw-r--r-- | source/game/scripting/StarWorldLuaBindings.cpp | 16 | ||||
-rw-r--r-- | source/game/scripting/StarWorldLuaBindings.hpp | 1 |
3 files changed, 20 insertions, 0 deletions
diff --git a/source/game/scripting/StarPlayerLuaBindings.cpp b/source/game/scripting/StarPlayerLuaBindings.cpp index ff0b877..f8032d2 100755 --- a/source/game/scripting/StarPlayerLuaBindings.cpp +++ b/source/game/scripting/StarPlayerLuaBindings.cpp @@ -118,6 +118,9 @@ LuaCallbacks LuaBindings::makePlayerCallbacks(Player* player) { callbacks.registerCallback( "name", [player]() { return player->name(); }); callbacks.registerCallback("setName", [player](String const& name) { player->setName(name); }); + callbacks.registerCallback( "nametag", [player]() { return player->nametag(); }); + callbacks.registerCallback("setNametag", [player](Maybe<String> const& nametag) { player->setNametag(nametag); }); + callbacks.registerCallback( "species", [player]() { return player->species(); }); callbacks.registerCallback("setSpecies", [player](String const& species) { player->setSpecies(species); }); diff --git a/source/game/scripting/StarWorldLuaBindings.cpp b/source/game/scripting/StarWorldLuaBindings.cpp index 2d952ea..64d1f30 100644 --- a/source/game/scripting/StarWorldLuaBindings.cpp +++ b/source/game/scripting/StarWorldLuaBindings.cpp @@ -512,6 +512,7 @@ namespace LuaBindings { callbacks.registerCallbackWithSignature<Maybe<String>, EntityId>("entitySpecies", bind(WorldEntityCallbacks::entitySpecies, world, _1)); callbacks.registerCallbackWithSignature<Maybe<String>, EntityId>("entityGender", bind(WorldEntityCallbacks::entityGender, world, _1)); callbacks.registerCallbackWithSignature<Maybe<String>, EntityId>("entityName", bind(WorldEntityCallbacks::entityName, world, _1)); + callbacks.registerCallbackWithSignature<Maybe<Json>, EntityId>("entityNametag", bind(WorldEntityCallbacks::entityNametag, world, _1)); callbacks.registerCallbackWithSignature<Maybe<String>, EntityId, Maybe<String>>("entityDescription", bind(WorldEntityCallbacks::entityDescription, world, _1, _2)); callbacks.registerCallbackWithSignature<LuaNullTermWrapper<Maybe<List<Drawable>>>, EntityId, String>("entityPortrait", bind(WorldEntityCallbacks::entityPortrait, world, _1, _2)); callbacks.registerCallbackWithSignature<Maybe<String>, EntityId, String>("entityHandItem", bind(WorldEntityCallbacks::entityHandItem, world, _1, _2)); @@ -1451,6 +1452,21 @@ namespace LuaBindings { return {}; } + Maybe<Json> WorldEntityCallbacks::entityNametag(World* world, EntityId entityId) { + auto entity = world->entity(entityId); + + if (auto nametagEntity = as<NametagEntity>(entity)) { + return JsonObject{ + {"nametag", nametagEntity->nametag()}, + {"displayed", nametagEntity->displayNametag()}, + {"color", jsonFromColor(Color::rgb(nametagEntity->nametagColor()))}, + {"origin", jsonFromVec2F(nametagEntity->nametagOrigin())}, + }; + } + + return {}; + } + Maybe<String> WorldEntityCallbacks::entityDescription(World* world, EntityId entityId, Maybe<String> const& species) { if (auto entity = world->entity(entityId)) { if (auto inspectableEntity = as<InspectableEntity>(entity)) { diff --git a/source/game/scripting/StarWorldLuaBindings.hpp b/source/game/scripting/StarWorldLuaBindings.hpp index 3f08a77..9d24d49 100644 --- a/source/game/scripting/StarWorldLuaBindings.hpp +++ b/source/game/scripting/StarWorldLuaBindings.hpp @@ -123,6 +123,7 @@ namespace LuaBindings { Maybe<String> entitySpecies(World* world, EntityId entityId); Maybe<String> entityGender(World* world, EntityId entityId); Maybe<String> entityName(World* world, EntityId entityId); + Maybe<Json> entityNametag(World* world, EntityId entityId); Maybe<String> entityDescription(World* world, EntityId entityId, Maybe<String> const& species); LuaNullTermWrapper<Maybe<List<Drawable>>> entityPortrait(World* world, EntityId entityId, String const& portraitMode); Maybe<String> entityHandItem(World* world, EntityId entityId, String const& handName); |