#pragma once #include #include /** List of slot numbers, used for inventory-painting */ typedef std::vector cSlotNums; // tolua_begin /** Experience Orb setup */ enum { // Open to suggestion on naming convention here :) MAX_EXPERIENCE_ORB_SIZE = 2000 } ; /** Block face constants, used in PlayerDigging and PlayerBlockPlacement packets and bbox collision calc */ enum eBlockFace { BLOCK_FACE_NONE = -1, // Interacting with no block face - swinging the item in the air BLOCK_FACE_XM = 4, // Interacting with the X- face of the block BLOCK_FACE_XP = 5, // Interacting with the X+ face of the block BLOCK_FACE_YM = 0, // Interacting with the Y- face of the block BLOCK_FACE_YP = 1, // Interacting with the Y+ face of the block BLOCK_FACE_ZM = 2, // Interacting with the Z- face of the block BLOCK_FACE_ZP = 3, // Interacting with the Z+ face of the block // Synonyms using the (deprecated) world directions: BLOCK_FACE_BOTTOM = BLOCK_FACE_YM, // Interacting with the bottom face of the block BLOCK_FACE_TOP = BLOCK_FACE_YP, // Interacting with the top face of the block BLOCK_FACE_NORTH = BLOCK_FACE_ZM, // Interacting with the northern face of the block BLOCK_FACE_SOUTH = BLOCK_FACE_ZP, // Interacting with the southern face of the block BLOCK_FACE_WEST = BLOCK_FACE_XM, // Interacting with the western face of the block BLOCK_FACE_EAST = BLOCK_FACE_XP, // Interacting with the eastern face of the block // Bounds, used for range-checking: BLOCK_FACE_MIN = -1, BLOCK_FACE_MAX = 5, } ; /** PlayerDigging status constants */ enum { DIG_STATUS_STARTED = 0, DIG_STATUS_CANCELLED = 1, DIG_STATUS_FINISHED = 2, DIG_STATUS_DROP_STACK= 3, DIG_STATUS_DROP_HELD = 4, DIG_STATUS_SHOOT_EAT = 5, } ; /** Individual actions sent in the WindowClick packet */ enum eClickAction { // Sorted by occurrence in the 1.5 protocol caLeftClick, caRightClick, caShiftLeftClick, caShiftRightClick, caNumber1, caNumber2, caNumber3, caNumber4, caNumber5, caNumber6, caNumber7, caNumber8, caNumber9, caMiddleClick, caDropKey, caCtrlDropKey, caLeftClickOutside, caRightClickOutside, caLeftClickOutsideHoldNothing, caRightClickOutsideHoldNothing, caLeftPaintBegin, caRightPaintBegin, caLeftPaintProgress, caRightPaintProgress, caLeftPaintEnd, caRightPaintEnd, caDblClick, // Add new actions here caUnknown = 255, // Keep this list in sync with ClickActionToString() function below! } ; enum eGameMode { eGameMode_NotSet = -1, eGameMode_Survival = 0, eGameMode_Creative = 1, eGameMode_Adventure = 2, eGameMode_Spectator = 3, // Easier-to-use synonyms: gmNotSet = eGameMode_NotSet, gmSurvival = eGameMode_Survival, gmCreative = eGameMode_Creative, gmAdventure = eGameMode_Adventure, gmSpectator = eGameMode_Spectator, // These two are used to check GameMode for validity when converting from integers. gmMax, // Gets automatically assigned gmMin = 0, } ; enum eChatType { ctChatBox = 0, ctSystem = 1, ctAboveActionBar = 2, } ; enum eWeather { eWeather_Sunny = 0, eWeather_Rain = 1, eWeather_ThunderStorm = 2, // Easier-to-use synonyms: wSunny = eWeather_Sunny, wRain = eWeather_Rain, wThunderstorm = eWeather_ThunderStorm, wStorm = wThunderstorm, } ; enum eMobHeadType { SKULL_TYPE_SKELETON = 0, SKULL_TYPE_WITHER = 1, SKULL_TYPE_ZOMBIE = 2, SKULL_TYPE_PLAYER = 3, SKULL_TYPE_CREEPER = 4, } ; enum eMobHeadRotation { SKULL_ROTATION_NORTH = 0, SKULL_ROTATION_NORTH_NORTH_EAST = 1, SKULL_ROTATION_NORTH_EAST = 2, SKULL_ROTATION_EAST_NORTH_EAST = 3, SKULL_ROTATION_EAST = 4, SKULL_ROTATION_EAST_SOUTH_EAST = 5, SKULL_ROTATION_SOUTH_EAST = 6, SKULL_ROTATION_SOUTH_SOUTH_EAST = 7, SKULL_ROTATION_SOUTH = 8, SKULL_ROTATION_SOUTH_SOUTH_WEST = 9, SKULL_ROTATION_SOUTH_WEST = 10, SKULL_ROTATION_WEST_SOUTH_WEST = 11, SKULL_ROTATION_WEST = 12, SKULL_ROTATION_WEST_NORTH_WEST = 13, SKULL_ROTATION_NORTH_WEST = 14, SKULL_ROTATION_NORTH_NORTH_WEST = 15, } ; inline const char * ClickActionToString(eClickAction a_ClickAction) { switch (a_ClickAction) { case caLeftClick: return "caLeftClick"; case caRightClick: return "caRightClick"; case caShiftLeftClick: return "caShiftLeftClick"; case caShiftRightClick: return "caShiftRightClick"; case caNumber1: return "caNumber1"; case caNumber2: return "caNumber2"; case caNumber3: return "caNumber3"; case caNumber4: return "caNumber4"; case caNumber5: return "caNumber5"; case caNumber6: return "caNumber6"; case caNumber7: return "caNumber7"; case caNumber8: return "caNumber8"; case caNumber9: return "caNumber9"; case caMiddleClick: return "caMiddleClick"; case caDropKey: return "caDropKey"; case caCtrlDropKey: return "caCtrlDropKey"; case caLeftClickOutside: return "caLeftClickOutside"; case caRightClickOutside: return "caRightClickOutside"; case caLeftClickOutsideHoldNothing: return "caLeftClickOutsideHoldNothing"; case caRightClickOutsideHoldNothing: return "caRightClickOutsideHoldNothing"; case caLeftPaintBegin: return "caLeftPaintBegin"; case caRightPaintBegin: return "caRightPaintBegin"; case caLeftPaintProgress: return "caLeftPaintProgress"; case caRightPaintProgress: return "caRightPaintProgress"; case caLeftPaintEnd: return "caLeftPaintEnd"; case caRightPaintEnd: return "caRightPaintEnd"; case caDblClick: return "caDblClick"; case caUnknown: return "caUnknown"; } ASSERT(!"Unknown click action"); return "caUnknown"; } /** Returns a blockface mirrored around the Y axis (doesn't change up / down). */ inline eBlockFace MirrorBlockFaceY(eBlockFace a_BlockFace) { switch (a_BlockFace) { case BLOCK_FACE_XM: return BLOCK_FACE_XP; case BLOCK_FACE_XP: return BLOCK_FACE_XM; case BLOCK_FACE_ZM: return BLOCK_FACE_ZP; case BLOCK_FACE_ZP: return BLOCK_FACE_ZM; case BLOCK_FACE_NONE: case BLOCK_FACE_YM: case BLOCK_FACE_YP: { return a_BlockFace; }; } #if !defined(__clang__) ASSERT(!"Unknown BLOCK_FACE"); return a_BlockFace; #endif } /** Returns a blockface rotated around the Y axis counter-clockwise. */ inline eBlockFace RotateBlockFaceCCW(eBlockFace a_BlockFace) { switch (a_BlockFace) { case BLOCK_FACE_XM: return BLOCK_FACE_ZP; case BLOCK_FACE_XP: return BLOCK_FACE_ZM; case BLOCK_FACE_ZM: return BLOCK_FACE_XM; case BLOCK_FACE_ZP: return BLOCK_FACE_XP; case BLOCK_FACE_NONE: case BLOCK_FACE_YM: case BLOCK_FACE_YP: { return a_BlockFace; } } #if !defined(__clang__) ASSERT(!"Unknown BLOCK_FACE"); return a_BlockFace; #endif } inline eBlockFace RotateBlockFaceCW(eBlockFace a_BlockFace) { switch (a_BlockFace) { case BLOCK_FACE_XM: return BLOCK_FACE_ZM; case BLOCK_FACE_XP: return BLOCK_FACE_ZP; case BLOCK_FACE_ZM: return BLOCK_FACE_XP; case BLOCK_FACE_ZP: return BLOCK_FACE_XM; case BLOCK_FACE_NONE: case BLOCK_FACE_YM: case BLOCK_FACE_YP: { return a_BlockFace; }; } #if !defined(__clang__) ASSERT(!"Unknown BLOCK_FACE"); return a_BlockFace; #endif } inline eBlockFace ReverseBlockFace(eBlockFace a_BlockFace) { switch (a_BlockFace) { case BLOCK_FACE_YP: return BLOCK_FACE_YM; case BLOCK_FACE_XP: return BLOCK_FACE_XM; case BLOCK_FACE_ZP: return BLOCK_FACE_ZM; case BLOCK_FACE_YM: return BLOCK_FACE_YP; case BLOCK_FACE_XM: return BLOCK_FACE_XP; case BLOCK_FACE_ZM: return BLOCK_FACE_ZP; case BLOCK_FACE_NONE: return a_BlockFace; } #if !defined(__clang__) ASSERT(!"Unknown BLOCK_FACE"); return a_BlockFace; #endif } /** Returns the textual representation of the BlockFace constant. */ inline AString BlockFaceToString(eBlockFace a_BlockFace) { switch (a_BlockFace) { case BLOCK_FACE_XM: return "BLOCK_FACE_XM"; case BLOCK_FACE_XP: return "BLOCK_FACE_XP"; case BLOCK_FACE_YM: return "BLOCK_FACE_YM"; case BLOCK_FACE_YP: return "BLOCK_FACE_YP"; case BLOCK_FACE_ZM: return "BLOCK_FACE_ZM"; case BLOCK_FACE_ZP: return "BLOCK_FACE_ZP"; case BLOCK_FACE_NONE: return "BLOCK_FACE_NONE"; } // clang optimisises this line away then warns that it has done so. #if !defined(__clang__) return Printf("Unknown BLOCK_FACE: %d", a_BlockFace); #endif } inline bool IsValidBlock(int a_BlockType) { if ( (a_BlockType > -1) && (a_BlockType <= E_BLOCK_MAX_TYPE_ID) ) { return true; } return false; } inline bool IsValidItem(int a_ItemType) { if ( ((a_ItemType >= E_ITEM_FIRST) && (a_ItemType <= E_ITEM_MAX_CONSECUTIVE_TYPE_ID)) || // Basic items range ((a_ItemType >= E_ITEM_FIRST_DISC) && (a_ItemType <= E_ITEM_LAST_DISC)) // Music discs' special range ) { return true; } if (a_ItemType == 0) { return false; } return IsValidBlock(a_ItemType); } // tolua_end inline bool IsBlockWater(BLOCKTYPE a_BlockType) { return ((a_BlockType == E_BLOCK_WATER) || (a_BlockType == E_BLOCK_STATIONARY_WATER)); } inline bool IsBlockWaterOrIce(BLOCKTYPE a_BlockType) { return (IsBlockWater(a_BlockType) || (a_BlockType == E_BLOCK_ICE)); } inline bool IsBlockLava(BLOCKTYPE a_BlockType) { return ((a_BlockType == E_BLOCK_LAVA) || (a_BlockType == E_BLOCK_STATIONARY_LAVA)); } inline bool IsBlockLiquid(BLOCKTYPE a_BlockType) { return IsBlockWater(a_BlockType) || IsBlockLava(a_BlockType); } inline bool IsBlockRail(BLOCKTYPE a_BlockType) { switch (a_BlockType) { case E_BLOCK_RAIL: case E_BLOCK_ACTIVATOR_RAIL: case E_BLOCK_DETECTOR_RAIL: case E_BLOCK_POWERED_RAIL: { return true; } default: return false; } } inline bool IsBlockTypeOfDirt(BLOCKTYPE a_BlockType) { switch (a_BlockType) { case E_BLOCK_DIRT: case E_BLOCK_GRASS: case E_BLOCK_FARMLAND: { return true; } } return false; } inline void AddFaceDirection(int & a_BlockX, int & a_BlockY, int & a_BlockZ, eBlockFace a_BlockFace, bool a_bInverse = false) // tolua_export { // tolua_export if (!a_bInverse) { switch (a_BlockFace) { case BLOCK_FACE_YP: a_BlockY++; break; case BLOCK_FACE_YM: a_BlockY--; break; case BLOCK_FACE_ZM: a_BlockZ--; break; case BLOCK_FACE_ZP: a_BlockZ++; break; case BLOCK_FACE_XP: a_BlockX++; break; case BLOCK_FACE_XM: a_BlockX--; break; case BLOCK_FACE_NONE: { LOGWARNING("%s: Unknown face: %d", __FUNCTION__, a_BlockFace); ASSERT(!"AddFaceDirection(): Unknown face"); break; } } } else { switch (a_BlockFace) { case BLOCK_FACE_YP: a_BlockY--; break; case BLOCK_FACE_YM: a_BlockY++; break; case BLOCK_FACE_ZM: a_BlockZ++; break; case BLOCK_FACE_ZP: a_BlockZ--; break; case BLOCK_FACE_XP: a_BlockX--; break; case BLOCK_FACE_XM: a_BlockX++; break; case BLOCK_FACE_NONE: { LOGWARNING("%s: Unknown inv face: %d", __FUNCTION__, a_BlockFace); ASSERT(!"AddFaceDirection(): Unknown face"); break; } } } } // tolua_export inline void AddFaceDirection(int & a_BlockX, unsigned char & a_BlockY, int & a_BlockZ, eBlockFace a_BlockFace, bool a_bInverse = false) { int Y = a_BlockY; AddFaceDirection(a_BlockX, Y, a_BlockZ, a_BlockFace, a_bInverse); a_BlockY = Clamp(static_cast(Y), 0, 255); } inline void EulerToVector(double a_Pan, double a_Pitch, double & a_X, double & a_Y, double & a_Z) { // a_X = sinf ( a_Pan / 180 * PI) * cosf ( a_Pitch / 180 * PI); // a_Y = -sinf ( a_Pitch / 180 * PI); // a_Z = -cosf ( a_Pan / 180 * PI) * cosf ( a_Pitch / 180 * PI); a_X = cos(a_Pan / 180 * M_PI) * cos(a_Pitch / 180 * M_PI); a_Y = sin(a_Pan / 180 * M_PI) * cos(a_Pitch / 180 * M_PI); a_Z = sin(a_Pitch / 180 * M_PI); } inline void VectorToEuler(double a_X, double a_Y, double a_Z, double & a_Pan, double & a_Pitch) { double r = sqrt((a_X * a_X) + (a_Z * a_Z)); if (r < std::numeric_limits::epsilon()) { a_Pan = 0; } else { a_Pan = atan2(a_Z, a_X) * 180 / M_PI - 90; } a_Pitch = atan2(a_Y, r) * 180 / M_PI; } inline float GetSignf(float a_Val) { return (a_Val < 0.f) ? -1.f : 1.f; } inline float GetSpecialSignf( float a_Val) { return (a_Val <= 0.f) ? -1.f : 1.f; } template inline T Diff(T a_Val1, T a_Val2) { return std::abs(a_Val1 - a_Val2); } // tolua_begin enum eMessageType { // http://forum.mc-server.org/showthread.php?tid=1212 // MessageType... mtCustom, // Send raw data without any processing mtFailure, // Something could not be done (i.e. command not executed due to insufficient privilege) mtInformation, // Informational message (i.e. command usage) mtSuccess, // Something executed successfully mtWarning, // Something concerning (i.e. reload) is about to happen mtFatal, // Something catastrophic occured (i.e. plugin crash) mtDeath, // Denotes death of player mtPrivateMessage, // Player to player messaging identifier mtJoin, // A player has joined the server mtLeave, // A player has left the server // Common aliases: mtFail = mtFailure, mtError = mtFailure, mtInfo = mtInformation, mtPM = mtPrivateMessage, }; /** Normalizes an angle in degrees to the [-180, +180) range: */ inline double NormalizeAngleDegrees(const double a_Degrees) { double Norm = fmod(a_Degrees + 180, 360); if (Norm < 0) { Norm += 360; } return Norm - 180; } namespace ItemCategory { inline bool IsPickaxe(short a_ItemID) { return (a_ItemID == E_ITEM_WOODEN_PICKAXE) || (a_ItemID == E_ITEM_STONE_PICKAXE) || (a_ItemID == E_ITEM_IRON_PICKAXE) || (a_ItemID == E_ITEM_GOLD_PICKAXE) || (a_ItemID == E_ITEM_DIAMOND_PICKAXE); } inline bool IsAxe(short a_ItemID) { return (a_ItemID == E_ITEM_WOODEN_AXE) || (a_ItemID == E_ITEM_STONE_AXE) || (a_ItemID == E_ITEM_IRON_AXE) || (a_ItemID == E_ITEM_GOLD_AXE) || (a_ItemID == E_ITEM_DIAMOND_AXE); } inline bool IsSword(short a_ItemID) { return (a_ItemID == E_ITEM_WOODEN_SWORD) || (a_ItemID == E_ITEM_STONE_SWORD) || (a_ItemID == E_ITEM_IRON_SWORD) || (a_ItemID == E_ITEM_GOLD_SWORD) || (a_ItemID == E_ITEM_DIAMOND_SWORD); } inline bool IsHoe(short a_ItemID) { return (a_ItemID == E_ITEM_WOODEN_HOE) || (a_ItemID == E_ITEM_STONE_HOE) || (a_ItemID == E_ITEM_IRON_HOE) || (a_ItemID == E_ITEM_GOLD_HOE) || (a_ItemID == E_ITEM_DIAMOND_HOE); } inline bool IsShovel(short a_ItemID) { return (a_ItemID == E_ITEM_WOODEN_SHOVEL) || (a_ItemID == E_ITEM_STONE_SHOVEL) || (a_ItemID == E_ITEM_IRON_SHOVEL) || (a_ItemID == E_ITEM_GOLD_SHOVEL) || (a_ItemID == E_ITEM_DIAMOND_SHOVEL); } inline bool IsTool(short a_ItemID) { return IsPickaxe( a_ItemID) || IsAxe ( a_ItemID) || IsSword ( a_ItemID) || IsHoe ( a_ItemID) || IsShovel ( a_ItemID); } inline bool IsHelmet(short a_ItemType) { return ( (a_ItemType == E_ITEM_LEATHER_CAP) || (a_ItemType == E_ITEM_GOLD_HELMET) || (a_ItemType == E_ITEM_CHAIN_HELMET) || (a_ItemType == E_ITEM_IRON_HELMET) || (a_ItemType == E_ITEM_DIAMOND_HELMET) ); } inline bool IsChestPlate(short a_ItemType) { return ( (a_ItemType == E_ITEM_LEATHER_TUNIC) || (a_ItemType == E_ITEM_GOLD_CHESTPLATE) || (a_ItemType == E_ITEM_CHAIN_CHESTPLATE) || (a_ItemType == E_ITEM_IRON_CHESTPLATE) || (a_ItemType == E_ITEM_DIAMOND_CHESTPLATE) ); } inline bool IsLeggings(short a_ItemType) { return ( (a_ItemType == E_ITEM_LEATHER_PANTS) || (a_ItemType == E_ITEM_GOLD_LEGGINGS) || (a_ItemType == E_ITEM_CHAIN_LEGGINGS) || (a_ItemType == E_ITEM_IRON_LEGGINGS) || (a_ItemType == E_ITEM_DIAMOND_LEGGINGS) ); } inline bool IsBoots(short a_ItemType) { return ( (a_ItemType == E_ITEM_LEATHER_BOOTS) || (a_ItemType == E_ITEM_GOLD_BOOTS) || (a_ItemType == E_ITEM_CHAIN_BOOTS) || (a_ItemType == E_ITEM_IRON_BOOTS) || (a_ItemType == E_ITEM_DIAMOND_BOOTS) ); } inline bool IsArmor(short a_ItemType) { return ( IsHelmet(a_ItemType) || IsChestPlate(a_ItemType) || IsLeggings(a_ItemType) || IsBoots(a_ItemType) ); } } // tolua_end