Merge branch 'master' of ssh://opensimulator.org/var/git/opensim
commit
1719dc9a9b
|
@ -131,6 +131,12 @@ namespace OpenSim.Region.CoreModules.Avatar.ObjectCaps
|
|||
|
||||
if (texture != null)
|
||||
{
|
||||
if (texture.Type != (sbyte)AssetType.Texture)
|
||||
{
|
||||
httpResponse.StatusCode = (int)System.Net.HttpStatusCode.NotFound;
|
||||
httpResponse.Send();
|
||||
return null;
|
||||
}
|
||||
SendTexture(httpRequest, httpResponse, texture);
|
||||
}
|
||||
else
|
||||
|
@ -147,6 +153,12 @@ namespace OpenSim.Region.CoreModules.Avatar.ObjectCaps
|
|||
|
||||
if (texture != null)
|
||||
{
|
||||
if (texture.Type != (sbyte)AssetType.Texture)
|
||||
{
|
||||
httpResponse.StatusCode = (int)System.Net.HttpStatusCode.NotFound;
|
||||
httpResponse.Send();
|
||||
return null;
|
||||
}
|
||||
SendTexture(httpRequest, httpResponse, texture);
|
||||
}
|
||||
else
|
||||
|
|
|
@ -52,6 +52,9 @@ namespace OpenSim.Region.Framework.Scenes
|
|||
public double GetUpdatePriority(IClientAPI client, ISceneEntity entity)
|
||||
{
|
||||
double priority = 0;
|
||||
|
||||
if (entity == null)
|
||||
return 100000;
|
||||
|
||||
switch (m_scene.UpdatePrioritizationScheme)
|
||||
{
|
||||
|
|
|
@ -6516,15 +6516,15 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
|
|||
if (cut.y > 1f)
|
||||
{
|
||||
cut.y = 1f;
|
||||
}
|
||||
if (cut.y - cut.x < 0.05f)
|
||||
{
|
||||
cut.x = cut.y - 0.05f;
|
||||
if (cut.x < 0.0f)
|
||||
{
|
||||
cut.x = 0.0f;
|
||||
cut.y = 0.05f;
|
||||
}
|
||||
}
|
||||
if (cut.y - cut.x < 0.05f)
|
||||
{
|
||||
cut.x = cut.y - 0.05f;
|
||||
if (cut.x < 0.0f)
|
||||
{
|
||||
cut.x = 0.0f;
|
||||
cut.y = 0.05f;
|
||||
}
|
||||
}
|
||||
shapeBlock.ProfileBegin = (ushort)(50000 * cut.x);
|
||||
shapeBlock.ProfileEnd = (ushort)(50000 * (1 - cut.y));
|
||||
|
@ -6722,11 +6722,11 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
|
|||
}
|
||||
if (profilecut.y - profilecut.x < 0.05f)
|
||||
{
|
||||
profilecut.x = profilecut.y - 0.05f;
|
||||
if (profilecut.x < 0.0f)
|
||||
{
|
||||
profilecut.x = 0.0f;
|
||||
profilecut.y = 0.05f;
|
||||
profilecut.x = profilecut.y - 0.05f;
|
||||
if (profilecut.x < 0.0f)
|
||||
{
|
||||
profilecut.x = 0.0f;
|
||||
profilecut.y = 0.05f;
|
||||
}
|
||||
}
|
||||
shapeBlock.ProfileBegin = (ushort)(50000 * profilecut.x);
|
||||
|
|
|
@ -198,6 +198,8 @@ namespace OpenSim.Services.Connectors.SimianGrid
|
|||
if (!String.IsNullOrEmpty(identifier))
|
||||
{
|
||||
// Add/update the md5hash identity
|
||||
// TODO: Support salts when AddIdentity does
|
||||
// TODO: Create an a1hash too for WebDAV logins
|
||||
requestArgs = new NameValueCollection
|
||||
{
|
||||
{ "RequestMethod", "AddIdentity" },
|
||||
|
|
|
@ -59,18 +59,35 @@ namespace OpenSim.Services.Connectors.SimianGrid
|
|||
MethodBase.GetCurrentMethod().DeclaringType);
|
||||
|
||||
private string m_serverUrl = String.Empty;
|
||||
private Dictionary<UUID, Scene> m_scenes = new Dictionary<UUID, Scene>();
|
||||
|
||||
#region ISharedRegionModule
|
||||
|
||||
public Type ReplaceableInterface { get { return null; } }
|
||||
public void RegionLoaded(Scene scene) { if (!String.IsNullOrEmpty(m_serverUrl)) { UploadMapTile(scene); } }
|
||||
public void RegionLoaded(Scene scene) { }
|
||||
public void PostInitialise() { }
|
||||
public void Close() { }
|
||||
|
||||
public SimianGridServiceConnector() { }
|
||||
public string Name { get { return "SimianGridServiceConnector"; } }
|
||||
public void AddRegion(Scene scene) { if (!String.IsNullOrEmpty(m_serverUrl)) { scene.RegisterModuleInterface<IGridService>(this); } }
|
||||
public void RemoveRegion(Scene scene) { if (!String.IsNullOrEmpty(m_serverUrl)) { scene.UnregisterModuleInterface<IGridService>(this); } }
|
||||
public void AddRegion(Scene scene)
|
||||
{
|
||||
// Every shared region module has to maintain an indepedent list of
|
||||
// currently running regions
|
||||
lock (m_scenes)
|
||||
m_scenes[scene.RegionInfo.RegionID] = scene;
|
||||
|
||||
if (!String.IsNullOrEmpty(m_serverUrl))
|
||||
scene.RegisterModuleInterface<IGridService>(this);
|
||||
}
|
||||
public void RemoveRegion(Scene scene)
|
||||
{
|
||||
lock (m_scenes)
|
||||
m_scenes.Remove(scene.RegionInfo.RegionID);
|
||||
|
||||
if (!String.IsNullOrEmpty(m_serverUrl))
|
||||
scene.UnregisterModuleInterface<IGridService>(this);
|
||||
}
|
||||
|
||||
#endregion ISharedRegionModule
|
||||
|
||||
|
@ -105,6 +122,13 @@ namespace OpenSim.Services.Connectors.SimianGrid
|
|||
|
||||
public string RegisterRegion(UUID scopeID, GridRegion regionInfo)
|
||||
{
|
||||
// Generate and upload our map tile in PNG format to the SimianGrid AddMapTile service
|
||||
Scene scene;
|
||||
if (m_scenes.TryGetValue(regionInfo.RegionID, out scene))
|
||||
UploadMapTile(scene);
|
||||
else
|
||||
m_log.Warn("Registering region " + regionInfo.RegionName + " (" + regionInfo.RegionID + ") that we are not tracking");
|
||||
|
||||
Vector3d minPosition = new Vector3d(regionInfo.RegionLocX, regionInfo.RegionLocY, 0.0);
|
||||
Vector3d maxPosition = minPosition + new Vector3d(Constants.RegionSize, Constants.RegionSize, 4096.0);
|
||||
|
||||
|
@ -430,7 +454,7 @@ namespace OpenSim.Services.Connectors.SimianGrid
|
|||
if (!String.IsNullOrEmpty(errorMessage))
|
||||
{
|
||||
m_log.WarnFormat("[SIMIAN GRID CONNECTOR]: Failed to store {0} byte PNG map tile for {1}: {2}",
|
||||
pngData.Length, scene.RegionInfo.RegionName, errorMessage);
|
||||
pngData.Length, scene.RegionInfo.RegionName, errorMessage.Replace('\n', ' '));
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue