Skip to content

Commit

Permalink
ObjectRef: fix some v3f checks (#10602)
Browse files Browse the repository at this point in the history
  • Loading branch information
Zughy committed Jan 21, 2021
1 parent d92da47 commit ea5d631
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 31 deletions.
23 changes: 12 additions & 11 deletions doc/lua_api.txt
Expand Up @@ -6239,21 +6239,22 @@ object you are working with still exists.
`frame_loop`.
* `set_animation_frame_speed(frame_speed)`
* `frame_speed`: number, default: `15.0`
* `set_attach(parent, bone, position, rotation, forced_visible)`
* `bone`: string
* `position`: `{x=num, y=num, z=num}` (relative)
* `rotation`: `{x=num, y=num, z=num}` = Rotation on each axis, in degrees
* `set_attach(parent[, bone, position, rotation, forced_visible])`
* `bone`: string. Default is `""`, the root bone
* `position`: `{x=num, y=num, z=num}`, relative, default `{x=0, y=0, z=0}`
* `rotation`: `{x=num, y=num, z=num}` = Rotation on each axis, in degrees.
Default `{x=0, y=0, z=0}`
* `forced_visible`: Boolean to control whether the attached entity
should appear in first person.
should appear in first person. Default `false`.
* `get_attach()`: returns parent, bone, position, rotation, forced_visible,
or nil if it isn't attached.
* `get_children()`: returns a list of ObjectRefs that are attached to the
object.
* `set_detach()`
* `set_bone_position(bone, position, rotation)`
* `bone`: string
* `position`: `{x=num, y=num, z=num}` (relative)
* `rotation`: `{x=num, y=num, z=num}`
* `set_bone_position([bone, position, rotation])`
* `bone`: string. Default is `""`, the root bone
* `position`: `{x=num, y=num, z=num}`, relative, `default {x=0, y=0, z=0}`
* `rotation`: `{x=num, y=num, z=num}`, default `{x=0, y=0, z=0}`
* `get_bone_position(bone)`: returns position and rotation of the bone
* `set_properties(object property table)`
* `get_properties()`: returns object property table
Expand Down Expand Up @@ -6581,8 +6582,8 @@ object you are working with still exists.
* `frame_speed` sets the animations frame speed. Default is 30.
* `get_local_animation()`: returns idle, walk, dig, walk_while_dig tables and
`frame_speed`.
* `set_eye_offset(firstperson, thirdperson)`: defines offset vectors for camera
per player.
* `set_eye_offset([firstperson, thirdperson])`: defines offset vectors for
camera per player. An argument defaults to `{x=0, y=0, z=0}` if unspecified.
* in first person view
* in third person view (max. values `{x=-10/10,y=-10,15,z=-5/5}`)
* `get_eye_offset()`: returns first and third person offsets.
Expand Down
37 changes: 17 additions & 20 deletions src/script/lua_api/l_object.cpp
Expand Up @@ -399,7 +399,7 @@ int ObjectRef::l_get_animation(lua_State *L)
if (sao == nullptr)
return 0;

v2f frames = v2f(1,1);
v2f frames = v2f(1, 1);
float frame_speed = 15;
float frame_blend = 0;
bool frame_loop = true;
Expand Down Expand Up @@ -463,8 +463,8 @@ int ObjectRef::l_set_eye_offset(lua_State *L)
if (player == nullptr)
return 0;

v3f offset_first = read_v3f(L, 2);
v3f offset_third = read_v3f(L, 3);
v3f offset_first = readParam<v3f>(L, 2, v3f(0, 0, 0));
v3f offset_third = readParam<v3f>(L, 3, v3f(0, 0, 0));

// Prevent abuse of offset values (keep player always visible)
offset_third.X = rangelim(offset_third.X,-10,10);
Expand Down Expand Up @@ -537,9 +537,9 @@ int ObjectRef::l_set_bone_position(lua_State *L)
if (sao == nullptr)
return 0;

std::string bone = readParam<std::string>(L, 2);
v3f position = check_v3f(L, 3);
v3f rotation = check_v3f(L, 4);
std::string bone = readParam<std::string>(L, 2, "");
v3f position = readParam<v3f>(L, 3, v3f(0, 0, 0));
v3f rotation = readParam<v3f>(L, 4, v3f(0, 0, 0));

sao->setBonePosition(bone, position, rotation);
return 0;
Expand All @@ -554,7 +554,7 @@ int ObjectRef::l_get_bone_position(lua_State *L)
if (sao == nullptr)
return 0;

std::string bone = readParam<std::string>(L, 2);
std::string bone = readParam<std::string>(L, 2, "");

v3f position = v3f(0, 0, 0);
v3f rotation = v3f(0, 0, 0);
Expand All @@ -578,10 +578,10 @@ int ObjectRef::l_set_attach(lua_State *L)
if (sao == parent)
throw LuaError("ObjectRef::set_attach: attaching object to itself is not allowed.");

int parent_id = 0;
int parent_id;
std::string bone;
v3f position = v3f(0, 0, 0);
v3f rotation = v3f(0, 0, 0);
v3f position;
v3f rotation;
bool force_visible;

sao->getAttachment(&parent_id, &bone, &position, &rotation, &force_visible);
Expand All @@ -590,9 +590,9 @@ int ObjectRef::l_set_attach(lua_State *L)
old_parent->removeAttachmentChild(sao->getId());
}

bone = readParam<std::string>(L, 3, "");
position = read_v3f(L, 4);
rotation = read_v3f(L, 5);
bone = readParam<std::string>(L, 3, "");
position = readParam<v3f>(L, 4, v3f(0, 0, 0));
rotation = readParam<v3f>(L, 5, v3f(0, 0, 0));
force_visible = readParam<bool>(L, 6, false);

sao->setAttachment(parent->getId(), bone, position, rotation, force_visible);
Expand All @@ -609,10 +609,10 @@ int ObjectRef::l_get_attach(lua_State *L)
if (sao == nullptr)
return 0;

int parent_id = 0;
int parent_id;
std::string bone;
v3f position = v3f(0, 0, 0);
v3f rotation = v3f(0, 0, 0);
v3f position;
v3f rotation;
bool force_visible;

sao->getAttachment(&parent_id, &bone, &position, &rotation, &force_visible);
Expand Down Expand Up @@ -892,9 +892,6 @@ int ObjectRef::l_set_yaw(lua_State *L)
if (entitysao == nullptr)
return 0;

if (isNaN(L, 2))
throw LuaError("ObjectRef::set_yaw: NaN value is not allowed.");

float yaw = readParam<float>(L, 2) * core::RADTODEG;

entitysao->setRotation(v3f(0, yaw, 0));
Expand Down Expand Up @@ -2199,7 +2196,7 @@ int ObjectRef::l_set_minimap_modes(lua_State *L)

luaL_checktype(L, 2, LUA_TTABLE);
std::vector<MinimapMode> modes;
s16 selected_mode = luaL_checkint(L, 3);
s16 selected_mode = readParam<s16>(L, 3);

lua_pushnil(L);
while (lua_next(L, 2) != 0) {
Expand Down

0 comments on commit ea5d631

Please sign in to comment.