From 04cf04600c01f2cb328847133430f777bc7f1a7c Mon Sep 17 00:00:00 2001 From: MW Date: Tue, 11 Sep 2007 14:18:34 +0000 Subject: Applied ldvoipeng's patch [#360], sorry for it taking so long to apply it. If in future anyone's patch hasn't been applied within a few days, please can someone kick one of the developers with svn access. --- .../Region/Environment/Scenes/SceneObjectPart.cs | 24 +++- .../Environment/Scenes/Scripting/IScriptHost.cs | 4 + .../Environment/Scenes/Scripting/NullScriptHost.cs | 20 +++ .../Compiler/Server_API/LSL_BuiltIn_Commands.cs | 137 +++++++++++++++++---- 4 files changed, 162 insertions(+), 23 deletions(-) diff --git a/OpenSim/Region/Environment/Scenes/SceneObjectPart.cs b/OpenSim/Region/Environment/Scenes/SceneObjectPart.cs index 2122a4f..81c759d 100644 --- a/OpenSim/Region/Environment/Scenes/SceneObjectPart.cs +++ b/OpenSim/Region/Environment/Scenes/SceneObjectPart.cs @@ -10,7 +10,7 @@ using libsecondlife.Packets; using OpenSim.Framework.Interfaces; using OpenSim.Framework.Types; using OpenSim.Region.Environment.Scenes.Scripting; -using OpenSim.Framework.Utilities; +using OpenSim.Framework; using OpenSim.Region.Physics.Manager; using OpenSim.Region.Environment.Interfaces; @@ -29,7 +29,6 @@ namespace OpenSim.Region.Environment.Scenes protected Dictionary TaskInventory = new Dictionary(); - public LLUUID CreatorID; public LLUUID OwnerID; public LLUUID GroupID; public LLUUID LastOwnerID; @@ -56,6 +55,9 @@ namespace OpenSim.Region.Environment.Scenes #region Properties + public LLUUID CreatorID; + public LLUUID ObjectCreator { get { return CreatorID; } } + /// /// Serial count for inventory file , used to tell if inventory has changed /// no need for this to be part of Database backup @@ -210,6 +212,11 @@ namespace OpenSim.Region.Environment.Scenes get { return OwnerID; } } + public SceneObjectGroup ParentGroup + { + get { return m_parentGroup; } + } + #region Constructors /// /// @@ -324,6 +331,15 @@ namespace OpenSim.Region.Environment.Scenes } + public LLUUID GetRootPartUUID() + { + if (m_parentGroup != null) + { + return m_parentGroup.UUID; + } + return LLUUID.Zero; + } + #region Copying /// /// @@ -615,12 +631,14 @@ namespace OpenSim.Region.Environment.Scenes for (int i = 0; i < avatars.Count; i++) { avatars[i].AddFullPart(this); + // avatars[i].QueuePartForUpdate(this); } } public void AddFullUpdateToAvatar(ScenePresence presence) { presence.AddFullPart(this); + //presence.QueuePartForUpdate(this); } /// @@ -677,12 +695,14 @@ namespace OpenSim.Region.Environment.Scenes for (int i = 0; i < avatars.Count; i++) { avatars[i].AddTersePart(this); + // avatars[i].QueuePartForUpdate(this); } } public void AddTerseUpdateToAvatar(ScenePresence presence) { presence.AddTersePart(this); + // presence.QueuePartForUpdate(this); } /// diff --git a/OpenSim/Region/Environment/Scenes/Scripting/IScriptHost.cs b/OpenSim/Region/Environment/Scenes/Scripting/IScriptHost.cs index e7d0570..2f248ce 100644 --- a/OpenSim/Region/Environment/Scenes/Scripting/IScriptHost.cs +++ b/OpenSim/Region/Environment/Scenes/Scripting/IScriptHost.cs @@ -8,8 +8,12 @@ namespace OpenSim.Region.Environment.Scenes.Scripting public interface IScriptHost { string Name { get; set;} + string SitName{ get; set;} + string TouchName { get; set;} + string Description { get; set; } LLUUID UUID { get; } LLUUID ObjectOwner { get;} + LLUUID ObjectCreator { get; } LLVector3 AbsolutePosition { get; } void SetText(string text, Axiom.Math.Vector3 color, double alpha); } diff --git a/OpenSim/Region/Environment/Scenes/Scripting/NullScriptHost.cs b/OpenSim/Region/Environment/Scenes/Scripting/NullScriptHost.cs index a50b142..5e3dcae 100644 --- a/OpenSim/Region/Environment/Scenes/Scripting/NullScriptHost.cs +++ b/OpenSim/Region/Environment/Scenes/Scripting/NullScriptHost.cs @@ -15,6 +15,24 @@ namespace OpenSim.Region.Environment.Scenes.Scripting set { } } + public string SitName + { + get { return ""; } + set { } + } + + public string TouchName + { + get { return ""; } + set { } + } + + public string Description + { + get { return ""; } + set { } + } + public LLUUID UUID { get { return LLUUID.Zero; } @@ -23,6 +41,8 @@ namespace OpenSim.Region.Environment.Scenes.Scripting public LLUUID ObjectOwner { get { return LLUUID.Zero; } } + public LLUUID ObjectCreator { get { return LLUUID.Zero; } } + public LLVector3 AbsolutePosition { get { return m_pos; } diff --git a/OpenSim/Region/ScriptEngine/DotNetEngine/Compiler/Server_API/LSL_BuiltIn_Commands.cs b/OpenSim/Region/ScriptEngine/DotNetEngine/Compiler/Server_API/LSL_BuiltIn_Commands.cs index 5d34229..d543eca 100644 --- a/OpenSim/Region/ScriptEngine/DotNetEngine/Compiler/Server_API/LSL_BuiltIn_Commands.cs +++ b/OpenSim/Region/ScriptEngine/DotNetEngine/Compiler/Server_API/LSL_BuiltIn_Commands.cs @@ -79,9 +79,9 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler public double llFrand(double mag) { - lock (OpenSim.Framework.Utilities.Util.RandomClass) + lock (OpenSim.Framework.Util.RandomClass) { - return OpenSim.Framework.Utilities.Util.RandomClass.Next((int)mag); + return OpenSim.Framework.Util.RandomClass.Next((int)mag); } } @@ -217,7 +217,12 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler public void llScaleTexture(double u, double v, int face) { return; } public void llOffsetTexture(double u, double v, int face) { return; } public void llRotateTexture(double rotation, int face) { return; } - public string llGetTexture(int face) { return ""; } + + public string llGetTexture(int face) + { + return ""; + } + public void llSetPos(LSL_Types.Vector3 pos) { return; } public LSL_Types.Vector3 llGetPos() @@ -265,11 +270,25 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler public void llTriggerSound(string sound, double volume) { } public void llStopSound() { } public void llPreloadSound(string sound) { } - public string llGetSubString(string src, int start, int end) { return src.Substring(start, end); } + + public string llGetSubString(string src, int start, int end) + { + return src.Substring(start, end); + } + public string llDeleteSubString(string src, int start, int end) {return "";} public string llInsertString(string dst, int position, string src) { return ""; } - public string llToUpper(string src) { return src.ToUpper(); } - public string llToLower(string src) { return src.ToLower(); } + + public string llToUpper(string src) + { + return src.ToUpper(); + } + + public string llToLower(string src) + { + return src.ToLower(); + } + public int llGiveMoney(string destination, int amount) { return 0; } public void llMakeExplosion() { } public void llMakeFountain() { } @@ -285,7 +304,11 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler m_ScriptEngine.myLSLLongCmdHandler.SetTimerEvent(m_localID, m_itemID, sec); } - public void llSleep(double sec) { System.Threading.Thread.Sleep((int)(sec * 1000)); } + public void llSleep(double sec) + { + System.Threading.Thread.Sleep((int)(sec * 1000)); + } + public double llGetMass() { return 0; } public void llCollisionFilter(string name, string id, int accept) { } public void llTakeControls(int controls, int accept, int pass_on) { } @@ -294,7 +317,12 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler public void llDetachFromAvatar() { } public void llTakeCamera() { } public void llReleaseCamera() { } - public string llGetOwner() { return m_host.ObjectOwner.ToStringHyphenated(); } + + public string llGetOwner() + { + return m_host.ObjectOwner.ToStringHyphenated(); + } + public void llInstantMessage(string user, string message) { } public void llEmail(string address, string subject, string message) { } public void llGetNextEmail(string address, string subject) { } @@ -368,12 +396,23 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler public void llPushObject(string target, LSL_Types.Vector3 impulse, LSL_Types.Vector3 ang_impulse, int local) { } public void llPassCollisions(int pass) { } public string llGetScriptName() { return ""; } + public int llGetNumberOfSides() { return 0; } + public LSL_Types.Quaternion llAxisAngle2Rot(LSL_Types.Vector3 axis, double angle) { return new LSL_Types.Quaternion(); } public LSL_Types.Vector3 llRot2Axis(LSL_Types.Quaternion rot) { return new LSL_Types.Vector3(); } public void llRot2Angle() { } - public double llAcos(double val) { return (double)Math.Acos(val); } - public double llAsin(double val) { return (double)Math.Asin(val); } + + public double llAcos(double val) + { + return (double)Math.Acos(val); + } + + public double llAsin(double val) + { + return (double)Math.Asin(val); + } + public double llAngleBetween(LSL_Types.Quaternion a, LSL_Types.Quaternion b) { return 0; } public string llGetInventoryKey(string name) { return ""; } public void llAllowInventoryDrop(int add) { } @@ -387,7 +426,11 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler return source.IndexOf(pattern); } - public string llGetOwnerKey(string id) { return ""; } + public string llGetOwnerKey(string id) + { + return ""; + } + public LSL_Types.Vector3 llGetCenterOfMass() { return new LSL_Types.Vector3(); } public List llListSort(List src, int stride, int ascending) @@ -459,8 +502,16 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler public List llListInsertList(List dest, List src, int start) { return new List(); } public int llListFindList(List src, List test) { return 0; } - public string llGetObjectName() { return m_host.Name; } - public void llSetObjectName(string name) { m_host.Name = name; } + + public string llGetObjectName() + { + return m_host.Name; + } + + public void llSetObjectName(string name) + { + m_host.Name = name; + } public string llGetDate() { @@ -478,7 +529,9 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler public void llSetTextureAnim(int mode, int face, int sizex, int sizey, double start, double length, double rate) { } public void llTriggerSoundLimited(string sound, double volume, LSL_Types.Vector3 top_north_east, LSL_Types.Vector3 bottom_south_west) { } public void llEjectFromLand(string pest) { } + public void llParseString2List() { } + public int llOverMyLand(string id) { return 0; } public string llGetLandOwnerAt(LSL_Types.Vector3 pos) { return ""; } public string llGetNotecardLine(string name, int line) { return ""; } @@ -490,7 +543,12 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler public LSL_Types.Vector3 llGroundContour(LSL_Types.Vector3 offset) { return new LSL_Types.Vector3(); } public int llGetAttached() { return 0; } public int llGetFreeMemory() { return 0; } - public string llGetRegionName() { return World.RegionInfo.RegionName; } + + public string llGetRegionName() + { + return World.RegionInfo.RegionName; + } + public double llGetRegionTimeDilation() { return 1.0f; } public double llGetRegionFPS() { return 10.0f; } public void llParticleSystem(List rules) { } @@ -505,13 +563,17 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler public void llSitTarget(LSL_Types.Vector3 offset, LSL_Types.Quaternion rot) { } public string llAvatarOnSitTarget() { return ""; } public void llAddToLandPassList(string avatar, double hours) { } + public void llSetTouchText(string text) { + m_host.TouchName = text; } public void llSetSitText(string text) { + m_host.SitName = text; } + public void llSetCameraEyeOffset(LSL_Types.Vector3 offset) { } public void llSetCameraAtOffset(LSL_Types.Vector3 offset) { } public void llDumpList2String() { } @@ -532,10 +594,12 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler public string llSendRemoteData(string channel, string dest, int idata, string sdata) { return ""; } public void llRemoteDataReply(string channel, string message_id, string sdata, int idata) { } public void llCloseRemoteDataChannel(string channel) { } + public string llMD5String(string src, int nonce) { - return OpenSim.Framework.Utilities.Util.Md5Hash(src + ":" + nonce.ToString()); + return OpenSim.Framework.Util.Md5Hash(src + ":" + nonce.ToString()); } + public void llSetPrimitiveParams(List rules) { } public string llStringToBase64(string str) { return ""; } public string llBase64ToString(string str) { return ""; } @@ -557,9 +621,21 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler return new LSL_Types.Quaternion(); } - public string llGetObjectDesc() { return ""; } - public void llSetObjectDesc(string desc) { } - public string llGetCreator() { return ""; } + public string llGetObjectDesc() + { + return m_host.Description; + } + + public void llSetObjectDesc(string desc) + { + m_host.Description = desc; + } + + public string llGetCreator() + { + return m_host.ObjectCreator.ToStringHyphenated(); + } + public string llGetTimestamp() { return ""; } public void llSetLinkAlpha(int linknumber, double alpha, int face) { } public int llGetNumberOfPrims() { return 0; } @@ -569,14 +645,26 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler public void llGetPrimitiveParams() { } public string llIntegerToBase64(int number) { return ""; } public int llBase64ToInteger(string str) { return 0; } - public double llGetGMTclock() { return DateTime.UtcNow.TimeOfDay.TotalSeconds; } - public string llGetSimulatorHostname() { return System.Environment.MachineName; } + + public double llGetGMTclock() + { + return DateTime.UtcNow.TimeOfDay.TotalSeconds; + } + + public string llGetSimulatorHostname() + { + return System.Environment.MachineName; + } + public void llSetLocalRot(LSL_Types.Quaternion rot) { } public List llParseStringKeepNulls(string src, List seperators, List spacers) { return new List(); } public void llRezAtRoot(string inventory, LSL_Types.Vector3 position, LSL_Types.Vector3 velocity, LSL_Types.Quaternion rot, int param) { } + public int llGetObjectPermMask(int mask) { return 0; } + public void llSetObjectPermMask(int mask, int value) { } + public void llGetInventoryPermMask(string item, int mask) { } public void llSetInventoryPermMask(string item, int mask, int value) { } public string llGetInventoryCreator(string item) { return ""; } @@ -585,11 +673,13 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler public void llForceMouselook(int mouselook) { } public double llGetObjectMass(string id) { return 0; } public void llListReplaceList() { } + public void llLoadURL(string avatar_id, string message, string url) { LLUUID avatarId = new LLUUID(avatar_id); m_ScriptEngine.World.SendUrlToUser(avatarId, m_host.Name, m_host.UUID, m_host.ObjectOwner, false, message, url); } + public void llParcelMediaCommandList(List commandList) { } public void llParcelMediaQuery() { } @@ -601,11 +691,13 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler } public int llGetInventoryType(string name) { return 0; } + public void llSetPayPrice(int price, List quick_pay_buttons) { } public LSL_Types.Vector3 llGetCameraPos() { return new LSL_Types.Vector3(); } public LSL_Types.Quaternion llGetCameraRot() { return new LSL_Types.Quaternion(); } public void llSetPrimURL() { } public void llRefreshPrimURL() { } + public string llEscapeURL(string url) { try @@ -617,6 +709,7 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler return "llEscapeURL: " + ex.ToString(); } } + public string llUnescapeURL(string url) { try @@ -635,10 +728,12 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler public void llSetCameraParams(List rules) { } public void llClearCameraParams() { } public double llListStatistics(int operation, List src) { return 0; } + public int llGetUnixTime() { - return OpenSim.Framework.Utilities.Util.UnixTimeSinceEpoch(); + return OpenSim.Framework.Util.UnixTimeSinceEpoch(); } + public int llGetParcelFlags(LSL_Types.Vector3 pos) { return 0; } public int llGetRegionFlags() { return 0; } public string llXorBase64StringsCorrect(string str1, string str2) { return ""; } -- cgit v1.1