-
Notifications
You must be signed in to change notification settings - Fork 20
/
Copy pathcylinder.h
244 lines (210 loc) · 9.51 KB
/
cylinder.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
//////////////////////////////////////////////////////////////////////
// OpenTibia - an opensource roleplaying game
//////////////////////////////////////////////////////////////////////
//
//////////////////////////////////////////////////////////////////////
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; either version 2
// of the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software Foundation,
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
//////////////////////////////////////////////////////////////////////
#ifndef __OTSERV_CYLINDER_H__
#define __OTSERV_CYLINDER_H__
#include <map>
#include "definitions.h"
#include "thing.h"
class Item;
class Creature;
#define INDEX_WHEREEVER -1
enum cylinderflags_t
{
FLAG_NOLIMIT = 1, //Bypass limits like capacity/container limits, blocking items/creatures etc.
FLAG_IGNOREBLOCKITEM = 2, //Bypass moveable blocking item checks
FLAG_IGNOREBLOCKCREATURE = 4, //Bypass creature checks
FLAG_CHILDISOWNER = 8, //Used by containers to query capacity of the carrier (player)
FLAG_PATHFINDING = 16, //An additional check is done for floor changing/teleport items
FLAG_IGNOREFIELDDAMAGE = 32, //Bypass field damage checks
FLAG_IGNORENOTMOVEABLE = 64, //Bypass check for movability
FLAG_IGNOREAUTOSTACK = 128 //__queryDestination will not try to stack items together
};
enum cylinderlink_t
{
LINK_OWNER,
LINK_PARENT,
LINK_TOPPARENT,
LINK_NEAR
};
class Cylinder : virtual public Thing
{
public:
/**
* Query if the cylinder can add an object
* \param index points to the destination index (inventory slot/container position)
* -1 is a internal value and means add to a empty position, with no destItem
* \param thing the object to move/add
* \param count is the amount that we want to move/add
* \param flags if FLAG_CHILDISOWNER if set the query is from a child-cylinder (check cap etc.)
* if FLAG_NOLIMIT is set blocking items/container limits is ignored
* \param actor the creature trying to add the thing
* \returns ReturnValue holds the return value
*/
virtual ReturnValue __queryAdd(int32_t index, const Thing* thing, uint32_t count,
uint32_t flags, Creature* actor = NULL) const = 0;
/**
* Query the cylinder how much it can accept
* \param index points to the destination index (inventory slot/container position)
* -1 is a internal value and means add to a empty position, with no destItem
* \param item the object to move/add
* \param count is the amount that we want to move/add
* \param maxQueryCount is the max amount that the cylinder can accept
* \param flags optional flags to modifiy the default behaviour
* \returns ReturnValue holds the return value
*/
virtual ReturnValue __queryMaxCount(int32_t index, const Thing* thing, uint32_t count, uint32_t& maxQueryCount,
uint32_t flags) const = 0;
/**
* Query if the cylinder can remove an object
* \param item the object to move/remove
* \param count is the amount that we want to remove
* \param flags optional flags to modifiy the default behaviour
* \returns ReturnValue holds the return value
*/
virtual ReturnValue __queryRemove(const Thing* thing, uint32_t count, uint32_t flags) const = 0;
/**
* Query the destination cylinder
* \param index points to the destination index (inventory slot/container position),
* -1 is a internal value and means add to a empty position, with no destItem
* this method can change the index to point to the new cylinder index
* \param destItem is the destination object
* \param flags optional flags to modifiy the default behaviour
* this method can modifiy the flags
* \returns Cylinder returns the destination cylinder
*/
virtual Cylinder* __queryDestination(int32_t& index, const Thing* thing, Item** destItem,
uint32_t& flags) = 0;
/**
* Add the object to the cylinder
* \param item is the object to add
*/
virtual void __addThing(Thing* thing) = 0;
/**
* Add the object to the cylinder
* \param index points to the destination index (inventory slot/container position)
* \param item is the object to add
*/
virtual void __addThing(int32_t index, Thing* thing) = 0;
/**
* Update the item count or type for an object
* \param thing is the object to update
* \param itemId is the new item id
* \param count is the new count value
*/
virtual void __updateThing(Thing* thing, uint16_t itemId, uint32_t count) = 0;
/**
* Replace an object with a new
* \param index is the position to change (inventory slot/container position)
* \param thing is the object to update
*/
virtual void __replaceThing(uint32_t index, Thing* thing) = 0;
/**
* Remove an object
* \param thing is the object to delete
* \param count is the new count value
*/
virtual void __removeThing(Thing* thing, uint32_t count) = 0;
/**
* Is sent after an operation (move/add) to update internal values
* \param thing is the object that has been added
* \param index is the objects new index value
* \param link holds the relation the object has to the cylinder
*/
virtual void postAddNotification(Thing* thing, const Cylinder* oldParent, int32_t index, cylinderlink_t link = LINK_OWNER) = 0;
/**
* Is sent after an operation (move/remove) to update internal values
* \param thing is the object that has been removed
* \param index is the previous index of the removed object
* \param isCompleteRemoval indicates if the item was completely removed or just partially (stackables)
* \param link holds the relation the object has to the cylinder
*/
virtual void postRemoveNotification(Thing* thing, const Cylinder* newParent, int32_t index, bool isCompleteRemoval, cylinderlink_t link = LINK_OWNER) = 0;
/**
* Gets the index of an object
* \param thing the object to get the index value from
* \returns the index of the object, returns -1 if not found
*/
virtual int32_t __getIndexOfThing(const Thing* thing) const;
/**
* Returns the first index
* \returns the first index, if not implemented -1 is returned
*/
virtual int32_t __getFirstIndex() const;
/**
* Returns the last index
* \returns the last index, if not implemented -1 is returned
*/
virtual int32_t __getLastIndex() const;
/**
* Gets the object based on index
* \returns the object, returns NULL if not found
*/
virtual Thing* __getThing(uint32_t index) const;
/**
* Get the amount of items of a certain type
* \param itemId is the item type to the get the count of
* \param subType is the extra type an item can have such as charges/fluidtype, -1 means not used
* \param returns the amount of items of the asked item type
*/
virtual uint32_t __getItemTypeCount(uint16_t itemId, int32_t subType = -1) const;
/**
* Get the amount of items of a all types
* \param countMap a map to put the itemID:count mapping in
* \param returns a map mapping item id to count (same as first argument)
*/
virtual std::map<uint32_t, uint32_t>& __getAllItemTypeCount(std::map<uint32_t, uint32_t>& countMap) const;
/**
* Adds an object to the cylinder without sending to the client(s)
* \param thing is the object to add
*/
virtual void __internalAddThing(Thing* thing);
/**
* Adds an object to the cylinder without sending to the client(s)
* \param thing is the object to add
* \param index points to the destination index (inventory slot/container position)
*/
virtual void __internalAddThing(uint32_t index, Thing* thing);
virtual void __startDecaying();
};
class VirtualCylinder : public Cylinder
{
public:
static VirtualCylinder* virtualCylinder;
virtual ReturnValue __queryAdd(int32_t index, const Thing* thing, uint32_t count,
uint32_t flags, Creature* actor = NULL) const {return RET_NOTPOSSIBLE;}
virtual ReturnValue __queryMaxCount(int32_t index, const Thing* thing, uint32_t count,
uint32_t& maxQueryCount, uint32_t flags) const {return RET_NOTPOSSIBLE;}
virtual ReturnValue __queryRemove(const Thing* thing, uint32_t count, uint32_t flags) const {return RET_NOTPOSSIBLE;}
virtual Cylinder* __queryDestination(int32_t& index, const Thing* thing, Item** destItem,
uint32_t& flags) {return NULL;}
virtual void __addThing(Thing* thing) {}
virtual void __addThing(int32_t index, Thing* thing) {}
virtual void __updateThing(Thing* thing, uint16_t itemId, uint32_t count) {}
virtual void __replaceThing(uint32_t index, Thing* thing) {}
virtual void __removeThing(Thing* thing, uint32_t count) {}
virtual void postAddNotification(Thing* thing, const Cylinder* oldParent, int32_t index, cylinderlink_t link = LINK_OWNER) {}
virtual void postRemoveNotification(Thing* thing, const Cylinder* newParent, int32_t index, bool isCompleteRemoval,
cylinderlink_t link = LINK_OWNER) {}
virtual bool isPushable() const {return false;}
virtual int getThrowRange() const {return 1;}
virtual std::string getDescription(int32_t lookDistance) const {return "";}
virtual bool isRemoved() const {return false;}
};
#endif