1
0
Fork 0
cuberite-2a/src/BlockEntities/FurnaceEntity.h

176 lines
4.7 KiB
C
Raw Normal View History

#pragma once
#include "BlockEntityWithItems.h"
#include "../FurnaceRecipe.h"
class cClientHandle;
// tolua_begin
class cFurnaceEntity :
public cBlockEntityWithItems
{
typedef cBlockEntityWithItems super;
2016-02-05 21:45:45 +00:00
public:
enum
{
fsInput = 0, // Input slot number
fsFuel = 1, // Fuel slot number
fsOutput = 2, // Output slot number
2016-02-05 21:45:45 +00:00
ContentsWidth = 3,
ContentsHeight = 1,
};
2016-02-05 21:45:45 +00:00
// tolua_end
2016-02-05 21:45:45 +00:00
BLOCKENTITY_PROTODEF(cFurnaceEntity)
2016-02-05 21:45:45 +00:00
/** Constructor used for normal operation */
cFurnaceEntity(int a_BlockX, int a_BlockY, int a_BlockZ, BLOCKTYPE a_BlockType, NIBBLETYPE a_BlockMeta, cWorld * a_World);
2016-02-05 21:45:45 +00:00
virtual ~cFurnaceEntity();
// cBlockEntity overrides:
virtual void SendTo(cClientHandle & a_Client) override;
virtual bool Tick(std::chrono::milliseconds a_Dt, cChunk & a_Chunk) override;
virtual bool UsedBy(cPlayer * a_Player) override;
virtual void Destroy() override
{
m_IsDestroyed = true;
super::Destroy();
}
/** Restarts cooking
Used after the furnace is loaded from storage to set up the internal variables so that cooking continues, if it was active
Returns true if cooking */
bool ContinueCooking(void);
2016-02-05 21:45:45 +00:00
// tolua_begin
2016-02-05 21:45:45 +00:00
/** Returns the item in the input slot */
const cItem & GetInputSlot(void) const { return GetSlot(fsInput); }
2016-02-05 21:45:45 +00:00
/** Returns the item in the fuel slot */
const cItem & GetFuelSlot(void) const { return GetSlot(fsFuel); }
2016-02-05 21:45:45 +00:00
/** Returns the item in the output slot */
const cItem & GetOutputSlot(void) const { return GetSlot(fsOutput); }
2016-02-05 21:45:45 +00:00
/** Sets the item in the input slot */
void SetInputSlot(const cItem & a_Item) { SetSlot(fsInput, a_Item); }
2016-02-05 21:45:45 +00:00
/** Sets the item in the fuel slot */
void SetFuelSlot(const cItem & a_Item) { SetSlot(fsFuel, a_Item); }
2016-02-05 21:45:45 +00:00
/** Sets the item in the output slot */
void SetOutputSlot(const cItem & a_Item) { SetSlot(fsOutput, a_Item); }
2016-02-05 21:45:45 +00:00
/** Returns the time that the current item has been cooking, in ticks */
int GetTimeCooked(void) const { return m_TimeCooked; }
2016-02-05 21:45:45 +00:00
/** Returns the time until the current item finishes cooking, in ticks */
int GetCookTimeLeft(void) const { return m_NeedCookTime - m_TimeCooked; }
2016-02-05 21:45:45 +00:00
/** Returns the time until the current fuel is depleted, in ticks */
int GetFuelBurnTimeLeft(void) const { return m_FuelBurnTime - m_TimeBurned; }
2016-02-05 21:45:45 +00:00
/** Returns true if there's time left before the current fuel is depleted */
bool HasFuelTimeLeft(void) const { return (GetFuelBurnTimeLeft() > 0); }
2016-02-05 21:45:45 +00:00
// tolua_end
2016-02-05 21:45:45 +00:00
void SetBurnTimes(int a_FuelBurnTime, int a_TimeBurned)
{
m_FuelBurnTime = a_FuelBurnTime;
m_TimeBurned = a_TimeBurned;
}
void SetCookTimes(int a_NeedCookTime, int a_TimeCooked)
{
m_NeedCookTime = a_NeedCookTime;
m_TimeCooked = a_TimeCooked;
}
2016-02-05 21:45:45 +00:00
void SetLoading(bool a_IsLoading)
{
m_IsLoading = a_IsLoading;
}
protected:
2016-02-05 21:45:45 +00:00
/** Block meta of the block currently represented by this entity */
NIBBLETYPE m_BlockMeta;
/** The recipe for the current input slot */
2014-08-31 17:00:36 +00:00
const cFurnaceRecipe::cRecipe * m_CurrentRecipe;
2016-02-05 21:45:45 +00:00
/** The item that is being smelted */
cItem m_LastInput;
/** Set to true when the furnace entity has been destroyed to prevent the block being set again */
bool m_IsDestroyed;
2016-02-05 21:45:45 +00:00
/** Set to true if the furnace is cooking an item */
bool m_IsCooking;
2016-02-05 21:45:45 +00:00
/** Amount of ticks needed to fully cook current item */
int m_NeedCookTime;
/** Amount of ticks that the current item has been cooking */
int m_TimeCooked;
/** Amount of ticks that the current fuel can burn (in total); zero if no fuel burning */
int m_FuelBurnTime;
/** Amount of ticks that the current fuel has been burning */
2014-10-21 20:00:31 +00:00
int m_TimeBurned;
/** Is the block currently being loaded into the world? */
bool m_IsLoading;
2016-02-05 21:45:45 +00:00
/** Sends the specified progressbar value to all clients of the window */
void BroadcastProgress(short a_ProgressbarID, short a_Value);
2016-02-05 21:45:45 +00:00
/** One item finished cooking */
2014-02-24 19:29:59 +00:00
void FinishOne();
2016-02-05 21:45:45 +00:00
/** Starts burning a new fuel, if possible */
void BurnNewFuel(void);
2016-02-05 21:45:45 +00:00
/** Updates the recipe, based on the current input */
void UpdateInput(void);
2016-02-05 21:45:45 +00:00
/** Called when the fuel slot changes or when the fuel is spent, burns another piece of fuel if appropriate */
void UpdateFuel(void);
2016-02-05 21:45:45 +00:00
/** Called when the output slot changes */
void UpdateOutput(void);
2016-02-05 21:45:45 +00:00
/** Returns true if the input can be cooked into output and the item counts allow for another cooking operation */
bool CanCookInputToOutput(void) const;
2016-02-05 21:45:45 +00:00
/** Broadcasts progressbar updates, if needed */
void UpdateProgressBars(bool a_ForceUpdate = false);
2016-02-05 21:45:45 +00:00
/** Sets the m_IsCooking variable, updates the furnace block type based on the value */
void SetIsCooking(bool a_IsCooking);
2016-02-05 21:45:45 +00:00
// cItemGrid::cListener overrides:
virtual void OnSlotChanged(cItemGrid * a_ItemGrid, int a_SlotNum) override;
2016-02-05 21:45:45 +00:00
} ; // tolua_export