* Refactor: Move the responsibility for applying physics and sending the initial client update to Scene.AddSceneObject() from some of the SceneObjectGroup constructors
* I think this has been done cleanly from inspection and testing, but if prim creation or load suddenly starts playing up more than usual, please open a mantis * This also has the effect of stopping the archiver generating ghost in-world prims * Some code dupliction also removed0.6.0-stable
							parent
							
								
									33d32355a1
								
							
						
					
					
						commit
						16d0a895cb
					
				|  | @ -45,7 +45,7 @@ namespace OpenSim.Region.Environment.Scenes | |||
|         { | ||||
|             XmlDocument doc = new XmlDocument(); | ||||
|             XmlNode rootNode; | ||||
|             int primCount = 0; | ||||
| 
 | ||||
|             if (fileName.StartsWith("http:") || File.Exists(fileName)) | ||||
|             { | ||||
|                 XmlTextReader reader = new XmlTextReader(fileName); | ||||
|  | @ -65,33 +65,6 @@ namespace OpenSim.Region.Environment.Scenes | |||
|                     //obj.RegenerateFullIDs(); | ||||
| 
 | ||||
|                     scene.AddSceneObject(obj, true); | ||||
| 
 | ||||
|                     SceneObjectPart rootPart = obj.GetChildPart(obj.UUID); | ||||
|                     // Apply loadOffsets for load/import and move combinations | ||||
|                     rootPart.GroupPosition = rootPart.AbsolutePosition + loadOffset; | ||||
|                     bool UsePhysics = (((rootPart.GetEffectiveObjectFlags() & (uint) LLObject.ObjectFlags.Physics) > 0) && | ||||
|                                        scene.m_physicalPrim); | ||||
|                     if ((rootPart.GetEffectiveObjectFlags() & (uint) LLObject.ObjectFlags.Phantom) == 0) | ||||
|                     { | ||||
|                         rootPart.PhysActor = scene.PhysicsScene.AddPrimShape( | ||||
|                             rootPart.Name, | ||||
|                             rootPart.Shape, | ||||
|                             new PhysicsVector(rootPart.AbsolutePosition.X + loadOffset.X, | ||||
|                                               rootPart.AbsolutePosition.Y + loadOffset.Y, | ||||
|                                               rootPart.AbsolutePosition.Z + loadOffset.Z), | ||||
|                             new PhysicsVector(rootPart.Scale.X, rootPart.Scale.Y, rootPart.Scale.Z), | ||||
|                             new Quaternion(rootPart.RotationOffset.W, rootPart.RotationOffset.X, | ||||
|                                            rootPart.RotationOffset.Y, rootPart.RotationOffset.Z), UsePhysics); | ||||
| 
 | ||||
|                         // to quote from SceneObjectPart: Basic | ||||
|                         // Physics returns null..  joy joy joy. | ||||
|                         if (rootPart.PhysActor != null) | ||||
|                         { | ||||
|                             rootPart.PhysActor.LocalID = rootPart.LocalId; | ||||
|                             rootPart.DoPhysicsPropertyUpdate(UsePhysics, true); | ||||
|                         } | ||||
|                     } | ||||
|                     primCount++; | ||||
|                 } | ||||
|             } | ||||
|             else | ||||
|  | @ -196,10 +169,6 @@ namespace OpenSim.Region.Environment.Scenes | |||
|             SceneObjectGroup obj = new SceneObjectGroup(xmlData); | ||||
| 
 | ||||
|             scene.AddSceneObjectFromStorage(obj); | ||||
| 
 | ||||
|             obj.ApplyPhysics(scene.m_physicalPrim); | ||||
| 
 | ||||
|             obj.ScheduleGroupForFullUpdate(); | ||||
|         } | ||||
| 
 | ||||
|         public static void SavePrimsToXml2(Scene scene, string fileName) | ||||
|  |  | |||
|  | @ -197,15 +197,16 @@ namespace OpenSim.Region.Environment.Scenes | |||
|             foreach (SceneObjectPart part in sceneObject.Children.Values) | ||||
|             { | ||||
|                 part.LocalId = m_parentScene.PrimIDAllocate(); | ||||
| 
 | ||||
|             } | ||||
|              | ||||
|             sceneObject.UpdateParentIDs(); | ||||
| 
 | ||||
|             AddSceneObject(sceneObject, true); | ||||
|         } | ||||
| 
 | ||||
|         /// <summary> | ||||
|         /// Add an object to the scene. | ||||
|         /// Add an object to the scene.  This will both update the scene, and send information about the | ||||
|         /// new object to all clients interested in the scene. | ||||
|         /// </summary> | ||||
|         /// <param name="sceneObject"></param> | ||||
|         /// <param name="attachToBackup"> | ||||
|  | @ -216,6 +217,9 @@ namespace OpenSim.Region.Environment.Scenes | |||
|         /// </returns> | ||||
|         protected internal bool AddSceneObject(SceneObjectGroup sceneObject, bool attachToBackup) | ||||
|         { | ||||
|             sceneObject.ApplyPhysics(m_parentScene.m_physicalPrim); | ||||
|             sceneObject.ScheduleGroupForFullUpdate(); | ||||
|              | ||||
|             lock (Entities) | ||||
|             { | ||||
|                 if (!Entities.ContainsKey(sceneObject.UUID)) | ||||
|  |  | |||
|  | @ -1499,7 +1499,7 @@ namespace OpenSim.Region.Environment.Scenes | |||
|                         { | ||||
|                             string xmlData = Helpers.FieldToUTF8String(rezAsset.Data); | ||||
|                             SceneObjectGroup group = new SceneObjectGroup(this, m_regionHandle, xmlData); | ||||
|                             if (!ExternalChecks.ExternalChecksCanRezObject(group.Children.Count,remoteClient.AgentId, pos) && !attachment) | ||||
|                             if (!ExternalChecks.ExternalChecksCanRezObject(group.Children.Count, remoteClient.AgentId, pos) && !attachment) | ||||
|                             { | ||||
|                                 return null; | ||||
|                             } | ||||
|  | @ -1513,8 +1513,8 @@ namespace OpenSim.Region.Environment.Scenes | |||
|                             if (!attachment) | ||||
|                             { | ||||
|                                 pos = GetNewRezLocation( | ||||
|                                             RayStart, RayEnd, RayTargetID, new LLQuaternion(0, 0, 0, 1), | ||||
|                                                BypassRayCast, bRayEndIsIntersection, true, group.GroupScale(), false); | ||||
|                                     RayStart, RayEnd, RayTargetID, new LLQuaternion(0, 0, 0, 1), | ||||
|                                     BypassRayCast, bRayEndIsIntersection, true, group.GroupScale(), false); | ||||
|                                 group.AbsolutePosition = pos; | ||||
|                             } | ||||
|                             else | ||||
|  |  | |||
|  | @ -1460,7 +1460,6 @@ namespace OpenSim.Region.Environment.Scenes | |||
|                 rootPart.ObjectFlags &= ~(uint)LLObject.ObjectFlags.Scripted; | ||||
|                 rootPart.TrimPermissions(); | ||||
|                 group.CheckSculptAndLoad(); | ||||
|                 group.ApplyPhysics(m_physicalPrim); | ||||
|                 //rootPart.DoPhysicsPropertyUpdate(UsePhysics, true); | ||||
|             } | ||||
| 
 | ||||
|  | @ -1578,9 +1577,12 @@ namespace OpenSim.Region.Environment.Scenes | |||
| 
 | ||||
|         public virtual SceneObjectGroup AddNewPrim(LLUUID ownerID, LLVector3 pos, LLQuaternion rot, PrimitiveBaseShape shape) | ||||
|         { | ||||
|             //m_log.DebugFormat( | ||||
|             //    "[SCENE]: Scene.AddNewPrim() called for agent {0} in {1}", ownerID, RegionInfo.RegionName); | ||||
|              | ||||
|             SceneObjectGroup sceneOb = | ||||
|                 new SceneObjectGroup(this, m_regionHandle, ownerID, PrimIDAllocate(), pos, rot, shape); | ||||
|             AddSceneObject(sceneOb, true); | ||||
|              | ||||
|             SceneObjectPart rootPart = sceneOb.GetChildPart(sceneOb.UUID); | ||||
|             // if grass or tree, make phantom | ||||
|             //rootPart.TrimPermissions(); | ||||
|  | @ -1591,9 +1593,8 @@ namespace OpenSim.Region.Environment.Scenes | |||
|                 if (rootPart.Shape.PCode != (byte)PCode.Grass) | ||||
|                     AdaptTree(ref shape); | ||||
|             } | ||||
|             // if not phantom, add to physics | ||||
|             sceneOb.ApplyPhysics(m_physicalPrim); | ||||
|             m_innerScene.AddToUpdateList(sceneOb); | ||||
| 
 | ||||
|             AddSceneObject(sceneOb, true); | ||||
| 
 | ||||
|             return sceneOb; | ||||
|         } | ||||
|  |  | |||
|  | @ -350,10 +350,6 @@ namespace OpenSim.Region.Environment.Scenes | |||
|             SetPartAsRoot(part); | ||||
| 
 | ||||
|             RegionHandle = regionHandle; | ||||
| 
 | ||||
|             ApplyPhysics(scene.m_physicalPrim); | ||||
| 
 | ||||
|             ScheduleGroupForFullUpdate(); | ||||
|         } | ||||
| 
 | ||||
|         /// <summary> | ||||
|  | @ -412,10 +408,6 @@ namespace OpenSim.Region.Environment.Scenes | |||
|             m_rootPart.ParentID = 0; | ||||
|             m_rootPart.RegionHandle = m_regionHandle; | ||||
|             UpdateParentIDs(); | ||||
| 
 | ||||
|             ApplyPhysics(scene.m_physicalPrim); | ||||
| 
 | ||||
|             ScheduleGroupForFullUpdate(); | ||||
|         } | ||||
| 
 | ||||
|         /// <summary> | ||||
|  | @ -854,7 +846,6 @@ namespace OpenSim.Region.Environment.Scenes | |||
|                     if (part.UUID != m_rootPart.UUID) | ||||
|                     { | ||||
|                         part.ParentID = m_rootPart.LocalId; | ||||
| 
 | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|  |  | |||
|  | @ -77,7 +77,6 @@ namespace OpenSim.Region.Examples.SimpleModule | |||
| 
 | ||||
|                 FileSystemObject fileObject = new FileSystemObject(m_scene, fileInfo, filePos); | ||||
|                 m_scene.AddSceneObject(fileObject, true); | ||||
|                 fileObject.ScheduleGroupForFullUpdate(); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Justin Clarke Casey
						Justin Clarke Casey