diff options
author | Jacek Antonelli | 2008-08-15 23:44:46 -0500 |
---|---|---|
committer | Jacek Antonelli | 2008-08-15 23:44:46 -0500 |
commit | 38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4 (patch) | |
tree | adca584755d22ca041a2dbfc35d4eca01f70b32c /linden/indra/llinventory/llinventory.h | |
parent | README.txt (diff) | |
download | meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.zip meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.gz meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.bz2 meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.xz |
Second Life viewer sources 1.13.2.12
Diffstat (limited to 'linden/indra/llinventory/llinventory.h')
-rw-r--r-- | linden/indra/llinventory/llinventory.h | 430 |
1 files changed, 430 insertions, 0 deletions
diff --git a/linden/indra/llinventory/llinventory.h b/linden/indra/llinventory/llinventory.h new file mode 100644 index 0000000..1ebcabf --- /dev/null +++ b/linden/indra/llinventory/llinventory.h | |||
@@ -0,0 +1,430 @@ | |||
1 | /** | ||
2 | * @file llinventory.h | ||
3 | * @brief LLInventoryItem and LLInventoryCategory class declaration. | ||
4 | * | ||
5 | * Copyright (c) 2001-2007, Linden Research, Inc. | ||
6 | * | ||
7 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
8 | * to you under the terms of the GNU General Public License, version 2.0 | ||
9 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
10 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
11 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
12 | * online at http://secondlife.com/developers/opensource/gplv2 | ||
13 | * | ||
14 | * There are special exceptions to the terms and conditions of the GPL as | ||
15 | * it is applied to this Source Code. View the full text of the exception | ||
16 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
17 | * online at http://secondlife.com/developers/opensource/flossexception | ||
18 | * | ||
19 | * By copying, modifying or distributing this software, you acknowledge | ||
20 | * that you have read and understood your obligations described above, | ||
21 | * and agree to abide by those obligations. | ||
22 | * | ||
23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
25 | * COMPLETENESS OR PERFORMANCE. | ||
26 | */ | ||
27 | |||
28 | #ifndef LL_LLINVENTORY_H | ||
29 | #define LL_LLINVENTORY_H | ||
30 | |||
31 | #include <functional> | ||
32 | |||
33 | #include "llassetstorage.h" | ||
34 | #include "lldarray.h" | ||
35 | #include "llpermissions.h" | ||
36 | #include "llsaleinfo.h" | ||
37 | #include "llsd.h" | ||
38 | #include "lluuid.h" | ||
39 | #include "llxmlnode.h" | ||
40 | |||
41 | // consts for Key field in the task inventory update message | ||
42 | extern const U8 TASK_INVENTORY_ITEM_KEY; | ||
43 | extern const U8 TASK_INVENTORY_ASSET_KEY; | ||
44 | |||
45 | // anonymous enumeration to specify a max inventory buffer size for | ||
46 | // use in packBinaryBucket() | ||
47 | enum | ||
48 | { | ||
49 | MAX_INVENTORY_BUFFER_SIZE = 1024 | ||
50 | }; | ||
51 | |||
52 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
53 | // Class LLInventoryType | ||
54 | // | ||
55 | // Class used to encapsulate operations around inventory type. | ||
56 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
57 | |||
58 | class LLInventoryType | ||
59 | { | ||
60 | public: | ||
61 | enum EType | ||
62 | { | ||
63 | IT_TEXTURE = 0, | ||
64 | IT_SOUND = 1, | ||
65 | IT_CALLINGCARD = 2, | ||
66 | IT_LANDMARK = 3, | ||
67 | //IT_SCRIPT = 4, | ||
68 | //IT_CLOTHING = 5, | ||
69 | IT_OBJECT = 6, | ||
70 | IT_NOTECARD = 7, | ||
71 | IT_CATEGORY = 8, | ||
72 | IT_ROOT_CATEGORY = 9, | ||
73 | IT_LSL = 10, | ||
74 | //IT_LSL_BYTECODE = 11, | ||
75 | //IT_TEXTURE_TGA = 12, | ||
76 | //IT_BODYPART = 13, | ||
77 | //IT_TRASH = 14, | ||
78 | IT_SNAPSHOT = 15, | ||
79 | //IT_LOST_AND_FOUND = 16, | ||
80 | IT_ATTACHMENT = 17, | ||
81 | IT_WEARABLE = 18, | ||
82 | IT_ANIMATION = 19, | ||
83 | IT_GESTURE = 20, | ||
84 | IT_COUNT = 21, | ||
85 | |||
86 | IT_NONE = -1 | ||
87 | }; | ||
88 | |||
89 | // machine transation between type and strings | ||
90 | static EType lookup(const char* name); | ||
91 | static const char* lookup(EType type); | ||
92 | |||
93 | // translation from a type to a human readable form. | ||
94 | static const char* lookupHumanReadable(EType type); | ||
95 | |||
96 | // return the default inventory for the given asset type. | ||
97 | static EType defaultForAssetType(LLAssetType::EType asset_type); | ||
98 | |||
99 | private: | ||
100 | // don't instantiate or derive one of these objects | ||
101 | LLInventoryType( void ) {} | ||
102 | ~LLInventoryType( void ) {} | ||
103 | |||
104 | //private: | ||
105 | // static const char* mInventoryTypeNames[]; | ||
106 | // static const char* mInventoryTypeHumanNames[]; | ||
107 | // static LLInventoryType::EType mInventoryAssetType[]; | ||
108 | }; | ||
109 | |||
110 | |||
111 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
112 | // Class LLInventoryObject | ||
113 | // | ||
114 | // This is the base class for inventory objects that handles the | ||
115 | // common code between items and categories. The 'mParentUUID' member | ||
116 | // means the parent category since all inventory objects except each | ||
117 | // user's root category are in some category. Each user's root | ||
118 | // category will have mParentUUID==LLUUID::null. | ||
119 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
120 | |||
121 | class LLMessageSystem; | ||
122 | |||
123 | class LLInventoryObject : public LLRefCount | ||
124 | { | ||
125 | protected: | ||
126 | LLUUID mUUID; | ||
127 | LLUUID mParentUUID; | ||
128 | LLAssetType::EType mType; | ||
129 | LLString mName; | ||
130 | |||
131 | protected: | ||
132 | virtual ~LLInventoryObject( void ); | ||
133 | |||
134 | public: | ||
135 | MEM_TYPE_NEW(LLMemType::MTYPE_INVENTORY); | ||
136 | LLInventoryObject(const LLUUID& uuid, const LLUUID& parent_uuid, | ||
137 | LLAssetType::EType type, const LLString& name); | ||
138 | LLInventoryObject(); | ||
139 | virtual void copy(const LLInventoryObject* other); // LLRefCount requires custom copy | ||
140 | |||
141 | // accessors | ||
142 | const LLUUID& getUUID() const; | ||
143 | const LLUUID& getParentUUID() const; | ||
144 | const LLString& getName() const; | ||
145 | LLAssetType::EType getType() const; | ||
146 | |||
147 | // mutators - will not call updateServer(); | ||
148 | void setUUID(const LLUUID& new_uuid); | ||
149 | void rename(const LLString& new_name); | ||
150 | void setParent(const LLUUID& new_parent); | ||
151 | void setType(LLAssetType::EType type); | ||
152 | |||
153 | // file support - implemented here so that a minimal information | ||
154 | // set can be transmitted between simulator and viewer. | ||
155 | // virtual BOOL importFile(FILE* fp); | ||
156 | virtual BOOL exportFile(FILE* fp, BOOL include_asset_key = TRUE) const; | ||
157 | |||
158 | virtual BOOL importLegacyStream(std::istream& input_stream); | ||
159 | virtual BOOL exportLegacyStream(std::ostream& output_stream, BOOL include_asset_key = TRUE) const; | ||
160 | |||
161 | // virtual methods | ||
162 | virtual void removeFromServer(); | ||
163 | virtual void updateParentOnServer(BOOL) const; | ||
164 | virtual void updateServer(BOOL) const; | ||
165 | }; | ||
166 | |||
167 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
168 | // Class LLInventoryItem | ||
169 | // | ||
170 | // An inventory item represents something that the current user has in | ||
171 | // their inventory. | ||
172 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
173 | |||
174 | class LLInventoryItem : public LLInventoryObject | ||
175 | { | ||
176 | public: | ||
177 | typedef LLDynamicArray<LLPointer<LLInventoryItem> > item_array_t; | ||
178 | |||
179 | protected: | ||
180 | LLPermissions mPermissions; | ||
181 | LLUUID mAssetUUID; | ||
182 | LLString mDescription; | ||
183 | LLSaleInfo mSaleInfo; | ||
184 | LLInventoryType::EType mInventoryType; | ||
185 | U32 mFlags; | ||
186 | S32 mCreationDate; // seconds from 1/1/1970, UTC | ||
187 | |||
188 | public: | ||
189 | enum | ||
190 | { | ||
191 | // The meaning of LLInventoryItem::mFlags is distinct for each | ||
192 | // inventory type. | ||
193 | II_FLAGS_NONE = 0, | ||
194 | |||
195 | // landmark flags | ||
196 | II_FLAGS_LANDMARK_VISITED = 1, | ||
197 | |||
198 | // flag to indicate that object permissions should have next | ||
199 | // owner perm be more restrictive on rez. We bump this into | ||
200 | // the second byte of the flags since the low byte is used to | ||
201 | // track attachment points. | ||
202 | II_FLAGS_OBJECT_SLAM_PERM = 0x100, | ||
203 | |||
204 | // These flags specify which permissions masks to overwrite | ||
205 | // upon rez. Normally, if no permissions slam (above) or | ||
206 | // overwrite flags are set, the asset's permissions are | ||
207 | // used and the inventory's permissions are ignored. If | ||
208 | // any of these flags are set, the inventory's permissions | ||
209 | // take precedence. | ||
210 | II_FLAGS_OBJECT_PERM_OVERWRITE_BASE = 0x010000, | ||
211 | II_FLAGS_OBJECT_PERM_OVERWRITE_OWNER = 0x020000, | ||
212 | II_FLAGS_OBJECT_PERM_OVERWRITE_GROUP = 0x040000, | ||
213 | II_FLAGS_OBJECT_PERM_OVERWRITE_EVERYONE = 0x080000, | ||
214 | II_FLAGS_OBJECT_PERM_OVERWRITE_NEXT_OWNER = 0x100000, | ||
215 | |||
216 | // wearables use the low order byte of flags to store the | ||
217 | // EWearableType enumeration found in newview/llwearable.h | ||
218 | }; | ||
219 | |||
220 | protected: | ||
221 | ~LLInventoryItem(); // ref counted | ||
222 | |||
223 | public: | ||
224 | MEM_TYPE_NEW(LLMemType::MTYPE_INVENTORY); | ||
225 | LLInventoryItem(const LLUUID& uuid, | ||
226 | const LLUUID& parent_uuid, | ||
227 | const LLPermissions& permissions, | ||
228 | const LLUUID& asset_uuid, | ||
229 | LLAssetType::EType type, | ||
230 | LLInventoryType::EType inv_type, | ||
231 | const LLString& name, | ||
232 | const LLString& desc, | ||
233 | const LLSaleInfo& sale_info, | ||
234 | U32 flags, | ||
235 | S32 creation_date_utc); | ||
236 | LLInventoryItem(); | ||
237 | // Create a copy of an inventory item from a pointer to another item | ||
238 | // Note: Because InventoryItems are ref counted, reference copy (a = b) | ||
239 | // is prohibited | ||
240 | LLInventoryItem(const LLInventoryItem* other); | ||
241 | virtual void copy(const LLInventoryItem* other); // LLRefCount requires custom copy | ||
242 | |||
243 | // As a constructor alternative, the clone() method works like a | ||
244 | // copy constructor, but gens a new UUID. | ||
245 | // It is up to the caller to delete (unref) the item. | ||
246 | virtual void clone(LLPointer<LLInventoryItem>& newitem) const; | ||
247 | |||
248 | // accessors | ||
249 | const LLPermissions& getPermissions() const; | ||
250 | const LLUUID& getCreatorUUID() const; | ||
251 | const LLUUID& getAssetUUID() const; | ||
252 | const LLString& getDescription() const; | ||
253 | const LLSaleInfo& getSaleInfo() const; | ||
254 | LLInventoryType::EType getInventoryType() const; | ||
255 | U32 getFlags() const; | ||
256 | S32 getCreationDate() const; | ||
257 | U32 getCRC32() const; // really more of a checksum. | ||
258 | |||
259 | // mutators - will not call updateServer(), and will never fail | ||
260 | // (though it may correct to sane values) | ||
261 | void setAssetUUID(const LLUUID& asset_id); | ||
262 | void setDescription(const LLString& new_desc); | ||
263 | void setSaleInfo(const LLSaleInfo& sale_info); | ||
264 | void setPermissions(const LLPermissions& perm); | ||
265 | void setInventoryType(LLInventoryType::EType inv_type); | ||
266 | void setFlags(U32 flags); | ||
267 | void setCreationDate(S32 creation_date_utc); | ||
268 | |||
269 | // Put this inventory item onto the current outgoing mesage. It | ||
270 | // assumes you have already called nextBlock(). | ||
271 | virtual void packMessage(LLMessageSystem* msg) const; | ||
272 | |||
273 | // unpack returns TRUE if the inventory item came through the | ||
274 | // network ok. It uses a simple crc check which is defeatable, but | ||
275 | // we want to detect network mangling somehow. | ||
276 | virtual BOOL unpackMessage(LLMessageSystem* msg, const char* block, S32 block_num = 0); | ||
277 | |||
278 | // file support | ||
279 | virtual BOOL importFile(FILE* fp); | ||
280 | virtual BOOL exportFile(FILE* fp, BOOL include_asset_key = TRUE) const; | ||
281 | |||
282 | virtual BOOL importLegacyStream(std::istream& input_stream); | ||
283 | virtual BOOL exportLegacyStream(std::ostream& output_stream, BOOL include_asset_key = TRUE) const; | ||
284 | |||
285 | virtual LLXMLNode *exportFileXML(BOOL include_asset_key = TRUE) const; | ||
286 | BOOL importXML(LLXMLNode* node); | ||
287 | |||
288 | // helper functions | ||
289 | |||
290 | // pack all information needed to reconstruct this item into the given binary bucket. | ||
291 | // perm_override is optional | ||
292 | S32 packBinaryBucket(U8* bin_bucket, LLPermissions* perm_override = NULL) const; | ||
293 | void unpackBinaryBucket(U8* bin_bucket, S32 bin_bucket_size); | ||
294 | LLSD asLLSD() const; | ||
295 | bool fromLLSD(LLSD& sd); | ||
296 | |||
297 | }; | ||
298 | |||
299 | BOOL item_dictionary_sort(LLInventoryItem* a,LLInventoryItem* b); | ||
300 | BOOL item_date_sort(LLInventoryItem* a, LLInventoryItem* b); | ||
301 | |||
302 | |||
303 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
304 | // Class LLInventoryCategory | ||
305 | // | ||
306 | // An instance of this class represents a category of inventory | ||
307 | // items. Users come with a set of default categories, and can create | ||
308 | // new ones as needed. | ||
309 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
310 | |||
311 | class LLInventoryCategory : public LLInventoryObject | ||
312 | { | ||
313 | public: | ||
314 | typedef LLDynamicArray<LLPointer<LLInventoryCategory> > cat_array_t; | ||
315 | |||
316 | protected: | ||
317 | ~LLInventoryCategory(); | ||
318 | |||
319 | public: | ||
320 | MEM_TYPE_NEW(LLMemType::MTYPE_INVENTORY); | ||
321 | LLInventoryCategory(const LLUUID& uuid, const LLUUID& parent_uuid, | ||
322 | LLAssetType::EType preferred_type, | ||
323 | const LLString& name); | ||
324 | LLInventoryCategory(); | ||
325 | LLInventoryCategory(const LLInventoryCategory* other); | ||
326 | virtual void copy(const LLInventoryCategory* other); // LLRefCount requires custom copy | ||
327 | |||
328 | // accessors and mutators | ||
329 | LLAssetType::EType getPreferredType() const; | ||
330 | void setPreferredType(LLAssetType::EType type); | ||
331 | // For messaging system support | ||
332 | virtual void packMessage(LLMessageSystem* msg) const; | ||
333 | virtual void unpackMessage(LLMessageSystem* msg, const char* block, S32 block_num = 0); | ||
334 | |||
335 | // file support | ||
336 | virtual BOOL importFile(FILE* fp); | ||
337 | virtual BOOL exportFile(FILE* fp, BOOL include_asset_key = TRUE) const; | ||
338 | |||
339 | virtual BOOL importLegacyStream(std::istream& input_stream); | ||
340 | virtual BOOL exportLegacyStream(std::ostream& output_stream, BOOL include_asset_key = TRUE) const; | ||
341 | |||
342 | protected: | ||
343 | // The type of asset that this category was "meant" to hold | ||
344 | // (although it may in fact hold any type). | ||
345 | LLAssetType::EType mPreferredType; | ||
346 | |||
347 | }; | ||
348 | |||
349 | |||
350 | //----------------------------------------------------------------------------- | ||
351 | // Useful bits | ||
352 | //----------------------------------------------------------------------------- | ||
353 | |||
354 | // This functor tests if an item is transferrable and returns true if | ||
355 | // it is. Derived from unary_function<> so that the object can be used | ||
356 | // in stl-compliant adaptable predicates (eg, not1<>). You might want | ||
357 | // to use this in std::partition() or similar logic. | ||
358 | struct IsItemTransferable : public std::unary_function<LLInventoryItem*, bool> | ||
359 | { | ||
360 | LLUUID mDestID; | ||
361 | IsItemTransferable(const LLUUID& dest_id) : mDestID(dest_id) {} | ||
362 | bool operator()(const LLInventoryItem* item) const | ||
363 | { | ||
364 | return (item->getPermissions().allowTransferTo(mDestID)) ? true:false; | ||
365 | } | ||
366 | }; | ||
367 | |||
368 | // This functor is used to set the owner and group of inventory items, | ||
369 | // for example, in a simple std::for_each() loop. Note that the call | ||
370 | // to setOwnerAndGroup can fail if authority_id != LLUUID::null. | ||
371 | struct SetItemOwnerAndGroup | ||
372 | { | ||
373 | LLUUID mAuthorityID; | ||
374 | LLUUID mOwnerID; | ||
375 | LLUUID mGroupID; | ||
376 | SetItemOwnerAndGroup(const LLUUID& authority_id, | ||
377 | const LLUUID& owner_id, | ||
378 | const LLUUID& group_id) : | ||
379 | mAuthorityID(authority_id), mOwnerID(owner_id), mGroupID(group_id) {} | ||
380 | void operator()(LLInventoryItem* item) const | ||
381 | { | ||
382 | LLPermissions perm = item->getPermissions(); | ||
383 | bool is_atomic = (LLAssetType::AT_OBJECT == item->getType()) ? false : true; | ||
384 | perm.setOwnerAndGroup(mAuthorityID, mOwnerID, mGroupID, is_atomic); | ||
385 | item->setPermissions(perm); | ||
386 | } | ||
387 | }; | ||
388 | |||
389 | // This functor is used to unset the share with group, everyone perms, and | ||
390 | // for sale info for objects being sold through contents. | ||
391 | struct SetNotForSale | ||
392 | { | ||
393 | LLUUID mAgentID; | ||
394 | LLUUID mGroupID; | ||
395 | SetNotForSale(const LLUUID& agent_id, | ||
396 | const LLUUID& group_id) : | ||
397 | mAgentID(agent_id), mGroupID(group_id) {} | ||
398 | void operator()(LLInventoryItem* item) const | ||
399 | { | ||
400 | // Clear group & everyone permissions. | ||
401 | LLPermissions perm = item->getPermissions(); | ||
402 | perm.setGroupBits(mAgentID, mGroupID, FALSE, PERM_MODIFY | PERM_MOVE | PERM_COPY); | ||
403 | perm.setEveryoneBits(mAgentID, mGroupID, FALSE, PERM_MOVE | PERM_COPY); | ||
404 | item->setPermissions(perm); | ||
405 | |||
406 | // Mark group & everyone permissions for overwrite on the next | ||
407 | // rez if it is an object. | ||
408 | if(LLAssetType::AT_OBJECT == item->getType()) | ||
409 | { | ||
410 | U32 flags = item->getFlags(); | ||
411 | flags |= LLInventoryItem::II_FLAGS_OBJECT_PERM_OVERWRITE_GROUP; | ||
412 | flags |= LLInventoryItem::II_FLAGS_OBJECT_PERM_OVERWRITE_EVERYONE; | ||
413 | item->setFlags(flags); | ||
414 | } | ||
415 | |||
416 | // Clear for sale info. | ||
417 | item->setSaleInfo(LLSaleInfo::DEFAULT); | ||
418 | } | ||
419 | }; | ||
420 | |||
421 | typedef std::list<LLPointer<LLInventoryObject> > InventoryObjectList; | ||
422 | |||
423 | // These functions convert between structured data and an inventroy | ||
424 | // item, appropriate for serialization. | ||
425 | LLSD ll_create_sd_from_inventory_item(LLPointer<LLInventoryItem> item); | ||
426 | LLPointer<LLInventoryItem> ll_create_item_from_sd(const LLSD& sd_item); | ||
427 | LLSD ll_create_sd_from_inventory_category(LLPointer<LLInventoryCategory> cat); | ||
428 | LLPointer<LLInventoryCategory> ll_create_category_from_sd(const LLSD& sd_cat); | ||
429 | |||
430 | #endif // LL_LLINVENTORY_H | ||