Merge branch 'master' of git://opensimulator.org/git/opensim
commit
335f2ddad2
|
@ -47,6 +47,7 @@ using Caps = OpenSim.Framework.Capabilities.Caps;
|
||||||
using OSD = OpenMetaverse.StructuredData.OSD;
|
using OSD = OpenMetaverse.StructuredData.OSD;
|
||||||
using OSDMap = OpenMetaverse.StructuredData.OSDMap;
|
using OSDMap = OpenMetaverse.StructuredData.OSDMap;
|
||||||
using OpenSim.Framework.Capabilities;
|
using OpenSim.Framework.Capabilities;
|
||||||
|
using ExtraParamType = OpenMetaverse.ExtraParamType;
|
||||||
|
|
||||||
namespace OpenSim.Region.CoreModules.Avatar.ObjectCaps
|
namespace OpenSim.Region.CoreModules.Avatar.ObjectCaps
|
||||||
{
|
{
|
||||||
|
@ -188,25 +189,74 @@ namespace OpenSim.Region.CoreModules.Avatar.ObjectCaps
|
||||||
rootrot = obj.Rotation;
|
rootrot = obj.Rotation;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Combine the extraparams data into it's ugly blob again....
|
// Combine the extraparams data into it's ugly blob again....
|
||||||
int bytelength = 0;
|
//int bytelength = 0;
|
||||||
|
//for (int extparams = 0; extparams < obj.ExtraParams.Length; extparams++)
|
||||||
|
//{
|
||||||
|
// bytelength += obj.ExtraParams[extparams].ExtraParamData.Length;
|
||||||
|
//}
|
||||||
|
//byte[] extraparams = new byte[bytelength];
|
||||||
|
//int position = 0;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//for (int extparams = 0; extparams < obj.ExtraParams.Length; extparams++)
|
||||||
|
//{
|
||||||
|
// Buffer.BlockCopy(obj.ExtraParams[extparams].ExtraParamData, 0, extraparams, position,
|
||||||
|
// obj.ExtraParams[extparams].ExtraParamData.Length);
|
||||||
|
//
|
||||||
|
// position += obj.ExtraParams[extparams].ExtraParamData.Length;
|
||||||
|
// }
|
||||||
|
|
||||||
|
//pbs.ExtraParams = extraparams;
|
||||||
for (int extparams = 0; extparams < obj.ExtraParams.Length; extparams++)
|
for (int extparams = 0; extparams < obj.ExtraParams.Length; extparams++)
|
||||||
{
|
{
|
||||||
bytelength += obj.ExtraParams[extparams].ExtraParamData.Length;
|
UploadObjectAssetMessage.Object.ExtraParam extraParam = obj.ExtraParams[extparams];
|
||||||
|
switch ((ushort)extraParam.Type)
|
||||||
|
{
|
||||||
|
case (ushort)ExtraParamType.Sculpt:
|
||||||
|
Primitive.SculptData sculpt = new Primitive.SculptData(extraParam.ExtraParamData, 0);
|
||||||
|
|
||||||
|
pbs.SculptEntry = true;
|
||||||
|
|
||||||
|
pbs.SculptTexture = obj.SculptID;
|
||||||
|
pbs.SculptType = (byte)sculpt.Type;
|
||||||
|
|
||||||
|
break;
|
||||||
|
case (ushort)ExtraParamType.Flexible:
|
||||||
|
Primitive.FlexibleData flex = new Primitive.FlexibleData(extraParam.ExtraParamData, 0);
|
||||||
|
pbs.FlexiEntry = true;
|
||||||
|
pbs.FlexiDrag = flex.Drag;
|
||||||
|
pbs.FlexiForceX = flex.Force.X;
|
||||||
|
pbs.FlexiForceY = flex.Force.Y;
|
||||||
|
pbs.FlexiForceZ = flex.Force.Z;
|
||||||
|
pbs.FlexiGravity = flex.Gravity;
|
||||||
|
pbs.FlexiSoftness = flex.Softness;
|
||||||
|
pbs.FlexiTension = flex.Tension;
|
||||||
|
pbs.FlexiWind = flex.Wind;
|
||||||
|
break;
|
||||||
|
case (ushort)ExtraParamType.Light:
|
||||||
|
Primitive.LightData light = new Primitive.LightData(extraParam.ExtraParamData, 0);
|
||||||
|
pbs.LightColorA = light.Color.A;
|
||||||
|
pbs.LightColorB = light.Color.B;
|
||||||
|
pbs.LightColorG = light.Color.G;
|
||||||
|
pbs.LightColorR = light.Color.R;
|
||||||
|
pbs.LightCutoff = light.Cutoff;
|
||||||
|
pbs.LightEntry = true;
|
||||||
|
pbs.LightFalloff = light.Falloff;
|
||||||
|
pbs.LightIntensity = light.Intensity;
|
||||||
|
pbs.LightRadius = light.Radius;
|
||||||
|
break;
|
||||||
|
case 0x40:
|
||||||
|
pbs.ReadProjectionData(extraParam.ExtraParamData, 0);
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
byte[] extraparams = new byte[bytelength];
|
|
||||||
int position = 0;
|
|
||||||
|
|
||||||
for (int extparams = 0; extparams < obj.ExtraParams.Length; extparams++)
|
|
||||||
{
|
|
||||||
Buffer.BlockCopy(obj.ExtraParams[extparams].ExtraParamData, 0, extraparams, position,
|
|
||||||
obj.ExtraParams[extparams].ExtraParamData.Length);
|
|
||||||
|
|
||||||
position += obj.ExtraParams[extparams].ExtraParamData.Length;
|
|
||||||
}
|
|
||||||
|
|
||||||
pbs.ExtraParams = extraparams;
|
|
||||||
|
|
||||||
pbs.PathBegin = (ushort) obj.PathBegin;
|
pbs.PathBegin = (ushort) obj.PathBegin;
|
||||||
pbs.PathCurve = (byte) obj.PathCurve;
|
pbs.PathCurve = (byte) obj.PathCurve;
|
||||||
pbs.PathEnd = (ushort) obj.PathEnd;
|
pbs.PathEnd = (ushort) obj.PathEnd;
|
||||||
|
@ -269,9 +319,7 @@ namespace OpenSim.Region.CoreModules.Avatar.ObjectCaps
|
||||||
pbs.TextureEntry = tmp.GetBytes();
|
pbs.TextureEntry = tmp.GetBytes();
|
||||||
prim.Shape = pbs;
|
prim.Shape = pbs;
|
||||||
prim.Scale = obj.Scale;
|
prim.Scale = obj.Scale;
|
||||||
prim.Shape.SculptEntry = true;
|
|
||||||
prim.Shape.SculptTexture = obj.SculptID;
|
|
||||||
prim.Shape.SculptType = (byte) SculptType.Mesh;
|
|
||||||
|
|
||||||
SceneObjectGroup grp = new SceneObjectGroup();
|
SceneObjectGroup grp = new SceneObjectGroup();
|
||||||
|
|
||||||
|
|
|
@ -36,7 +36,7 @@ namespace OpenSim.Region.CoreModules.ServiceConnectorsOut.UserAccounts
|
||||||
{
|
{
|
||||||
public class UserAccountCache
|
public class UserAccountCache
|
||||||
{
|
{
|
||||||
private const double CACHE_EXPIRATION_SECONDS = 120.0;
|
private const double CACHE_EXPIRATION_SECONDS = 120000.0; // 33 hours!
|
||||||
|
|
||||||
private static readonly ILog m_log =
|
private static readonly ILog m_log =
|
||||||
LogManager.GetLogger(
|
LogManager.GetLogger(
|
||||||
|
@ -57,7 +57,7 @@ namespace OpenSim.Region.CoreModules.ServiceConnectorsOut.UserAccounts
|
||||||
if (account != null)
|
if (account != null)
|
||||||
m_NameCache.AddOrUpdate(account.Name, account.PrincipalID, CACHE_EXPIRATION_SECONDS);
|
m_NameCache.AddOrUpdate(account.Name, account.PrincipalID, CACHE_EXPIRATION_SECONDS);
|
||||||
|
|
||||||
m_log.DebugFormat("[USER CACHE]: cached user {0}", userID);
|
//m_log.DebugFormat("[USER CACHE]: cached user {0}", userID);
|
||||||
}
|
}
|
||||||
|
|
||||||
public UserAccount Get(UUID userID, out bool inCache)
|
public UserAccount Get(UUID userID, out bool inCache)
|
||||||
|
|
|
@ -113,7 +113,7 @@ namespace OpenSim.Services.Connectors
|
||||||
|
|
||||||
public virtual UserAccount GetUserAccount(UUID scopeID, UUID userID)
|
public virtual UserAccount GetUserAccount(UUID scopeID, UUID userID)
|
||||||
{
|
{
|
||||||
m_log.DebugFormat("[ACCOUNTS CONNECTOR]: GetUserAccount {0}", userID);
|
//m_log.DebugFormat("[ACCOUNTS CONNECTOR]: GetUserAccount {0}", userID);
|
||||||
Dictionary<string, object> sendData = new Dictionary<string, object>();
|
Dictionary<string, object> sendData = new Dictionary<string, object>();
|
||||||
//sendData["SCOPEID"] = scopeID.ToString();
|
//sendData["SCOPEID"] = scopeID.ToString();
|
||||||
sendData["VERSIONMIN"] = ProtocolVersions.ClientProtocolVersionMin.ToString();
|
sendData["VERSIONMIN"] = ProtocolVersions.ClientProtocolVersionMin.ToString();
|
||||||
|
|
Loading…
Reference in New Issue