2012-06-14 09:06:06 -04:00
// CraftingRecipes.h
// Interfaces to the cCraftingRecipes class representing the storage of crafting recipes
# pragma once
2012-09-23 18:09:57 -04:00
# include "Item.h"
2012-06-14 09:06:06 -04:00
// fwd: cPlayer.h
class cPlayer ;
class cCraftingGrid // tolua_export
{ // tolua_export
public :
cCraftingGrid ( const cCraftingGrid & a_Original ) ;
cCraftingGrid ( int a_Width , int a_Height ) ; // tolua_export
2012-09-20 09:25:54 -04:00
cCraftingGrid ( const cItem * a_Items , int a_Width , int a_Height ) ;
2012-06-14 09:06:06 -04:00
~ cCraftingGrid ( ) ;
2016-02-05 16:45:45 -05:00
2012-06-14 09:06:06 -04:00
// tolua_begin
int GetWidth ( void ) const { return m_Width ; }
int GetHeight ( void ) const { return m_Height ; }
cItem & GetItem ( int x , int y ) const ;
2020-04-03 02:57:01 -04:00
void SetItem ( int x , int y , ENUM_ITEM_TYPE a_ItemType , char a_ItemCount , short a_ItemHealth ) ;
2012-06-14 09:06:06 -04:00
void SetItem ( int x , int y , const cItem & a_Item ) ;
void Clear ( void ) ;
2016-02-05 16:45:45 -05:00
2015-07-31 10:49:10 -04:00
/** Removes items in a_Grid from m_Items[] (used by cCraftingRecipe::ConsumeIngredients()) */
2012-06-14 09:06:06 -04:00
void ConsumeGrid ( const cCraftingGrid & a_Grid ) ;
2015-07-31 10:49:10 -04:00
/** Dumps the entire crafting grid using LOGD() */
2012-06-14 09:06:06 -04:00
void Dump ( void ) ;
2016-02-05 16:45:45 -05:00
2012-06-14 09:06:06 -04:00
// tolua_end
2016-02-05 16:45:45 -05:00
2012-06-14 09:06:06 -04:00
cItem * GetItems ( void ) const { return m_Items ; }
2016-02-05 16:45:45 -05:00
2015-07-31 10:49:10 -04:00
/** Copies internal contents into the item array specified. Assumes that the array has the same dimensions as self */
2012-06-14 09:06:06 -04:00
void CopyToItems ( cItem * a_Items ) const ;
2016-02-05 16:45:45 -05:00
2012-06-14 09:06:06 -04:00
protected :
int m_Width ;
int m_Height ;
cItem * m_Items ;
} ; // tolua_export
class cCraftingRecipe // tolua_export
{ // tolua_export
public :
cCraftingRecipe ( const cCraftingGrid & a_CraftingGrid ) ;
2016-02-05 16:45:45 -05:00
2012-06-14 09:06:06 -04:00
// tolua_begin
void Clear ( void ) ;
int GetIngredientsWidth ( void ) const { return m_Ingredients . GetWidth ( ) ; }
int GetIngredientsHeight ( void ) const { return m_Ingredients . GetHeight ( ) ; }
cItem & GetIngredient ( int x , int y ) const { return m_Ingredients . GetItem ( x , y ) ; }
const cItem & GetResult ( void ) const { return m_Result ; }
2020-04-03 02:57:01 -04:00
void SetResult ( ENUM_ITEM_TYPE a_ItemType , char a_ItemCount , short a_ItemHealth ) ;
2012-06-14 09:06:06 -04:00
void SetResult ( const cItem & a_Item )
{
m_Result = a_Item ;
}
2016-02-05 16:45:45 -05:00
2020-04-03 02:57:01 -04:00
void SetIngredient ( int x , int y , ENUM_ITEM_TYPE a_ItemType , char a_ItemCount , short a_ItemHealth )
2012-06-14 09:06:06 -04:00
{
m_Ingredients . SetItem ( x , y , a_ItemType , a_ItemCount , a_ItemHealth ) ;
}
2016-02-05 16:45:45 -05:00
2012-06-14 09:06:06 -04:00
void SetIngredient ( int x , int y , const cItem & a_Item )
{
m_Ingredients . SetItem ( x , y , a_Item ) ;
}
2016-02-05 16:45:45 -05:00
2015-07-31 10:49:10 -04:00
/** Consumes ingredients from the crafting grid specified */
2012-06-14 09:06:06 -04:00
void ConsumeIngredients ( cCraftingGrid & a_CraftingGrid ) ;
2015-07-31 10:49:10 -04:00
/** Dumps the entire recipe using LOGD() */
2012-06-14 09:06:06 -04:00
void Dump ( void ) ;
// tolua_end
2016-02-05 16:45:45 -05:00
2012-06-14 09:06:06 -04:00
protected :
cCraftingGrid m_Ingredients ; // Adjusted to correspond to the input crafting grid!
cItem m_Result ;
} ; // tolua_export
class cCraftingRecipes
{
public :
static const int MAX_GRID_WIDTH = 3 ;
static const int MAX_GRID_HEIGHT = 3 ;
2016-02-05 16:45:45 -05:00
2012-06-14 09:06:06 -04:00
cCraftingRecipes ( void ) ;
~ cCraftingRecipes ( ) ;
2016-02-05 16:45:45 -05:00
2015-07-31 10:49:10 -04:00
/** Returns the recipe for current crafting grid. Doesn't modify the grid. Clears a_Recipe if no recipe found. */
2014-10-15 13:01:55 -04:00
void GetRecipe ( cPlayer & a_Player , cCraftingGrid & a_CraftingGrid , cCraftingRecipe & a_Recipe ) ;
2016-02-05 16:45:45 -05:00
2012-06-14 09:06:06 -04:00
protected :
struct cRecipeSlot
{
cItem m_Item ;
int x , y ; // 1..3, or -1 for "any"
} ;
typedef std : : vector < cRecipeSlot > cRecipeSlots ;
2016-02-05 16:45:45 -05:00
2012-06-14 09:06:06 -04:00
/** A single recipe, stored. Each recipe is normalized right after parsing (NormalizeIngredients())
2015-07-31 10:49:10 -04:00
A normalized recipe starts at ( 0 , 0 ) */
2012-06-14 09:06:06 -04:00
struct cRecipe
{
cRecipeSlots m_Ingredients ;
cItem m_Result ;
2016-02-05 16:45:45 -05:00
2012-06-14 09:06:06 -04:00
// Size of the regular items in the recipe; "anywhere" items are excluded:
int m_Width ;
int m_Height ;
} ;
typedef std : : vector < cRecipe * > cRecipes ;
2016-02-05 16:45:45 -05:00
2012-06-14 09:06:06 -04:00
cRecipes m_Recipes ;
2016-02-05 16:45:45 -05:00
2012-06-14 09:06:06 -04:00
void LoadRecipes ( void ) ;
void ClearRecipes ( void ) ;
2016-02-05 16:45:45 -05:00
2015-07-31 10:49:10 -04:00
/** Parses the recipe line and adds it into m_Recipes. a_LineNum is used for diagnostic warnings only */
2012-06-14 09:06:06 -04:00
void AddRecipeLine ( int a_LineNum , const AString & a_RecipeLine ) ;
2016-02-05 16:45:45 -05:00
2015-07-31 10:49:10 -04:00
/** Parses an item string in the format "<ItemType>[^<Damage>]", returns true if successful. */
2012-06-14 09:06:06 -04:00
bool ParseItem ( const AString & a_String , cItem & a_Item ) ;
2016-02-05 16:45:45 -05:00
2015-07-31 10:49:10 -04:00
/** Parses one ingredient and adds it to the specified recipe. Returns true if successful. */
2012-06-14 09:06:06 -04:00
bool ParseIngredient ( const AString & a_String , cRecipe * a_Recipe ) ;
2016-02-05 16:45:45 -05:00
2015-07-31 10:49:10 -04:00
/** Moves the recipe to top-left corner, sets its MinWidth / MinHeight */
2012-06-14 09:06:06 -04:00
void NormalizeIngredients ( cRecipe * a_Recipe ) ;
2016-02-05 16:45:45 -05:00
2015-07-31 10:49:10 -04:00
/** Finds a recipe matching the crafting grid. Returns a newly allocated recipe (with all its coords set) or nullptr if not found. Caller must delete return value! */
2012-06-14 09:06:06 -04:00
cRecipe * FindRecipe ( const cItem * a_CraftingGrid , int a_GridWidth , int a_GridHeight ) ;
2016-02-05 16:45:45 -05:00
2015-07-31 10:49:10 -04:00
/** Same as FindRecipe, but the grid is guaranteed to be of minimal dimensions needed */
2012-06-14 09:06:06 -04:00
cRecipe * FindRecipeCropped ( const cItem * a_CraftingGrid , int a_GridWidth , int a_GridHeight , int a_GridStride ) ;
2016-02-05 16:45:45 -05:00
2015-07-31 10:49:10 -04:00
/** Checks if the grid matches the specified recipe, offset by the specified offsets. Returns a matched cRecipe * if so, or nullptr if not matching. Caller must delete the return value! */
2012-06-14 09:06:06 -04:00
cRecipe * MatchRecipe ( const cItem * a_CraftingGrid , int a_GridWidth , int a_GridHeight , int a_GridStride , const cRecipe * a_Recipe , int a_OffsetX , int a_OffsetY ) ;
2014-03-01 16:25:01 -05:00
/** Searches for anything firework related, and does the data setting if appropriate */
void HandleFireworks ( const cItem * a_CraftingGrid , cCraftingRecipes : : cRecipe * a_Recipe , int a_GridStride , int a_OffsetX , int a_OffsetY ) ;
2015-07-13 20:15:37 -04:00
2015-07-31 10:49:10 -04:00
/** Searches for anything dye related for leather, calculates the appropriate color value, and sets the resulting value. */
2015-07-13 20:15:37 -04:00
void HandleDyedLeather ( const cItem * a_CraftingGrid , cCraftingRecipes : : cRecipe * a_Recipe , int a_GridStride , int a_GridWidth , int a_GridHeight ) ;
2012-06-14 09:06:06 -04:00
} ;