aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region')
-rw-r--r--OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs1
-rw-r--r--OpenSim/Region/CoreModules/Avatar/Inventory/Archiver/InventoryArchiverModule.cs3
-rwxr-xr-xOpenSim/Region/Framework/Scenes/SceneGraph.cs2
-rw-r--r--OpenSim/Region/Framework/Scenes/SceneObjectPart.cs97
-rw-r--r--OpenSim/Region/PhysicsModules/ubOdeMeshing/Meshmerizer.cs7
-rw-r--r--OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs11
-rwxr-xr-xOpenSim/Region/ScriptEngine/XEngine/XEngine.cs12
7 files changed, 60 insertions, 73 deletions
diff --git a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
index ad25bc8..17e4400 100644
--- a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
+++ b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
@@ -2920,7 +2920,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
2920 { 2920 {
2921 m_log.Error("Unable to send part Physics Proprieties - exception: " + ex.ToString()); 2921 m_log.Error("Unable to send part Physics Proprieties - exception: " + ex.ToString());
2922 } 2922 }
2923 part.UpdatePhysRequired = false;
2924 } 2923 }
2925 } 2924 }
2926 2925
diff --git a/OpenSim/Region/CoreModules/Avatar/Inventory/Archiver/InventoryArchiverModule.cs b/OpenSim/Region/CoreModules/Avatar/Inventory/Archiver/InventoryArchiverModule.cs
index 8d11d20..8847414 100644
--- a/OpenSim/Region/CoreModules/Avatar/Inventory/Archiver/InventoryArchiverModule.cs
+++ b/OpenSim/Region/CoreModules/Avatar/Inventory/Archiver/InventoryArchiverModule.cs
@@ -565,8 +565,6 @@ namespace OpenSim.Region.CoreModules.Avatar.Inventory.Archiver
565 return null; 565 return null;
566 } 566 }
567 567
568 return account;
569 /*
570 try 568 try
571 { 569 {
572 string encpass = Util.Md5Hash(pass); 570 string encpass = Util.Md5Hash(pass);
@@ -587,7 +585,6 @@ namespace OpenSim.Region.CoreModules.Avatar.Inventory.Archiver
587 m_log.ErrorFormat("[INVENTORY ARCHIVER]: Could not authenticate password, {0}", e); 585 m_log.ErrorFormat("[INVENTORY ARCHIVER]: Could not authenticate password, {0}", e);
588 return null; 586 return null;
589 } 587 }
590 */
591 } 588 }
592 589
593 /// <summary> 590 /// <summary>
diff --git a/OpenSim/Region/Framework/Scenes/SceneGraph.cs b/OpenSim/Region/Framework/Scenes/SceneGraph.cs
index 238ec8e..1141f54 100755
--- a/OpenSim/Region/Framework/Scenes/SceneGraph.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneGraph.cs
@@ -1660,7 +1660,7 @@ namespace OpenSim.Region.Framework.Scenes
1660 if (part != null) 1660 if (part != null)
1661 { 1661 {
1662 part.UpdateExtraPhysics(PhysData); 1662 part.UpdateExtraPhysics(PhysData);
1663 if (part.UpdatePhysRequired && remoteClient != null) 1663 if (remoteClient != null)
1664 remoteClient.SendPartPhysicsProprieties(part); 1664 remoteClient.SendPartPhysicsProprieties(part);
1665 } 1665 }
1666 } 1666 }
diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
index 06d767d..9d1dca2 100644
--- a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs
@@ -1222,7 +1222,6 @@ namespace OpenSim.Region.Framework.Scenes
1222 } 1222 }
1223 1223
1224 public UpdateRequired UpdateFlag { get; set; } 1224 public UpdateRequired UpdateFlag { get; set; }
1225 public bool UpdatePhysRequired { get; set; }
1226 1225
1227 /// <summary> 1226 /// <summary>
1228 /// Used for media on a prim. 1227 /// Used for media on a prim.
@@ -1637,7 +1636,6 @@ namespace OpenSim.Region.Framework.Scenes
1637 if(ParentGroup != null) 1636 if(ParentGroup != null)
1638 ParentGroup.HasGroupChanged = true; 1637 ParentGroup.HasGroupChanged = true;
1639 ScheduleFullUpdateIfNone(); 1638 ScheduleFullUpdateIfNone();
1640 UpdatePhysRequired = true;
1641 } 1639 }
1642 } 1640 }
1643 } 1641 }
@@ -1729,7 +1727,7 @@ namespace OpenSim.Region.Framework.Scenes
1729 set 1727 set
1730 { 1728 {
1731 byte oldv = m_physicsShapeType; 1729 byte oldv = m_physicsShapeType;
1732 1730
1733 if (value >= 0 && value <= (byte)PhysShapeType.convex) 1731 if (value >= 0 && value <= (byte)PhysShapeType.convex)
1734 { 1732 {
1735 if (value == (byte)PhysShapeType.none && ParentGroup != null && ParentGroup.RootPart == this) 1733 if (value == (byte)PhysShapeType.none && ParentGroup != null && ParentGroup.RootPart == this)
@@ -1748,28 +1746,21 @@ namespace OpenSim.Region.Framework.Scenes
1748 { 1746 {
1749 ParentGroup.Scene.RemovePhysicalPrim(1); 1747 ParentGroup.Scene.RemovePhysicalPrim(1);
1750 RemoveFromPhysics(); 1748 RemoveFromPhysics();
1751 Stop(); 1749// Stop();
1752 } 1750 }
1753 } 1751 }
1754 else if (PhysActor == null) 1752 else if (PhysActor == null)
1755 { 1753 {
1756 ApplyPhysics((uint)Flags, VolumeDetectActive, false); 1754 if(oldv == (byte)PhysShapeType.none)
1757 UpdatePhysicsSubscribedEvents(); 1755 {
1756 ApplyPhysics((uint)Flags, VolumeDetectActive, false);
1757 UpdatePhysicsSubscribedEvents();
1758 }
1758 } 1759 }
1759 else 1760 else
1760 {
1761 PhysActor.PhysicsShapeType = m_physicsShapeType; 1761 PhysActor.PhysicsShapeType = m_physicsShapeType;
1762// if (Shape.SculptEntry)
1763// CheckSculptAndLoad();
1764 }
1765 1762
1766 if (ParentGroup != null) 1763 ParentGroup.HasGroupChanged = true;
1767 ParentGroup.HasGroupChanged = true;
1768 }
1769
1770 if (m_physicsShapeType != value)
1771 {
1772 UpdatePhysRequired = true;
1773 } 1764 }
1774 } 1765 }
1775 } 1766 }
@@ -1782,17 +1773,16 @@ namespace OpenSim.Region.Framework.Scenes
1782 if (value >=1 && value <= 22587.0) 1773 if (value >=1 && value <= 22587.0)
1783 { 1774 {
1784 m_density = value; 1775 m_density = value;
1785 UpdatePhysRequired = true;
1786 }
1787 1776
1788 ScheduleFullUpdateIfNone(); 1777 ScheduleFullUpdateIfNone();
1789 1778
1790 if (ParentGroup != null) 1779 if (ParentGroup != null)
1791 ParentGroup.HasGroupChanged = true; 1780 ParentGroup.HasGroupChanged = true;
1792 1781
1793 PhysicsActor pa = PhysActor; 1782 PhysicsActor pa = PhysActor;
1794 if (pa != null) 1783 if (pa != null)
1795 pa.Density = Density; 1784 pa.Density = m_density;
1785 }
1796 } 1786 }
1797 } 1787 }
1798 1788
@@ -1804,17 +1794,16 @@ namespace OpenSim.Region.Framework.Scenes
1804 if( value >= -1 && value <=28.0f) 1794 if( value >= -1 && value <=28.0f)
1805 { 1795 {
1806 m_gravitymod = value; 1796 m_gravitymod = value;
1807 UpdatePhysRequired = true;
1808 }
1809 1797
1810 ScheduleFullUpdateIfNone(); 1798 ScheduleFullUpdateIfNone();
1811 1799
1812 if (ParentGroup != null) 1800 if (ParentGroup != null)
1813 ParentGroup.HasGroupChanged = true; 1801 ParentGroup.HasGroupChanged = true;
1814 1802
1815 PhysicsActor pa = PhysActor; 1803 PhysicsActor pa = PhysActor;
1816 if (pa != null) 1804 if (pa != null)
1817 pa.GravModifier = GravityModifier; 1805 pa.GravModifier = m_gravitymod;
1806 }
1818 } 1807 }
1819 } 1808 }
1820 1809
@@ -1826,17 +1815,16 @@ namespace OpenSim.Region.Framework.Scenes
1826 if (value >= 0 && value <= 255.0f) 1815 if (value >= 0 && value <= 255.0f)
1827 { 1816 {
1828 m_friction = value; 1817 m_friction = value;
1829 UpdatePhysRequired = true;
1830 }
1831 1818
1832 ScheduleFullUpdateIfNone(); 1819 ScheduleFullUpdateIfNone();
1833 1820
1834 if (ParentGroup != null) 1821 if (ParentGroup != null)
1835 ParentGroup.HasGroupChanged = true; 1822 ParentGroup.HasGroupChanged = true;
1836 1823
1837 PhysicsActor pa = PhysActor; 1824 PhysicsActor pa = PhysActor;
1838 if (pa != null) 1825 if (pa != null)
1839 pa.Friction = Friction; 1826 pa.Friction = m_friction;
1827 }
1840 } 1828 }
1841 } 1829 }
1842 1830
@@ -1848,17 +1836,16 @@ namespace OpenSim.Region.Framework.Scenes
1848 if (value >= 0 && value <= 1.0f) 1836 if (value >= 0 && value <= 1.0f)
1849 { 1837 {
1850 m_bounce = value; 1838 m_bounce = value;
1851 UpdatePhysRequired = true;
1852 }
1853 1839
1854 ScheduleFullUpdateIfNone(); 1840 ScheduleFullUpdateIfNone();
1855 1841
1856 if (ParentGroup != null) 1842 if (ParentGroup != null)
1857 ParentGroup.HasGroupChanged = true; 1843 ParentGroup.HasGroupChanged = true;
1858 1844
1859 PhysicsActor pa = PhysActor; 1845 PhysicsActor pa = PhysActor;
1860 if (pa != null) 1846 if (pa != null)
1861 pa.Restitution = Restitution; 1847 pa.Restitution = m_bounce;
1848 }
1862 } 1849 }
1863 } 1850 }
1864 1851
@@ -4541,24 +4528,24 @@ SendFullUpdateToClient(remoteClient, Position) ignores position parameter
4541 } 4528 }
4542 } 4529 }
4543 4530
4544
4545 public void UpdateExtraPhysics(ExtraPhysicsData physdata) 4531 public void UpdateExtraPhysics(ExtraPhysicsData physdata)
4546 { 4532 {
4547 if (physdata.PhysShapeType == PhysShapeType.invalid || ParentGroup == null) 4533 if (physdata.PhysShapeType == PhysShapeType.invalid || ParentGroup == null)
4548 return; 4534 return;
4549 4535
4550 if (PhysicsShapeType != (byte)physdata.PhysShapeType) 4536 byte newtype = (byte)physdata.PhysShapeType;
4551 { 4537 if (PhysicsShapeType != newtype)
4552 PhysicsShapeType = (byte)physdata.PhysShapeType; 4538 PhysicsShapeType = newtype;
4553
4554 }
4555 4539
4556 if(Density != physdata.Density) 4540 if(Density != physdata.Density)
4557 Density = physdata.Density; 4541 Density = physdata.Density;
4542
4558 if(GravityModifier != physdata.GravitationModifier) 4543 if(GravityModifier != physdata.GravitationModifier)
4559 GravityModifier = physdata.GravitationModifier; 4544 GravityModifier = physdata.GravitationModifier;
4545
4560 if(Friction != physdata.Friction) 4546 if(Friction != physdata.Friction)
4561 Friction = physdata.Friction; 4547 Friction = physdata.Friction;
4548
4562 if(Restitution != physdata.Bounce) 4549 if(Restitution != physdata.Bounce)
4563 Restitution = physdata.Bounce; 4550 Restitution = physdata.Bounce;
4564 } 4551 }
diff --git a/OpenSim/Region/PhysicsModules/ubOdeMeshing/Meshmerizer.cs b/OpenSim/Region/PhysicsModules/ubOdeMeshing/Meshmerizer.cs
index ff10e7f..bcd1530 100644
--- a/OpenSim/Region/PhysicsModules/ubOdeMeshing/Meshmerizer.cs
+++ b/OpenSim/Region/PhysicsModules/ubOdeMeshing/Meshmerizer.cs
@@ -443,6 +443,11 @@ namespace OpenSim.Region.PhysicsModule.ubODEMeshing
443 443
444 if (physicsParms != null) 444 if (physicsParms != null)
445 usemesh = true; 445 usemesh = true;
446 else
447 {
448 m_log.WarnFormat("[MESH]: Data for PRIM shape type not found for prim {0}",primName);
449 return false;
450 }
446 } 451 }
447 452
448 if(!usemesh && (map.ContainsKey("physics_convex"))) 453 if(!usemesh && (map.ContainsKey("physics_convex")))
@@ -451,7 +456,7 @@ namespace OpenSim.Region.PhysicsModule.ubODEMeshing
451 456
452 if (physicsParms == null) 457 if (physicsParms == null)
453 { 458 {
454 m_log.WarnFormat("[MESH]: unknown mesh type for {0}",primName); 459 m_log.WarnFormat("[MESH]: unknown mesh type for prim {0}",primName);
455 return false; 460 return false;
456 } 461 }
457 462
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
index 66cb30c..85837e4 100644
--- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
+++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
@@ -100,11 +100,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
100 100
101 protected IScriptEngine m_ScriptEngine; 101 protected IScriptEngine m_ScriptEngine;
102 protected SceneObjectPart m_host; 102 protected SceneObjectPart m_host;
103 103
104 /// <summary>
105 /// Used for script sleeps when we are using co-operative script termination.
106 /// </summary>
107 /// <remarks>null if co-operative script termination is not active</remarks>
108 /// <summary> 104 /// <summary>
109 /// The item that hosts this script 105 /// The item that hosts this script
110 /// </summary> 106 /// </summary>
@@ -1641,12 +1637,15 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
1641 1637
1642 foreach (SceneObjectPart part in group.Parts) 1638 foreach (SceneObjectPart part in group.Parts)
1643 { 1639 {
1640 if (part.PhysicsShapeType == (byte)PhysicsShapeType.None)
1641 continue;
1642
1644 if (part.Scale.X > World.m_maxPhys || part.Scale.Y > World.m_maxPhys || part.Scale.Z > World.m_maxPhys) 1643 if (part.Scale.X > World.m_maxPhys || part.Scale.Y > World.m_maxPhys || part.Scale.Z > World.m_maxPhys)
1645 { 1644 {
1646 allow = false; 1645 allow = false;
1647 break; 1646 break;
1648 } 1647 }
1649 if (checkShape && part.PhysicsShapeType != (byte)PhysicsShapeType.None) 1648 if (checkShape)
1650 { 1649 {
1651 if (--maxprims < 0) 1650 if (--maxprims < 0)
1652 { 1651 {
diff --git a/OpenSim/Region/ScriptEngine/XEngine/XEngine.cs b/OpenSim/Region/ScriptEngine/XEngine/XEngine.cs
index 3038915..e12f850 100755
--- a/OpenSim/Region/ScriptEngine/XEngine/XEngine.cs
+++ b/OpenSim/Region/ScriptEngine/XEngine/XEngine.cs
@@ -110,6 +110,7 @@ namespace OpenSim.Region.ScriptEngine.XEngine
110 private int m_ScriptFailCount; // Number of script fails since compile queue was last empty 110 private int m_ScriptFailCount; // Number of script fails since compile queue was last empty
111 private string m_ScriptErrorMessage; 111 private string m_ScriptErrorMessage;
112 private bool m_AppDomainLoading; 112 private bool m_AppDomainLoading;
113 private bool m_CompactMemOnLoad;
113 private Dictionary<UUID,ArrayList> m_ScriptErrors = 114 private Dictionary<UUID,ArrayList> m_ScriptErrors =
114 new Dictionary<UUID,ArrayList>(); 115 new Dictionary<UUID,ArrayList>();
115 116
@@ -301,8 +302,8 @@ namespace OpenSim.Region.ScriptEngine.XEngine
301 m_MaxScriptQueue = m_ScriptConfig.GetInt("MaxScriptEventQueue",300); 302 m_MaxScriptQueue = m_ScriptConfig.GetInt("MaxScriptEventQueue",300);
302 m_StackSize = m_ScriptConfig.GetInt("ThreadStackSize", 262144); 303 m_StackSize = m_ScriptConfig.GetInt("ThreadStackSize", 262144);
303 m_SleepTime = m_ScriptConfig.GetInt("MaintenanceInterval", 10) * 1000; 304 m_SleepTime = m_ScriptConfig.GetInt("MaintenanceInterval", 10) * 1000;
304 m_AppDomainLoading = m_ScriptConfig.GetBoolean("AppDomainLoading", true); 305 m_AppDomainLoading = m_ScriptConfig.GetBoolean("AppDomainLoading", false);
305 306 m_CompactMemOnLoad = m_ScriptConfig.GetBoolean("CompactMemOnLoad", false);
306 m_EventLimit = m_ScriptConfig.GetInt("EventLimit", 30); 307 m_EventLimit = m_ScriptConfig.GetInt("EventLimit", 30);
307 m_KillTimedOutScripts = m_ScriptConfig.GetBoolean("KillTimedOutScripts", false); 308 m_KillTimedOutScripts = m_ScriptConfig.GetBoolean("KillTimedOutScripts", false);
308 m_SaveTime = m_ScriptConfig.GetInt("SaveInterval", 120) * 1000; 309 m_SaveTime = m_ScriptConfig.GetInt("SaveInterval", 120) * 1000;
@@ -1278,10 +1279,9 @@ namespace OpenSim.Region.ScriptEngine.XEngine
1278 } 1279 }
1279 } 1280 }
1280 1281
1281 // do not load a assembly on top of a lot of to release memory 1282 // optionaly do not load a assembly on top of a lot of to release memory
1282 // also yield a bit 1283 // only if logins disable since causes a lot of rubber banding
1283 // only if logins disable since causes a lot of rubber banding 1284 if(m_CompactMemOnLoad && !m_Scene.LoginsEnabled)
1284 if(!m_Scene.LoginsEnabled)
1285 GC.Collect(2); 1285 GC.Collect(2);
1286 1286
1287 ScriptInstance instance = null; 1287 ScriptInstance instance = null;