123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251 |
- /**
- * @file llmessagetemplate.cpp
- * @brief Implementation of message template classes.
- *
- * $LicenseInfo:firstyear=2007&license=viewergpl$
- *
- * Copyright (c) 2007-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$
- */
- #include "linden_common.h"
- #include "llmessagetemplate.h"
- #include "llmessage.h"
- void LLMsgVarData::addData(const void* data, S32 size, EMsgVariableType type,
- S32 data_size)
- {
- mSize = size;
- mDataSize = data_size;
- if (type != MVT_VARIABLE && type != MVT_FIXED && mType != MVT_VARIABLE &&
- mType != MVT_FIXED)
- {
- if (mType != type)
- {
- llwarns << "Type mismatch for " << mName << " - Expected type: "
- << variableTypeToString(mType) << " - Passed type: "
- << variableTypeToString(type) << llendl;
- }
- }
- if (size)
- {
- delete[] mData; // Delete it if it already exists
- mData = new U8[size];
- htonmemcpy(mData, data, mType, size);
- }
- }
- void LLMsgData::addDataFast(char* blockname, char* varname, const void* data,
- S32 size, EMsgVariableType type, S32 data_size)
- {
- // remember that if the blocknumber is > 0 then the number is appended to
- // the name
- char* namep = (char*)blockname;
- LLMsgBlkData* block_data = mMemberBlocks[namep];
- if (block_data->mBlockNumber)
- {
- namep += block_data->mBlockNumber;
- block_data->addData(varname, data, size, type, data_size);
- }
- else
- {
- block_data->addData(varname, data, size, type, data_size);
- }
- }
- //static
- std::string LLMsgVarData::variableTypeToString(EMsgVariableType type)
- {
- #define RTNENUM(E) case E: return #E
- switch (type)
- {
- RTNENUM(MVT_NULL);
- RTNENUM(MVT_FIXED);
- RTNENUM(MVT_VARIABLE);
- RTNENUM(MVT_U8);
- RTNENUM(MVT_U16);
- RTNENUM(MVT_U32);
- RTNENUM(MVT_U64);
- RTNENUM(MVT_S8);
- RTNENUM(MVT_S16);
- RTNENUM(MVT_S32);
- RTNENUM(MVT_S64);
- RTNENUM(MVT_F32);
- RTNENUM(MVT_F64);
- RTNENUM(MVT_LLVector3);
- RTNENUM(MVT_LLVector3d);
- RTNENUM(MVT_LLVector4);
- RTNENUM(MVT_LLQuaternion);
- RTNENUM(MVT_LLUUID);
- RTNENUM(MVT_BOOL);
- RTNENUM(MVT_IP_ADDR);
- RTNENUM(MVT_IP_PORT);
- RTNENUM(MVT_U16Vec3);
- RTNENUM(MVT_U16Quat);
- RTNENUM(MVT_S16Array);
- default:
- return llformat("%d", (S32)type);
- }
- #undef RTNENUM
- }
- // LLMessageVariable functions and friends
- std::ostream& operator<<(std::ostream& s, LLMessageVariable& msg)
- {
- s << "\t\t" << msg.mName << " (";
- switch (msg.mType)
- {
- case MVT_FIXED:
- s << "Fixed, " << msg.mSize << " bytes total)\n";
- break;
- case MVT_VARIABLE:
- s << "Variable, " << msg.mSize << " bytes of size info)\n";
- break;
- default:
- s << "Unknown\n";
- break;
- }
- return s;
- }
- // LLMessageBlock functions and friends
- std::ostream& operator<<(std::ostream& s, LLMessageBlock& msg)
- {
- s << "\t" << msg.mName << " (";
- switch (msg.mType)
- {
- case MBT_SINGLE:
- s << "Fixed";
- break;
- case MBT_MULTIPLE:
- s << "Multiple - " << msg.mNumber << " copies";
- break;
- case MBT_VARIABLE:
- s << "Variable";
- break;
- default:
- s << "Unknown";
- break;
- }
- if (msg.mTotalSize != -1)
- {
- s << ", " << msg.mTotalSize << " bytes each, "
- << msg.mNumber * msg.mTotalSize << " bytes total)\n";
- }
- else
- {
- s << ")\n";
- }
- for (LLMessageBlock::message_variable_map_t::iterator
- iter = msg.mMemberVariables.begin(),
- end = msg.mMemberVariables.end();
- iter != end; ++iter)
- {
- LLMessageVariable& ci = *(*iter);
- s << ci;
- }
- return s;
- }
- // LLMessageTemplate functions and friends
- std::ostream& operator<<(std::ostream& s, LLMessageTemplate& msg)
- {
- switch (msg.mFrequency)
- {
- case MFT_HIGH:
- s << "========================================\n" << "Message #"
- << msg.mMessageNumber << "\n" << msg.mName << " (";
- s << "High";
- break;
- case MFT_MEDIUM:
- s << "========================================\n" << "Message #";
- s << (msg.mMessageNumber & 0xFF) << "\n" << msg.mName << " (";
- s << "Medium";
- break;
- case MFT_LOW:
- s << "========================================\n" << "Message #";
- s << (msg.mMessageNumber & 0xFFFF) << "\n" << msg.mName << " (";
- s << "Low";
- break;
- default:
- s << "Unknown";
- break;
- }
- if (msg.mTotalSize != -1)
- {
- s << ", " << msg.mTotalSize << " bytes total)\n";
- }
- else
- {
- s << ")\n";
- }
- for (LLMessageTemplate::message_block_map_t::iterator
- iter = msg.mMemberBlocks.begin(), end = msg.mMemberBlocks.end();
- iter != end; ++iter)
- {
- LLMessageBlock* ci = *iter;
- s << *ci;
- }
- return s;
- }
- void LLMessageTemplate::banUdp()
- {
- static const char* deprecation[] = {
- "NotDeprecated",
- "Deprecated",
- "UDPDeprecated",
- "UDPBlackListed"
- };
- if (mDeprecation != MD_DEPRECATED)
- {
- llinfos << "Setting " << mName << " to UDPBlackListed was "
- << deprecation[mDeprecation] << llendl;
- mDeprecation = MD_UDPBLACKLISTED;
- }
- else
- {
- llinfos << mName << " is already more deprecated than UDPBlackListed"
- << llendl;
- }
- }
|