aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llworld.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llworld.cpp')
-rw-r--r--linden/indra/newview/llworld.cpp101
1 files changed, 58 insertions, 43 deletions
diff --git a/linden/indra/newview/llworld.cpp b/linden/indra/newview/llworld.cpp
index 60312db..8c95260 100644
--- a/linden/indra/newview/llworld.cpp
+++ b/linden/indra/newview/llworld.cpp
@@ -61,7 +61,6 @@
61// 61//
62// Globals 62// Globals
63// 63//
64LLWorld* gWorldp = NULL;
65U32 gAgentPauseSerialNum = 0; 64U32 gAgentPauseSerialNum = 0;
66 65
67// 66//
@@ -72,15 +71,19 @@ const S32 WORLD_PATCH_SIZE = 16;
72 71
73extern LLColor4U MAX_WATER_COLOR; 72extern LLColor4U MAX_WATER_COLOR;
74 73
74const U32 LLWorld::mWidth = 256;
75
76// meters/point, therefore mWidth * mScale = meters per edge
77const F32 LLWorld::mScale = 1.f;
78
79const F32 LLWorld::mWidthInMeters = mWidth * mScale;
80
75// 81//
76// Functions 82// Functions
77// 83//
78 84
79// allocate the stack 85// allocate the stack
80LLWorld::LLWorld(const U32 grids_per_region, const F32 meters_per_grid) 86LLWorld::LLWorld()
81: mWidth(grids_per_region),
82 mScale(meters_per_grid),
83 mWidthInMeters( grids_per_region * meters_per_grid )
84{ 87{
85 mSpaceTimeUSec = 0; 88 mSpaceTimeUSec = 0;
86 mLastPacketsIn = 0; 89 mLastPacketsIn = 0;
@@ -112,10 +115,15 @@ LLWorld::LLWorld(const U32 grids_per_region, const F32 meters_per_grid)
112} 115}
113 116
114 117
115LLWorld::~LLWorld() 118void LLWorld::destroyClass()
116{ 119{
117 gObjectList.killAllObjects(); 120 gObjectList.destroy();
118 for_each(mRegionList.begin(), mRegionList.end(), DeletePointer()); 121 for(region_list_t::iterator region_it = mRegionList.begin(); region_it != mRegionList.end(); )
122 {
123 LLViewerRegion* region_to_delete = *region_it++;
124 removeRegion(region_to_delete->getHost());
125 }
126 LLViewerPartSim::getInstance()->destroyClass();
119} 127}
120 128
121 129
@@ -523,6 +531,11 @@ F32 LLWorld::resolveStepHeightGlobal(const LLVOAvatar* avatarp, const LLVector3d
523 intersection.mdV[VZ] -= norm_dist_from_plane * segment_length; 531 intersection.mdV[VZ] -= norm_dist_from_plane * segment_length;
524 intersection_normal = foot_plane_normal; 532 intersection_normal = foot_plane_normal;
525 } 533 }
534 else
535 {
536 intersection = land_intersection;
537 intersection_normal = resolveLandNormalGlobal(land_intersection);
538 }
526 } 539 }
527 540
528 return normalized_land_distance; 541 return normalized_land_distance;
@@ -556,9 +569,9 @@ LLVector3 LLWorld::resolveLandNormalGlobal(const LLVector3d &pos_global)
556 569
557void LLWorld::updateVisibilities() 570void LLWorld::updateVisibilities()
558{ 571{
559 F32 cur_far_clip = gCamera->getFar(); 572 F32 cur_far_clip = LLViewerCamera::getInstance()->getFar();
560 573
561 gCamera->setFar(mLandFarClip); 574 LLViewerCamera::getInstance()->setFar(mLandFarClip);
562 575
563 F32 diagonal_squared = F_SQRT2 * F_SQRT2 * mWidth * mWidth; 576 F32 diagonal_squared = F_SQRT2 * F_SQRT2 * mWidth * mWidth;
564 // Go through the culled list and check for visible regions 577 // Go through the culled list and check for visible regions
@@ -570,7 +583,7 @@ void LLWorld::updateVisibilities()
570 F32 height = regionp->getLand().getMaxZ() - regionp->getLand().getMinZ(); 583 F32 height = regionp->getLand().getMaxZ() - regionp->getLand().getMinZ();
571 F32 radius = 0.5f*fsqrtf(height * height + diagonal_squared); 584 F32 radius = 0.5f*fsqrtf(height * height + diagonal_squared);
572 if (!regionp->getLand().hasZData() 585 if (!regionp->getLand().hasZData()
573 || gCamera->sphereInFrustum(regionp->getCenterAgent(), radius)) 586 || LLViewerCamera::getInstance()->sphereInFrustum(regionp->getCenterAgent(), radius))
574 { 587 {
575 mCulledRegionList.erase(curiter); 588 mCulledRegionList.erase(curiter);
576 mVisibleRegionList.push_back(regionp); 589 mVisibleRegionList.push_back(regionp);
@@ -590,7 +603,7 @@ void LLWorld::updateVisibilities()
590 603
591 F32 height = regionp->getLand().getMaxZ() - regionp->getLand().getMinZ(); 604 F32 height = regionp->getLand().getMaxZ() - regionp->getLand().getMinZ();
592 F32 radius = 0.5f*fsqrtf(height * height + diagonal_squared); 605 F32 radius = 0.5f*fsqrtf(height * height + diagonal_squared);
593 if (gCamera->sphereInFrustum(regionp->getCenterAgent(), radius)) 606 if (LLViewerCamera::getInstance()->sphereInFrustum(regionp->getCenterAgent(), radius))
594 { 607 {
595 regionp->calculateCameraDistance(); 608 regionp->calculateCameraDistance();
596 if (!gNoRender) 609 if (!gNoRender)
@@ -608,7 +621,7 @@ void LLWorld::updateVisibilities()
608 // Sort visible regions 621 // Sort visible regions
609 mVisibleRegionList.sort(LLViewerRegion::CompareDistance()); 622 mVisibleRegionList.sort(LLViewerRegion::CompareDistance());
610 623
611 gCamera->setFar(cur_far_clip); 624 LLViewerCamera::getInstance()->setFar(cur_far_clip);
612} 625}
613 626
614void LLWorld::updateRegions(F32 max_update_time) 627void LLWorld::updateRegions(F32 max_update_time)
@@ -631,7 +644,7 @@ void LLWorld::updateRegions(F32 max_update_time)
631 644
632void LLWorld::updateParticles() 645void LLWorld::updateParticles()
633{ 646{
634 mPartSim.updateSimulation(); 647 LLViewerPartSim::getInstance()->updateSimulation();
635} 648}
636 649
637void LLWorld::updateClouds(const F32 dt) 650void LLWorld::updateClouds(const F32 dt)
@@ -727,19 +740,19 @@ void LLWorld::updateNetStats()
727 740
728 S32 actual_in_bits = gMessageSystem->mPacketRing.getAndResetActualInBits(); 741 S32 actual_in_bits = gMessageSystem->mPacketRing.getAndResetActualInBits();
729 S32 actual_out_bits = gMessageSystem->mPacketRing.getAndResetActualOutBits(); 742 S32 actual_out_bits = gMessageSystem->mPacketRing.getAndResetActualOutBits();
730 gViewerStats->mActualInKBitStat.addValue(actual_in_bits/1024.f); 743 LLViewerStats::getInstance()->mActualInKBitStat.addValue(actual_in_bits/1024.f);
731 gViewerStats->mActualOutKBitStat.addValue(actual_out_bits/1024.f); 744 LLViewerStats::getInstance()->mActualOutKBitStat.addValue(actual_out_bits/1024.f);
732 gViewerStats->mKBitStat.addValue(bits/1024.f); 745 LLViewerStats::getInstance()->mKBitStat.addValue(bits/1024.f);
733 gViewerStats->mPacketsInStat.addValue(packets_in); 746 LLViewerStats::getInstance()->mPacketsInStat.addValue(packets_in);
734 gViewerStats->mPacketsOutStat.addValue(packets_out); 747 LLViewerStats::getInstance()->mPacketsOutStat.addValue(packets_out);
735 gViewerStats->mPacketsLostStat.addValue(gMessageSystem->mDroppedPackets); 748 LLViewerStats::getInstance()->mPacketsLostStat.addValue(gMessageSystem->mDroppedPackets);
736 if (packets_in) 749 if (packets_in)
737 { 750 {
738 gViewerStats->mPacketsLostPercentStat.addValue(100.f*((F32)packets_lost/(F32)packets_in)); 751 LLViewerStats::getInstance()->mPacketsLostPercentStat.addValue(100.f*((F32)packets_lost/(F32)packets_in));
739 } 752 }
740 else 753 else
741 { 754 {
742 gViewerStats->mPacketsLostPercentStat.addValue(0.f); 755 LLViewerStats::getInstance()->mPacketsLostPercentStat.addValue(0.f);
743 } 756 }
744 757
745 mLastPacketsIn = gMessageSystem->mPacketsIn; 758 mLastPacketsIn = gMessageSystem->mPacketsIn;
@@ -771,8 +784,7 @@ void LLWorld::printPacketsLost()
771 784
772void LLWorld::processCoarseUpdate(LLMessageSystem* msg, void** user_data) 785void LLWorld::processCoarseUpdate(LLMessageSystem* msg, void** user_data)
773{ 786{
774 if(!gWorldp) return; 787 LLViewerRegion* region = LLWorld::getInstance()->getRegion(msg->getSender());
775 LLViewerRegion* region = gWorldp->getRegion(msg->getSender());
776 if( region ) 788 if( region )
777 { 789 {
778 region->updateCoarseLocations(msg); 790 region->updateCoarseLocations(msg);
@@ -812,7 +824,7 @@ void LLWorld::updateWaterObjects()
812 S32 rwidth = 256; 824 S32 rwidth = 256;
813 825
814 // We only want to fill in water for stuff that's near us, say, within 256 or 512m 826 // We only want to fill in water for stuff that's near us, say, within 256 or 512m
815 S32 range = gCamera->getFar() > 256.f ? 512 : 256; 827 S32 range = LLViewerCamera::getInstance()->getFar() > 256.f ? 512 : 256;
816 828
817 LLViewerRegion* regionp = gAgent.getRegion(); 829 LLViewerRegion* regionp = gAgent.getRegion();
818 from_region_handle(regionp->getHandle(), &region_x, &region_y); 830 from_region_handle(regionp->getHandle(), &region_x, &region_y);
@@ -940,7 +952,7 @@ void LLWorld::shiftRegions(const LLVector3& offset)
940 region->updateRenderMatrix(); 952 region->updateRenderMatrix();
941 } 953 }
942 954
943 mPartSim.shift(offset); 955 LLViewerPartSim::getInstance()->shift(offset);
944} 956}
945 957
946LLViewerImage* LLWorld::getDefaultWaterTexture() 958LLViewerImage* LLWorld::getDefaultWaterTexture()
@@ -1022,8 +1034,7 @@ void process_enable_simulator(LLMessageSystem *msg, void **user_data)
1022 1034
1023 // Viewer trusts the simulator. 1035 // Viewer trusts the simulator.
1024 msg->enableCircuit(sim, TRUE); 1036 msg->enableCircuit(sim, TRUE);
1025 if(!gWorldp) return; 1037 LLWorld::getInstance()->addRegion(handle, sim);
1026 gWorldp->addRegion(handle, sim);
1027 1038
1028 // give the simulator a message it can use to get ip and port 1039 // give the simulator a message it can use to get ip and port
1029 llinfos << "simulator_enable() Enabling " << sim << " with code " << msg->getOurCircuitCode() << llendl; 1040 llinfos << "simulator_enable() Enabling " << sim << " with code " << msg->getOurCircuitCode() << llendl;
@@ -1060,8 +1071,7 @@ public:
1060 1071
1061 LLHost sim(input["body"]["sim-ip-and-port"].asString()); 1072 LLHost sim(input["body"]["sim-ip-and-port"].asString());
1062 1073
1063 if(!gWorldp) return; 1074 LLViewerRegion* regionp = LLWorld::getInstance()->getRegion(sim);
1064 LLViewerRegion* regionp = gWorldp->getRegion(sim);
1065 if (!regionp) 1075 if (!regionp)
1066 { 1076 {
1067 llwarns << "Got EstablishAgentCommunication for unknown region " 1077 llwarns << "Got EstablishAgentCommunication for unknown region "
@@ -1079,8 +1089,7 @@ void process_disable_simulator(LLMessageSystem *mesgsys, void **user_data)
1079 LLHost host = mesgsys->getSender(); 1089 LLHost host = mesgsys->getSender();
1080 1090
1081 //llinfos << "Disabling simulator with message from " << host << llendl; 1091 //llinfos << "Disabling simulator with message from " << host << llendl;
1082 if(!gWorldp) return; 1092 LLWorld::getInstance()->removeRegion(host);
1083 gWorldp->removeRegion(host);
1084 1093
1085 mesgsys->disableCircuit(host); 1094 mesgsys->disableCircuit(host);
1086} 1095}
@@ -1089,8 +1098,7 @@ void process_disable_simulator(LLMessageSystem *mesgsys, void **user_data)
1089void process_region_handshake(LLMessageSystem* msg, void** user_data) 1098void process_region_handshake(LLMessageSystem* msg, void** user_data)
1090{ 1099{
1091 LLHost host = msg->getSender(); 1100 LLHost host = msg->getSender();
1092 if(!gWorldp) return; 1101 LLViewerRegion* regionp = LLWorld::getInstance()->getRegion(host);
1093 LLViewerRegion* regionp = gWorldp->getRegion(host);
1094 if (!regionp) 1102 if (!regionp)
1095 { 1103 {
1096 llwarns << "Got region handshake for unknown region " 1104 llwarns << "Got region handshake for unknown region "
@@ -1104,8 +1112,10 @@ void process_region_handshake(LLMessageSystem* msg, void** user_data)
1104 1112
1105void send_agent_pause() 1113void send_agent_pause()
1106{ 1114{
1107 // world not initialized yet 1115 // Note: used to check for LLWorld initialization before it became a singleton.
1108 if (!gWorldp) 1116 // Rather than just remove this check I'm changing it to assure that the message
1117 // system has been initialized. -MG
1118 if (!gMessageSystem)
1109 { 1119 {
1110 return; 1120 return;
1111 } 1121 }
@@ -1118,8 +1128,8 @@ void send_agent_pause()
1118 gAgentPauseSerialNum++; 1128 gAgentPauseSerialNum++;
1119 gMessageSystem->addU32Fast(_PREHASH_SerialNum, gAgentPauseSerialNum); 1129 gMessageSystem->addU32Fast(_PREHASH_SerialNum, gAgentPauseSerialNum);
1120 1130
1121 for (LLWorld::region_list_t::iterator iter = gWorldp->mActiveRegionList.begin(); 1131 for (LLWorld::region_list_t::iterator iter = LLWorld::getInstance()->mActiveRegionList.begin();
1122 iter != gWorldp->mActiveRegionList.end(); ++iter) 1132 iter != LLWorld::getInstance()->mActiveRegionList.end(); ++iter)
1123 { 1133 {
1124 LLViewerRegion* regionp = *iter; 1134 LLViewerRegion* regionp = *iter;
1125 gMessageSystem->sendReliable(regionp->getHost()); 1135 gMessageSystem->sendReliable(regionp->getHost());
@@ -1131,8 +1141,13 @@ void send_agent_pause()
1131 1141
1132void send_agent_resume() 1142void send_agent_resume()
1133{ 1143{
1134 // world not initialized yet 1144 // Note: used to check for LLWorld initialization before it became a singleton.
1135 if (!gWorldp) return; 1145 // Rather than just remove this check I'm changing it to assure that the message
1146 // system has been initialized. -MG
1147 if (!gMessageSystem)
1148 {
1149 return;
1150 }
1136 1151
1137 gMessageSystem->newMessageFast(_PREHASH_AgentResume); 1152 gMessageSystem->newMessageFast(_PREHASH_AgentResume);
1138 gMessageSystem->nextBlockFast(_PREHASH_AgentData); 1153 gMessageSystem->nextBlockFast(_PREHASH_AgentData);
@@ -1143,15 +1158,15 @@ void send_agent_resume()
1143 gMessageSystem->addU32Fast(_PREHASH_SerialNum, gAgentPauseSerialNum); 1158 gMessageSystem->addU32Fast(_PREHASH_SerialNum, gAgentPauseSerialNum);
1144 1159
1145 1160
1146 for (LLWorld::region_list_t::iterator iter = gWorldp->mActiveRegionList.begin(); 1161 for (LLWorld::region_list_t::iterator iter = LLWorld::getInstance()->mActiveRegionList.begin();
1147 iter != gWorldp->mActiveRegionList.end(); ++iter) 1162 iter != LLWorld::getInstance()->mActiveRegionList.end(); ++iter)
1148 { 1163 {
1149 LLViewerRegion* regionp = *iter; 1164 LLViewerRegion* regionp = *iter;
1150 gMessageSystem->sendReliable(regionp->getHost()); 1165 gMessageSystem->sendReliable(regionp->getHost());
1151 } 1166 }
1152 1167
1153 // Reset the FPS counter to avoid an invalid fps 1168 // Reset the FPS counter to avoid an invalid fps
1154 gViewerStats->mFPSStat.start(); 1169 LLViewerStats::getInstance()->mFPSStat.start();
1155} 1170}
1156 1171
1157 1172