123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 |
- /**
- * @file llgesture.h
- * @brief A gesture is a combination of a triggering chat phrase or
- * key, a sound, an animation, and a chat string.
- *
- * $LicenseInfo:firstyear=2002&license=viewergpl$
- *
- * Copyright (c) 2002-2009, Linden Research, Inc.
- *
- * Second Life Viewer Source Code
- * The source code in this file ("Source Code") is provided by Linden Lab
- * to you under the terms of the GNU General Public License, version 2.0
- * ("GPL"), unless you have obtained a separate licensing agreement
- * ("Other License"), formally executed by you and Linden Lab. Terms of
- * the GPL can be found in doc/GPL-license.txt in this distribution, or
- * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2
- *
- * There are special exceptions to the terms and conditions of the GPL as
- * it is applied to this Source Code. View the full text of the exception
- * in the file doc/FLOSS-exception.txt in this software distribution, or
- * online at
- * http://secondlifegrid.net/programs/open_source/licensing/flossexception
- *
- * By copying, modifying or distributing this software, you acknowledge
- * that you have read and understood your obligations described above,
- * and agree to abide by those obligations.
- *
- * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
- * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
- * COMPLETENESS OR PERFORMANCE.
- * $/LicenseInfo$
- */
- #ifndef LL_LLGESTURE_H
- #define LL_LLGESTURE_H
- #include <vector>
- #include "llanimationstates.h"
- #include "llstring.h"
- #include "lluuid.h"
- class LLGesture
- {
- protected:
- LOG_CLASS(LLGesture);
- public:
- LLGesture();
- LLGesture(KEY key, MASK mask, const std::string& trigger,
- const LLUUID& sound_item_id, const std::string& animation,
- const std::string& output_string);
- LLGesture(U8** buffer, S32 max_size); // Deserializes, advances buffer
- LLGesture(const LLGesture& gesture);
- const LLGesture& operator=(const LLGesture& rhs);
- virtual ~LLGesture() = default;
- // Accessors
- LL_INLINE KEY getKey() const { return mKey; }
- LL_INLINE MASK getMask() const { return mMask; }
- LL_INLINE const std::string& getTrigger() const { return mTrigger; }
- LL_INLINE const LLUUID& getSound() const { return mSoundItemID; }
- LL_INLINE const std::string& getAnimation() const { return mAnimation; }
- LL_INLINE const std::string& getOutputString() const { return mOutputString; }
- // Triggers if a key/mask matches it
- virtual bool trigger(KEY key, MASK mask);
- // Triggers if case-insensitive substring matches (assumes string is
- // lowercase)
- virtual bool trigger(const std::string& string);
- // Non-endian-neutral serialization
- U8* serialize(U8* buffer) const;
- U8* deserialize(U8* buffer, S32 max_size);
- static S32 getMaxSerialSize();
- protected:
- KEY mKey; // usually a function key
- MASK mMask; // usually MASK_NONE, or MASK_SHIFT
- std::string mTrigger; // string, no whitespace allowed
- std::string mTriggerLower; // lowercase version of mTrigger
- LLUUID mSoundItemID; // ItemID of sound to play, LLUUID::null if none
- std::string mAnimation; // canonical name of animation or face animation
- std::string mOutputString; // string to say
- // For allocating serialization buffers; need to be updated when members
- // change
- static constexpr S32 MAX_SERIAL_SIZE = sizeof(KEY) + sizeof(MASK) +
- 16 + 26 + 41 + 41;
- };
- class LLGestureList
- {
- protected:
- LOG_CLASS(LLGestureList);
- public:
- LLGestureList();
- virtual ~LLGestureList();
- // Triggers if a key/mask matches one in the list
- bool trigger(KEY key, MASK mask);
- // Triggers if substring matches and generates revised string.
- bool triggerAndReviseString(const std::string& string,
- std::string* revised_string);
- // Used for construction from UI
- LL_INLINE S32 count() const { return mList.size(); }
- virtual LLGesture* get(S32 i) const { return mList[i]; }
- virtual void put(LLGesture* gesture) { mList.push_back(gesture); }
- void deleteAll();
- // non-endian-neutral serialization
- U8* serialize(U8* buffer) const;
- U8* deserialize(U8* buffer, S32 max_size);
- S32 getMaxSerialSize();
- protected:
- // overridden by child class to use local LLGesture implementation
- virtual LLGesture *create_gesture(U8** buffer, S32 max_size);
- protected:
- std::vector<LLGesture*> mList;
- // For allocating serialization buffers; need to be updated when members
- // change
- static constexpr S32 SERIAL_HEADER_SIZE = sizeof(S32);
- };
- #endif
|