Merge branch 'master' of ssh://3dhosting.de/var/git/careminster into ubitwork
commit
04279e36d1
|
@ -235,4 +235,11 @@ CREATE NONCLUSTERED INDEX IX_regions_name ON dbo.regions
|
||||||
regionName
|
regionName
|
||||||
) WITH( STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
|
) WITH( STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
|
||||||
|
|
||||||
COMMIT
|
COMMIT
|
||||||
|
|
||||||
|
:VERSION 9
|
||||||
|
|
||||||
|
BEGIN TRANSACTION
|
||||||
|
ALTER TABLE regions ADD parcelMapTexture uniqueidentifier NULL;
|
||||||
|
|
||||||
|
COMMIT
|
||||||
|
|
|
@ -472,3 +472,73 @@ COMMIT;
|
||||||
BEGIN;
|
BEGIN;
|
||||||
ALTER TABLE regionsettings ADD COLUMN covenant_datetime INTEGER NOT NULL default 0;
|
ALTER TABLE regionsettings ADD COLUMN covenant_datetime INTEGER NOT NULL default 0;
|
||||||
COMMIT;
|
COMMIT;
|
||||||
|
|
||||||
|
:VERSION 23
|
||||||
|
BEGIN;
|
||||||
|
CREATE TABLE regionwindlight (
|
||||||
|
region_id VARCHAR(36) NOT NULL DEFAULT '000000-0000-0000-0000-000000000000' PRIMARY KEY,
|
||||||
|
water_color_r FLOAT NOT NULL DEFAULT '4.000000',
|
||||||
|
water_color_g FLOAT NOT NULL DEFAULT '38.000000',
|
||||||
|
water_color_b FLOAT NOT NULL DEFAULT '64.000000',
|
||||||
|
water_color_i FLOAT NOT NULL DEFAULT '1.000000',
|
||||||
|
water_fog_density_exponent FLOAT NOT NULL DEFAULT '4.0',
|
||||||
|
underwater_fog_modifier FLOAT NOT NULL DEFAULT '0.25',
|
||||||
|
reflection_wavelet_scale_1 FLOAT NOT NULL DEFAULT '2.0',
|
||||||
|
reflection_wavelet_scale_2 FLOAT NOT NULL DEFAULT '2.0',
|
||||||
|
reflection_wavelet_scale_3 FLOAT NOT NULL DEFAULT '2.0',
|
||||||
|
fresnel_scale FLOAT NOT NULL DEFAULT '0.40',
|
||||||
|
fresnel_offset FLOAT NOT NULL DEFAULT '0.50',
|
||||||
|
refract_scale_above FLOAT NOT NULL DEFAULT '0.03',
|
||||||
|
refract_scale_below FLOAT NOT NULL DEFAULT '0.20',
|
||||||
|
blur_multiplier FLOAT NOT NULL DEFAULT '0.040',
|
||||||
|
big_wave_direction_x FLOAT NOT NULL DEFAULT '1.05',
|
||||||
|
big_wave_direction_y FLOAT NOT NULL DEFAULT '-0.42',
|
||||||
|
little_wave_direction_x FLOAT NOT NULL DEFAULT '1.11',
|
||||||
|
little_wave_direction_y FLOAT NOT NULL DEFAULT '-1.16',
|
||||||
|
normal_map_texture VARCHAR(36) NOT NULL DEFAULT '822ded49-9a6c-f61c-cb89-6df54f42cdf4',
|
||||||
|
horizon_r FLOAT NOT NULL DEFAULT '0.25',
|
||||||
|
horizon_g FLOAT NOT NULL DEFAULT '0.25',
|
||||||
|
horizon_b FLOAT NOT NULL DEFAULT '0.32',
|
||||||
|
horizon_i FLOAT NOT NULL DEFAULT '0.32',
|
||||||
|
haze_horizon FLOAT NOT NULL DEFAULT '0.19',
|
||||||
|
blue_density_r FLOAT NOT NULL DEFAULT '0.12',
|
||||||
|
blue_density_g FLOAT NOT NULL DEFAULT '0.22',
|
||||||
|
blue_density_b FLOAT NOT NULL DEFAULT '0.38',
|
||||||
|
blue_density_i FLOAT NOT NULL DEFAULT '0.38',
|
||||||
|
haze_density FLOAT NOT NULL DEFAULT '0.70',
|
||||||
|
density_multiplier FLOAT NOT NULL DEFAULT '0.18',
|
||||||
|
distance_multiplier FLOAT NOT NULL DEFAULT '0.8',
|
||||||
|
max_altitude INTEGER NOT NULL DEFAULT '1605',
|
||||||
|
sun_moon_color_r FLOAT NOT NULL DEFAULT '0.24',
|
||||||
|
sun_moon_color_g FLOAT NOT NULL DEFAULT '0.26',
|
||||||
|
sun_moon_color_b FLOAT NOT NULL DEFAULT '0.30',
|
||||||
|
sun_moon_color_i FLOAT NOT NULL DEFAULT '0.30',
|
||||||
|
sun_moon_position FLOAT NOT NULL DEFAULT '0.317',
|
||||||
|
ambient_r FLOAT NOT NULL DEFAULT '0.35',
|
||||||
|
ambient_g FLOAT NOT NULL DEFAULT '0.35',
|
||||||
|
ambient_b FLOAT NOT NULL DEFAULT '0.35',
|
||||||
|
ambient_i FLOAT NOT NULL DEFAULT '0.35',
|
||||||
|
east_angle FLOAT NOT NULL DEFAULT '0.00',
|
||||||
|
sun_glow_focus FLOAT NOT NULL DEFAULT '0.10',
|
||||||
|
sun_glow_size FLOAT NOT NULL DEFAULT '1.75',
|
||||||
|
scene_gamma FLOAT NOT NULL DEFAULT '1.00',
|
||||||
|
star_brightness FLOAT NOT NULL DEFAULT '0.00',
|
||||||
|
cloud_color_r FLOAT NOT NULL DEFAULT '0.41',
|
||||||
|
cloud_color_g FLOAT NOT NULL DEFAULT '0.41',
|
||||||
|
cloud_color_b FLOAT NOT NULL DEFAULT '0.41',
|
||||||
|
cloud_color_i FLOAT NOT NULL DEFAULT '0.41',
|
||||||
|
cloud_x FLOAT NOT NULL DEFAULT '1.00',
|
||||||
|
cloud_y FLOAT NOT NULL DEFAULT '0.53',
|
||||||
|
cloud_density FLOAT NOT NULL DEFAULT '1.00',
|
||||||
|
cloud_coverage FLOAT NOT NULL DEFAULT '0.27',
|
||||||
|
cloud_scale FLOAT NOT NULL DEFAULT '0.42',
|
||||||
|
cloud_detail_x FLOAT NOT NULL DEFAULT '1.00',
|
||||||
|
cloud_detail_y FLOAT NOT NULL DEFAULT '0.53',
|
||||||
|
cloud_detail_density FLOAT NOT NULL DEFAULT '0.12',
|
||||||
|
cloud_scroll_x FLOAT NOT NULL DEFAULT '0.20',
|
||||||
|
cloud_scroll_x_lock INTEGER NOT NULL DEFAULT '0',
|
||||||
|
cloud_scroll_y FLOAT NOT NULL DEFAULT '0.01',
|
||||||
|
cloud_scroll_y_lock INTEGER NOT NULL DEFAULT '0',
|
||||||
|
draw_classic_clouds INTEGER NOT NULL DEFAULT '1');
|
||||||
|
|
||||||
|
COMMIT;
|
File diff suppressed because it is too large
Load Diff
|
@ -308,6 +308,8 @@ namespace OpenSim.Framework
|
||||||
public Animation[] Anims;
|
public Animation[] Anims;
|
||||||
|
|
||||||
public UUID GranterID;
|
public UUID GranterID;
|
||||||
|
public UUID ParentPart;
|
||||||
|
public Vector3 SitOffset;
|
||||||
|
|
||||||
// Appearance
|
// Appearance
|
||||||
public AvatarAppearance Appearance;
|
public AvatarAppearance Appearance;
|
||||||
|
@ -468,6 +470,10 @@ namespace OpenSim.Framework
|
||||||
}
|
}
|
||||||
args["attach_objects"] = attObjs;
|
args["attach_objects"] = attObjs;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
args["parent_part"] = OSD.FromUUID(ParentPart);
|
||||||
|
args["sit_offset"] = OSD.FromString(SitOffset.ToString());
|
||||||
|
|
||||||
return args;
|
return args;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -675,6 +681,11 @@ namespace OpenSim.Framework
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (args["parent_part"] != null)
|
||||||
|
ParentPart = args["parent_part"].AsUUID();
|
||||||
|
if (args["sit_offset"] != null)
|
||||||
|
Vector3.TryParse(args["sit_offset"].AsString(), out SitOffset);
|
||||||
}
|
}
|
||||||
|
|
||||||
public AgentData()
|
public AgentData()
|
||||||
|
|
|
@ -31,6 +31,7 @@ using System.Collections.Generic;
|
||||||
using System.Diagnostics;
|
using System.Diagnostics;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
|
using System.Text.RegularExpressions;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using log4net;
|
using log4net;
|
||||||
using OpenSim.Framework;
|
using OpenSim.Framework;
|
||||||
|
@ -531,6 +532,11 @@ namespace OpenSim.Framework.Console
|
||||||
|
|
||||||
public class Parser
|
public class Parser
|
||||||
{
|
{
|
||||||
|
// If an unquoted portion ends with an element matching this regex
|
||||||
|
// and the next element contains a space, then we have stripped
|
||||||
|
// embedded quotes that should not have been stripped
|
||||||
|
private static Regex optionRegex = new Regex("^--[a-zA-Z0-9-]+=$");
|
||||||
|
|
||||||
public static string[] Parse(string text)
|
public static string[] Parse(string text)
|
||||||
{
|
{
|
||||||
List<string> result = new List<string>();
|
List<string> result = new List<string>();
|
||||||
|
@ -544,10 +550,38 @@ namespace OpenSim.Framework.Console
|
||||||
if (index % 2 == 0)
|
if (index % 2 == 0)
|
||||||
{
|
{
|
||||||
string[] words = unquoted[index].Split(new char[] {' '});
|
string[] words = unquoted[index].Split(new char[] {' '});
|
||||||
|
|
||||||
|
bool option = false;
|
||||||
foreach (string w in words)
|
foreach (string w in words)
|
||||||
{
|
{
|
||||||
if (w != String.Empty)
|
if (w != String.Empty)
|
||||||
|
{
|
||||||
|
if (optionRegex.Match(w) == Match.Empty)
|
||||||
|
option = false;
|
||||||
|
else
|
||||||
|
option = true;
|
||||||
result.Add(w);
|
result.Add(w);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// The last item matched the regex, put the quotes back
|
||||||
|
if (option)
|
||||||
|
{
|
||||||
|
// If the line ended with it, don't do anything
|
||||||
|
if (index < (unquoted.Length - 1))
|
||||||
|
{
|
||||||
|
// Get and remove the option name
|
||||||
|
string optionText = result[result.Count - 1];
|
||||||
|
result.RemoveAt(result.Count - 1);
|
||||||
|
|
||||||
|
// Add the quoted value back
|
||||||
|
optionText += "\"" + unquoted[index + 1] + "\"";
|
||||||
|
|
||||||
|
// Push the result into our return array
|
||||||
|
result.Add(optionText);
|
||||||
|
|
||||||
|
// Skip the already used value
|
||||||
|
index++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
|
@ -627,7 +627,6 @@ namespace OpenSim.Framework
|
||||||
|
|
||||||
foreach (String s in allKeys)
|
foreach (String s in allKeys)
|
||||||
{
|
{
|
||||||
string val = config.GetString(s);
|
|
||||||
SetOtherSetting(s, config.GetString(s));
|
SetOtherSetting(s, config.GetString(s));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,15 +49,16 @@ namespace OpenSim.Framework.Serialization.External
|
||||||
/// <param name="nodeToFill"></param>
|
/// <param name="nodeToFill"></param>
|
||||||
/// <param name="processors">/param>
|
/// <param name="processors">/param>
|
||||||
/// <param name="xtr"></param>
|
/// <param name="xtr"></param>
|
||||||
public static void ExecuteReadProcessors<NodeType>(
|
/// <returns>true on successful, false if there were any processing failures</returns>
|
||||||
|
public static bool ExecuteReadProcessors<NodeType>(
|
||||||
NodeType nodeToFill, Dictionary<string, Action<NodeType, XmlTextReader>> processors, XmlTextReader xtr)
|
NodeType nodeToFill, Dictionary<string, Action<NodeType, XmlTextReader>> processors, XmlTextReader xtr)
|
||||||
{
|
{
|
||||||
ExecuteReadProcessors(
|
return ExecuteReadProcessors(
|
||||||
nodeToFill,
|
nodeToFill,
|
||||||
processors,
|
processors,
|
||||||
xtr,
|
xtr,
|
||||||
(o, name, e)
|
(o, name, e)
|
||||||
=> m_log.ErrorFormat(
|
=> m_log.DebugFormat(
|
||||||
"[ExternalRepresentationUtils]: Exception while parsing element {0}, continuing. Exception {1}{2}",
|
"[ExternalRepresentationUtils]: Exception while parsing element {0}, continuing. Exception {1}{2}",
|
||||||
name, e.Message, e.StackTrace));
|
name, e.Message, e.StackTrace));
|
||||||
}
|
}
|
||||||
|
@ -71,12 +72,15 @@ namespace OpenSim.Framework.Serialization.External
|
||||||
/// <param name="parseExceptionAction">
|
/// <param name="parseExceptionAction">
|
||||||
/// Action to take if there is a parsing problem. This will usually just be to log the exception
|
/// Action to take if there is a parsing problem. This will usually just be to log the exception
|
||||||
/// </param>
|
/// </param>
|
||||||
public static void ExecuteReadProcessors<NodeType>(
|
/// <returns>true on successful, false if there were any processing failures</returns>
|
||||||
|
public static bool ExecuteReadProcessors<NodeType>(
|
||||||
NodeType nodeToFill,
|
NodeType nodeToFill,
|
||||||
Dictionary<string, Action<NodeType, XmlTextReader>> processors,
|
Dictionary<string, Action<NodeType, XmlTextReader>> processors,
|
||||||
XmlTextReader xtr,
|
XmlTextReader xtr,
|
||||||
Action<NodeType, string, Exception> parseExceptionAction)
|
Action<NodeType, string, Exception> parseExceptionAction)
|
||||||
{
|
{
|
||||||
|
bool errors = false;
|
||||||
|
|
||||||
string nodeName = string.Empty;
|
string nodeName = string.Empty;
|
||||||
while (xtr.NodeType != XmlNodeType.EndElement)
|
while (xtr.NodeType != XmlNodeType.EndElement)
|
||||||
{
|
{
|
||||||
|
@ -95,6 +99,7 @@ namespace OpenSim.Framework.Serialization.External
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
|
errors = true;
|
||||||
parseExceptionAction(nodeToFill, nodeName, e);
|
parseExceptionAction(nodeToFill, nodeName, e);
|
||||||
|
|
||||||
if (xtr.NodeType == XmlNodeType.EndElement)
|
if (xtr.NodeType == XmlNodeType.EndElement)
|
||||||
|
@ -107,6 +112,8 @@ namespace OpenSim.Framework.Serialization.External
|
||||||
xtr.ReadOuterXml(); // ignore
|
xtr.ReadOuterXml(); // ignore
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return errors;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
@ -140,6 +147,7 @@ namespace OpenSim.Framework.Serialization.External
|
||||||
UUID.TryParse(node.InnerText, out uuid);
|
UUID.TryParse(node.InnerText, out uuid);
|
||||||
creator = userService.GetUserAccount(scopeID, uuid);
|
creator = userService.GetUserAccount(scopeID, uuid);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (node.Name == "CreatorData" && node.InnerText != null && node.InnerText != string.Empty)
|
if (node.Name == "CreatorData" && node.InnerText != null && node.InnerText != string.Empty)
|
||||||
hasCreatorData = true;
|
hasCreatorData = true;
|
||||||
|
|
||||||
|
@ -163,7 +171,6 @@ namespace OpenSim.Framework.Serialization.External
|
||||||
doc.Save(wr);
|
doc.Save(wr);
|
||||||
return wr.ToString();
|
return wr.ToString();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1676,13 +1676,14 @@ namespace OpenSim.Framework
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static void PrintCallStack()
|
public static void PrintCallStack()
|
||||||
{
|
{
|
||||||
StackTrace stackTrace = new StackTrace(); // get call stack
|
StackTrace stackTrace = new StackTrace(true); // get call stack
|
||||||
StackFrame[] stackFrames = stackTrace.GetFrames(); // get method calls (frames)
|
StackFrame[] stackFrames = stackTrace.GetFrames(); // get method calls (frames)
|
||||||
|
|
||||||
// write call stack method names
|
// write call stack method names
|
||||||
foreach (StackFrame stackFrame in stackFrames)
|
foreach (StackFrame stackFrame in stackFrames)
|
||||||
{
|
{
|
||||||
m_log.Debug(stackFrame.GetMethod().DeclaringType + "." + stackFrame.GetMethod().Name); // write method name
|
MethodBase mb = stackFrame.GetMethod();
|
||||||
|
m_log.DebugFormat("{0}.{1}:{2}", mb.DeclaringType, mb.Name, stackFrame.GetFileLineNumber()); // write method name
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1549,7 +1549,8 @@ namespace OpenSim.Region.ClientStack.LindenUDP
|
||||||
|
|
||||||
public void SendKillObject(ulong regionHandle, List<uint> localIDs)
|
public void SendKillObject(ulong regionHandle, List<uint> localIDs)
|
||||||
{
|
{
|
||||||
// m_log.DebugFormat("[CLIENT]: Sending KillObjectPacket to {0} for {1} in {2}", Name, localID, regionHandle);
|
// foreach (uint id in localIDs)
|
||||||
|
// m_log.DebugFormat("[CLIENT]: Sending KillObjectPacket to {0} for {1} in {2}", Name, id, regionHandle);
|
||||||
|
|
||||||
KillObjectPacket kill = (KillObjectPacket)PacketPool.Instance.GetPacket(PacketType.KillObject);
|
KillObjectPacket kill = (KillObjectPacket)PacketPool.Instance.GetPacket(PacketType.KillObject);
|
||||||
// TODO: don't create new blocks if recycling an old packet
|
// TODO: don't create new blocks if recycling an old packet
|
||||||
|
@ -7689,6 +7690,13 @@ namespace OpenSim.Region.ClientStack.LindenUDP
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
if (transfer.TransferInfo.SourceType == (int)SourceType.SimEstate)
|
||||||
|
{
|
||||||
|
//TransferRequestPacket does not include covenant uuid?
|
||||||
|
//get scene covenant uuid
|
||||||
|
taskID = m_scene.RegionInfo.RegionSettings.Covenant;
|
||||||
|
}
|
||||||
|
|
||||||
MakeAssetRequest(transfer, taskID);
|
MakeAssetRequest(transfer, taskID);
|
||||||
|
|
||||||
|
@ -12113,6 +12121,11 @@ namespace OpenSim.Region.ClientStack.LindenUDP
|
||||||
{
|
{
|
||||||
requestID = new UUID(transferRequest.TransferInfo.Params, 80);
|
requestID = new UUID(transferRequest.TransferInfo.Params, 80);
|
||||||
}
|
}
|
||||||
|
else if (transferRequest.TransferInfo.SourceType == (int)SourceType.SimEstate)
|
||||||
|
{
|
||||||
|
requestID = taskID;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// m_log.DebugFormat("[CLIENT]: {0} requesting asset {1}", Name, requestID);
|
// m_log.DebugFormat("[CLIENT]: {0} requesting asset {1}", Name, requestID);
|
||||||
|
|
||||||
|
|
|
@ -111,6 +111,15 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
|
||||||
|
|
||||||
#region IAvatarFactoryModule
|
#region IAvatarFactoryModule
|
||||||
|
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="sp"></param>
|
||||||
|
/// <param name="texture"></param>
|
||||||
|
/// <param name="visualParam"></param>
|
||||||
|
public void SetAppearance(IScenePresence sp, AvatarAppearance appearance)
|
||||||
|
{
|
||||||
|
SetAppearance(sp, appearance.Texture, appearance.VisualParams);
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Set appearance data (texture asset IDs and slider settings)
|
/// Set appearance data (texture asset IDs and slider settings)
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -156,14 +165,23 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
|
||||||
changed = sp.Appearance.SetTextureEntries(textureEntry) || changed;
|
changed = sp.Appearance.SetTextureEntries(textureEntry) || changed;
|
||||||
|
|
||||||
// WriteBakedTexturesReport(sp, m_log.DebugFormat);
|
// WriteBakedTexturesReport(sp, m_log.DebugFormat);
|
||||||
if (!ValidateBakedTextureCache(sp))
|
|
||||||
|
// If bake textures are missing and this is not an NPC, request a rebake from client
|
||||||
|
if (!ValidateBakedTextureCache(sp) && (((ScenePresence)sp).PresenceType != PresenceType.Npc))
|
||||||
RequestRebake(sp, true);
|
RequestRebake(sp, true);
|
||||||
|
|
||||||
// This appears to be set only in the final stage of the appearance
|
// This appears to be set only in the final stage of the appearance
|
||||||
// update transaction. In theory, we should be able to do an immediate
|
// update transaction. In theory, we should be able to do an immediate
|
||||||
// appearance send and save here.
|
// appearance send and save here.
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// NPC should send to clients immediately and skip saving appearance
|
||||||
|
if (((ScenePresence)sp).PresenceType == PresenceType.Npc)
|
||||||
|
{
|
||||||
|
SendAppearance((ScenePresence)sp);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// save only if there were changes, send no matter what (doesn't hurt to send twice)
|
// save only if there were changes, send no matter what (doesn't hurt to send twice)
|
||||||
if (changed)
|
if (changed)
|
||||||
QueueAppearanceSave(sp.ControllingClient.AgentId);
|
QueueAppearanceSave(sp.ControllingClient.AgentId);
|
||||||
|
@ -174,6 +192,15 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
|
||||||
// m_log.WarnFormat("[AVFACTORY]: complete SetAppearance for {0}:\n{1}",client.AgentId,sp.Appearance.ToString());
|
// m_log.WarnFormat("[AVFACTORY]: complete SetAppearance for {0}:\n{1}",client.AgentId,sp.Appearance.ToString());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void SendAppearance(ScenePresence sp)
|
||||||
|
{
|
||||||
|
// Send the appearance to everyone in the scene
|
||||||
|
sp.SendAppearanceToAllOtherAgents();
|
||||||
|
|
||||||
|
// Send animations back to the avatar as well
|
||||||
|
sp.Animator.SendAnimPack();
|
||||||
|
}
|
||||||
|
|
||||||
public bool SendAppearance(UUID agentId)
|
public bool SendAppearance(UUID agentId)
|
||||||
{
|
{
|
||||||
// m_log.DebugFormat("[AVFACTORY]: Sending appearance for {0}", agentId);
|
// m_log.DebugFormat("[AVFACTORY]: Sending appearance for {0}", agentId);
|
||||||
|
@ -185,12 +212,7 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Send the appearance to everyone in the scene
|
SendAppearance(sp);
|
||||||
sp.SendAppearanceToAllOtherAgents();
|
|
||||||
|
|
||||||
// Send animations back to the avatar as well
|
|
||||||
sp.Animator.SendAnimPack();
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -626,4 +648,4 @@ namespace OpenSim.Region.CoreModules.Avatar.AvatarFactory
|
||||||
outputAction("{0} baked appearance texture is {1}", sp.Name, bakedTextureValid ? "OK" : "corrupt");
|
outputAction("{0} baked appearance texture is {1}", sp.Name, bakedTextureValid ? "OK" : "corrupt");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -681,11 +681,10 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
|
||||||
|
|
||||||
#region Agent Crossings
|
#region Agent Crossings
|
||||||
|
|
||||||
public bool Cross(ScenePresence agent, bool isFlying)
|
public GridRegion GetDestination(Scene scene, UUID agentID, Vector3 pos, out uint xDest, out uint yDest, out string version, out Vector3 newpos)
|
||||||
{
|
{
|
||||||
Scene scene = agent.Scene;
|
version = String.Empty;
|
||||||
Vector3 pos = agent.AbsolutePosition;
|
newpos = new Vector3(pos.X, pos.Y, pos.Z);
|
||||||
Vector3 newpos = new Vector3(pos.X, pos.Y, pos.Z);
|
|
||||||
uint neighbourx = scene.RegionInfo.RegionLocX;
|
uint neighbourx = scene.RegionInfo.RegionLocX;
|
||||||
uint neighboury = scene.RegionInfo.RegionLocY;
|
uint neighboury = scene.RegionInfo.RegionLocY;
|
||||||
const float boundaryDistance = 1.7f;
|
const float boundaryDistance = 1.7f;
|
||||||
|
@ -706,53 +705,12 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
|
||||||
}
|
}
|
||||||
else if (scene.TestBorderCross(pos + southCross, Cardinals.S))
|
else if (scene.TestBorderCross(pos + southCross, Cardinals.S))
|
||||||
{
|
{
|
||||||
Border b = scene.GetCrossedBorder(pos + southCross, Cardinals.S);
|
neighboury--;
|
||||||
if (b.TriggerRegionX == 0 && b.TriggerRegionY == 0)
|
newpos.Y = Constants.RegionSize - enterDistance;
|
||||||
{
|
|
||||||
neighboury--;
|
|
||||||
newpos.Y = Constants.RegionSize - enterDistance;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
agent.IsInTransit = true;
|
|
||||||
|
|
||||||
neighboury = b.TriggerRegionY;
|
|
||||||
neighbourx = b.TriggerRegionX;
|
|
||||||
|
|
||||||
Vector3 newposition = pos;
|
|
||||||
newposition.X += (scene.RegionInfo.RegionLocX - neighbourx) * Constants.RegionSize;
|
|
||||||
newposition.Y += (scene.RegionInfo.RegionLocY - neighboury) * Constants.RegionSize;
|
|
||||||
agent.ControllingClient.SendAgentAlertMessage(
|
|
||||||
String.Format("Moving you to region {0},{1}", neighbourx, neighboury), false);
|
|
||||||
InformClientToInitateTeleportToLocation(agent, neighbourx, neighboury, newposition, scene);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Border ba = scene.GetCrossedBorder(pos + westCross, Cardinals.W);
|
neighbourx--;
|
||||||
if (ba.TriggerRegionX == 0 && ba.TriggerRegionY == 0)
|
newpos.X = Constants.RegionSize - enterDistance;
|
||||||
{
|
|
||||||
neighbourx--;
|
|
||||||
newpos.X = Constants.RegionSize - enterDistance;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
agent.IsInTransit = true;
|
|
||||||
|
|
||||||
neighboury = ba.TriggerRegionY;
|
|
||||||
neighbourx = ba.TriggerRegionX;
|
|
||||||
|
|
||||||
|
|
||||||
Vector3 newposition = pos;
|
|
||||||
newposition.X += (scene.RegionInfo.RegionLocX - neighbourx) * Constants.RegionSize;
|
|
||||||
newposition.Y += (scene.RegionInfo.RegionLocY - neighboury) * Constants.RegionSize;
|
|
||||||
agent.ControllingClient.SendAgentAlertMessage(
|
|
||||||
String.Format("Moving you to region {0},{1}", neighbourx, neighboury), false);
|
|
||||||
InformClientToInitateTeleportToLocation(agent, neighbourx, neighboury, newposition, scene);
|
|
||||||
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
else if (scene.TestBorderCross(pos + eastCross, Cardinals.E))
|
else if (scene.TestBorderCross(pos + eastCross, Cardinals.E))
|
||||||
|
@ -763,26 +721,8 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
|
||||||
|
|
||||||
if (scene.TestBorderCross(pos + southCross, Cardinals.S))
|
if (scene.TestBorderCross(pos + southCross, Cardinals.S))
|
||||||
{
|
{
|
||||||
Border ba = scene.GetCrossedBorder(pos + southCross, Cardinals.S);
|
neighboury--;
|
||||||
if (ba.TriggerRegionX == 0 && ba.TriggerRegionY == 0)
|
newpos.Y = Constants.RegionSize - enterDistance;
|
||||||
{
|
|
||||||
neighboury--;
|
|
||||||
newpos.Y = Constants.RegionSize - enterDistance;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
agent.IsInTransit = true;
|
|
||||||
|
|
||||||
neighboury = ba.TriggerRegionY;
|
|
||||||
neighbourx = ba.TriggerRegionX;
|
|
||||||
Vector3 newposition = pos;
|
|
||||||
newposition.X += (scene.RegionInfo.RegionLocX - neighbourx) * Constants.RegionSize;
|
|
||||||
newposition.Y += (scene.RegionInfo.RegionLocY - neighboury) * Constants.RegionSize;
|
|
||||||
agent.ControllingClient.SendAgentAlertMessage(
|
|
||||||
String.Format("Moving you to region {0},{1}", neighbourx, neighboury), false);
|
|
||||||
InformClientToInitateTeleportToLocation(agent, neighbourx, neighboury, newposition, scene);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else if (scene.TestBorderCross(pos + northCross, Cardinals.N))
|
else if (scene.TestBorderCross(pos + northCross, Cardinals.N))
|
||||||
{
|
{
|
||||||
|
@ -790,35 +730,15 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
|
||||||
neighboury += (uint)(int)(c.BorderLine.Z / (int)Constants.RegionSize);
|
neighboury += (uint)(int)(c.BorderLine.Z / (int)Constants.RegionSize);
|
||||||
newpos.Y = enterDistance;
|
newpos.Y = enterDistance;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
else if (scene.TestBorderCross(pos + southCross, Cardinals.S))
|
else if (scene.TestBorderCross(pos + southCross, Cardinals.S))
|
||||||
{
|
{
|
||||||
Border b = scene.GetCrossedBorder(pos + southCross, Cardinals.S);
|
Border b = scene.GetCrossedBorder(pos + southCross, Cardinals.S);
|
||||||
if (b.TriggerRegionX == 0 && b.TriggerRegionY == 0)
|
neighboury--;
|
||||||
{
|
newpos.Y = Constants.RegionSize - enterDistance;
|
||||||
neighboury--;
|
|
||||||
newpos.Y = Constants.RegionSize - enterDistance;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
agent.IsInTransit = true;
|
|
||||||
|
|
||||||
neighboury = b.TriggerRegionY;
|
|
||||||
neighbourx = b.TriggerRegionX;
|
|
||||||
Vector3 newposition = pos;
|
|
||||||
newposition.X += (scene.RegionInfo.RegionLocX - neighbourx) * Constants.RegionSize;
|
|
||||||
newposition.Y += (scene.RegionInfo.RegionLocY - neighboury) * Constants.RegionSize;
|
|
||||||
agent.ControllingClient.SendAgentAlertMessage(
|
|
||||||
String.Format("Moving you to region {0},{1}", neighbourx, neighboury), false);
|
|
||||||
InformClientToInitateTeleportToLocation(agent, neighbourx, neighboury, newposition, scene);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else if (scene.TestBorderCross(pos + northCross, Cardinals.N))
|
else if (scene.TestBorderCross(pos + northCross, Cardinals.N))
|
||||||
{
|
{
|
||||||
|
|
||||||
Border b = scene.GetCrossedBorder(pos + northCross, Cardinals.N);
|
Border b = scene.GetCrossedBorder(pos + northCross, Cardinals.N);
|
||||||
neighboury += (uint)(int)(b.BorderLine.Z / (int)Constants.RegionSize);
|
neighboury += (uint)(int)(b.BorderLine.Z / (int)Constants.RegionSize);
|
||||||
newpos.Y = enterDistance;
|
newpos.Y = enterDistance;
|
||||||
|
@ -849,19 +769,22 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
ulong neighbourHandle = Utils.UIntsToLong((uint)(neighbourx * Constants.RegionSize), (uint)(neighboury * Constants.RegionSize));
|
xDest = neighbourx;
|
||||||
|
yDest = neighboury;
|
||||||
|
|
||||||
int x = (int)(neighbourx * Constants.RegionSize), y = (int)(neighboury * Constants.RegionSize);
|
int x = (int)(neighbourx * Constants.RegionSize), y = (int)(neighboury * Constants.RegionSize);
|
||||||
|
|
||||||
|
ulong neighbourHandle = Utils.UIntsToLong((uint)x, (uint)y);
|
||||||
|
|
||||||
ExpiringCache<ulong, DateTime> r;
|
ExpiringCache<ulong, DateTime> r;
|
||||||
DateTime banUntil;
|
DateTime banUntil;
|
||||||
|
|
||||||
if (m_bannedRegions.TryGetValue(agent.ControllingClient.AgentId, out r))
|
if (m_bannedRegions.TryGetValue(agentID, out r))
|
||||||
{
|
{
|
||||||
if (r.TryGetValue(neighbourHandle, out banUntil))
|
if (r.TryGetValue(neighbourHandle, out banUntil))
|
||||||
{
|
{
|
||||||
if (DateTime.Now < banUntil)
|
if (DateTime.Now < banUntil)
|
||||||
return false;
|
return null;
|
||||||
r.Remove(neighbourHandle);
|
r.Remove(neighbourHandle);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -873,28 +796,43 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
|
||||||
GridRegion neighbourRegion = scene.GridService.GetRegionByPosition(scene.RegionInfo.ScopeID, (int)x, (int)y);
|
GridRegion neighbourRegion = scene.GridService.GetRegionByPosition(scene.RegionInfo.ScopeID, (int)x, (int)y);
|
||||||
|
|
||||||
string reason;
|
string reason;
|
||||||
string version;
|
if (!scene.SimulationService.QueryAccess(neighbourRegion, agentID, newpos, out version, out reason))
|
||||||
if (!scene.SimulationService.QueryAccess(neighbourRegion, agent.ControllingClient.AgentId, newpos, out version, out reason))
|
|
||||||
{
|
{
|
||||||
agent.ControllingClient.SendAlertMessage("Cannot region cross into banned parcel");
|
|
||||||
if (r == null)
|
if (r == null)
|
||||||
{
|
{
|
||||||
r = new ExpiringCache<ulong, DateTime>();
|
r = new ExpiringCache<ulong, DateTime>();
|
||||||
r.Add(neighbourHandle, DateTime.Now + TimeSpan.FromSeconds(15), TimeSpan.FromSeconds(15));
|
r.Add(neighbourHandle, DateTime.Now + TimeSpan.FromSeconds(15), TimeSpan.FromSeconds(15));
|
||||||
|
|
||||||
m_bannedRegions.Add(agent.ControllingClient.AgentId, r, TimeSpan.FromSeconds(45));
|
m_bannedRegions.Add(agentID, r, TimeSpan.FromSeconds(45));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
r.Add(neighbourHandle, DateTime.Now + TimeSpan.FromSeconds(15), TimeSpan.FromSeconds(15));
|
r.Add(neighbourHandle, DateTime.Now + TimeSpan.FromSeconds(15), TimeSpan.FromSeconds(15));
|
||||||
}
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
return neighbourRegion;
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool Cross(ScenePresence agent, bool isFlying)
|
||||||
|
{
|
||||||
|
uint x;
|
||||||
|
uint y;
|
||||||
|
Vector3 newpos;
|
||||||
|
string version;
|
||||||
|
|
||||||
|
GridRegion neighbourRegion = GetDestination(agent.Scene, agent.UUID, agent.AbsolutePosition, out x, out y, out version, out newpos);
|
||||||
|
if (neighbourRegion == null)
|
||||||
|
{
|
||||||
|
agent.ControllingClient.SendAlertMessage("Cannot region cross into banned parcel");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
agent.IsInTransit = true;
|
agent.IsInTransit = true;
|
||||||
|
|
||||||
CrossAgentToNewRegionDelegate d = CrossAgentToNewRegionAsync;
|
CrossAgentToNewRegionDelegate d = CrossAgentToNewRegionAsync;
|
||||||
d.BeginInvoke(agent, newpos, neighbourx, neighboury, neighbourRegion, isFlying, version, CrossAgentToNewRegionCompleted, d);
|
d.BeginInvoke(agent, newpos, x, y, neighbourRegion, isFlying, version, CrossAgentToNewRegionCompleted, d);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -951,13 +889,11 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
|
||||||
icon.EndInvoke(iar);
|
icon.EndInvoke(iar);
|
||||||
}
|
}
|
||||||
|
|
||||||
public delegate ScenePresence CrossAgentToNewRegionDelegate(ScenePresence agent, Vector3 pos, uint neighbourx, uint neighboury, GridRegion neighbourRegion, bool isFlying, string version);
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// This Closes child agents on neighbouring regions
|
/// This Closes child agents on neighbouring regions
|
||||||
/// Calls an asynchronous method to do so.. so it doesn't lag the sim.
|
/// Calls an asynchronous method to do so.. so it doesn't lag the sim.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
protected ScenePresence CrossAgentToNewRegionAsync(
|
public ScenePresence CrossAgentToNewRegionAsync(
|
||||||
ScenePresence agent, Vector3 pos, uint neighbourx, uint neighboury, GridRegion neighbourRegion,
|
ScenePresence agent, Vector3 pos, uint neighbourx, uint neighboury, GridRegion neighbourRegion,
|
||||||
bool isFlying, string version)
|
bool isFlying, string version)
|
||||||
{
|
{
|
||||||
|
@ -1731,17 +1667,17 @@ namespace OpenSim.Region.CoreModules.Framework.EntityTransfer
|
||||||
{
|
{
|
||||||
m_log.InfoFormat("[ENTITY TRANSFER MODULE] cross region transfer failed for object {0}",grp.UUID);
|
m_log.InfoFormat("[ENTITY TRANSFER MODULE] cross region transfer failed for object {0}",grp.UUID);
|
||||||
|
|
||||||
|
// Need to turn off the physics flags, otherwise the object will continue to attempt to
|
||||||
|
// move out of the region creating an infinite loop of failed attempts to cross
|
||||||
|
grp.UpdatePrimFlags(grp.RootPart.LocalId,false,grp.IsTemporary,grp.IsPhantom,false);
|
||||||
|
|
||||||
// We are going to move the object back to the old position so long as the old position
|
// We are going to move the object back to the old position so long as the old position
|
||||||
// is in the region
|
// is in the region
|
||||||
oldGroupPosition.X = Util.Clamp<float>(oldGroupPosition.X,1.0f,(float)Constants.RegionSize-1);
|
oldGroupPosition.X = Util.Clamp<float>(oldGroupPosition.X,1.0f,(float)Constants.RegionSize-1);
|
||||||
oldGroupPosition.Y = Util.Clamp<float>(oldGroupPosition.Y,1.0f,(float)Constants.RegionSize-1);
|
oldGroupPosition.Y = Util.Clamp<float>(oldGroupPosition.Y,1.0f,(float)Constants.RegionSize-1);
|
||||||
oldGroupPosition.Z = Util.Clamp<float>(oldGroupPosition.Z,1.0f,4096.0f);
|
oldGroupPosition.Z = Util.Clamp<float>(oldGroupPosition.Z,1.0f,4096.0f);
|
||||||
|
|
||||||
grp.RootPart.GroupPosition = oldGroupPosition;
|
grp.AbsolutePosition = oldGroupPosition;
|
||||||
|
|
||||||
// Need to turn off the physics flags, otherwise the object will continue to attempt to
|
|
||||||
// move out of the region creating an infinite loop of failed attempts to cross
|
|
||||||
grp.UpdatePrimFlags(grp.RootPart.LocalId,false,grp.IsTemporary,grp.IsPhantom,false);
|
|
||||||
|
|
||||||
grp.ScheduleGroupForFullUpdate();
|
grp.ScheduleGroupForFullUpdate();
|
||||||
}
|
}
|
||||||
|
|
|
@ -560,12 +560,20 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess
|
||||||
return null;
|
return null;
|
||||||
|
|
||||||
userID = remoteClient.AgentId;
|
userID = remoteClient.AgentId;
|
||||||
|
|
||||||
|
// m_log.DebugFormat(
|
||||||
|
// "[INVENTORY ACCESS MODULE]: Target of {0} in CreateItemForObject() is {1} {2}",
|
||||||
|
// action, remoteClient.Name, userID);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// All returns / deletes go to the object owner
|
// All returns / deletes go to the object owner
|
||||||
//
|
//
|
||||||
userID = so.RootPart.OwnerID;
|
userID = so.RootPart.OwnerID;
|
||||||
|
|
||||||
|
// m_log.DebugFormat(
|
||||||
|
// "[INVENTORY ACCESS MODULE]: Target of {0} in CreateItemForObject() is object owner {1}",
|
||||||
|
// action, userID);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (userID == UUID.Zero) // Can't proceed
|
if (userID == UUID.Zero) // Can't proceed
|
||||||
|
@ -651,11 +659,11 @@ namespace OpenSim.Region.CoreModules.Framework.InventoryAccess
|
||||||
}
|
}
|
||||||
|
|
||||||
// Override and put into where it came from, if it came
|
// Override and put into where it came from, if it came
|
||||||
// from anywhere in inventory
|
// from anywhere in inventory and the owner is taking it back.
|
||||||
//
|
//
|
||||||
if (action == DeRezAction.Take || action == DeRezAction.TakeCopy)
|
if (action == DeRezAction.Take || action == DeRezAction.TakeCopy)
|
||||||
{
|
{
|
||||||
if (so.RootPart.FromFolderID != UUID.Zero)
|
if (so.RootPart.FromFolderID != UUID.Zero && userID == remoteClient.AgentId)
|
||||||
{
|
{
|
||||||
InventoryFolderBase f = new InventoryFolderBase(so.RootPart.FromFolderID, userID);
|
InventoryFolderBase f = new InventoryFolderBase(so.RootPart.FromFolderID, userID);
|
||||||
if (f != null)
|
if (f != null)
|
||||||
|
|
|
@ -707,7 +707,12 @@ namespace OpenSim.Region.CoreModules.World.Permissions
|
||||||
// Object owners should be able to edit their own content
|
// Object owners should be able to edit their own content
|
||||||
if (currentUser == objectOwner)
|
if (currentUser == objectOwner)
|
||||||
{
|
{
|
||||||
permission = true;
|
// there is no way that later code can change this back to false
|
||||||
|
// so just return true immediately and short circuit the more
|
||||||
|
// expensive group checks
|
||||||
|
return true;
|
||||||
|
|
||||||
|
//permission = true;
|
||||||
}
|
}
|
||||||
else if (group.IsAttachment)
|
else if (group.IsAttachment)
|
||||||
{
|
{
|
||||||
|
|
|
@ -35,6 +35,7 @@ namespace OpenSim.Region.Framework.Interfaces
|
||||||
|
|
||||||
public interface IAvatarFactoryModule
|
public interface IAvatarFactoryModule
|
||||||
{
|
{
|
||||||
|
void SetAppearance(IScenePresence sp, AvatarAppearance appearance);
|
||||||
void SetAppearance(IScenePresence sp, Primitive.TextureEntry textureEntry, byte[] visualParams);
|
void SetAppearance(IScenePresence sp, Primitive.TextureEntry textureEntry, byte[] visualParams);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
|
|
@ -35,6 +35,8 @@ using OpenSim.Region.Framework.Scenes;
|
||||||
|
|
||||||
namespace OpenSim.Region.Framework.Interfaces
|
namespace OpenSim.Region.Framework.Interfaces
|
||||||
{
|
{
|
||||||
|
public delegate ScenePresence CrossAgentToNewRegionDelegate(ScenePresence agent, Vector3 pos, uint neighbourx, uint neighboury, GridRegion neighbourRegion, bool isFlying, string version);
|
||||||
|
|
||||||
public interface IEntityTransferModule
|
public interface IEntityTransferModule
|
||||||
{
|
{
|
||||||
void Teleport(ScenePresence agent, ulong regionHandle, Vector3 position,
|
void Teleport(ScenePresence agent, ulong regionHandle, Vector3 position,
|
||||||
|
@ -53,7 +55,12 @@ namespace OpenSim.Region.Framework.Interfaces
|
||||||
|
|
||||||
void EnableChildAgent(ScenePresence agent, GridRegion region);
|
void EnableChildAgent(ScenePresence agent, GridRegion region);
|
||||||
|
|
||||||
|
GridRegion GetDestination(Scene scene, UUID agentID, Vector3 pos, out uint xDest, out uint yDest, out string version, out Vector3 newpos);
|
||||||
|
|
||||||
void Cross(SceneObjectGroup sog, Vector3 position, bool silent);
|
void Cross(SceneObjectGroup sog, Vector3 position, bool silent);
|
||||||
|
|
||||||
|
ScenePresence CrossAgentToNewRegionAsync(ScenePresence agent, Vector3 pos, uint neighbourx, uint neighboury, GridRegion neighbourRegion, bool isFlying, string version);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public interface IUserAgentVerificationModule
|
public interface IUserAgentVerificationModule
|
||||||
|
|
|
@ -148,7 +148,8 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
x = m_inventoryDeletes.Dequeue();
|
x = m_inventoryDeletes.Dequeue();
|
||||||
|
|
||||||
m_log.DebugFormat(
|
m_log.DebugFormat(
|
||||||
"[ASYNC DELETER]: Sending object to user's inventory, action {1}, count {2}, {0} item(s) remaining.", left, x.action, x.objectGroups.Count);
|
"[ASYNC DELETER]: Sending object to user's inventory, action {1}, count {2}, {0} item(s) remaining.",
|
||||||
|
left, x.action, x.objectGroups.Count);
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
|
|
@ -3408,9 +3408,9 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
// Don't disable this log message - it's too helpful
|
// Don't disable this log message - it's too helpful
|
||||||
m_log.DebugFormat(
|
m_log.DebugFormat(
|
||||||
"[SCENE]: Region {0} told of incoming {1} agent {2} {3} {4} (circuit code {5}, teleportflags {6}, position {7})",
|
"[SCENE]: Region {0} told of incoming {1} agent {2} {3} {4} (circuit code {5}, IP {6}, viewer {7}, teleportflags {8}, position {9})",
|
||||||
RegionInfo.RegionName, (agent.child ? "child" : "root"), agent.firstname, agent.lastname,
|
RegionInfo.RegionName, (agent.child ? "child" : "root"),agent.firstname, agent.lastname,
|
||||||
agent.AgentID, agent.circuitcode, teleportFlags, agent.startpos);
|
agent.AgentID, agent.circuitcode, agent.IPAddress, agent.Viewer, teleportFlags, agent.startpos);
|
||||||
|
|
||||||
if (LoginsDisabled)
|
if (LoginsDisabled)
|
||||||
{
|
{
|
||||||
|
|
|
@ -465,7 +465,77 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|| Scene.TestBorderCross(val - Vector3.UnitY, Cardinals.N) || Scene.TestBorderCross(val + Vector3.UnitY, Cardinals.S))
|
|| Scene.TestBorderCross(val - Vector3.UnitY, Cardinals.N) || Scene.TestBorderCross(val + Vector3.UnitY, Cardinals.S))
|
||||||
&& !IsAttachmentCheckFull() && (!Scene.LoadingPrims))
|
&& !IsAttachmentCheckFull() && (!Scene.LoadingPrims))
|
||||||
{
|
{
|
||||||
m_scene.CrossPrimGroupIntoNewRegion(val, this, true);
|
IEntityTransferModule entityTransfer = m_scene.RequestModuleInterface<IEntityTransferModule>();
|
||||||
|
uint x = 0;
|
||||||
|
uint y = 0;
|
||||||
|
string version = String.Empty;
|
||||||
|
Vector3 newpos = Vector3.Zero;
|
||||||
|
OpenSim.Services.Interfaces.GridRegion destination = null;
|
||||||
|
|
||||||
|
bool canCross = true;
|
||||||
|
foreach (ScenePresence av in m_linkedAvatars)
|
||||||
|
{
|
||||||
|
// We need to cross these agents. First, let's find
|
||||||
|
// out if any of them can't cross for some reason.
|
||||||
|
// We have to deny the crossing entirely if any
|
||||||
|
// of them are banned. Alternatively, we could
|
||||||
|
// unsit banned agents....
|
||||||
|
|
||||||
|
|
||||||
|
// We set the avatar position as being the object
|
||||||
|
// position to get the region to send to
|
||||||
|
if ((destination = entityTransfer.GetDestination(m_scene, av.UUID, val, out x, out y, out version, out newpos)) == null)
|
||||||
|
{
|
||||||
|
canCross = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_log.DebugFormat("[SCENE OBJECT]: Avatar {0} needs to be crossed to {1}", av.Name, destination.RegionName);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (canCross)
|
||||||
|
{
|
||||||
|
// We unparent the SP quietly so that it won't
|
||||||
|
// be made to stand up
|
||||||
|
foreach (ScenePresence av in m_linkedAvatars)
|
||||||
|
{
|
||||||
|
SceneObjectPart parentPart = m_scene.GetSceneObjectPart(av.ParentID);
|
||||||
|
if (parentPart != null)
|
||||||
|
av.ParentUUID = parentPart.UUID;
|
||||||
|
|
||||||
|
av.ParentID = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_scene.CrossPrimGroupIntoNewRegion(val, this, true);
|
||||||
|
|
||||||
|
// Normalize
|
||||||
|
if (val.X >= Constants.RegionSize)
|
||||||
|
val.X -= Constants.RegionSize;
|
||||||
|
if (val.Y >= Constants.RegionSize)
|
||||||
|
val.Y -= Constants.RegionSize;
|
||||||
|
if (val.X < 0)
|
||||||
|
val.X += Constants.RegionSize;
|
||||||
|
if (val.Y < 0)
|
||||||
|
val.Y += Constants.RegionSize;
|
||||||
|
|
||||||
|
// If it's deleted, crossing was successful
|
||||||
|
if (IsDeleted)
|
||||||
|
{
|
||||||
|
foreach (ScenePresence av in m_linkedAvatars)
|
||||||
|
{
|
||||||
|
m_log.DebugFormat("[SCENE OBJECT]: Crossing avatar {0} to {1}", av.Name, val);
|
||||||
|
|
||||||
|
av.IsInTransit = true;
|
||||||
|
|
||||||
|
CrossAgentToNewRegionDelegate d = entityTransfer.CrossAgentToNewRegionAsync;
|
||||||
|
d.BeginInvoke(av, val, x, y, destination, av.Flying, version, CrossAgentToNewRegionCompleted, d);
|
||||||
|
}
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
val = AbsolutePosition;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -524,6 +594,23 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void CrossAgentToNewRegionCompleted(IAsyncResult iar)
|
||||||
|
{
|
||||||
|
CrossAgentToNewRegionDelegate icon = (CrossAgentToNewRegionDelegate)iar.AsyncState;
|
||||||
|
ScenePresence agent = icon.EndInvoke(iar);
|
||||||
|
|
||||||
|
//// If the cross was successful, this agent is a child agent
|
||||||
|
//if (agent.IsChildAgent)
|
||||||
|
// agent.Reset();
|
||||||
|
//else // Not successful
|
||||||
|
// agent.RestoreInCurrentScene();
|
||||||
|
|
||||||
|
// In any case
|
||||||
|
agent.IsInTransit = false;
|
||||||
|
|
||||||
|
m_log.DebugFormat("[SCENE OBJECT]: Crossing agent {0} {1} completed.", agent.Firstname, agent.Lastname);
|
||||||
|
}
|
||||||
|
|
||||||
public override uint LocalId
|
public override uint LocalId
|
||||||
{
|
{
|
||||||
get { return m_rootPart.LocalId; }
|
get { return m_rootPart.LocalId; }
|
||||||
|
|
|
@ -233,6 +233,8 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
private bool m_collisionEventFlag = false;
|
private bool m_collisionEventFlag = false;
|
||||||
private object m_collisionEventLock = new Object();
|
private object m_collisionEventLock = new Object();
|
||||||
|
|
||||||
|
private Vector3 m_prevSitOffset;
|
||||||
|
|
||||||
protected AvatarAppearance m_appearance;
|
protected AvatarAppearance m_appearance;
|
||||||
|
|
||||||
public AvatarAppearance Appearance
|
public AvatarAppearance Appearance
|
||||||
|
@ -295,13 +297,10 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public PhysicsActor PhysicsActor { get; private set; }
|
public PhysicsActor PhysicsActor { get; private set; }
|
||||||
|
|
||||||
private byte m_movementflag;
|
/// <summary>
|
||||||
|
/// Record user movement inputs.
|
||||||
public byte MovementFlag
|
/// </summary>
|
||||||
{
|
public byte MovementFlag { get; private set; }
|
||||||
set { m_movementflag = value; }
|
|
||||||
get { return m_movementflag; }
|
|
||||||
}
|
|
||||||
|
|
||||||
private bool m_updateflag;
|
private bool m_updateflag;
|
||||||
|
|
||||||
|
@ -647,6 +646,13 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
}
|
}
|
||||||
private uint m_parentID;
|
private uint m_parentID;
|
||||||
|
|
||||||
|
public UUID ParentUUID
|
||||||
|
{
|
||||||
|
get { return m_parentUUID; }
|
||||||
|
set { m_parentUUID = value; }
|
||||||
|
}
|
||||||
|
private UUID m_parentUUID = UUID.Zero;
|
||||||
|
|
||||||
public float Health
|
public float Health
|
||||||
{
|
{
|
||||||
get { return m_health; }
|
get { return m_health; }
|
||||||
|
@ -868,7 +874,26 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
"[SCENE]: Upgrading child to root agent for {0} in {1}",
|
"[SCENE]: Upgrading child to root agent for {0} in {1}",
|
||||||
Name, m_scene.RegionInfo.RegionName);
|
Name, m_scene.RegionInfo.RegionName);
|
||||||
|
|
||||||
//m_log.DebugFormat("[SCENE]: known regions in {0}: {1}", Scene.RegionInfo.RegionName, KnownChildRegionHandles.Count);
|
if (ParentUUID != UUID.Zero)
|
||||||
|
{
|
||||||
|
m_log.DebugFormat("[SCENE PRESENCE]: Sitting avatar back on prim {0}", ParentUUID);
|
||||||
|
SceneObjectPart part = m_scene.GetSceneObjectPart(ParentUUID);
|
||||||
|
if (part == null)
|
||||||
|
{
|
||||||
|
m_log.ErrorFormat("[SCENE PRESENCE]: Can't find prim {0} to sit on", ParentUUID);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
part.ParentGroup.AddAvatar(UUID);
|
||||||
|
if (part.SitTargetPosition != Vector3.Zero)
|
||||||
|
part.SitTargetAvatar = UUID;
|
||||||
|
ParentPosition = part.GetWorldPosition();
|
||||||
|
ParentID = part.LocalId;
|
||||||
|
m_pos = m_prevSitOffset;
|
||||||
|
pos = ParentPosition;
|
||||||
|
}
|
||||||
|
ParentUUID = UUID.Zero;
|
||||||
|
}
|
||||||
|
|
||||||
bool wasChild = IsChildAgent;
|
bool wasChild = IsChildAgent;
|
||||||
IsChildAgent = false;
|
IsChildAgent = false;
|
||||||
|
@ -881,62 +906,64 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
m_scene.EventManager.TriggerSetRootAgentScene(m_uuid, m_scene);
|
m_scene.EventManager.TriggerSetRootAgentScene(m_uuid, m_scene);
|
||||||
|
|
||||||
// Moved this from SendInitialData to ensure that Appearance is initialized
|
if (ParentID == 0)
|
||||||
// before the inventory is processed in MakeRootAgent. This fixes a race condition
|
|
||||||
// related to the handling of attachments
|
|
||||||
//m_scene.GetAvatarAppearance(ControllingClient, out Appearance);
|
|
||||||
if (m_scene.TestBorderCross(pos, Cardinals.E))
|
|
||||||
{
|
{
|
||||||
Border crossedBorder = m_scene.GetCrossedBorder(pos, Cardinals.E);
|
// Moved this from SendInitialData to ensure that Appearance is initialized
|
||||||
pos.X = crossedBorder.BorderLine.Z - 1;
|
// before the inventory is processed in MakeRootAgent. This fixes a race condition
|
||||||
|
// related to the handling of attachments
|
||||||
|
//m_scene.GetAvatarAppearance(ControllingClient, out Appearance);
|
||||||
|
if (m_scene.TestBorderCross(pos, Cardinals.E))
|
||||||
|
{
|
||||||
|
Border crossedBorder = m_scene.GetCrossedBorder(pos, Cardinals.E);
|
||||||
|
pos.X = crossedBorder.BorderLine.Z - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (m_scene.TestBorderCross(pos, Cardinals.N))
|
||||||
|
{
|
||||||
|
Border crossedBorder = m_scene.GetCrossedBorder(pos, Cardinals.N);
|
||||||
|
pos.Y = crossedBorder.BorderLine.Z - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
CheckAndAdjustLandingPoint(ref pos);
|
||||||
|
|
||||||
|
if (pos.X < 0f || pos.Y < 0f || pos.Z < 0f)
|
||||||
|
{
|
||||||
|
m_log.WarnFormat(
|
||||||
|
"[SCENE PRESENCE]: MakeRootAgent() was given an illegal position of {0} for avatar {1}, {2}. Clamping",
|
||||||
|
pos, Name, UUID);
|
||||||
|
|
||||||
|
if (pos.X < 0f) pos.X = 0f;
|
||||||
|
if (pos.Y < 0f) pos.Y = 0f;
|
||||||
|
if (pos.Z < 0f) pos.Z = 0f;
|
||||||
|
}
|
||||||
|
|
||||||
|
float localAVHeight = 1.56f;
|
||||||
|
if (Appearance.AvatarHeight > 0)
|
||||||
|
localAVHeight = Appearance.AvatarHeight;
|
||||||
|
|
||||||
|
float posZLimit = 0;
|
||||||
|
|
||||||
|
if (pos.X < Constants.RegionSize && pos.Y < Constants.RegionSize)
|
||||||
|
posZLimit = (float)m_scene.Heightmap[(int)pos.X, (int)pos.Y];
|
||||||
|
|
||||||
|
float newPosZ = posZLimit + localAVHeight / 2;
|
||||||
|
if (posZLimit >= (pos.Z - (localAVHeight / 2)) && !(Single.IsInfinity(newPosZ) || Single.IsNaN(newPosZ)))
|
||||||
|
{
|
||||||
|
pos.Z = newPosZ;
|
||||||
|
}
|
||||||
|
AbsolutePosition = pos;
|
||||||
|
|
||||||
|
AddToPhysicalScene(isFlying);
|
||||||
|
|
||||||
|
if (ForceFly)
|
||||||
|
{
|
||||||
|
Flying = true;
|
||||||
|
}
|
||||||
|
else if (FlyDisabled)
|
||||||
|
{
|
||||||
|
Flying = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_scene.TestBorderCross(pos, Cardinals.N))
|
|
||||||
{
|
|
||||||
Border crossedBorder = m_scene.GetCrossedBorder(pos, Cardinals.N);
|
|
||||||
pos.Y = crossedBorder.BorderLine.Z - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
CheckAndAdjustLandingPoint(ref pos);
|
|
||||||
|
|
||||||
if (pos.X < 0f || pos.Y < 0f || pos.Z < 0f)
|
|
||||||
{
|
|
||||||
m_log.WarnFormat(
|
|
||||||
"[SCENE PRESENCE]: MakeRootAgent() was given an illegal position of {0} for avatar {1}, {2}. Clamping",
|
|
||||||
pos, Name, UUID);
|
|
||||||
|
|
||||||
if (pos.X < 0f) pos.X = 0f;
|
|
||||||
if (pos.Y < 0f) pos.Y = 0f;
|
|
||||||
if (pos.Z < 0f) pos.Z = 0f;
|
|
||||||
}
|
|
||||||
|
|
||||||
float localAVHeight = 1.56f;
|
|
||||||
if (Appearance.AvatarHeight > 0)
|
|
||||||
localAVHeight = Appearance.AvatarHeight;
|
|
||||||
|
|
||||||
float posZLimit = 0;
|
|
||||||
|
|
||||||
if (pos.X < Constants.RegionSize && pos.Y < Constants.RegionSize)
|
|
||||||
posZLimit = (float)m_scene.Heightmap[(int)pos.X, (int)pos.Y];
|
|
||||||
|
|
||||||
float newPosZ = posZLimit + localAVHeight / 2;
|
|
||||||
if (posZLimit >= (pos.Z - (localAVHeight / 2)) && !(Single.IsInfinity(newPosZ) || Single.IsNaN(newPosZ)))
|
|
||||||
{
|
|
||||||
pos.Z = newPosZ;
|
|
||||||
}
|
|
||||||
AbsolutePosition = pos;
|
|
||||||
|
|
||||||
AddToPhysicalScene(isFlying);
|
|
||||||
|
|
||||||
if (ForceFly)
|
|
||||||
{
|
|
||||||
Flying = true;
|
|
||||||
}
|
|
||||||
else if (FlyDisabled)
|
|
||||||
{
|
|
||||||
Flying = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Don't send an animation pack here, since on a region crossing this will sometimes cause a flying
|
// Don't send an animation pack here, since on a region crossing this will sometimes cause a flying
|
||||||
// avatar to return to the standing position in mid-air. On login it looks like this is being sent
|
// avatar to return to the standing position in mid-air. On login it looks like this is being sent
|
||||||
// elsewhere anyway
|
// elsewhere anyway
|
||||||
|
@ -954,11 +981,13 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
{
|
{
|
||||||
m_log.DebugFormat("[SCENE PRESENCE]: Restarting scripts in attachments...");
|
m_log.DebugFormat("[SCENE PRESENCE]: Restarting scripts in attachments...");
|
||||||
// Resume scripts
|
// Resume scripts
|
||||||
foreach (SceneObjectGroup sog in m_attachments)
|
Util.FireAndForget(delegate(object x) {
|
||||||
{
|
foreach (SceneObjectGroup sog in m_attachments)
|
||||||
sog.RootPart.ParentGroup.CreateScriptInstances(0, false, m_scene.DefaultScriptEngine, GetStateSource());
|
{
|
||||||
sog.ResumeScripts();
|
sog.RootPart.ParentGroup.CreateScriptInstances(0, false, m_scene.DefaultScriptEngine, GetStateSource());
|
||||||
}
|
sog.ResumeScripts();
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3122,6 +3151,9 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
cAgent.AlwaysRun = SetAlwaysRun;
|
cAgent.AlwaysRun = SetAlwaysRun;
|
||||||
|
|
||||||
cAgent.Appearance = new AvatarAppearance(Appearance);
|
cAgent.Appearance = new AvatarAppearance(Appearance);
|
||||||
|
|
||||||
|
cAgent.ParentPart = ParentUUID;
|
||||||
|
cAgent.SitOffset = m_pos;
|
||||||
|
|
||||||
lock (scriptedcontrols)
|
lock (scriptedcontrols)
|
||||||
{
|
{
|
||||||
|
@ -3181,6 +3213,8 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
CameraAtAxis = cAgent.AtAxis;
|
CameraAtAxis = cAgent.AtAxis;
|
||||||
CameraLeftAxis = cAgent.LeftAxis;
|
CameraLeftAxis = cAgent.LeftAxis;
|
||||||
m_CameraUpAxis = cAgent.UpAxis;
|
m_CameraUpAxis = cAgent.UpAxis;
|
||||||
|
ParentUUID = cAgent.ParentPart;
|
||||||
|
m_prevSitOffset = cAgent.SitOffset;
|
||||||
|
|
||||||
// When we get to the point of re-computing neighbors everytime this
|
// When we get to the point of re-computing neighbors everytime this
|
||||||
// changes, then start using the agent's drawdistance rather than the
|
// changes, then start using the agent's drawdistance rather than the
|
||||||
|
|
|
@ -1486,7 +1486,7 @@ namespace OpenSim.Region.Framework.Scenes.Serialization
|
||||||
m_SOPXmlProcessors,
|
m_SOPXmlProcessors,
|
||||||
reader,
|
reader,
|
||||||
(o, nodeName, e)
|
(o, nodeName, e)
|
||||||
=> m_log.ErrorFormat(
|
=> m_log.DebugFormat(
|
||||||
"[SceneObjectSerializer]: Exception while parsing {0} in object {1} {2}: {3}{4}",
|
"[SceneObjectSerializer]: Exception while parsing {0} in object {1} {2}: {3}{4}",
|
||||||
((SceneObjectPart)o).Name, ((SceneObjectPart)o).UUID, nodeName, e.Message, e.StackTrace));
|
((SceneObjectPart)o).Name, ((SceneObjectPart)o).UUID, nodeName, e.Message, e.StackTrace));
|
||||||
|
|
||||||
|
@ -1539,14 +1539,18 @@ namespace OpenSim.Region.Framework.Scenes.Serialization
|
||||||
|
|
||||||
reader.ReadStartElement(name, String.Empty); // Shape
|
reader.ReadStartElement(name, String.Empty); // Shape
|
||||||
|
|
||||||
ExternalRepresentationUtils.ExecuteReadProcessors(
|
errors = ExternalRepresentationUtils.ExecuteReadProcessors(
|
||||||
shape,
|
shape,
|
||||||
m_ShapeXmlProcessors,
|
m_ShapeXmlProcessors,
|
||||||
reader,
|
reader,
|
||||||
(o, nodeName, e)
|
(o, nodeName, e)
|
||||||
=> m_log.ErrorFormat(
|
=>
|
||||||
"[SceneObjectSerializer]: Exception while parsing Shape property {0}: {1}{2}",
|
{
|
||||||
nodeName, e.Message, e.StackTrace));
|
m_log.DebugFormat(
|
||||||
|
"[SceneObjectSerializer]: Exception while parsing Shape property {0}: {1}{2}",
|
||||||
|
nodeName, e.Message, e.StackTrace);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
reader.ReadEndElement(); // Shape
|
reader.ReadEndElement(); // Shape
|
||||||
|
|
||||||
|
|
|
@ -63,9 +63,9 @@ namespace OpenSim.Region.OptionalModules.Avatar.Voice.FreeSwitchVoice
|
||||||
private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
|
private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
|
||||||
|
|
||||||
// Capability string prefixes
|
// Capability string prefixes
|
||||||
private static readonly string m_parcelVoiceInfoRequestPath = "0007/";
|
private static readonly string m_parcelVoiceInfoRequestPath = "0207/";
|
||||||
private static readonly string m_provisionVoiceAccountRequestPath = "0008/";
|
private static readonly string m_provisionVoiceAccountRequestPath = "0208/";
|
||||||
private static readonly string m_chatSessionRequestPath = "0009/";
|
private static readonly string m_chatSessionRequestPath = "0209/";
|
||||||
|
|
||||||
// Control info
|
// Control info
|
||||||
private static bool m_Enabled = false;
|
private static bool m_Enabled = false;
|
||||||
|
|
|
@ -30,6 +30,7 @@ using System.Collections;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Collections.Specialized;
|
using System.Collections.Specialized;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
|
using System.Threading;
|
||||||
|
|
||||||
using Nwc.XmlRpc;
|
using Nwc.XmlRpc;
|
||||||
|
|
||||||
|
@ -167,6 +168,8 @@ namespace OpenSim.Region.OptionalModules.Avatar.XmlRpcGroups
|
||||||
|
|
||||||
private bool m_debugEnabled = false;
|
private bool m_debugEnabled = false;
|
||||||
|
|
||||||
|
private Dictionary<string, bool> m_pendingRequests = new Dictionary<string,bool>();
|
||||||
|
|
||||||
private ExpiringCache<string, OSDMap> m_memoryCache;
|
private ExpiringCache<string, OSDMap> m_memoryCache;
|
||||||
private int m_cacheTimeout = 30;
|
private int m_cacheTimeout = 30;
|
||||||
|
|
||||||
|
@ -1348,6 +1351,7 @@ namespace OpenSim.Region.OptionalModules.Avatar.XmlRpcGroups
|
||||||
// Immediately forward the request if the cache is disabled.
|
// Immediately forward the request if the cache is disabled.
|
||||||
if (m_cacheTimeout == 0)
|
if (m_cacheTimeout == 0)
|
||||||
{
|
{
|
||||||
|
m_log.WarnFormat("[SIMIAN GROUPS CONNECTOR]: cache is disabled");
|
||||||
return WebUtil.PostToService(m_groupsServerURI, requestArgs);
|
return WebUtil.PostToService(m_groupsServerURI, requestArgs);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1355,6 +1359,8 @@ namespace OpenSim.Region.OptionalModules.Avatar.XmlRpcGroups
|
||||||
if (requestArgs["RequestMethod"] == "RemoveGeneric"
|
if (requestArgs["RequestMethod"] == "RemoveGeneric"
|
||||||
|| requestArgs["RequestMethod"] == "AddGeneric")
|
|| requestArgs["RequestMethod"] == "AddGeneric")
|
||||||
{
|
{
|
||||||
|
m_log.WarnFormat("[SIMIAN GROUPS CONNECTOR]: clearing generics cache");
|
||||||
|
|
||||||
// Any and all updates cause the cache to clear
|
// Any and all updates cause the cache to clear
|
||||||
m_memoryCache.Clear();
|
m_memoryCache.Clear();
|
||||||
|
|
||||||
|
@ -1366,18 +1372,67 @@ namespace OpenSim.Region.OptionalModules.Avatar.XmlRpcGroups
|
||||||
|
|
||||||
// Create the cache key for the request and see if we have it cached
|
// Create the cache key for the request and see if we have it cached
|
||||||
string CacheKey = WebUtil.BuildQueryString(requestArgs);
|
string CacheKey = WebUtil.BuildQueryString(requestArgs);
|
||||||
OSDMap response = null;
|
|
||||||
if (!m_memoryCache.TryGetValue(CacheKey, out response))
|
|
||||||
{
|
|
||||||
// if it wasn't in the cache, pass the request to the Simian Grid Services
|
|
||||||
response = WebUtil.PostToService(m_groupsServerURI, requestArgs);
|
|
||||||
|
|
||||||
// and cache the response
|
// This code uses a leader/follower pattern. On a cache miss, the request is added
|
||||||
m_memoryCache.AddOrUpdate(CacheKey, response, TimeSpan.FromSeconds(m_cacheTimeout));
|
// to a queue; the first thread to add it to the queue completes the request while
|
||||||
|
// follow on threads busy wait for the results, this situation seems to happen
|
||||||
|
// often when checking permissions
|
||||||
|
while (true)
|
||||||
|
{
|
||||||
|
OSDMap response = null;
|
||||||
|
bool firstRequest = false;
|
||||||
|
|
||||||
|
lock (m_memoryCache)
|
||||||
|
{
|
||||||
|
if (m_memoryCache.TryGetValue(CacheKey, out response))
|
||||||
|
return response;
|
||||||
|
|
||||||
|
if (! m_pendingRequests.ContainsKey(CacheKey))
|
||||||
|
{
|
||||||
|
m_pendingRequests.Add(CacheKey,true);
|
||||||
|
firstRequest = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (firstRequest)
|
||||||
|
{
|
||||||
|
// if it wasn't in the cache, pass the request to the Simian Grid Services
|
||||||
|
try
|
||||||
|
{
|
||||||
|
response = WebUtil.PostToService(m_groupsServerURI, requestArgs);
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
m_log.InfoFormat("[SIMIAN GROUPS CONNECTOR] request failed {0}",CacheKey);
|
||||||
|
}
|
||||||
|
|
||||||
|
// and cache the response
|
||||||
|
lock (m_memoryCache)
|
||||||
|
{
|
||||||
|
m_memoryCache.AddOrUpdate(CacheKey, response, TimeSpan.FromSeconds(m_cacheTimeout));
|
||||||
|
m_pendingRequests.Remove(CacheKey);
|
||||||
|
}
|
||||||
|
|
||||||
|
return response;
|
||||||
|
}
|
||||||
|
|
||||||
|
Thread.Sleep(50); // waiting for a web request to complete, 50msecs is reasonable
|
||||||
}
|
}
|
||||||
|
|
||||||
// return cached response
|
// if (!m_memoryCache.TryGetValue(CacheKey, out response))
|
||||||
return response;
|
// {
|
||||||
|
// m_log.WarnFormat("[SIMIAN GROUPS CONNECTOR]: query not in the cache");
|
||||||
|
// Util.PrintCallStack();
|
||||||
|
|
||||||
|
// // if it wasn't in the cache, pass the request to the Simian Grid Services
|
||||||
|
// response = WebUtil.PostToService(m_groupsServerURI, requestArgs);
|
||||||
|
|
||||||
|
// // and cache the response
|
||||||
|
// m_memoryCache.AddOrUpdate(CacheKey, response, TimeSpan.FromSeconds(m_cacheTimeout));
|
||||||
|
// }
|
||||||
|
|
||||||
|
// // return cached response
|
||||||
|
// return response;
|
||||||
}
|
}
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
|
|
@ -96,15 +96,15 @@ namespace OpenSim.Region.OptionalModules.World.NPC
|
||||||
if (!m_avatars.ContainsKey(agentId))
|
if (!m_avatars.ContainsKey(agentId))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
// Delete existing sp attachments
|
||||||
scene.AttachmentsModule.DeleteAttachmentsFromScene(sp, false);
|
scene.AttachmentsModule.DeleteAttachmentsFromScene(sp, false);
|
||||||
|
|
||||||
AvatarAppearance npcAppearance = new AvatarAppearance(appearance, true);
|
// Set new sp appearance. Also sends to clients.
|
||||||
sp.Appearance = npcAppearance;
|
scene.RequestModuleInterface<IAvatarFactoryModule>().SetAppearance(sp, new AvatarAppearance(appearance, true));
|
||||||
|
|
||||||
|
// Rez needed sp attachments
|
||||||
scene.AttachmentsModule.RezAttachments(sp);
|
scene.AttachmentsModule.RezAttachments(sp);
|
||||||
|
|
||||||
IAvatarFactoryModule module = scene.RequestModuleInterface<IAvatarFactoryModule>();
|
|
||||||
module.SendAppearance(sp.UUID);
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -156,6 +156,22 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
internal UUID m_uuid { get; private set; }
|
internal UUID m_uuid { get; private set; }
|
||||||
internal bool bad = false;
|
internal bool bad = false;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// ODE Avatar.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="avName"></param>
|
||||||
|
/// <param name="parent_scene"></param>
|
||||||
|
/// <param name="pos"></param>
|
||||||
|
/// <param name="size"></param>
|
||||||
|
/// <param name="pid_d"></param>
|
||||||
|
/// <param name="pid_p"></param>
|
||||||
|
/// <param name="capsule_radius"></param>
|
||||||
|
/// <param name="tensor"></param>
|
||||||
|
/// <param name="density">
|
||||||
|
/// Only used right now to return information to LSL. Not actually used to set mass in ODE!
|
||||||
|
/// </param>
|
||||||
|
/// <param name="walk_divisor"></param>
|
||||||
|
/// <param name="rundivisor"></param>
|
||||||
public OdeCharacter(
|
public OdeCharacter(
|
||||||
String avName, OdeScene parent_scene, Vector3 pos, Vector3 size, float pid_d, float pid_p,
|
String avName, OdeScene parent_scene, Vector3 pos, Vector3 size, float pid_d, float pid_p,
|
||||||
float capsule_radius, float tensor, float density,
|
float capsule_radius, float tensor, float density,
|
||||||
|
@ -786,6 +802,10 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
Vector3 vec = Vector3.Zero;
|
Vector3 vec = Vector3.Zero;
|
||||||
d.Vector3 vel = d.BodyGetLinearVel(Body);
|
d.Vector3 vel = d.BodyGetLinearVel(Body);
|
||||||
|
|
||||||
|
// m_log.DebugFormat(
|
||||||
|
// "[ODE CHARACTER]: Current velocity in Move() is <{0},{1},{2}>, target {3} for {4}",
|
||||||
|
// vel.X, vel.Y, vel.Z, _target_velocity, Name);
|
||||||
|
|
||||||
float movementdivisor = 1f;
|
float movementdivisor = 1f;
|
||||||
|
|
||||||
if (!m_alwaysRun)
|
if (!m_alwaysRun)
|
||||||
|
@ -884,18 +904,20 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
|
|
||||||
if (flying)
|
if (flying)
|
||||||
{
|
{
|
||||||
|
// This also acts as anti-gravity so that we hover when flying rather than fall.
|
||||||
vec.Z = (_target_velocity.Z - vel.Z) * (PID_D);
|
vec.Z = (_target_velocity.Z - vel.Z) * (PID_D);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (flying)
|
if (flying)
|
||||||
{
|
{
|
||||||
|
// Anti-gravity so that we hover when flying rather than fall.
|
||||||
vec.Z += ((-1 * _parent_scene.gravityz) * m_mass);
|
vec.Z += ((-1 * _parent_scene.gravityz) * m_mass);
|
||||||
|
|
||||||
//Added for auto fly height. Kitto Flora
|
//Added for auto fly height. Kitto Flora
|
||||||
//d.Vector3 pos = d.BodyGetPosition(Body);
|
//d.Vector3 pos = d.BodyGetPosition(Body);
|
||||||
float target_altitude = _parent_scene.GetTerrainHeightAtXY(_position.X, _position.Y) + MinimumGroundFlightOffset;
|
float target_altitude = _parent_scene.GetTerrainHeightAtXY(_position.X, _position.Y) + MinimumGroundFlightOffset;
|
||||||
|
|
||||||
if (_position.Z < target_altitude)
|
if (_position.Z < target_altitude)
|
||||||
{
|
{
|
||||||
vec.Z += (target_altitude - _position.Z) * PID_P * 5.0f;
|
vec.Z += (target_altitude - _position.Z) * PID_P * 5.0f;
|
||||||
|
@ -921,6 +943,25 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
d.Vector3 newVel = d.BodyGetLinearVel(Body);
|
||||||
|
if (newVel.X >= 256 || newVel.X <= 256 || newVel.Y >= 256 || newVel.Y <= 256 || newVel.Z >= 256 || newVel.Z <= 256)
|
||||||
|
{
|
||||||
|
// m_log.DebugFormat(
|
||||||
|
// "[ODE CHARACTER]: Limiting falling velocity from {0} to {1} for {2}", newVel.Z, -9.8, Name);
|
||||||
|
|
||||||
|
newVel.X = Util.Clamp<float>(newVel.X, -255f, 255f);
|
||||||
|
newVel.Y = Util.Clamp<float>(newVel.Y, -255f, 255f);
|
||||||
|
|
||||||
|
if (!flying)
|
||||||
|
newVel.Z
|
||||||
|
= Util.Clamp<float>(
|
||||||
|
newVel.Z, -_parent_scene.AvatarTerminalVelocity, _parent_scene.AvatarTerminalVelocity);
|
||||||
|
else
|
||||||
|
newVel.Z = Util.Clamp<float>(newVel.Z, -255f, 255f);
|
||||||
|
|
||||||
|
d.BodySetLinearVel(Body, newVel.X, newVel.Y, newVel.Z);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
|
|
@ -144,6 +144,8 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
public float gravityy = 0f;
|
public float gravityy = 0f;
|
||||||
public float gravityz = -9.8f;
|
public float gravityz = -9.8f;
|
||||||
|
|
||||||
|
public float AvatarTerminalVelocity { get; set; }
|
||||||
|
|
||||||
private float contactsurfacelayer = 0.001f;
|
private float contactsurfacelayer = 0.001f;
|
||||||
|
|
||||||
private int worldHashspaceLow = -4;
|
private int worldHashspaceLow = -4;
|
||||||
|
@ -459,6 +461,15 @@ namespace OpenSim.Region.Physics.OdePlugin
|
||||||
gravityy = physicsconfig.GetFloat("world_gravityy", 0f);
|
gravityy = physicsconfig.GetFloat("world_gravityy", 0f);
|
||||||
gravityz = physicsconfig.GetFloat("world_gravityz", -9.8f);
|
gravityz = physicsconfig.GetFloat("world_gravityz", -9.8f);
|
||||||
|
|
||||||
|
float avatarTerminalVelocity = physicsconfig.GetFloat("avatar_terminal_velocity", 54f);
|
||||||
|
AvatarTerminalVelocity = Util.Clamp<float>(avatarTerminalVelocity, 0, 255f);
|
||||||
|
if (AvatarTerminalVelocity != avatarTerminalVelocity)
|
||||||
|
{
|
||||||
|
m_log.WarnFormat(
|
||||||
|
"[ODE SCENE]: avatar_terminal_velocity of {0} is invalid. Clamping to {1}",
|
||||||
|
avatarTerminalVelocity, AvatarTerminalVelocity);
|
||||||
|
}
|
||||||
|
|
||||||
worldHashspaceLow = physicsconfig.GetInt("world_hashspace_size_low", -4);
|
worldHashspaceLow = physicsconfig.GetInt("world_hashspace_size_low", -4);
|
||||||
worldHashspaceHigh = physicsconfig.GetInt("world_hashspace_size_high", 128);
|
worldHashspaceHigh = physicsconfig.GetInt("world_hashspace_size_high", 128);
|
||||||
|
|
||||||
|
|
|
@ -2188,7 +2188,9 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
|
||||||
if (part.ParentGroup.RootPart == part)
|
if (part.ParentGroup.RootPart == part)
|
||||||
{
|
{
|
||||||
SceneObjectGroup parent = part.ParentGroup;
|
SceneObjectGroup parent = part.ParentGroup;
|
||||||
parent.UpdateGroupPosition(new Vector3((float)toPos.x, (float)toPos.y, (float)toPos.z));
|
Util.FireAndForget(delegate(object x) {
|
||||||
|
parent.UpdateGroupPosition(new Vector3((float)toPos.x, (float)toPos.y, (float)toPos.z));
|
||||||
|
});
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -7973,7 +7975,9 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
|
||||||
if (part.ParentGroup.RootPart == part)
|
if (part.ParentGroup.RootPart == part)
|
||||||
{
|
{
|
||||||
SceneObjectGroup parent = part.ParentGroup;
|
SceneObjectGroup parent = part.ParentGroup;
|
||||||
parent.UpdateGroupPosition(new Vector3((float)currentPosition.x, (float)currentPosition.y, (float)currentPosition.z));
|
Util.FireAndForget(delegate(object x) {
|
||||||
|
parent.UpdateGroupPosition(new Vector3((float)currentPosition.x, (float)currentPosition.y, (float)currentPosition.z));
|
||||||
|
});
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -7990,7 +7994,9 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
|
||||||
if (part.ParentGroup.RootPart == part)
|
if (part.ParentGroup.RootPart == part)
|
||||||
{
|
{
|
||||||
SceneObjectGroup parent = part.ParentGroup;
|
SceneObjectGroup parent = part.ParentGroup;
|
||||||
parent.UpdateGroupPosition(new Vector3((float)currentPosition.x, (float)currentPosition.y, (float)currentPosition.z));
|
Util.FireAndForget(delegate(object x) {
|
||||||
|
parent.UpdateGroupPosition(new Vector3((float)currentPosition.x, (float)currentPosition.y, (float)currentPosition.z));
|
||||||
|
});
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -450,17 +450,28 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api.Plugins
|
||||||
Vector3 toRegionPos;
|
Vector3 toRegionPos;
|
||||||
double dis;
|
double dis;
|
||||||
|
|
||||||
Action<ScenePresence> senseEntity = new Action<ScenePresence>(delegate(ScenePresence presence)
|
Action<ScenePresence> senseEntity = new Action<ScenePresence>(presence =>
|
||||||
{
|
{
|
||||||
if ((ts.type & NPC) == 0
|
if ((ts.type & NPC) == 0 && presence.PresenceType == PresenceType.Npc)
|
||||||
&& presence.PresenceType == PresenceType.Npc
|
{
|
||||||
&& !npcModule.GetNPC(presence.UUID, presence.Scene).SenseAsAgent)
|
INPC npcData = npcModule.GetNPC(presence.UUID, presence.Scene);
|
||||||
return;
|
if (npcData == null || !npcData.SenseAsAgent)
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if ((ts.type & AGENT) == 0
|
if ((ts.type & AGENT) == 0)
|
||||||
&& (presence.PresenceType == PresenceType.User
|
{
|
||||||
|| npcModule.GetNPC(presence.UUID, presence.Scene).SenseAsAgent))
|
if (presence.PresenceType == PresenceType.User)
|
||||||
return;
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
INPC npcData = npcModule.GetNPC(presence.UUID, presence.Scene);
|
||||||
|
if (npcData != null && npcData.SenseAsAgent)
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (presence.IsDeleted || presence.IsChildAgent || presence.GodLevel > 0.0)
|
if (presence.IsDeleted || presence.IsChildAgent || presence.GodLevel > 0.0)
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -433,11 +433,14 @@ namespace OpenSim.Services.Connectors.Simulation
|
||||||
args["destination_name"] = OSD.FromString(destination.RegionName);
|
args["destination_name"] = OSD.FromString(destination.RegionName);
|
||||||
args["destination_uuid"] = OSD.FromString(destination.RegionID.ToString());
|
args["destination_uuid"] = OSD.FromString(destination.RegionID.ToString());
|
||||||
|
|
||||||
WebUtil.PostToService(uri, args, 40000);
|
OSDMap response = WebUtil.PostToService(uri, args, 40000);
|
||||||
|
if (response["Success"] == "False")
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
m_log.WarnFormat("[REMOTE SIMULATION CONNECTOR] CreateObject failed with exception; {0}",e.ToString());
|
m_log.WarnFormat("[REMOTE SIMULATION CONNECTOR] CreateObject failed with exception; {0}",e.ToString());
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -484,7 +484,6 @@
|
||||||
;; such as the Meta7 viewer.
|
;; such as the Meta7 viewer.
|
||||||
;; It has no ill effect on viewers which do not support server-side
|
;; It has no ill effect on viewers which do not support server-side
|
||||||
;; windlight settings.
|
;; windlight settings.
|
||||||
;; Currently we only have support for MySQL databases.
|
|
||||||
; enable_windlight = false
|
; enable_windlight = false
|
||||||
|
|
||||||
|
|
||||||
|
@ -573,10 +572,15 @@
|
||||||
; DeleteScriptsOnStartup = true
|
; DeleteScriptsOnStartup = true
|
||||||
|
|
||||||
;; Set this to true (the default) to load each script into a separate
|
;; Set this to true (the default) to load each script into a separate
|
||||||
;; AppDomain. Setting this to false will load all script assemblies into the
|
;; AppDomain.
|
||||||
;; current AppDomain, which will reduce the per-script overhead at the
|
;;
|
||||||
;; expense of reduced security and the inability to garbage collect the
|
;; Setting this to false will load all script assemblies into the
|
||||||
;; script assemblies
|
;; current AppDomain, which will significantly improve script loading times.
|
||||||
|
;; It will also reduce initial per-script memory overhead.
|
||||||
|
;;
|
||||||
|
;; However, setting this to false will also prevent script DLLs from being unloaded from memory if the script is deleted.
|
||||||
|
;; This may cause an OutOfMemory problem over time when avatars with scripted attachments move in and out of the region.
|
||||||
|
;; Some Windows users have also reported script loading problems when AppDomainLoading = false
|
||||||
; AppDomainLoading = true
|
; AppDomainLoading = true
|
||||||
|
|
||||||
;# {DefaultCompileLanguage} {Enabled:true} {Default script language?} {lsl vb cs} lsl
|
;# {DefaultCompileLanguage} {Enabled:true} {Default script language?} {lsl vb cs} lsl
|
||||||
|
|
|
@ -655,6 +655,11 @@
|
||||||
world_gravityy = 0
|
world_gravityy = 0
|
||||||
world_gravityz = -9.8
|
world_gravityz = -9.8
|
||||||
|
|
||||||
|
; Terminal velocity of a falling avatar
|
||||||
|
; This is the same http://en.wikipedia.org/wiki/Terminal_velocity#Examples
|
||||||
|
; Max value is 255, min value is 0
|
||||||
|
avatar_terminal_velocity = 54
|
||||||
|
|
||||||
; World Step size. (warning these are dangerous. Changing these will probably cause your scene to explode dramatically)
|
; World Step size. (warning these are dangerous. Changing these will probably cause your scene to explode dramatically)
|
||||||
; reference: fps = (0.089/ODE_STEPSIZE) * 1000;
|
; reference: fps = (0.089/ODE_STEPSIZE) * 1000;
|
||||||
world_stepsize = 0.0178
|
world_stepsize = 0.0178
|
||||||
|
@ -1065,7 +1070,6 @@
|
||||||
[LightShare]
|
[LightShare]
|
||||||
; This enables the transmission of Windlight scenes to supporting clients, such as the Meta7 viewer.
|
; This enables the transmission of Windlight scenes to supporting clients, such as the Meta7 viewer.
|
||||||
; It has no ill effect on viewers which do not support server-side windlight settings.
|
; It has no ill effect on viewers which do not support server-side windlight settings.
|
||||||
; Currently we only have support for MySQL databases.
|
|
||||||
enable_windlight = false
|
enable_windlight = false
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue