Merge branch 'master' into VillageGen
* master: Fixed profiling flags for MSVC. Fixed cWither::KilledBy Cleaned up cPlayer::UpdateMovementStats; Wither achievements Fixed MCADefrag compilation. Derp Should have fixed assumptions about entity width. Fixed clanging errors. Implemented cacti damage
This commit is contained in:
commit
64dbc45a00
@ -118,8 +118,8 @@ endmacro()
|
|||||||
macro(enable_profile)
|
macro(enable_profile)
|
||||||
# Declare the flags used for profiling builds:
|
# Declare the flags used for profiling builds:
|
||||||
if (MSVC)
|
if (MSVC)
|
||||||
set (CXX_PROFILING "")
|
set (CXX_PROFILING "/Zi")
|
||||||
set (LNK_PROFILING "/PROFILE")
|
set (LNK_PROFILING "/PROFILE /DEBUG")
|
||||||
else()
|
else()
|
||||||
set (CXX_PROFILING "-pg")
|
set (CXX_PROFILING "-pg")
|
||||||
set (LNK_PROFILING "-pg")
|
set (LNK_PROFILING "-pg")
|
||||||
|
@ -22,6 +22,15 @@
|
|||||||
#define ALIGN_8
|
#define ALIGN_8
|
||||||
#define ALIGN_16
|
#define ALIGN_16
|
||||||
|
|
||||||
|
#define FORMATSTRING(formatIndex, va_argsIndex)
|
||||||
|
|
||||||
|
// MSVC has its own custom version of zu format
|
||||||
|
#define SIZE_T_FMT "%Iu"
|
||||||
|
#define SIZE_T_FMT_PRECISION(x) "%" #x "Iu"
|
||||||
|
#define SIZE_T_FMT_HEX "%Ix"
|
||||||
|
|
||||||
|
#define NORETURN __declspec(noreturn)
|
||||||
|
|
||||||
#elif defined(__GNUC__)
|
#elif defined(__GNUC__)
|
||||||
|
|
||||||
// TODO: Can GCC explicitly mark classes as abstract (no instances can be created)?
|
// TODO: Can GCC explicitly mark classes as abstract (no instances can be created)?
|
||||||
@ -39,6 +48,12 @@
|
|||||||
#define stricmp strcasecmp
|
#define stricmp strcasecmp
|
||||||
|
|
||||||
#define FORMATSTRING(formatIndex,va_argsIndex)
|
#define FORMATSTRING(formatIndex,va_argsIndex)
|
||||||
|
|
||||||
|
#define SIZE_T_FMT "%zu"
|
||||||
|
#define SIZE_T_FMT_PRECISION(x) "%" #x "zu"
|
||||||
|
#define SIZE_T_FMT_HEX "%zx"
|
||||||
|
|
||||||
|
#define NORETURN __attribute((__noreturn__))
|
||||||
#else
|
#else
|
||||||
|
|
||||||
#error "You are using an unsupported compiler, you might need to #define some stuff here for your compiler"
|
#error "You are using an unsupported compiler, you might need to #define some stuff here for your compiler"
|
||||||
|
@ -46,8 +46,30 @@ public:
|
|||||||
bool IsWither(void) const { return m_IsWither; }
|
bool IsWither(void) const { return m_IsWither; }
|
||||||
|
|
||||||
void Reset(void) { m_IsWither = false; }
|
void Reset(void) { m_IsWither = false; }
|
||||||
|
|
||||||
} CallbackA, CallbackB;
|
} CallbackA, CallbackB;
|
||||||
|
|
||||||
|
class cPlayerCallback : public cPlayerListCallback
|
||||||
|
{
|
||||||
|
Vector3f m_Pos;
|
||||||
|
|
||||||
|
virtual bool Item(cPlayer * a_Player)
|
||||||
|
{
|
||||||
|
// TODO 2014-05-21 xdot: Vanilla minecraft uses an AABB check instead of a radius one
|
||||||
|
double Dist = (a_Player->GetPosition() - m_Pos).Length();
|
||||||
|
if (Dist < 50.0)
|
||||||
|
{
|
||||||
|
// If player is close, award achievement
|
||||||
|
a_Player->AwardAchievement(achSpawnWither);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public:
|
||||||
|
cPlayerCallback(const Vector3f & a_Pos) : m_Pos(a_Pos) {}
|
||||||
|
|
||||||
|
} PlayerCallback(Vector3f(a_BlockX, a_BlockY, a_BlockZ));
|
||||||
|
|
||||||
a_World->DoWithMobHeadAt(a_BlockX, a_BlockY, a_BlockZ, CallbackA);
|
a_World->DoWithMobHeadAt(a_BlockX, a_BlockY, a_BlockZ, CallbackA);
|
||||||
|
|
||||||
if (!CallbackA.IsWither())
|
if (!CallbackA.IsWither())
|
||||||
@ -86,6 +108,9 @@ public:
|
|||||||
// Spawn the wither:
|
// Spawn the wither:
|
||||||
a_World->SpawnMob(a_BlockX + 0.5, a_BlockY - 2, a_BlockZ + 0.5, cMonster::mtWither);
|
a_World->SpawnMob(a_BlockX + 0.5, a_BlockY - 2, a_BlockZ + 0.5, cMonster::mtWither);
|
||||||
|
|
||||||
|
// Award Achievement
|
||||||
|
a_World->ForEachPlayer(PlayerCallback);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -113,6 +138,9 @@ public:
|
|||||||
// Spawn the wither:
|
// Spawn the wither:
|
||||||
a_World->SpawnMob(a_BlockX + 0.5, a_BlockY - 2, a_BlockZ + 0.5, cMonster::mtWither);
|
a_World->SpawnMob(a_BlockX + 0.5, a_BlockY - 2, a_BlockZ + 0.5, cMonster::mtWither);
|
||||||
|
|
||||||
|
// Award Achievement
|
||||||
|
a_World->ForEachPlayer(PlayerCallback);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -816,9 +816,10 @@ void cClientHandle::HandleLeftClick(int a_BlockX, int a_BlockY, int a_BlockZ, eB
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (
|
if (
|
||||||
(Diff(m_Player->GetPosX(), (double)a_BlockX) > 6) ||
|
((a_Status == DIG_STATUS_STARTED) || (a_Status == DIG_STATUS_FINISHED)) && // Only do a radius check for block destruction - things like pickup tossing send coordinates that are to be ignored
|
||||||
|
((Diff(m_Player->GetPosX(), (double)a_BlockX) > 6) ||
|
||||||
(Diff(m_Player->GetPosY(), (double)a_BlockY) > 6) ||
|
(Diff(m_Player->GetPosY(), (double)a_BlockY) > 6) ||
|
||||||
(Diff(m_Player->GetPosZ(), (double)a_BlockZ) > 6)
|
(Diff(m_Player->GetPosZ(), (double)a_BlockZ) > 6))
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
m_Player->GetWorld()->SendBlockTo(a_BlockX, a_BlockY, a_BlockZ, m_Player);
|
m_Player->GetWorld()->SendBlockTo(a_BlockX, a_BlockY, a_BlockZ, m_Player);
|
||||||
|
@ -617,6 +617,10 @@ void cEntity::Tick(float a_Dt, cChunk & a_Chunk)
|
|||||||
m_TicksSinceLastVoidDamage = 0;
|
m_TicksSinceLastVoidDamage = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (IsMob() || IsPlayer() || IsPickup() || IsExpOrb())
|
||||||
|
{
|
||||||
|
DetectCacti();
|
||||||
|
}
|
||||||
if (IsMob() || IsPlayer())
|
if (IsMob() || IsPlayer())
|
||||||
{
|
{
|
||||||
// Set swimming state
|
// Set swimming state
|
||||||
@ -1014,6 +1018,26 @@ void cEntity::TickInVoid(cChunk & a_Chunk)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void cEntity::DetectCacti()
|
||||||
|
{
|
||||||
|
int X = POSX_TOINT, Y = POSY_TOINT, Z = POSZ_TOINT;
|
||||||
|
float w = m_Width / 2;
|
||||||
|
if (
|
||||||
|
(((X + 1) - GetPosX() < w) && (GetWorld()->GetBlock(X + 1, Y, Z) == E_BLOCK_CACTUS)) ||
|
||||||
|
(((GetPosX() - (X - 1)) - 1 < w) && (GetWorld()->GetBlock(X - 1, Y, Z) == E_BLOCK_CACTUS)) ||
|
||||||
|
(((Z + 1) - GetPosZ() < w) && (GetWorld()->GetBlock(X, Y, Z + 1) == E_BLOCK_CACTUS)) ||
|
||||||
|
(((GetPosZ() - (Z - 1)) - 1 < w) && (GetWorld()->GetBlock(X, Y, Z - 1) == E_BLOCK_CACTUS)) ||
|
||||||
|
(((Y > 0) && (Y < cChunkDef::Height)) && ((GetPosY() - Y < 1) && (GetWorld()->GetBlock(X, Y, Z) == E_BLOCK_CACTUS)))
|
||||||
|
)
|
||||||
|
{
|
||||||
|
TakeDamage(dtCactusContact, NULL, 1, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void cEntity::SetSwimState(cChunk & a_Chunk)
|
void cEntity::SetSwimState(cChunk & a_Chunk)
|
||||||
{
|
{
|
||||||
int RelY = (int)floor(GetPosY() + 0.1);
|
int RelY = (int)floor(GetPosY() + 0.1);
|
||||||
|
@ -321,6 +321,9 @@ public:
|
|||||||
/// Updates the state related to this entity being on fire
|
/// Updates the state related to this entity being on fire
|
||||||
virtual void TickBurning(cChunk & a_Chunk);
|
virtual void TickBurning(cChunk & a_Chunk);
|
||||||
|
|
||||||
|
/** Detects the time for application of cacti damage */
|
||||||
|
virtual void DetectCacti(void);
|
||||||
|
|
||||||
/// Handles when the entity is in the void
|
/// Handles when the entity is in the void
|
||||||
virtual void TickInVoid(cChunk & a_Chunk);
|
virtual void TickInVoid(cChunk & a_Chunk);
|
||||||
|
|
||||||
|
@ -456,8 +456,18 @@ void cPlayer::SetTouchGround(bool a_bTouchGround)
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
float Dist = (float)(m_LastGroundHeight - floor(GetPosY()));
|
float Dist = (float)(m_LastGroundHeight - floor(GetPosY()));
|
||||||
|
|
||||||
|
if (Dist >= 2.0) // At least two blocks - TODO: Use m_LastJumpHeight instead of m_LastGroundHeight above
|
||||||
|
{
|
||||||
|
// Increment statistic
|
||||||
|
m_Stats.AddValue(statDistFallen, (StatValue)floor(Dist * 100 + 0.5));
|
||||||
|
}
|
||||||
|
|
||||||
int Damage = (int)(Dist - 3.f);
|
int Damage = (int)(Dist - 3.f);
|
||||||
if (m_LastJumpHeight > m_LastGroundHeight) Damage++;
|
if (m_LastJumpHeight > m_LastGroundHeight)
|
||||||
|
{
|
||||||
|
Damage++;
|
||||||
|
}
|
||||||
m_LastJumpHeight = (float)GetPosY();
|
m_LastJumpHeight = (float)GetPosY();
|
||||||
|
|
||||||
if (Damage > 0)
|
if (Damage > 0)
|
||||||
@ -1951,31 +1961,64 @@ void cPlayer::HandleFloater()
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
bool cPlayer::IsClimbing(void) const
|
||||||
|
{
|
||||||
|
int PosX = POSX_TOINT;
|
||||||
|
int PosY = POSY_TOINT;
|
||||||
|
int PosZ = POSZ_TOINT;
|
||||||
|
|
||||||
|
if ((PosY < 0) || (PosY >= cChunkDef::Height))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
BLOCKTYPE Block = m_World->GetBlock(PosX, PosY, PosZ);
|
||||||
|
switch (Block)
|
||||||
|
{
|
||||||
|
case E_BLOCK_LADDER:
|
||||||
|
case E_BLOCK_VINES:
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
default: return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void cPlayer::UpdateMovementStats(const Vector3d & a_DeltaPos)
|
void cPlayer::UpdateMovementStats(const Vector3d & a_DeltaPos)
|
||||||
{
|
{
|
||||||
StatValue Value = (StatValue)floor(a_DeltaPos.Length() * 100 + 0.5);
|
StatValue Value = (StatValue)floor(a_DeltaPos.Length() * 100 + 0.5);
|
||||||
|
|
||||||
if (m_AttachedTo == NULL)
|
if (m_AttachedTo == NULL)
|
||||||
{
|
{
|
||||||
int PosX = POSX_TOINT;
|
if (IsClimbing())
|
||||||
int PosY = POSY_TOINT;
|
|
||||||
int PosZ = POSZ_TOINT;
|
|
||||||
|
|
||||||
BLOCKTYPE Block;
|
|
||||||
NIBBLETYPE Meta;
|
|
||||||
if (!m_World->GetBlockTypeMeta(PosX, PosY, PosZ, Block, Meta))
|
|
||||||
{
|
{
|
||||||
return;
|
if (a_DeltaPos.y > 0.0) // Going up
|
||||||
|
{
|
||||||
|
m_Stats.AddValue(statDistClimbed, (StatValue)floor(a_DeltaPos.y * 100 + 0.5));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
else if (IsSubmerged())
|
||||||
if ((Block == E_BLOCK_LADDER) && (a_DeltaPos.y > 0.0)) // Going up
|
|
||||||
{
|
{
|
||||||
m_Stats.AddValue(statDistClimbed, (StatValue)floor(a_DeltaPos.y * 100 + 0.5));
|
m_Stats.AddValue(statDistDove, Value);
|
||||||
|
}
|
||||||
|
else if (IsSwimming())
|
||||||
|
{
|
||||||
|
m_Stats.AddValue(statDistSwum, Value);
|
||||||
|
}
|
||||||
|
else if (IsOnGround())
|
||||||
|
{
|
||||||
|
m_Stats.AddValue(statDistWalked, Value);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// TODO 2014-05-12 xdot: Other types
|
if (Value >= 25) // Ignore small/slow movement
|
||||||
m_Stats.AddValue(statDistWalked, Value);
|
{
|
||||||
|
m_Stats.AddValue(statDistFlown, Value);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -127,6 +127,9 @@ public:
|
|||||||
|
|
||||||
inline const cItem & GetEquippedItem(void) const { return GetInventory().GetEquippedItem(); } // tolua_export
|
inline const cItem & GetEquippedItem(void) const { return GetInventory().GetEquippedItem(); } // tolua_export
|
||||||
|
|
||||||
|
/** Returns whether the player is climbing (ladders, vines e.t.c). */
|
||||||
|
bool IsClimbing(void) const;
|
||||||
|
|
||||||
virtual void TeleportToCoords(double a_PosX, double a_PosY, double a_PosZ) override;
|
virtual void TeleportToCoords(double a_PosX, double a_PosY, double a_PosZ) override;
|
||||||
|
|
||||||
// tolua_begin
|
// tolua_begin
|
||||||
|
@ -142,6 +142,8 @@ public:
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
a_Player->GetStatManager().AddValue(statTreasureFished, 1);
|
||||||
}
|
}
|
||||||
else if (ItemCategory <= 14) // Junk 10%
|
else if (ItemCategory <= 14) // Junk 10%
|
||||||
{
|
{
|
||||||
@ -190,6 +192,8 @@ public:
|
|||||||
{
|
{
|
||||||
Drops.Add(cItem(E_BLOCK_TRIPWIRE_HOOK));
|
Drops.Add(cItem(E_BLOCK_TRIPWIRE_HOOK));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
a_Player->GetStatManager().AddValue(statJunkFished, 1);
|
||||||
}
|
}
|
||||||
else // Fish
|
else // Fish
|
||||||
{
|
{
|
||||||
@ -210,6 +214,8 @@ public:
|
|||||||
{
|
{
|
||||||
Drops.Add(cItem(E_ITEM_RAW_FISH, 1, E_META_RAW_FISH_FISH));
|
Drops.Add(cItem(E_ITEM_RAW_FISH, 1, E_META_RAW_FISH_FISH));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
a_Player->GetStatManager().AddValue(statFishCaught, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cRoot::Get()->GetPluginManager()->CallHookPlayerFishing(*a_Player, Drops))
|
if (cRoot::Get()->GetPluginManager()->CallHookPlayerFishing(*a_Player, Drops))
|
||||||
|
@ -2,7 +2,9 @@
|
|||||||
#include "Globals.h" // NOTE: MSVC stupidness requires this to be the same across all modules
|
#include "Globals.h" // NOTE: MSVC stupidness requires this to be the same across all modules
|
||||||
|
|
||||||
#include "Wither.h"
|
#include "Wither.h"
|
||||||
|
|
||||||
#include "../World.h"
|
#include "../World.h"
|
||||||
|
#include "../Entities/Player.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -100,3 +102,35 @@ void cWither::GetDrops(cItems & a_Drops, cEntity * a_Killer)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void cWither::KilledBy(cEntity * a_Killer)
|
||||||
|
{
|
||||||
|
super::KilledBy(a_Killer);
|
||||||
|
|
||||||
|
class cPlayerCallback : public cPlayerListCallback
|
||||||
|
{
|
||||||
|
Vector3f m_Pos;
|
||||||
|
|
||||||
|
virtual bool Item(cPlayer * a_Player)
|
||||||
|
{
|
||||||
|
// TODO 2014-05-21 xdot: Vanilla minecraft uses an AABB check instead of a radius one
|
||||||
|
double Dist = (a_Player->GetPosition() - m_Pos).Length();
|
||||||
|
if (Dist < 50.0)
|
||||||
|
{
|
||||||
|
// If player is close, award achievement
|
||||||
|
a_Player->AwardAchievement(achKillWither);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public:
|
||||||
|
cPlayerCallback(const Vector3f & a_Pos) : m_Pos(a_Pos) {}
|
||||||
|
|
||||||
|
} PlayerCallback(GetPosition());
|
||||||
|
|
||||||
|
m_World->ForEachPlayer(PlayerCallback);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -29,6 +29,7 @@ public:
|
|||||||
virtual void GetDrops(cItems & a_Drops, cEntity * a_Killer = NULL) override;
|
virtual void GetDrops(cItems & a_Drops, cEntity * a_Killer = NULL) override;
|
||||||
virtual bool DoTakeDamage(TakeDamageInfo & a_TDI) override;
|
virtual bool DoTakeDamage(TakeDamageInfo & a_TDI) override;
|
||||||
virtual void Tick(float a_Dt, cChunk & a_Chunk) override;
|
virtual void Tick(float a_Dt, cChunk & a_Chunk) override;
|
||||||
|
virtual void KilledBy(cEntity * a_Killer) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
|
@ -52,7 +52,7 @@ cStatInfo cStatInfo::ms_Info[statCount] = {
|
|||||||
/* Type | Name */
|
/* Type | Name */
|
||||||
cStatInfo(statGamesQuit, "stat.leaveGame"),
|
cStatInfo(statGamesQuit, "stat.leaveGame"),
|
||||||
cStatInfo(statMinutesPlayed, "stat.playOneMinute"),
|
cStatInfo(statMinutesPlayed, "stat.playOneMinute"),
|
||||||
cStatInfo(statDistWalked, "stat.walkOnCm"),
|
cStatInfo(statDistWalked, "stat.walkOneCm"),
|
||||||
cStatInfo(statDistSwum, "stat.swimOneCm"),
|
cStatInfo(statDistSwum, "stat.swimOneCm"),
|
||||||
cStatInfo(statDistFallen, "stat.fallOneCm"),
|
cStatInfo(statDistFallen, "stat.fallOneCm"),
|
||||||
cStatInfo(statDistClimbed, "stat.climbOneCm"),
|
cStatInfo(statDistClimbed, "stat.climbOneCm"),
|
||||||
|
Loading…
Reference in New Issue
Block a user