From d845da215f8d30ef3f34a3c207fb892c815d1fac Mon Sep 17 00:00:00 2001 From: mingchen Date: Mon, 17 Dec 2007 03:49:13 +0000 Subject: *Land has now been linked to the StorageManager. Next step is to fill in the functions for the different datastore interfaces for Land Objects. --- OpenSim/Region/Environment/LandManagement/Land.cs | 69 ++++++++++++----------- 1 file changed, 36 insertions(+), 33 deletions(-) (limited to 'OpenSim/Region/Environment/LandManagement/Land.cs') diff --git a/OpenSim/Region/Environment/LandManagement/Land.cs b/OpenSim/Region/Environment/LandManagement/Land.cs index 45e8aac..3f60b1b 100644 --- a/OpenSim/Region/Environment/LandManagement/Land.cs +++ b/OpenSim/Region/Environment/LandManagement/Land.cs @@ -32,6 +32,7 @@ using libsecondlife; using libsecondlife.Packets; using OpenSim.Framework; using OpenSim.Region.Environment.Scenes; +using OpenSim.Region.Environment.Interfaces; namespace OpenSim.Region.Environment.LandManagement { @@ -47,7 +48,6 @@ namespace OpenSim.Region.Environment.LandManagement public LandData landData = new LandData(); public List primsOverMe = new List(); - public List parcelAccessList = new List(); public Scene m_scene; private bool[,] landBitmap = new bool[64,64]; @@ -93,21 +93,12 @@ namespace OpenSim.Region.Environment.LandManagement //Place all new variables here! newLand.landBitmap = (bool[,]) (landBitmap.Clone()); - newLand.parcelAccessList.Clear(); - foreach (ParcelManager.ParcelAccessEntry entry in parcelAccessList) - { - ParcelManager.ParcelAccessEntry newEntry = new ParcelManager.ParcelAccessEntry(); - newEntry.AgentID = entry.AgentID; - newEntry.Flags = entry.Flags; - newEntry.Time = entry.Time; - - newLand.parcelAccessList.Add(newEntry); - } newLand.landData = landData.Copy(); return newLand; } + #endregion #region Packet Request Handling @@ -209,24 +200,30 @@ namespace OpenSim.Region.Environment.LandManagement if (remote_client.AgentId == landData.ownerID) { //Needs later group support - landData.authBuyerID = packet.ParcelData.AuthBuyerID; - landData.category = (Parcel.ParcelCategory) packet.ParcelData.Category; - landData.landDesc = Helpers.FieldToUTF8String(packet.ParcelData.Desc); - landData.groupID = packet.ParcelData.GroupID; - landData.landingType = packet.ParcelData.LandingType; - landData.mediaAutoScale = packet.ParcelData.MediaAutoScale; - landData.mediaID = packet.ParcelData.MediaID; - landData.mediaURL = Helpers.FieldToUTF8String(packet.ParcelData.MediaURL); - landData.musicURL = Helpers.FieldToUTF8String(packet.ParcelData.MusicURL); - landData.landName = Helpers.FieldToUTF8String(packet.ParcelData.Name); - landData.landFlags = packet.ParcelData.ParcelFlags; - landData.passHours = packet.ParcelData.PassHours; - landData.passPrice = packet.ParcelData.PassPrice; - landData.salePrice = packet.ParcelData.SalePrice; - landData.snapshotID = packet.ParcelData.SnapshotID; - landData.userLocation = packet.ParcelData.UserLocation; - landData.userLookAt = packet.ParcelData.UserLookAt; + LandData newData = landData.Copy(); + newData.authBuyerID = packet.ParcelData.AuthBuyerID; + newData.category = (Parcel.ParcelCategory)packet.ParcelData.Category; + newData.landDesc = Helpers.FieldToUTF8String(packet.ParcelData.Desc); + newData.groupID = packet.ParcelData.GroupID; + newData.landingType = packet.ParcelData.LandingType; + newData.mediaAutoScale = packet.ParcelData.MediaAutoScale; + newData.mediaID = packet.ParcelData.MediaID; + newData.mediaURL = Helpers.FieldToUTF8String(packet.ParcelData.MediaURL); + newData.musicURL = Helpers.FieldToUTF8String(packet.ParcelData.MusicURL); + newData.landName = Helpers.FieldToUTF8String(packet.ParcelData.Name); + newData.landFlags = packet.ParcelData.ParcelFlags; + newData.passHours = packet.ParcelData.PassHours; + newData.passPrice = packet.ParcelData.PassPrice; + newData.salePrice = packet.ParcelData.SalePrice; + newData.snapshotID = packet.ParcelData.SnapshotID; + newData.userLocation = packet.ParcelData.UserLocation; + newData.userLookAt = packet.ParcelData.UserLookAt; + + m_scene.LandManager.updateLandObject(landData.localID, newData); + sendLandUpdateToAvatarsOverMe(); + + } } @@ -257,7 +254,7 @@ namespace OpenSim.Region.Environment.LandManagement public ParcelAccessListReplyPacket.ListBlock[] createAccessListArrayByFlag(ParcelManager.AccessList flag) { List list = new List(); - foreach (ParcelManager.ParcelAccessEntry entry in parcelAccessList) + foreach (ParcelManager.ParcelAccessEntry entry in landData.parcelAccessList) { if (entry.Flags == flag) { @@ -317,13 +314,15 @@ namespace OpenSim.Region.Environment.LandManagement public void updateAccessList(uint flags, List entries, IClientAPI remote_client) { + LandData newData = landData.Copy(); + if (entries.Count == 1 && entries[0].AgentID == LLUUID.Zero) { entries.Clear(); } List toRemove = new List(); - foreach (ParcelManager.ParcelAccessEntry entry in parcelAccessList) + foreach (ParcelManager.ParcelAccessEntry entry in newData.parcelAccessList) { if (entry.Flags == (ParcelManager.AccessList)flags) { @@ -333,7 +332,7 @@ namespace OpenSim.Region.Environment.LandManagement foreach (ParcelManager.ParcelAccessEntry entry in toRemove) { - parcelAccessList.Remove(entry); + newData.parcelAccessList.Remove(entry); } foreach (ParcelManager.ParcelAccessEntry entry in entries) { @@ -342,11 +341,14 @@ namespace OpenSim.Region.Environment.LandManagement temp.Time = new DateTime() ; //Pointless? Yes. temp.Flags = (ParcelManager.AccessList)flags; - if (!this.parcelAccessList.Contains(temp)) + if (!newData.parcelAccessList.Contains(temp)) { - this.parcelAccessList.Add(temp); + newData.parcelAccessList.Add(temp); } } + + m_scene.LandManager.updateLandObject(landData.localID, newData); + } #endregion @@ -385,6 +387,7 @@ namespace OpenSim.Region.Environment.LandManagement new LLVector3((float) (max_x*4), (float) (max_y*4), (float) m_scene.Terrain.GetHeight((max_x*4), (max_y*4))); landData.area = tempArea; + } public void updateLandBitmapByteArray() -- cgit v1.1