aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/Environment/Scenes/Scene.Inventory.cs')
-rw-r--r--OpenSim/Region/Environment/Scenes/Scene.Inventory.cs32
1 files changed, 30 insertions, 2 deletions
diff --git a/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs b/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs
index 765fafc..bf7bb7e 100644
--- a/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs
+++ b/OpenSim/Region/Environment/Scenes/Scene.Inventory.cs
@@ -189,7 +189,6 @@ namespace OpenSim.Region.Environment.Scenes
189 /// <param name="primLocalID"></param> 189 /// <param name="primLocalID"></param>
190 public void RequestTaskInventory(IClientAPI remoteClient, uint primLocalID) 190 public void RequestTaskInventory(IClientAPI remoteClient, uint primLocalID)
191 { 191 {
192
193 bool hasPrim = false; 192 bool hasPrim = false;
194 foreach (EntityBase ent in Entities.Values) 193 foreach (EntityBase ent in Entities.Values)
195 { 194 {
@@ -198,7 +197,11 @@ namespace OpenSim.Region.Environment.Scenes
198 hasPrim = ((SceneObjectGroup)ent).HasChildPrim(primLocalID); 197 hasPrim = ((SceneObjectGroup)ent).HasChildPrim(primLocalID);
199 if (hasPrim != false) 198 if (hasPrim != false)
200 { 199 {
201 ((SceneObjectGroup)ent).GetPartInventoryFileName(remoteClient, primLocalID); 200 bool fileChange = ((SceneObjectGroup)ent).GetPartInventoryFileName(remoteClient, primLocalID);
201 if (fileChange)
202 {
203 ((SceneObjectGroup)ent).RequestInventoryFile(primLocalID, xferManager);
204 }
202 break; 205 break;
203 } 206 }
204 } 207 }
@@ -216,6 +219,7 @@ namespace OpenSim.Region.Environment.Scenes
216 if (item != null) 219 if (item != null)
217 { 220 {
218 bool isTexture = false; 221 bool isTexture = false;
222 bool rezzed = false;
219 if (item.invType == 0) 223 if (item.invType == 0)
220 { 224 {
221 isTexture = true; 225 isTexture = true;
@@ -226,6 +230,7 @@ namespace OpenSim.Region.Environment.Scenes
226 string script = Util.FieldToString(rezAsset.Data); 230 string script = Util.FieldToString(rezAsset.Data);
227 //Console.WriteLine("rez script "+script); 231 //Console.WriteLine("rez script "+script);
228 this.EventManager.TriggerRezScript(localID, script); 232 this.EventManager.TriggerRezScript(localID, script);
233 rezzed = true;
229 } 234 }
230 else 235 else
231 { 236 {
@@ -236,8 +241,31 @@ namespace OpenSim.Region.Environment.Scenes
236 string script = Util.FieldToString(rezAsset.Data); 241 string script = Util.FieldToString(rezAsset.Data);
237 // Console.WriteLine("rez script " + script); 242 // Console.WriteLine("rez script " + script);
238 this.EventManager.TriggerRezScript(localID, script); 243 this.EventManager.TriggerRezScript(localID, script);
244 rezzed = true;
239 } 245 }
240 } 246 }
247
248 if (rezzed)
249 {
250 bool hasPrim = false;
251 foreach (EntityBase ent in Entities.Values)
252 {
253 if (ent is SceneObjectGroup)
254 {
255 hasPrim = ((SceneObjectGroup)ent).HasChildPrim(localID);
256 if (hasPrim != false)
257 {
258 bool added = ((SceneObjectGroup)ent).AddInventoryItem(remoteClient, localID, item);
259 if (added)
260 {
261 userInfo.DeleteItem(remoteClient.AgentId, item);
262 remoteClient.SendRemoveInventoryItem(itemID);
263 }
264 }
265 }
266 }
267
268 }
241 } 269 }
242 } 270 }
243 } 271 }