diff options
author | Diva Canto | 2014-05-31 08:22:56 -0700 |
---|---|---|
committer | Diva Canto | 2014-05-31 08:22:56 -0700 |
commit | d6f9f690e56f129c4fcfb2d6fdb85f750ab3dd37 (patch) | |
tree | e198838d321f9adbce57e7744c8aebc2609b87e4 /OpenSim/Region | |
parent | Added missing reference (diff) | |
parent | minor: rename velocidyDiff -> velocityDiff (diff) | |
download | opensim-SC_OLD-d6f9f690e56f129c4fcfb2d6fdb85f750ab3dd37.zip opensim-SC_OLD-d6f9f690e56f129c4fcfb2d6fdb85f750ab3dd37.tar.gz opensim-SC_OLD-d6f9f690e56f129c4fcfb2d6fdb85f750ab3dd37.tar.bz2 opensim-SC_OLD-d6f9f690e56f129c4fcfb2d6fdb85f750ab3dd37.tar.xz |
Merge branch 'master' of ssh://opensimulator.org/var/git/opensim
Diffstat (limited to 'OpenSim/Region')
6 files changed, 63 insertions, 21 deletions
diff --git a/OpenSim/Region/ClientStack/Linden/Caps/Tests/WebFetchInvDescModuleTests.cs b/OpenSim/Region/ClientStack/Linden/Caps/Tests/WebFetchInvDescModuleTests.cs index edc5016..ee1ea1a 100644 --- a/OpenSim/Region/ClientStack/Linden/Caps/Tests/WebFetchInvDescModuleTests.cs +++ b/OpenSim/Region/ClientStack/Linden/Caps/Tests/WebFetchInvDescModuleTests.cs | |||
@@ -152,7 +152,7 @@ namespace OpenSim.Region.ClientStack.Linden.Caps.Tests | |||
152 | 152 | ||
153 | // A sanity check that the response has the expected number of descendents for a default inventory | 153 | // A sanity check that the response has the expected number of descendents for a default inventory |
154 | // TODO: Need a more thorough check. | 154 | // TODO: Need a more thorough check. |
155 | Assert.That((int)folderOsd["descendents"], Is.EqualTo(14)); | 155 | Assert.That((int)folderOsd["descendents"], Is.EqualTo(16)); |
156 | } | 156 | } |
157 | } | 157 | } |
158 | } \ No newline at end of file | 158 | } \ No newline at end of file |
diff --git a/OpenSim/Region/CoreModules/World/WorldMap/WorldMapModule.cs b/OpenSim/Region/CoreModules/World/WorldMap/WorldMapModule.cs index b98afbc..e4977cf 100644 --- a/OpenSim/Region/CoreModules/World/WorldMap/WorldMapModule.cs +++ b/OpenSim/Region/CoreModules/World/WorldMap/WorldMapModule.cs | |||
@@ -1578,12 +1578,20 @@ namespace OpenSim.Region.CoreModules.World.WorldMap | |||
1578 | 1578 | ||
1579 | private Byte[] GenerateOverlay() | 1579 | private Byte[] GenerateOverlay() |
1580 | { | 1580 | { |
1581 | using (Bitmap overlay = new Bitmap(256, 256)) | 1581 | // These need to be ints for bitmap generation |
1582 | int regionSizeX = (int)m_scene.RegionInfo.RegionSizeX; | ||
1583 | int regionSizeY = (int)m_scene.RegionInfo.RegionSizeY; | ||
1584 | |||
1585 | int landTileSize = LandManagementModule.LandUnit; | ||
1586 | int regionLandTilesX = regionSizeX / landTileSize; | ||
1587 | int regionLandTilesY = regionSizeY / landTileSize; | ||
1588 | |||
1589 | using (Bitmap overlay = new Bitmap(regionSizeX, regionSizeY)) | ||
1582 | { | 1590 | { |
1583 | bool[,] saleBitmap = new bool[64, 64]; | 1591 | bool[,] saleBitmap = new bool[regionLandTilesX, regionLandTilesY]; |
1584 | for (int x = 0 ; x < 64 ; x++) | 1592 | for (int x = 0; x < regionLandTilesX; x++) |
1585 | { | 1593 | { |
1586 | for (int y = 0 ; y < 64 ; y++) | 1594 | for (int y = 0; y < regionLandTilesY; y++) |
1587 | saleBitmap[x, y] = false; | 1595 | saleBitmap[x, y] = false; |
1588 | } | 1596 | } |
1589 | 1597 | ||
@@ -1596,8 +1604,7 @@ namespace OpenSim.Region.CoreModules.World.WorldMap | |||
1596 | using (Graphics g = Graphics.FromImage(overlay)) | 1604 | using (Graphics g = Graphics.FromImage(overlay)) |
1597 | { | 1605 | { |
1598 | using (SolidBrush transparent = new SolidBrush(background)) | 1606 | using (SolidBrush transparent = new SolidBrush(background)) |
1599 | g.FillRectangle(transparent, 0, 0, 256, 256); | 1607 | g.FillRectangle(transparent, 0, 0, regionSizeX, regionSizeY); |
1600 | |||
1601 | 1608 | ||
1602 | foreach (ILandObject land in parcels) | 1609 | foreach (ILandObject land in parcels) |
1603 | { | 1610 | { |
@@ -1620,12 +1627,16 @@ namespace OpenSim.Region.CoreModules.World.WorldMap | |||
1620 | 1627 | ||
1621 | using (SolidBrush yellow = new SolidBrush(Color.FromArgb(255, 249, 223, 9))) | 1628 | using (SolidBrush yellow = new SolidBrush(Color.FromArgb(255, 249, 223, 9))) |
1622 | { | 1629 | { |
1623 | for (int x = 0 ; x < 64 ; x++) | 1630 | for (int x = 0 ; x < regionLandTilesX ; x++) |
1624 | { | 1631 | { |
1625 | for (int y = 0 ; y < 64 ; y++) | 1632 | for (int y = 0 ; y < regionLandTilesY ; y++) |
1626 | { | 1633 | { |
1627 | if (saleBitmap[x, y]) | 1634 | if (saleBitmap[x, y]) |
1628 | g.FillRectangle(yellow, x * 4, 252 - (y * 4), 4, 4); | 1635 | g.FillRectangle( |
1636 | yellow, x * landTileSize, | ||
1637 | regionSizeX - landTileSize - (y * landTileSize), | ||
1638 | landTileSize, | ||
1639 | landTileSize); | ||
1629 | } | 1640 | } |
1630 | } | 1641 | } |
1631 | } | 1642 | } |
@@ -1654,4 +1665,4 @@ namespace OpenSim.Region.CoreModules.World.WorldMap | |||
1654 | public uint itemtype; | 1665 | public uint itemtype; |
1655 | public ulong regionhandle; | 1666 | public ulong regionhandle; |
1656 | } | 1667 | } |
1657 | } | 1668 | } \ No newline at end of file |
diff --git a/OpenSim/Region/Framework/Scenes/ScenePresence.cs b/OpenSim/Region/Framework/Scenes/ScenePresence.cs index 17f54c2..37353c1 100644 --- a/OpenSim/Region/Framework/Scenes/ScenePresence.cs +++ b/OpenSim/Region/Framework/Scenes/ScenePresence.cs | |||
@@ -3257,7 +3257,11 @@ namespace OpenSim.Region.Framework.Scenes | |||
3257 | float distanceError = Vector3.Distance(OffsetPosition, expectedPosition); | 3257 | float distanceError = Vector3.Distance(OffsetPosition, expectedPosition); |
3258 | 3258 | ||
3259 | float speed = Velocity.Length(); | 3259 | float speed = Velocity.Length(); |
3260 | float velocidyDiff = Vector3.Distance(lastVelocitySentToAllClients, Velocity); | 3260 | float velocityDiff = Vector3.Distance(lastVelocitySentToAllClients, Velocity); |
3261 | |||
3262 | // m_log.DebugFormat( | ||
3263 | // "[SCENE PRESENCE]: Delta-v {0}, lastVelocity {1}, Velocity {2} for {3} in {4}", | ||
3264 | // velocidyDiff, lastVelocitySentToAllClients, Velocity, Name, Scene.Name); | ||
3261 | 3265 | ||
3262 | // assuming 5 ms. worst case precision for timer, use 2x that | 3266 | // assuming 5 ms. worst case precision for timer, use 2x that |
3263 | // for distance error threshold | 3267 | // for distance error threshold |
@@ -3265,8 +3269,12 @@ namespace OpenSim.Region.Framework.Scenes | |||
3265 | 3269 | ||
3266 | if (speed < 0.01f // allow rotation updates if avatar position is unchanged | 3270 | if (speed < 0.01f // allow rotation updates if avatar position is unchanged |
3267 | || Math.Abs(distanceError) > distanceErrorThreshold | 3271 | || Math.Abs(distanceError) > distanceErrorThreshold |
3268 | || velocidyDiff > 0.01f) // did velocity change from last update? | 3272 | || velocityDiff > 0.01f) // did velocity change from last update? |
3269 | { | 3273 | { |
3274 | // m_log.DebugFormat( | ||
3275 | // "[SCENE PRESENCE]: Update triggered with speed {0}, distanceError {1}, distanceThreshold {2}, delta-v {3} for {4} in {5}", | ||
3276 | // speed, distanceError, distanceErrorThreshold, velocidyDiff, Name, Scene.Name); | ||
3277 | |||
3270 | lastVelocitySentToAllClients = Velocity; | 3278 | lastVelocitySentToAllClients = Velocity; |
3271 | lastTerseUpdateToAllClientsTick = currentTick; | 3279 | lastTerseUpdateToAllClientsTick = currentTick; |
3272 | lastPositionSentToAllClients = OffsetPosition; | 3280 | lastPositionSentToAllClients = OffsetPosition; |
diff --git a/OpenSim/Region/OptionalModules/Scripting/RegionReadyModule/RegionReadyModule.cs b/OpenSim/Region/OptionalModules/Scripting/RegionReadyModule/RegionReadyModule.cs index d059b97..870c0bb 100644 --- a/OpenSim/Region/OptionalModules/Scripting/RegionReadyModule/RegionReadyModule.cs +++ b/OpenSim/Region/OptionalModules/Scripting/RegionReadyModule/RegionReadyModule.cs | |||
@@ -105,8 +105,10 @@ namespace OpenSim.Region.OptionalModules.Scripting.RegionReady | |||
105 | m_scene.LoginLock = true; | 105 | m_scene.LoginLock = true; |
106 | m_scene.EventManager.OnEmptyScriptCompileQueue += OnEmptyScriptCompileQueue; | 106 | m_scene.EventManager.OnEmptyScriptCompileQueue += OnEmptyScriptCompileQueue; |
107 | 107 | ||
108 | // Warn level because the region cannot be used while logins are disabled | 108 | // This should always show up to the user but should not trigger warn/errors as these messages are |
109 | m_log.WarnFormat("[RegionReady]: Region {0} - LOGINS DISABLED DURING INITIALIZATION.", m_scene.Name); | 109 | // expected and are not simulator problems. Ideally, there would be a status level in log4net but |
110 | // failing that, we will print out to console instead. | ||
111 | MainConsole.Instance.OutputFormat("Region {0} - LOGINS DISABLED DURING INITIALIZATION.", m_scene.Name); | ||
110 | 112 | ||
111 | if (m_uri != string.Empty) | 113 | if (m_uri != string.Empty) |
112 | { | 114 | { |
diff --git a/OpenSim/Region/Physics/BulletSPlugin/BSCharacter.cs b/OpenSim/Region/Physics/BulletSPlugin/BSCharacter.cs index dfcd2bf..9b56fb4 100644 --- a/OpenSim/Region/Physics/BulletSPlugin/BSCharacter.cs +++ b/OpenSim/Region/Physics/BulletSPlugin/BSCharacter.cs | |||
@@ -744,7 +744,18 @@ public sealed class BSCharacter : BSPhysObject | |||
744 | // and will send agent updates to the clients if velocity changes by more than | 744 | // and will send agent updates to the clients if velocity changes by more than |
745 | // 0.001m/s. Bullet introduces a lot of jitter in the velocity which causes many | 745 | // 0.001m/s. Bullet introduces a lot of jitter in the velocity which causes many |
746 | // extra updates. | 746 | // extra updates. |
747 | if (!entprop.Velocity.ApproxEquals(RawVelocity, 0.1f)) | 747 | // |
748 | // XXX: Contrary to the above comment, setting an update threshold here above 0.4 actually introduces jitter to | ||
749 | // avatar movement rather than removes it. The larger the threshold, the bigger the jitter. | ||
750 | // This is most noticeable in level flight and can be seen with | ||
751 | // the "show updates" option in a viewer. With an update threshold, the RawVelocity cycles between a lower | ||
752 | // bound and an upper bound, where the difference between the two is enough to trigger a large delta v update | ||
753 | // and subsequently trigger an update in ScenePresence.SendTerseUpdateToAllClients(). The cause of this cycle (feedback?) | ||
754 | // has not yet been identified. | ||
755 | // | ||
756 | // If there is a threshold below 0.4 or no threshold check at all (as in ODE), then RawVelocity stays constant and extra | ||
757 | // updates are not triggered in ScenePresence.SendTerseUpdateToAllClients(). | ||
758 | // if (!entprop.Velocity.ApproxEquals(RawVelocity, 0.1f)) | ||
748 | RawVelocity = entprop.Velocity; | 759 | RawVelocity = entprop.Velocity; |
749 | 760 | ||
750 | _acceleration = entprop.Acceleration; | 761 | _acceleration = entprop.Acceleration; |
diff --git a/OpenSim/Region/ScriptEngine/Shared/CodeTools/Tests/CompilerTest.cs b/OpenSim/Region/ScriptEngine/Shared/CodeTools/Tests/CompilerTest.cs index badf82a..713b280 100644 --- a/OpenSim/Region/ScriptEngine/Shared/CodeTools/Tests/CompilerTest.cs +++ b/OpenSim/Region/ScriptEngine/Shared/CodeTools/Tests/CompilerTest.cs | |||
@@ -25,6 +25,7 @@ | |||
25 | * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 25 | * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
26 | */ | 26 | */ |
27 | 27 | ||
28 | using System; | ||
28 | using System.IO; | 29 | using System.IO; |
29 | using System.CodeDom.Compiler; | 30 | using System.CodeDom.Compiler; |
30 | using System.Collections.Generic; | 31 | using System.Collections.Generic; |
@@ -48,6 +49,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.CodeTools.Tests | |||
48 | private CSharpCodeProvider m_CSCodeProvider; | 49 | private CSharpCodeProvider m_CSCodeProvider; |
49 | private CompilerParameters m_compilerParameters; | 50 | private CompilerParameters m_compilerParameters; |
50 | private CompilerResults m_compilerResults; | 51 | private CompilerResults m_compilerResults; |
52 | private ResolveEventHandler m_resolveEventHandler; | ||
51 | 53 | ||
52 | /// <summary> | 54 | /// <summary> |
53 | /// Creates a temporary directory where build artifacts are stored. | 55 | /// Creates a temporary directory where build artifacts are stored. |
@@ -67,7 +69,12 @@ namespace OpenSim.Region.ScriptEngine.Shared.CodeTools.Tests | |||
67 | m_CSCodeProvider = new CSharpCodeProvider(); | 69 | m_CSCodeProvider = new CSharpCodeProvider(); |
68 | m_compilerParameters = new CompilerParameters(); | 70 | m_compilerParameters = new CompilerParameters(); |
69 | 71 | ||
70 | string rootPath = Path.Combine(Path.GetDirectoryName(System.AppDomain.CurrentDomain.BaseDirectory)); | 72 | string rootPath = System.AppDomain.CurrentDomain.BaseDirectory; |
73 | |||
74 | m_resolveEventHandler = new ResolveEventHandler(AssemblyResolver.OnAssemblyResolve); | ||
75 | |||
76 | System.AppDomain.CurrentDomain.AssemblyResolve += m_resolveEventHandler; | ||
77 | |||
71 | m_compilerParameters.ReferencedAssemblies.Add(Path.Combine(rootPath, "OpenSim.Region.ScriptEngine.Shared.dll")); | 78 | m_compilerParameters.ReferencedAssemblies.Add(Path.Combine(rootPath, "OpenSim.Region.ScriptEngine.Shared.dll")); |
72 | m_compilerParameters.ReferencedAssemblies.Add(Path.Combine(rootPath, "OpenSim.Region.ScriptEngine.Shared.Api.Runtime.dll")); | 79 | m_compilerParameters.ReferencedAssemblies.Add(Path.Combine(rootPath, "OpenSim.Region.ScriptEngine.Shared.Api.Runtime.dll")); |
73 | m_compilerParameters.ReferencedAssemblies.Add(Path.Combine(rootPath, "OpenMetaverseTypes.dll")); | 80 | m_compilerParameters.ReferencedAssemblies.Add(Path.Combine(rootPath, "OpenMetaverseTypes.dll")); |
@@ -81,6 +88,8 @@ namespace OpenSim.Region.ScriptEngine.Shared.CodeTools.Tests | |||
81 | [TestFixtureTearDown] | 88 | [TestFixtureTearDown] |
82 | public void CleanUp() | 89 | public void CleanUp() |
83 | { | 90 | { |
91 | System.AppDomain.CurrentDomain.AssemblyResolve -= m_resolveEventHandler; | ||
92 | |||
84 | if (Directory.Exists(m_testDir)) | 93 | if (Directory.Exists(m_testDir)) |
85 | { | 94 | { |
86 | // Blow away the temporary directory with artifacts. | 95 | // Blow away the temporary directory with artifacts. |
@@ -166,10 +175,11 @@ default | |||
166 | 175 | ||
167 | m_compilerResults = m_CSCodeProvider.CompileAssemblyFromSource(m_compilerParameters, output); | 176 | m_compilerResults = m_CSCodeProvider.CompileAssemblyFromSource(m_compilerParameters, output); |
168 | 177 | ||
169 | // foreach (CompilerError compErr in m_compilerResults.Errors) | 178 | System.Console.WriteLine("ERRORS: {0}", m_compilerResults.Errors.Count); |
170 | // { | 179 | foreach (CompilerError compErr in m_compilerResults.Errors) |
171 | // System.Console.WriteLine("Error: {0}", compErr); | 180 | { |
172 | // } | 181 | System.Console.WriteLine("Error: {0}", compErr); |
182 | } | ||
173 | 183 | ||
174 | Assert.AreEqual(0, m_compilerResults.Errors.Count); | 184 | Assert.AreEqual(0, m_compilerResults.Errors.Count); |
175 | } | 185 | } |