diff options
author | PilzAdam <adam-k@outlook.com> | 2012-12-09 13:34:16 +0100 |
---|---|---|
committer | PilzAdam <adam-k@outlook.com> | 2012-12-11 16:44:13 +0100 |
commit | 52ba413185f96add259c480a68f5dffa389e80f4 (patch) | |
tree | a20aafa92b5ce3ad22eb2074afc4aea30d09260c /src/localplayer.cpp | |
parent | 1d13d106dd58cd18a019046840c180da25001b02 (diff) | |
download | minetest-52ba413185f96add259c480a68f5dffa389e80f4.tar.gz minetest-52ba413185f96add259c480a68f5dffa389e80f4.tar.bz2 minetest-52ba413185f96add259c480a68f5dffa389e80f4.zip |
Only fly through walls in noclip mode wich requires the noclip privilege
Diffstat (limited to 'src/localplayer.cpp')
-rw-r--r-- | src/localplayer.cpp | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/src/localplayer.cpp b/src/localplayer.cpp index 14d1ac60e..96ddb4bb2 100644 --- a/src/localplayer.cpp +++ b/src/localplayer.cpp @@ -73,9 +73,11 @@ void LocalPlayer::move(f32 dtime, Map &map, f32 pos_max_d, return; } - // Skip collision detection if a special movement mode is used + // Skip collision detection if noclip mode is used bool fly_allowed = m_gamedef->checkLocalPrivilege("fly"); - bool free_move = fly_allowed && g_settings->getBool("free_move"); + bool noclip = m_gamedef->checkLocalPrivilege("noclip") && + g_settings->getBool("noclip"); + bool free_move = noclip && fly_allowed && g_settings->getBool("free_move"); if(free_move) { position += m_speed * dtime; @@ -300,7 +302,8 @@ void LocalPlayer::move(f32 dtime, Map &map, f32 pos_max_d, Report collisions */ bool bouncy_jump = false; - if(collision_info) + // Dont report if flying + if(collision_info && !g_settings->getBool("free_move")) { for(size_t i=0; i<result.collisions.size(); i++){ const CollisionInfo &info = result.collisions[i]; |