aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/CoreModules/World/Land
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/CoreModules/World/Land')
-rw-r--r--OpenSim/Region/CoreModules/World/Land/LandChannel.cs6
-rw-r--r--OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs71
2 files changed, 56 insertions, 21 deletions
diff --git a/OpenSim/Region/CoreModules/World/Land/LandChannel.cs b/OpenSim/Region/CoreModules/World/Land/LandChannel.cs
index 9e27ef0..7d990c2 100644
--- a/OpenSim/Region/CoreModules/World/Land/LandChannel.cs
+++ b/OpenSim/Region/CoreModules/World/Land/LandChannel.cs
@@ -116,6 +116,12 @@ namespace OpenSim.Region.CoreModules.World.Land
116 116
117 return new List<ILandObject>(); 117 return new List<ILandObject>();
118 } 118 }
119
120 public void Clear(bool setupDefaultParcel)
121 {
122 if (m_landManagementModule != null)
123 m_landManagementModule.Clear(setupDefaultParcel);
124 }
119 125
120 public List<ILandObject> ParcelsNearPoint(Vector3 position) 126 public List<ILandObject> ParcelsNearPoint(Vector3 position)
121 { 127 {
diff --git a/OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs b/OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs
index cb8c5de..a4e85d6 100644
--- a/OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs
+++ b/OpenSim/Region/CoreModules/World/Land/LandManagementModule.cs
@@ -306,13 +306,19 @@ namespace OpenSim.Region.CoreModules.World.Land
306 m_lastLandLocalID = LandChannel.START_LAND_LOCAL_ID - 1; 306 m_lastLandLocalID = LandChannel.START_LAND_LOCAL_ID - 1;
307 m_landIDList.Initialize(); 307 m_landIDList.Initialize();
308 } 308 }
309 309 }
310
311 /// <summary>
312 /// Create a default parcel that spans the entire region and is owned by the estate owner.
313 /// </summary>
314 /// <returns>The parcel created.</returns>
315 protected ILandObject CreateDefaultParcel()
316 {
310 ILandObject fullSimParcel = new LandObject(UUID.Zero, false, m_scene); 317 ILandObject fullSimParcel = new LandObject(UUID.Zero, false, m_scene);
311
312 fullSimParcel.SetLandBitmap(fullSimParcel.GetSquareLandBitmap(0, 0, (int)Constants.RegionSize, (int)Constants.RegionSize)); 318 fullSimParcel.SetLandBitmap(fullSimParcel.GetSquareLandBitmap(0, 0, (int)Constants.RegionSize, (int)Constants.RegionSize));
313 fullSimParcel.LandData.OwnerID = m_scene.RegionInfo.EstateSettings.EstateOwner; 319 fullSimParcel.LandData.OwnerID = m_scene.RegionInfo.EstateSettings.EstateOwner;
314 fullSimParcel.LandData.ClaimDate = Util.UnixTimeSinceEpoch(); 320 fullSimParcel.LandData.ClaimDate = Util.UnixTimeSinceEpoch();
315 AddLandObject(fullSimParcel); 321 return AddLandObject(fullSimParcel);
316 } 322 }
317 323
318 public List<ILandObject> AllParcels() 324 public List<ILandObject> AllParcels()
@@ -586,15 +592,6 @@ namespace OpenSim.Region.CoreModules.World.Land
586 } 592 }
587 593
588 /// <summary> 594 /// <summary>
589 /// Creates a basic Parcel object without an owner (a zeroed key)
590 /// </summary>
591 /// <returns></returns>
592 public ILandObject CreateBaseLand()
593 {
594 return new LandObject(UUID.Zero, false, m_scene);
595 }
596
597 /// <summary>
598 /// Adds a land object to the stored list and adds them to the landIDList to what they own 595 /// Adds a land object to the stored list and adds them to the landIDList to what they own
599 /// </summary> 596 /// </summary>
600 /// <param name="new_land">The land object being added</param> 597 /// <param name="new_land">The land object being added</param>
@@ -653,6 +650,28 @@ namespace OpenSim.Region.CoreModules.World.Land
653 m_landList.Remove(local_id); 650 m_landList.Remove(local_id);
654 } 651 }
655 } 652 }
653
654 /// <summary>
655 /// Clear the scene of all parcels
656 /// </summary>
657 public void Clear(bool setupDefaultParcel)
658 {
659 lock (m_landList)
660 {
661 foreach (ILandObject lo in m_landList.Values)
662 {
663 //m_scene.SimulationDataService.RemoveLandObject(lo.LandData.GlobalID);
664 m_scene.EventManager.TriggerLandObjectRemoved(lo.LandData.GlobalID);
665 }
666
667 m_landList.Clear();
668 }
669
670 ResetSimLandObjects();
671
672 if (setupDefaultParcel)
673 CreateDefaultParcel();
674 }
656 675
657 private void performFinalLandJoin(ILandObject master, ILandObject slave) 676 private void performFinalLandJoin(ILandObject master, ILandObject slave)
658 { 677 {
@@ -1323,7 +1342,6 @@ namespace OpenSim.Region.CoreModules.World.Land
1323 } 1342 }
1324 } 1343 }
1325 1344
1326
1327 void ClientOnParcelDeedToGroup(int parcelLocalID, UUID groupID, IClientAPI remote_client) 1345 void ClientOnParcelDeedToGroup(int parcelLocalID, UUID groupID, IClientAPI remote_client)
1328 { 1346 {
1329 ILandObject land; 1347 ILandObject land;
@@ -1342,7 +1360,6 @@ namespace OpenSim.Region.CoreModules.World.Land
1342 EventManagerOnParcelPrimCountTainted(); 1360 EventManagerOnParcelPrimCountTainted();
1343 } 1361 }
1344 1362
1345
1346 #region Land Object From Storage Functions 1363 #region Land Object From Storage Functions
1347 1364
1348 public void EventManagerOnIncomingLandDataFromStorage(List<LandData> data) 1365 public void EventManagerOnIncomingLandDataFromStorage(List<LandData> data)
@@ -1390,6 +1407,7 @@ namespace OpenSim.Region.CoreModules.World.Land
1390 public void EventManagerOnNoLandDataFromStorage() 1407 public void EventManagerOnNoLandDataFromStorage()
1391 { 1408 {
1392 ResetSimLandObjects(); 1409 ResetSimLandObjects();
1410 CreateDefaultParcel();
1393 } 1411 }
1394 1412
1395 #endregion 1413 #endregion
@@ -1963,14 +1981,24 @@ namespace OpenSim.Region.CoreModules.World.Land
1963 1981
1964 protected void InstallInterfaces() 1982 protected void InstallInterfaces()
1965 { 1983 {
1966 Command showCommand = 1984 Command clearCommand
1967 new Command("show", CommandIntentions.COMMAND_STATISTICAL, ShowParcelsCommand, "Shows all parcels on the current region."); 1985 = new Command("clear", CommandIntentions.COMMAND_HAZARDOUS, ClearCommand, "Clears all the parcels from the region.");
1986 Command showCommand
1987 = new Command("show", CommandIntentions.COMMAND_STATISTICAL, ShowParcelsCommand, "Shows all parcels on the region.");
1968 1988
1989 m_commander.RegisterCommand("clear", clearCommand);
1969 m_commander.RegisterCommand("show", showCommand); 1990 m_commander.RegisterCommand("show", showCommand);
1970 1991
1971 // Add this to our scene so scripts can call these functions 1992 // Add this to our scene so scripts can call these functions
1972 m_scene.RegisterModuleCommander(m_commander); 1993 m_scene.RegisterModuleCommander(m_commander);
1973 } 1994 }
1995
1996 protected void ClearCommand(Object[] args)
1997 {
1998 Clear(true);
1999
2000 MainConsole.Instance.OutputFormat("Cleared all parcels from {0}", m_scene.RegionInfo.RegionName);
2001 }
1974 2002
1975 protected void ShowParcelsCommand(Object[] args) 2003 protected void ShowParcelsCommand(Object[] args)
1976 { 2004 {
@@ -1978,8 +2006,9 @@ namespace OpenSim.Region.CoreModules.World.Land
1978 2006
1979 report.AppendFormat("Land information for {0}\n", m_scene.RegionInfo.RegionName); 2007 report.AppendFormat("Land information for {0}\n", m_scene.RegionInfo.RegionName);
1980 report.AppendFormat( 2008 report.AppendFormat(
1981 "{0,-20} {1,-9} {2,-18} {3,-18} {4,-20}\n", 2009 "{0,-20} {1,-10} {2,-9} {3,-18} {4,-18} {5,-20}\n",
1982 "Parcel Name", 2010 "Parcel Name",
2011 "Local ID",
1983 "Area", 2012 "Area",
1984 "Starts", 2013 "Starts",
1985 "Ends", 2014 "Ends",
@@ -1992,12 +2021,12 @@ namespace OpenSim.Region.CoreModules.World.Land
1992 LandData ld = lo.LandData; 2021 LandData ld = lo.LandData;
1993 2022
1994 report.AppendFormat( 2023 report.AppendFormat(
1995 "{0,-20} {1,-9} {2,-18} {3,-18} {4,-20}\n", 2024 "{0,-20} {1,-10} {2,-9} {3,-18} {4,-18} {5,-20}\n",
1996 ld.Name, ld.Area, lo.StartPoint, lo.EndPoint, m_userManager.GetUserName(ld.OwnerID)); 2025 ld.Name, ld.LocalID, ld.Area, lo.StartPoint, lo.EndPoint, m_userManager.GetUserName(ld.OwnerID));
1997 } 2026 }
1998 } 2027 }
1999 2028
2000 MainConsole.Instance.Output(report.ToString()); 2029 MainConsole.Instance.Output(report.ToString());
2001 } 2030 }
2002 } 2031 }
2003} 2032}