diff options
Diffstat (limited to 'OpenSim/Region/Environment/Modules/World')
-rw-r--r-- | OpenSim/Region/Environment/Modules/World/Land/LandManagementModule.cs | 5 | ||||
-rw-r--r-- | OpenSim/Region/Environment/Modules/World/Land/LandObject.cs | 67 |
2 files changed, 57 insertions, 15 deletions
diff --git a/OpenSim/Region/Environment/Modules/World/Land/LandManagementModule.cs b/OpenSim/Region/Environment/Modules/World/Land/LandManagementModule.cs index f656fb6..99128bc 100644 --- a/OpenSim/Region/Environment/Modules/World/Land/LandManagementModule.cs +++ b/OpenSim/Region/Environment/Modules/World/Land/LandManagementModule.cs | |||
@@ -1149,10 +1149,7 @@ namespace OpenSim.Region.Environment.Modules.World.Land | |||
1149 | 1149 | ||
1150 | if (selectedParcel == null) return; | 1150 | if (selectedParcel == null) return; |
1151 | 1151 | ||
1152 | if (returnType == 16) // parcel return | 1152 | selectedParcel.returnLandObjects(returnType, agentIDs, taskIDs, remoteClient); |
1153 | { | ||
1154 | selectedParcel.returnLandObjects(returnType, agentIDs, remoteClient); | ||
1155 | } | ||
1156 | } | 1153 | } |
1157 | 1154 | ||
1158 | public void NoLandDataFromStorage() | 1155 | public void NoLandDataFromStorage() |
diff --git a/OpenSim/Region/Environment/Modules/World/Land/LandObject.cs b/OpenSim/Region/Environment/Modules/World/Land/LandObject.cs index 208338f..1483118 100644 --- a/OpenSim/Region/Environment/Modules/World/Land/LandObject.cs +++ b/OpenSim/Region/Environment/Modules/World/Land/LandObject.cs | |||
@@ -776,28 +776,73 @@ namespace OpenSim.Region.Environment.Modules.World.Land | |||
776 | m_scene.returnObjects(objs, obj.OwnerID); | 776 | m_scene.returnObjects(objs, obj.OwnerID); |
777 | } | 777 | } |
778 | 778 | ||
779 | public void returnLandObjects(uint type, UUID[] owners, IClientAPI remote_client) | 779 | public void returnLandObjects(uint type, UUID[] owners, UUID[] tasks, IClientAPI remote_client) |
780 | { | 780 | { |
781 | List<SceneObjectGroup> objlist = new List<SceneObjectGroup>(); | 781 | Dictionary<UUID,List<SceneObjectGroup>> returns = |
782 | for (int i = 0; i < owners.Length; i++) | 782 | new Dictionary<UUID,List<SceneObjectGroup>>(); |
783 | |||
784 | lock (primsOverMe) | ||
783 | { | 785 | { |
784 | lock (primsOverMe) | 786 | if (type == (uint)ObjectReturnType.Owner) |
785 | { | 787 | { |
786 | try | 788 | foreach (SceneObjectGroup obj in primsOverMe) |
787 | { | 789 | { |
788 | foreach (SceneObjectGroup obj in primsOverMe) | 790 | if (obj.OwnerID == m_landData.OwnerID) |
789 | { | 791 | { |
790 | if (obj.OwnerID == owners[i]) | 792 | if (!returns.ContainsKey(obj.OwnerID)) |
791 | objlist.Add(obj); | 793 | returns[obj.OwnerID] = |
794 | new List<SceneObjectGroup>(); | ||
795 | returns[obj.OwnerID].Add(obj); | ||
792 | } | 796 | } |
793 | } | 797 | } |
794 | catch (InvalidOperationException) | 798 | } |
799 | else if (type == (uint)ObjectReturnType.Group && m_landData.GroupID != UUID.Zero) | ||
800 | { | ||
801 | foreach (SceneObjectGroup obj in primsOverMe) | ||
802 | { | ||
803 | if (obj.GroupID == m_landData.GroupID) | ||
804 | { | ||
805 | if (!returns.ContainsKey(obj.OwnerID)) | ||
806 | returns[obj.OwnerID] = | ||
807 | new List<SceneObjectGroup>(); | ||
808 | returns[obj.OwnerID].Add(obj); | ||
809 | } | ||
810 | } | ||
811 | } | ||
812 | else if (type == (uint)ObjectReturnType.Other) | ||
813 | { | ||
814 | foreach (SceneObjectGroup obj in primsOverMe) | ||
815 | { | ||
816 | if (obj.OwnerID != m_landData.OwnerID && | ||
817 | (obj.GroupID != m_landData.GroupID || | ||
818 | m_landData.GroupID == UUID.Zero)) | ||
819 | { | ||
820 | if (!returns.ContainsKey(obj.OwnerID)) | ||
821 | returns[obj.OwnerID] = | ||
822 | new List<SceneObjectGroup>(); | ||
823 | returns[obj.OwnerID].Add(obj); | ||
824 | } | ||
825 | } | ||
826 | } | ||
827 | else if (type == (uint)ObjectReturnType.List) | ||
828 | { | ||
829 | List<UUID> ownerlist = new List<UUID>(owners); | ||
830 | |||
831 | foreach (SceneObjectGroup obj in primsOverMe) | ||
795 | { | 832 | { |
796 | m_log.Info("[PARCEL]: Unable to figure out all the objects owned by " + owners[i].ToString() + " arr."); | 833 | if (ownerlist.Contains(obj.OwnerID)) |
834 | { | ||
835 | if (!returns.ContainsKey(obj.OwnerID)) | ||
836 | returns[obj.OwnerID] = | ||
837 | new List<SceneObjectGroup>(); | ||
838 | returns[obj.OwnerID].Add(obj); | ||
839 | } | ||
797 | } | 840 | } |
798 | } | 841 | } |
799 | } | 842 | } |
800 | m_scene.returnObjects(objlist.ToArray(), remote_client.AgentId); | 843 | |
844 | foreach (List<SceneObjectGroup> ol in returns.Values) | ||
845 | m_scene.returnObjects(ol.ToArray(), remote_client.AgentId); | ||
801 | } | 846 | } |
802 | 847 | ||
803 | #endregion | 848 | #endregion |