diff options
Diffstat (limited to 'linden/indra/newview/llviewerregion.cpp')
-rw-r--r-- | linden/indra/newview/llviewerregion.cpp | 51 |
1 files changed, 42 insertions, 9 deletions
diff --git a/linden/indra/newview/llviewerregion.cpp b/linden/indra/newview/llviewerregion.cpp index f8b8f76..1cc6d42 100644 --- a/linden/indra/newview/llviewerregion.cpp +++ b/linden/indra/newview/llviewerregion.cpp | |||
@@ -64,6 +64,7 @@ | |||
64 | #include "llvocache.h" | 64 | #include "llvocache.h" |
65 | #include "llvoclouds.h" | 65 | #include "llvoclouds.h" |
66 | #include "llworld.h" | 66 | #include "llworld.h" |
67 | #include "llspatialpartition.h" | ||
67 | 68 | ||
68 | // Viewer object cache version, change if object update | 69 | // Viewer object cache version, change if object update |
69 | // format changes. JC | 70 | // format changes. JC |
@@ -97,7 +98,6 @@ LLViewerRegion::LLViewerRegion(const U64 &handle, | |||
97 | mBillableFactor(1.0), | 98 | mBillableFactor(1.0), |
98 | mMaxTasks(MAX_TASKS_PER_REGION), | 99 | mMaxTasks(MAX_TASKS_PER_REGION), |
99 | mCacheLoaded(FALSE), | 100 | mCacheLoaded(FALSE), |
100 | mCacheMap(), | ||
101 | mCacheEntriesCount(0), | 101 | mCacheEntriesCount(0), |
102 | mCacheID(), | 102 | mCacheID(), |
103 | mEventPoll(NULL) | 103 | mEventPoll(NULL) |
@@ -105,6 +105,7 @@ LLViewerRegion::LLViewerRegion(const U64 &handle, | |||
105 | mWidth = region_width_meters; | 105 | mWidth = region_width_meters; |
106 | 106 | ||
107 | mOriginGlobal = from_region_handle(handle); | 107 | mOriginGlobal = from_region_handle(handle); |
108 | updateRenderMatrix(); | ||
108 | 109 | ||
109 | mLandp = new LLSurface('l', NULL); | 110 | mLandp = new LLSurface('l', NULL); |
110 | if (!gNoRender) | 111 | if (!gNoRender) |
@@ -138,6 +139,19 @@ LLViewerRegion::LLViewerRegion(const U64 &handle, | |||
138 | 139 | ||
139 | mCacheStart.append(mCacheEnd); | 140 | mCacheStart.append(mCacheEnd); |
140 | 141 | ||
142 | //create object partitions | ||
143 | //MUST MATCH declaration of eObjectPartitions | ||
144 | mObjectPartition.push_back(new LLHUDPartition()); //PARTITION_HUD | ||
145 | mObjectPartition.push_back(new LLTerrainPartition()); //PARTITION_TERRAIN | ||
146 | mObjectPartition.push_back(new LLWaterPartition()); //PARTITION_WATER | ||
147 | mObjectPartition.push_back(new LLTreePartition()); //PARTITION_TREE | ||
148 | mObjectPartition.push_back(new LLParticlePartition()); //PARTITION_PARTICLE | ||
149 | mObjectPartition.push_back(new LLCloudPartition()); //PARTITION_CLOUD | ||
150 | mObjectPartition.push_back(new LLGrassPartition()); //PARTITION_GRASS | ||
151 | mObjectPartition.push_back(new LLVolumePartition()); //PARTITION_VOLUME | ||
152 | mObjectPartition.push_back(new LLBridgePartition()); //PARTITION_BRIDGE | ||
153 | mObjectPartition.push_back(NULL); //PARTITION_NONE | ||
154 | |||
141 | } | 155 | } |
142 | 156 | ||
143 | 157 | ||
@@ -176,6 +190,8 @@ LLViewerRegion::~LLViewerRegion() | |||
176 | LLHTTPSender::clearSender(mHost); | 190 | LLHTTPSender::clearSender(mHost); |
177 | 191 | ||
178 | saveCache(); | 192 | saveCache(); |
193 | |||
194 | std::for_each(mObjectPartition.begin(), mObjectPartition.end(), DeletePointer()); | ||
179 | } | 195 | } |
180 | 196 | ||
181 | 197 | ||
@@ -326,7 +342,7 @@ void LLViewerRegion::saveCache() | |||
326 | entry->writeToFile(fp); | 342 | entry->writeToFile(fp); |
327 | } | 343 | } |
328 | 344 | ||
329 | mCacheMap.removeAllData(); | 345 | mCacheMap.clear(); |
330 | mCacheEnd.unlink(); | 346 | mCacheEnd.unlink(); |
331 | mCacheEnd.init(); | 347 | mCacheEnd.init(); |
332 | mCacheStart.deleteAll(); | 348 | mCacheStart.deleteAll(); |
@@ -381,12 +397,17 @@ void LLViewerRegion::setRegionFlags(U32 flags) | |||
381 | void LLViewerRegion::setOriginGlobal(const LLVector3d &origin_global) | 397 | void LLViewerRegion::setOriginGlobal(const LLVector3d &origin_global) |
382 | { | 398 | { |
383 | mOriginGlobal = origin_global; | 399 | mOriginGlobal = origin_global; |
400 | updateRenderMatrix(); | ||
384 | mLandp->setOriginGlobal(origin_global); | 401 | mLandp->setOriginGlobal(origin_global); |
385 | mWind.setOriginGlobal(origin_global); | 402 | mWind.setOriginGlobal(origin_global); |
386 | mCloudLayer.setOriginGlobal(origin_global); | 403 | mCloudLayer.setOriginGlobal(origin_global); |
387 | calculateCenterGlobal(); | 404 | calculateCenterGlobal(); |
388 | } | 405 | } |
389 | 406 | ||
407 | void LLViewerRegion::updateRenderMatrix() | ||
408 | { | ||
409 | mRenderMatrix.setTranslation(getOriginAgent()); | ||
410 | } | ||
390 | 411 | ||
391 | void LLViewerRegion::setTimeDilation(F32 time_dilation) | 412 | void LLViewerRegion::setTimeDilation(F32 time_dilation) |
392 | { | 413 | { |
@@ -952,8 +973,7 @@ void LLViewerRegion::updateCoarseLocations(LLMessageSystem* msg) | |||
952 | // << " Z: " << (S32)(z_pos * 4) | 973 | // << " Z: " << (S32)(z_pos * 4) |
953 | // << llendl; | 974 | // << llendl; |
954 | 975 | ||
955 | // treat the target specially for the map, and don't add you | 976 | // treat the target specially for the map |
956 | // or the target | ||
957 | if(i == target_index) | 977 | if(i == target_index) |
958 | { | 978 | { |
959 | LLVector3d global_pos(mOriginGlobal); | 979 | LLVector3d global_pos(mOriginGlobal); |
@@ -962,7 +982,9 @@ void LLViewerRegion::updateCoarseLocations(LLMessageSystem* msg) | |||
962 | global_pos.mdV[VZ] += (F64)(z_pos) * 4.0; | 982 | global_pos.mdV[VZ] += (F64)(z_pos) * 4.0; |
963 | LLAvatarTracker::instance().setTrackedCoarseLocation(global_pos); | 983 | LLAvatarTracker::instance().setTrackedCoarseLocation(global_pos); |
964 | } | 984 | } |
965 | else if( i != agent_index) | 985 | |
986 | //don't add you | ||
987 | if( i != agent_index) | ||
966 | { | 988 | { |
967 | pos = 0x0; | 989 | pos = 0x0; |
968 | pos |= x_pos; | 990 | pos |= x_pos; |
@@ -990,7 +1012,7 @@ void LLViewerRegion::cacheFullUpdate(LLViewerObject* objectp, LLDataPackerBinary | |||
990 | U32 local_id = objectp->getLocalID(); | 1012 | U32 local_id = objectp->getLocalID(); |
991 | U32 crc = objectp->getCRC(); | 1013 | U32 crc = objectp->getCRC(); |
992 | 1014 | ||
993 | LLVOCacheEntry *entry = mCacheMap.getIfThere(local_id); | 1015 | LLVOCacheEntry* entry = get_if_there(mCacheMap, local_id, (LLVOCacheEntry*)NULL); |
994 | 1016 | ||
995 | if (entry) | 1017 | if (entry) |
996 | { | 1018 | { |
@@ -1003,7 +1025,7 @@ void LLViewerRegion::cacheFullUpdate(LLViewerObject* objectp, LLDataPackerBinary | |||
1003 | else | 1025 | else |
1004 | { | 1026 | { |
1005 | // Update the cache entry | 1027 | // Update the cache entry |
1006 | mCacheMap.removeData(local_id); | 1028 | mCacheMap.erase(local_id); |
1007 | delete entry; | 1029 | delete entry; |
1008 | entry = new LLVOCacheEntry(local_id, crc, dp); | 1030 | entry = new LLVOCacheEntry(local_id, crc, dp); |
1009 | mCacheEnd.insert(*entry); | 1031 | mCacheEnd.insert(*entry); |
@@ -1018,7 +1040,7 @@ void LLViewerRegion::cacheFullUpdate(LLViewerObject* objectp, LLDataPackerBinary | |||
1018 | if (mCacheEntriesCount > MAX_OBJECT_CACHE_ENTRIES) | 1040 | if (mCacheEntriesCount > MAX_OBJECT_CACHE_ENTRIES) |
1019 | { | 1041 | { |
1020 | entry = mCacheStart.getNext(); | 1042 | entry = mCacheStart.getNext(); |
1021 | mCacheMap.removeData(entry->getLocalID()); | 1043 | mCacheMap.erase(entry->getLocalID()); |
1022 | delete entry; | 1044 | delete entry; |
1023 | mCacheEntriesCount--; | 1045 | mCacheEntriesCount--; |
1024 | } | 1046 | } |
@@ -1037,7 +1059,7 @@ LLDataPacker *LLViewerRegion::getDP(U32 local_id, U32 crc) | |||
1037 | { | 1059 | { |
1038 | llassert(mCacheLoaded); | 1060 | llassert(mCacheLoaded); |
1039 | 1061 | ||
1040 | LLVOCacheEntry *entry = mCacheMap.getIfThere(local_id); | 1062 | LLVOCacheEntry* entry = get_if_there(mCacheMap, local_id, (LLVOCacheEntry*)NULL); |
1041 | 1063 | ||
1042 | if (entry) | 1064 | if (entry) |
1043 | { | 1065 | { |
@@ -1353,12 +1375,15 @@ void LLViewerRegion::setSeedCapability(const std::string& url) | |||
1353 | capabilityNames.append("ChatSessionRequest"); | 1375 | capabilityNames.append("ChatSessionRequest"); |
1354 | capabilityNames.append("CopyInventoryFromNotecard"); | 1376 | capabilityNames.append("CopyInventoryFromNotecard"); |
1355 | capabilityNames.append("DispatchRegionInfo"); | 1377 | capabilityNames.append("DispatchRegionInfo"); |
1378 | capabilityNames.append("EstateChangeInfo"); | ||
1356 | capabilityNames.append("EventQueueGet"); | 1379 | capabilityNames.append("EventQueueGet"); |
1380 | capabilityNames.append("FetchInventoryDescendents"); | ||
1357 | capabilityNames.append("GroupProposalBallot"); | 1381 | capabilityNames.append("GroupProposalBallot"); |
1358 | capabilityNames.append("MapLayer"); | 1382 | capabilityNames.append("MapLayer"); |
1359 | capabilityNames.append("MapLayerGod"); | 1383 | capabilityNames.append("MapLayerGod"); |
1360 | capabilityNames.append("NewFileAgentInventory"); | 1384 | capabilityNames.append("NewFileAgentInventory"); |
1361 | capabilityNames.append("ParcelGodReserveForNewbie"); | 1385 | capabilityNames.append("ParcelGodReserveForNewbie"); |
1386 | capabilityNames.append("ParcelPropertiesUpdate"); | ||
1362 | capabilityNames.append("ParcelVoiceInfoRequest"); | 1387 | capabilityNames.append("ParcelVoiceInfoRequest"); |
1363 | capabilityNames.append("ProvisionVoiceAccountRequest"); | 1388 | capabilityNames.append("ProvisionVoiceAccountRequest"); |
1364 | capabilityNames.append("RemoteParcelRequest"); | 1389 | capabilityNames.append("RemoteParcelRequest"); |
@@ -1429,4 +1454,12 @@ void LLViewerRegion::logActiveCapabilities() const | |||
1429 | llinfos << "Dumped " << count << " entries." << llendl; | 1454 | llinfos << "Dumped " << count << " entries." << llendl; |
1430 | } | 1455 | } |
1431 | 1456 | ||
1457 | LLSpatialPartition* LLViewerRegion::getSpatialPartition(U32 type) | ||
1458 | { | ||
1459 | if (type < mObjectPartition.size()) | ||
1460 | { | ||
1461 | return mObjectPartition[type]; | ||
1462 | } | ||
1463 | return NULL; | ||
1464 | } | ||
1432 | 1465 | ||