diff options
Diffstat (limited to 'linden/indra/llmessage/lltemplatemessagereader.cpp')
-rw-r--r-- | linden/indra/llmessage/lltemplatemessagereader.cpp | 151 |
1 files changed, 97 insertions, 54 deletions
diff --git a/linden/indra/llmessage/lltemplatemessagereader.cpp b/linden/indra/llmessage/lltemplatemessagereader.cpp index bb3f4f4..a1f5213 100644 --- a/linden/indra/llmessage/lltemplatemessagereader.cpp +++ b/linden/indra/llmessage/lltemplatemessagereader.cpp | |||
@@ -1,3 +1,31 @@ | |||
1 | /** | ||
2 | * @file lltemplatemessagereader.cpp | ||
3 | * @brief LLTemplateMessageReader class implementation. | ||
4 | * | ||
5 | * Copyright (c) 2007-2007, Linden Research, Inc. | ||
6 | * | ||
7 | * Second Life Viewer Source Code | ||
8 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
9 | * to you under the terms of the GNU General Public License, version 2.0 | ||
10 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
11 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
12 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
13 | * online at http://secondlife.com/developers/opensource/gplv2 | ||
14 | * | ||
15 | * There are special exceptions to the terms and conditions of the GPL as | ||
16 | * it is applied to this Source Code. View the full text of the exception | ||
17 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
18 | * online at http://secondlife.com/developers/opensource/flossexception | ||
19 | * | ||
20 | * By copying, modifying or distributing this software, you acknowledge | ||
21 | * that you have read and understood your obligations described above, | ||
22 | * and agree to abide by those obligations. | ||
23 | * | ||
24 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
25 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
26 | * COMPLETENESS OR PERFORMANCE. | ||
27 | */ | ||
28 | |||
1 | #include "lltemplatemessagereader.h" | 29 | #include "lltemplatemessagereader.h" |
2 | 30 | ||
3 | #include "llfasttimer.h" | 31 | #include "llfasttimer.h" |
@@ -53,7 +81,7 @@ void LLTemplateMessageReader::getData(const char *blockname, const char *varname | |||
53 | char *bnamep = (char *)blockname + blocknum; // this works because it's just a hash. The bnamep is never derefference | 81 | char *bnamep = (char *)blockname + blocknum; // this works because it's just a hash. The bnamep is never derefference |
54 | char *vnamep = (char *)varname; | 82 | char *vnamep = (char *)varname; |
55 | 83 | ||
56 | LLMsgData::msg_blk_data_map_t::iterator iter = mCurrentRMessageData->mMemberBlocks.find(bnamep); | 84 | LLMsgData::msg_blk_data_map_t::const_iterator iter = mCurrentRMessageData->mMemberBlocks.find(bnamep); |
57 | 85 | ||
58 | if (iter == mCurrentRMessageData->mMemberBlocks.end()) | 86 | if (iter == mCurrentRMessageData->mMemberBlocks.end()) |
59 | { | 87 | { |
@@ -135,7 +163,7 @@ S32 LLTemplateMessageReader::getNumberOfBlocks(const char *blockname) | |||
135 | 163 | ||
136 | char *bnamep = (char *)blockname; | 164 | char *bnamep = (char *)blockname; |
137 | 165 | ||
138 | LLMsgData::msg_blk_data_map_t::iterator iter = mCurrentRMessageData->mMemberBlocks.find(bnamep); | 166 | LLMsgData::msg_blk_data_map_t::const_iterator iter = mCurrentRMessageData->mMemberBlocks.find(bnamep); |
139 | 167 | ||
140 | if (iter == mCurrentRMessageData->mMemberBlocks.end()) | 168 | if (iter == mCurrentRMessageData->mMemberBlocks.end()) |
141 | { | 169 | { |
@@ -165,7 +193,7 @@ S32 LLTemplateMessageReader::getSize(const char *blockname, const char *varname) | |||
165 | 193 | ||
166 | char *bnamep = (char *)blockname; | 194 | char *bnamep = (char *)blockname; |
167 | 195 | ||
168 | LLMsgData::msg_blk_data_map_t::iterator iter = mCurrentRMessageData->mMemberBlocks.find(bnamep); | 196 | LLMsgData::msg_blk_data_map_t::const_iterator iter = mCurrentRMessageData->mMemberBlocks.find(bnamep); |
169 | 197 | ||
170 | if (iter == mCurrentRMessageData->mMemberBlocks.end()) | 198 | if (iter == mCurrentRMessageData->mMemberBlocks.end()) |
171 | { | 199 | { |
@@ -214,7 +242,7 @@ S32 LLTemplateMessageReader::getSize(const char *blockname, S32 blocknum, const | |||
214 | char *bnamep = (char *)blockname + blocknum; | 242 | char *bnamep = (char *)blockname + blocknum; |
215 | char *vnamep = (char *)varname; | 243 | char *vnamep = (char *)varname; |
216 | 244 | ||
217 | LLMsgData::msg_blk_data_map_t::iterator iter = mCurrentRMessageData->mMemberBlocks.find(bnamep); | 245 | LLMsgData::msg_blk_data_map_t::const_iterator iter = mCurrentRMessageData->mMemberBlocks.find(bnamep); |
218 | 246 | ||
219 | if (iter == mCurrentRMessageData->mMemberBlocks.end()) | 247 | if (iter == mCurrentRMessageData->mMemberBlocks.end()) |
220 | { | 248 | { |
@@ -497,16 +525,21 @@ BOOL LLTemplateMessageReader::decodeData(const U8* buffer, const LLHost& sender | |||
497 | llassert( !mCurrentRMessageData ); | 525 | llassert( !mCurrentRMessageData ); |
498 | delete mCurrentRMessageData; // just to make sure | 526 | delete mCurrentRMessageData; // just to make sure |
499 | 527 | ||
500 | S32 decode_pos = LL_PACKET_ID_SIZE + (S32)(mCurrentRMessageTemplate->mFrequency); | 528 | // The offset tells us how may bytes to skip after the end of the |
529 | // message name. | ||
530 | U8 offset = buffer[PHL_OFFSET]; | ||
531 | S32 decode_pos = LL_PACKET_ID_SIZE + (S32)(mCurrentRMessageTemplate->mFrequency) + offset; | ||
501 | 532 | ||
502 | // create base working data set | 533 | // create base working data set |
503 | mCurrentRMessageData = new LLMsgData(mCurrentRMessageTemplate->mName); | 534 | mCurrentRMessageData = new LLMsgData(mCurrentRMessageTemplate->mName); |
504 | 535 | ||
505 | // loop through the template building the data structure as we go | 536 | // loop through the template building the data structure as we go |
506 | for (LLMessageTemplate::message_block_map_t::iterator iter = mCurrentRMessageTemplate->mMemberBlocks.begin(); | 537 | LLMessageTemplate::message_block_map_t::const_iterator iter; |
507 | iter != mCurrentRMessageTemplate->mMemberBlocks.end(); iter++) | 538 | for(iter = mCurrentRMessageTemplate->mMemberBlocks.begin(); |
539 | iter != mCurrentRMessageTemplate->mMemberBlocks.end(); | ||
540 | ++iter) | ||
508 | { | 541 | { |
509 | LLMessageBlock* mbci = iter->second; | 542 | LLMessageBlock* mbci = *iter; |
510 | U8 repeat_number; | 543 | U8 repeat_number; |
511 | S32 i; | 544 | S32 i; |
512 | 545 | ||
@@ -528,11 +561,16 @@ BOOL LLTemplateMessageReader::decodeData(const U8* buffer, const LLHost& sender | |||
528 | // repeat number is a single byte | 561 | // repeat number is a single byte |
529 | if (decode_pos >= mReceiveSize) | 562 | if (decode_pos >= mReceiveSize) |
530 | { | 563 | { |
531 | logRanOffEndOfPacket( sender ); | 564 | logRanOffEndOfPacket(sender); |
532 | return FALSE; | 565 | |
566 | // default to 0 repeats | ||
567 | repeat_number = 0; | ||
568 | } | ||
569 | else | ||
570 | { | ||
571 | repeat_number = buffer[decode_pos]; | ||
572 | decode_pos++; | ||
533 | } | 573 | } |
534 | repeat_number = buffer[decode_pos]; | ||
535 | decode_pos++; | ||
536 | } | 574 | } |
537 | else | 575 | else |
538 | { | 576 | { |
@@ -561,10 +599,12 @@ BOOL LLTemplateMessageReader::decodeData(const U8* buffer, const LLHost& sender | |||
561 | mCurrentRMessageData->addBlock(cur_data_block); | 599 | mCurrentRMessageData->addBlock(cur_data_block); |
562 | 600 | ||
563 | // now read the variables | 601 | // now read the variables |
564 | for (LLMessageBlock::message_variable_map_t::iterator iter = mbci->mMemberVariables.begin(); | 602 | for (LLMessageBlock::message_variable_map_t::const_iterator iter = |
603 | mbci->mMemberVariables.begin(); | ||
565 | iter != mbci->mMemberVariables.end(); iter++) | 604 | iter != mbci->mMemberVariables.end(); iter++) |
566 | { | 605 | { |
567 | LLMessageVariable& mvci = *(iter->second); | 606 | const LLMessageVariable& mvci = **iter; |
607 | |||
568 | // ok, build out the variables | 608 | // ok, build out the variables |
569 | // add variable block | 609 | // add variable block |
570 | cur_data_block->addVariable(mvci.getName(), mvci.getType()); | 610 | cur_data_block->addVariable(mvci.getName(), mvci.getType()); |
@@ -580,34 +620,33 @@ BOOL LLTemplateMessageReader::decodeData(const U8* buffer, const LLHost& sender | |||
580 | 620 | ||
581 | if ((decode_pos + data_size) > mReceiveSize) | 621 | if ((decode_pos + data_size) > mReceiveSize) |
582 | { | 622 | { |
583 | logRanOffEndOfPacket( sender ); | 623 | logRanOffEndOfPacket(sender); |
584 | return FALSE; | 624 | |
625 | // default to 0 length variable blocks | ||
626 | tsize = 0; | ||
585 | } | 627 | } |
586 | switch(data_size) | 628 | else |
587 | { | 629 | { |
588 | case 1: | 630 | switch(data_size) |
589 | htonmemcpy(&tsizeb, &buffer[decode_pos], MVT_U8, 1); | 631 | { |
590 | tsize = tsizeb; | 632 | case 1: |
591 | break; | 633 | htonmemcpy(&tsizeb, &buffer[decode_pos], MVT_U8, 1); |
592 | case 2: | 634 | tsize = tsizeb; |
593 | htonmemcpy(&tsizeh, &buffer[decode_pos], MVT_U16, 2); | 635 | break; |
594 | tsize = tsizeh; | 636 | case 2: |
595 | break; | 637 | htonmemcpy(&tsizeh, &buffer[decode_pos], MVT_U16, 2); |
596 | case 4: | 638 | tsize = tsizeh; |
597 | htonmemcpy(&tsize, &buffer[decode_pos], MVT_U32, 4); | 639 | break; |
598 | break; | 640 | case 4: |
599 | default: | 641 | htonmemcpy(&tsize, &buffer[decode_pos], MVT_U32, 4); |
600 | llerrs << "Attempting to read variable field with unknown size of " << data_size << llendl; | 642 | break; |
601 | break; | 643 | default: |
602 | 644 | llerrs << "Attempting to read variable field with unknown size of " << data_size << llendl; | |
645 | break; | ||
646 | } | ||
603 | } | 647 | } |
604 | decode_pos += data_size; | 648 | decode_pos += data_size; |
605 | 649 | ||
606 | if ((decode_pos + (S32)tsize) > mReceiveSize) | ||
607 | { | ||
608 | logRanOffEndOfPacket( sender ); | ||
609 | return FALSE; | ||
610 | } | ||
611 | cur_data_block->addData(mvci.getName(), &buffer[decode_pos], tsize, mvci.getType()); | 650 | cur_data_block->addData(mvci.getName(), &buffer[decode_pos], tsize, mvci.getType()); |
612 | decode_pos += tsize; | 651 | decode_pos += tsize; |
613 | } | 652 | } |
@@ -615,14 +654,24 @@ BOOL LLTemplateMessageReader::decodeData(const U8* buffer, const LLHost& sender | |||
615 | { | 654 | { |
616 | // fixed! | 655 | // fixed! |
617 | // so, copy data pointer and set data size to fixed size | 656 | // so, copy data pointer and set data size to fixed size |
618 | |||
619 | if ((decode_pos + mvci.getSize()) > mReceiveSize) | 657 | if ((decode_pos + mvci.getSize()) > mReceiveSize) |
620 | { | 658 | { |
621 | logRanOffEndOfPacket( sender ); | 659 | logRanOffEndOfPacket(sender); |
622 | return FALSE; | 660 | |
661 | // default to 0s. | ||
662 | U32 size = mvci.getSize(); | ||
663 | std::vector<U8> data(size); | ||
664 | memset(&(data[0]), 0, size); | ||
665 | cur_data_block->addData(mvci.getName(), &(data[0]), | ||
666 | size, mvci.getType()); | ||
667 | } | ||
668 | else | ||
669 | { | ||
670 | cur_data_block->addData(mvci.getName(), | ||
671 | &buffer[decode_pos], | ||
672 | mvci.getSize(), | ||
673 | mvci.getType()); | ||
623 | } | 674 | } |
624 | |||
625 | cur_data_block->addData(mvci.getName(), &buffer[decode_pos], mvci.getSize(), mvci.getType()); | ||
626 | decode_pos += mvci.getSize(); | 675 | decode_pos += mvci.getSize(); |
627 | } | 676 | } |
628 | } | 677 | } |
@@ -644,11 +693,6 @@ BOOL LLTemplateMessageReader::decodeData(const U8* buffer, const LLHost& sender | |||
644 | decode_timer.reset(); | 693 | decode_timer.reset(); |
645 | } | 694 | } |
646 | 695 | ||
647 | // if( mCurrentRMessageTemplate->mName == _PREHASH_AgentToNewRegion ) | ||
648 | // { | ||
649 | // VTResume(); // VTune | ||
650 | // } | ||
651 | |||
652 | { | 696 | { |
653 | LLFastTimer t(LLFastTimer::FTM_PROCESS_MESSAGES); | 697 | LLFastTimer t(LLFastTimer::FTM_PROCESS_MESSAGES); |
654 | if( !mCurrentRMessageTemplate->callHandlerFunc(gMessageSystem) ) | 698 | if( !mCurrentRMessageTemplate->callHandlerFunc(gMessageSystem) ) |
@@ -657,11 +701,6 @@ BOOL LLTemplateMessageReader::decodeData(const U8* buffer, const LLHost& sender | |||
657 | } | 701 | } |
658 | } | 702 | } |
659 | 703 | ||
660 | // if( mCurrentRMessageTemplate->mName == _PREHASH_AgentToNewRegion ) | ||
661 | // { | ||
662 | // VTPause(); // VTune | ||
663 | // } | ||
664 | |||
665 | if(LLMessageReader::getTimeDecodes() || gMessageSystem->getTimingCallback()) | 704 | if(LLMessageReader::getTimeDecodes() || gMessageSystem->getTimingCallback()) |
666 | { | 705 | { |
667 | F32 decode_time = decode_timer.getElapsedTimeF32(); | 706 | F32 decode_time = decode_timer.getElapsedTimeF32(); |
@@ -723,8 +762,12 @@ BOOL LLTemplateMessageReader::readMessage(const U8* buffer, | |||
723 | //virtual | 762 | //virtual |
724 | const char* LLTemplateMessageReader::getMessageName() const | 763 | const char* LLTemplateMessageReader::getMessageName() const |
725 | { | 764 | { |
726 | static char empty_string[] = ""; | 765 | if (!mCurrentRMessageTemplate) |
727 | return mCurrentRMessageTemplate ? mCurrentRMessageTemplate->mName : empty_string; | 766 | { |
767 | llwarns << "no mCurrentRMessageTemplate" << llendl; | ||
768 | return ""; | ||
769 | } | ||
770 | return mCurrentRMessageTemplate->mName; | ||
728 | } | 771 | } |
729 | 772 | ||
730 | //virtual | 773 | //virtual |