diff options
Diffstat (limited to 'OpenSim/Region/ScriptEngine')
3 files changed, 234 insertions, 168 deletions
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs index ce1c364..d6aafaf 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs | |||
@@ -226,6 +226,12 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
226 | public void llResetScript() | 226 | public void llResetScript() |
227 | { | 227 | { |
228 | m_host.AddScriptLPS(1); | 228 | m_host.AddScriptLPS(1); |
229 | |||
230 | // We need to tell the URL module, if we hav one, to release | ||
231 | // the allocated URLs | ||
232 | if (m_UrlModule != null) | ||
233 | m_UrlModule.ScriptRemoved(m_item.ItemID); | ||
234 | |||
229 | m_ScriptEngine.ApiResetScript(m_item.ItemID); | 235 | m_ScriptEngine.ApiResetScript(m_item.ItemID); |
230 | } | 236 | } |
231 | 237 | ||
@@ -332,34 +338,39 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
332 | 338 | ||
333 | public List<SceneObjectPart> GetLinkParts(int linkType) | 339 | public List<SceneObjectPart> GetLinkParts(int linkType) |
334 | { | 340 | { |
341 | return GetLinkParts(m_host, linkType); | ||
342 | } | ||
343 | |||
344 | private List<SceneObjectPart> GetLinkParts(SceneObjectPart part, int linkType) | ||
345 | { | ||
335 | List<SceneObjectPart> ret = new List<SceneObjectPart>(); | 346 | List<SceneObjectPart> ret = new List<SceneObjectPart>(); |
336 | if (m_host == null || m_host.ParentGroup == null || m_host.ParentGroup.IsDeleted) | 347 | if (part == null || part.ParentGroup == null || part.ParentGroup.IsDeleted) |
337 | return ret; | 348 | return ret; |
338 | ret.Add(m_host); | 349 | ret.Add(part); |
339 | 350 | ||
340 | switch (linkType) | 351 | switch (linkType) |
341 | { | 352 | { |
342 | case ScriptBaseClass.LINK_SET: | 353 | case ScriptBaseClass.LINK_SET: |
343 | return new List<SceneObjectPart>(m_host.ParentGroup.Parts); | 354 | return new List<SceneObjectPart>(part.ParentGroup.Parts); |
344 | 355 | ||
345 | case ScriptBaseClass.LINK_ROOT: | 356 | case ScriptBaseClass.LINK_ROOT: |
346 | ret = new List<SceneObjectPart>(); | 357 | ret = new List<SceneObjectPart>(); |
347 | ret.Add(m_host.ParentGroup.RootPart); | 358 | ret.Add(part.ParentGroup.RootPart); |
348 | return ret; | 359 | return ret; |
349 | 360 | ||
350 | case ScriptBaseClass.LINK_ALL_OTHERS: | 361 | case ScriptBaseClass.LINK_ALL_OTHERS: |
351 | ret = new List<SceneObjectPart>(m_host.ParentGroup.Parts); | 362 | ret = new List<SceneObjectPart>(part.ParentGroup.Parts); |
352 | 363 | ||
353 | if (ret.Contains(m_host)) | 364 | if (ret.Contains(part)) |
354 | ret.Remove(m_host); | 365 | ret.Remove(part); |
355 | 366 | ||
356 | return ret; | 367 | return ret; |
357 | 368 | ||
358 | case ScriptBaseClass.LINK_ALL_CHILDREN: | 369 | case ScriptBaseClass.LINK_ALL_CHILDREN: |
359 | ret = new List<SceneObjectPart>(m_host.ParentGroup.Parts); | 370 | ret = new List<SceneObjectPart>(part.ParentGroup.Parts); |
360 | 371 | ||
361 | if (ret.Contains(m_host.ParentGroup.RootPart)) | 372 | if (ret.Contains(part.ParentGroup.RootPart)) |
362 | ret.Remove(m_host.ParentGroup.RootPart); | 373 | ret.Remove(part.ParentGroup.RootPart); |
363 | return ret; | 374 | return ret; |
364 | 375 | ||
365 | case ScriptBaseClass.LINK_THIS: | 376 | case ScriptBaseClass.LINK_THIS: |
@@ -369,7 +380,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
369 | if (linkType < 0) | 380 | if (linkType < 0) |
370 | return new List<SceneObjectPart>(); | 381 | return new List<SceneObjectPart>(); |
371 | 382 | ||
372 | SceneObjectPart target = m_host.ParentGroup.GetLinkNumPart(linkType); | 383 | SceneObjectPart target = part.ParentGroup.GetLinkNumPart(linkType); |
373 | if (target == null) | 384 | if (target == null) |
374 | return new List<SceneObjectPart>(); | 385 | return new List<SceneObjectPart>(); |
375 | ret = new List<SceneObjectPart>(); | 386 | ret = new List<SceneObjectPart>(); |
@@ -1764,13 +1775,11 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
1764 | { | 1775 | { |
1765 | try | 1776 | try |
1766 | { | 1777 | { |
1767 | parts[0].ParentGroup.areUpdatesSuspended = true; | ||
1768 | foreach (SceneObjectPart part in parts) | 1778 | foreach (SceneObjectPart part in parts) |
1769 | SetAlpha(part, alpha, face); | 1779 | SetAlpha(part, alpha, face); |
1770 | } | 1780 | } |
1771 | finally | 1781 | finally |
1772 | { | 1782 | { |
1773 | parts[0].ParentGroup.areUpdatesSuspended = false; | ||
1774 | } | 1783 | } |
1775 | } | 1784 | } |
1776 | } | 1785 | } |
@@ -1951,13 +1960,11 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
1951 | { | 1960 | { |
1952 | try | 1961 | try |
1953 | { | 1962 | { |
1954 | parts[0].ParentGroup.areUpdatesSuspended = true; | ||
1955 | foreach (SceneObjectPart part in parts) | 1963 | foreach (SceneObjectPart part in parts) |
1956 | SetTexture(part, texture, face); | 1964 | SetTexture(part, texture, face); |
1957 | } | 1965 | } |
1958 | finally | 1966 | finally |
1959 | { | 1967 | { |
1960 | parts[0].ParentGroup.areUpdatesSuspended = false; | ||
1961 | } | 1968 | } |
1962 | } | 1969 | } |
1963 | ScriptSleep(200); | 1970 | ScriptSleep(200); |
@@ -3340,7 +3347,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3340 | IAttachmentsModule attachmentsModule = m_ScriptEngine.World.AttachmentsModule; | 3347 | IAttachmentsModule attachmentsModule = m_ScriptEngine.World.AttachmentsModule; |
3341 | 3348 | ||
3342 | if (attachmentsModule != null) | 3349 | if (attachmentsModule != null) |
3343 | return attachmentsModule.AttachObject(presence, grp, (uint)attachmentPoint, false, true); | 3350 | return attachmentsModule.AttachObject(presence, grp, (uint)attachmentPoint, false, true, false); |
3344 | else | 3351 | else |
3345 | return false; | 3352 | return false; |
3346 | } | 3353 | } |
@@ -3747,29 +3754,17 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3747 | 3754 | ||
3748 | m_host.AddScriptLPS(1); | 3755 | m_host.AddScriptLPS(1); |
3749 | 3756 | ||
3757 | int implicitPerms = 0; | ||
3758 | |||
3750 | if (m_host.ParentGroup.IsAttachment && (UUID)agent == m_host.ParentGroup.AttachedAvatar) | 3759 | if (m_host.ParentGroup.IsAttachment && (UUID)agent == m_host.ParentGroup.AttachedAvatar) |
3751 | { | 3760 | { |
3752 | // When attached, certain permissions are implicit if requested from owner | 3761 | // When attached, certain permissions are implicit if requested from owner |
3753 | int implicitPerms = ScriptBaseClass.PERMISSION_TAKE_CONTROLS | | 3762 | implicitPerms = ScriptBaseClass.PERMISSION_TAKE_CONTROLS | |
3754 | ScriptBaseClass.PERMISSION_TRIGGER_ANIMATION | | 3763 | ScriptBaseClass.PERMISSION_TRIGGER_ANIMATION | |
3755 | ScriptBaseClass.PERMISSION_CONTROL_CAMERA | | 3764 | ScriptBaseClass.PERMISSION_CONTROL_CAMERA | |
3756 | ScriptBaseClass.PERMISSION_TRACK_CAMERA | | 3765 | ScriptBaseClass.PERMISSION_TRACK_CAMERA | |
3757 | ScriptBaseClass.PERMISSION_ATTACH; | 3766 | ScriptBaseClass.PERMISSION_ATTACH; |
3758 | 3767 | ||
3759 | if ((perm & (~implicitPerms)) == 0) // Requested only implicit perms | ||
3760 | { | ||
3761 | m_host.TaskInventory.LockItemsForWrite(true); | ||
3762 | m_host.TaskInventory[m_item.ItemID].PermsGranter = agentID; | ||
3763 | m_host.TaskInventory[m_item.ItemID].PermsMask = perm; | ||
3764 | m_host.TaskInventory.LockItemsForWrite(false); | ||
3765 | |||
3766 | m_ScriptEngine.PostScriptEvent(m_item.ItemID, new EventParams( | ||
3767 | "run_time_permissions", new Object[] { | ||
3768 | new LSL_Integer(perm) }, | ||
3769 | new DetectParams[0])); | ||
3770 | |||
3771 | return; | ||
3772 | } | ||
3773 | } | 3768 | } |
3774 | else | 3769 | else |
3775 | { | 3770 | { |
@@ -3790,26 +3785,31 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3790 | if (sitting) | 3785 | if (sitting) |
3791 | { | 3786 | { |
3792 | // When agent is sitting, certain permissions are implicit if requested from sitting agent | 3787 | // When agent is sitting, certain permissions are implicit if requested from sitting agent |
3793 | int implicitPerms = ScriptBaseClass.PERMISSION_TRIGGER_ANIMATION | | 3788 | implicitPerms = ScriptBaseClass.PERMISSION_TRIGGER_ANIMATION | |
3794 | ScriptBaseClass.PERMISSION_CONTROL_CAMERA | | 3789 | ScriptBaseClass.PERMISSION_CONTROL_CAMERA | |
3795 | ScriptBaseClass.PERMISSION_TRACK_CAMERA | | 3790 | ScriptBaseClass.PERMISSION_TRACK_CAMERA | |
3796 | ScriptBaseClass.PERMISSION_TAKE_CONTROLS; | 3791 | ScriptBaseClass.PERMISSION_TAKE_CONTROLS; |
3792 | } | ||
3793 | else | ||
3794 | { | ||
3795 | if (World.GetExtraSetting("auto_grant_attach_perms") == "true") | ||
3796 | implicitPerms = ScriptBaseClass.PERMISSION_ATTACH; | ||
3797 | } | ||
3798 | } | ||
3797 | 3799 | ||
3798 | if ((perm & (~implicitPerms)) == 0) // Requested only implicit perms | 3800 | if ((perm & (~implicitPerms)) == 0) // Requested only implicit perms |
3799 | { | 3801 | { |
3800 | m_host.TaskInventory.LockItemsForWrite(true); | 3802 | m_host.TaskInventory.LockItemsForWrite(true); |
3801 | m_host.TaskInventory[m_item.ItemID].PermsGranter = agentID; | 3803 | m_host.TaskInventory[m_item.ItemID].PermsGranter = agentID; |
3802 | m_host.TaskInventory[m_item.ItemID].PermsMask = perm; | 3804 | m_host.TaskInventory[m_item.ItemID].PermsMask = perm; |
3803 | m_host.TaskInventory.LockItemsForWrite(false); | 3805 | m_host.TaskInventory.LockItemsForWrite(false); |
3804 | 3806 | ||
3805 | m_ScriptEngine.PostScriptEvent(m_item.ItemID, new EventParams( | 3807 | m_ScriptEngine.PostScriptEvent(m_item.ItemID, new EventParams( |
3806 | "run_time_permissions", new Object[] { | 3808 | "run_time_permissions", new Object[] { |
3807 | new LSL_Integer(perm) }, | 3809 | new LSL_Integer(perm) }, |
3808 | new DetectParams[0])); | 3810 | new DetectParams[0])); |
3809 | 3811 | ||
3810 | return; | 3812 | return; |
3811 | } | ||
3812 | } | ||
3813 | } | 3813 | } |
3814 | 3814 | ||
3815 | ScenePresence presence = World.GetScenePresence(agentID); | 3815 | ScenePresence presence = World.GetScenePresence(agentID); |
@@ -3927,13 +3927,11 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3927 | { | 3927 | { |
3928 | try | 3928 | try |
3929 | { | 3929 | { |
3930 | parts[0].ParentGroup.areUpdatesSuspended = true; | ||
3931 | foreach (SceneObjectPart part in parts) | 3930 | foreach (SceneObjectPart part in parts) |
3932 | part.SetFaceColor(new Vector3((float)color.x, (float)color.y, (float)color.z), face); | 3931 | part.SetFaceColor(new Vector3((float)color.x, (float)color.y, (float)color.z), face); |
3933 | } | 3932 | } |
3934 | finally | 3933 | finally |
3935 | { | 3934 | { |
3936 | parts[0].ParentGroup.areUpdatesSuspended = false; | ||
3937 | } | 3935 | } |
3938 | } | 3936 | } |
3939 | } | 3937 | } |
@@ -4051,7 +4049,6 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
4051 | { | 4049 | { |
4052 | try | 4050 | try |
4053 | { | 4051 | { |
4054 | parts[0].ParentGroup.areUpdatesSuspended = true; | ||
4055 | foreach (SceneObjectPart part in parts) | 4052 | foreach (SceneObjectPart part in parts) |
4056 | { | 4053 | { |
4057 | parentPrim.DelinkFromGroup(part.LocalId, true); | 4054 | parentPrim.DelinkFromGroup(part.LocalId, true); |
@@ -4059,7 +4056,6 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
4059 | } | 4056 | } |
4060 | finally | 4057 | finally |
4061 | { | 4058 | { |
4062 | parts[0].ParentGroup.areUpdatesSuspended = false; | ||
4063 | } | 4059 | } |
4064 | } | 4060 | } |
4065 | 4061 | ||
@@ -4074,7 +4070,6 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
4074 | 4070 | ||
4075 | try | 4071 | try |
4076 | { | 4072 | { |
4077 | parts[0].ParentGroup.areUpdatesSuspended = true; | ||
4078 | foreach (SceneObjectPart part in parts) | 4073 | foreach (SceneObjectPart part in parts) |
4079 | { | 4074 | { |
4080 | part.ClearUpdateSchedule(); | 4075 | part.ClearUpdateSchedule(); |
@@ -4083,7 +4078,6 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
4083 | } | 4078 | } |
4084 | finally | 4079 | finally |
4085 | { | 4080 | { |
4086 | parts[0].ParentGroup.areUpdatesSuspended = false; | ||
4087 | } | 4081 | } |
4088 | 4082 | ||
4089 | 4083 | ||
@@ -5369,12 +5363,21 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
5369 | { | 5363 | { |
5370 | return 0; | 5364 | return 0; |
5371 | } | 5365 | } |
5366 | |||
5367 | // Vectors & Rotations always return zero in SL, but | ||
5368 | // keys don't always return zero, it seems to be a bit complex. | ||
5369 | else if (src.Data[index] is LSL_Vector || | ||
5370 | src.Data[index] is LSL_Rotation) | ||
5371 | { | ||
5372 | return 0; | ||
5373 | } | ||
5372 | try | 5374 | try |
5373 | { | 5375 | { |
5376 | |||
5374 | if (src.Data[index] is LSL_Integer) | 5377 | if (src.Data[index] is LSL_Integer) |
5375 | return (LSL_Integer) src.Data[index]; | 5378 | return (LSL_Integer)src.Data[index]; |
5376 | else if (src.Data[index] is LSL_Float) | 5379 | else if (src.Data[index] is LSL_Float) |
5377 | return Convert.ToInt32(((LSL_Float) src.Data[index]).value); | 5380 | return Convert.ToInt32(((LSL_Float)src.Data[index]).value); |
5378 | return new LSL_Integer(src.Data[index].ToString()); | 5381 | return new LSL_Integer(src.Data[index].ToString()); |
5379 | } | 5382 | } |
5380 | catch (FormatException) | 5383 | catch (FormatException) |
@@ -5394,12 +5397,28 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
5394 | { | 5397 | { |
5395 | return 0.0; | 5398 | return 0.0; |
5396 | } | 5399 | } |
5400 | |||
5401 | // Vectors & Rotations always return zero in SL | ||
5402 | else if (src.Data[index] is LSL_Vector || | ||
5403 | src.Data[index] is LSL_Rotation) | ||
5404 | { | ||
5405 | return 0; | ||
5406 | } | ||
5407 | // valid keys seem to get parsed as integers then converted to floats | ||
5408 | else | ||
5409 | { | ||
5410 | UUID uuidt; | ||
5411 | if (src.Data[index] is LSL_Key && UUID.TryParse(src.Data[index].ToString(), out uuidt)) | ||
5412 | { | ||
5413 | return Convert.ToDouble(new LSL_Integer(src.Data[index].ToString()).value); | ||
5414 | } | ||
5415 | } | ||
5397 | try | 5416 | try |
5398 | { | 5417 | { |
5399 | if (src.Data[index] is LSL_Integer) | 5418 | if (src.Data[index] is LSL_Integer) |
5400 | return Convert.ToDouble(((LSL_Integer) src.Data[index]).value); | 5419 | return Convert.ToDouble(((LSL_Integer)src.Data[index]).value); |
5401 | else if (src.Data[index] is LSL_Float) | 5420 | else if (src.Data[index] is LSL_Float) |
5402 | return Convert.ToDouble(((LSL_Float) src.Data[index]).value); | 5421 | return Convert.ToDouble(((LSL_Float)src.Data[index]).value); |
5403 | else if (src.Data[index] is LSL_String) | 5422 | else if (src.Data[index] is LSL_String) |
5404 | { | 5423 | { |
5405 | string str = ((LSL_String) src.Data[index]).m_string; | 5424 | string str = ((LSL_String) src.Data[index]).m_string; |
@@ -5437,17 +5456,30 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
5437 | return src.Data[index].ToString(); | 5456 | return src.Data[index].ToString(); |
5438 | } | 5457 | } |
5439 | 5458 | ||
5440 | public LSL_String llList2Key(LSL_List src, int index) | 5459 | public LSL_Key llList2Key(LSL_List src, int index) |
5441 | { | 5460 | { |
5442 | m_host.AddScriptLPS(1); | 5461 | m_host.AddScriptLPS(1); |
5443 | if (index < 0) | 5462 | if (index < 0) |
5444 | { | 5463 | { |
5445 | index = src.Length + index; | 5464 | index = src.Length + index; |
5446 | } | 5465 | } |
5466 | |||
5447 | if (index >= src.Length || index < 0) | 5467 | if (index >= src.Length || index < 0) |
5448 | { | 5468 | { |
5449 | return ""; | 5469 | return ""; |
5450 | } | 5470 | } |
5471 | |||
5472 | // SL spits out an empty string for types other than key & string | ||
5473 | // At the time of patching, LSL_Key is currently LSL_String, | ||
5474 | // so the OR check may be a little redundant, but it's being done | ||
5475 | // for completion and should LSL_Key ever be implemented | ||
5476 | // as it's own struct | ||
5477 | else if (!(src.Data[index] is LSL_String || | ||
5478 | src.Data[index] is LSL_Key)) | ||
5479 | { | ||
5480 | return ""; | ||
5481 | } | ||
5482 | |||
5451 | return src.Data[index].ToString(); | 5483 | return src.Data[index].ToString(); |
5452 | } | 5484 | } |
5453 | 5485 | ||
@@ -5466,6 +5498,18 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
5466 | { | 5498 | { |
5467 | return (LSL_Vector)src.Data[index]; | 5499 | return (LSL_Vector)src.Data[index]; |
5468 | } | 5500 | } |
5501 | |||
5502 | // SL spits always out ZERO_VECTOR for anything other than | ||
5503 | // strings or vectors. Although keys always return ZERO_VECTOR, | ||
5504 | // it is currently difficult to make the distinction between | ||
5505 | // a string, a key as string and a string that by coincidence | ||
5506 | // is a string, so we're going to leave that up to the | ||
5507 | // LSL_Vector constructor. | ||
5508 | else if (!(src.Data[index] is LSL_String || | ||
5509 | src.Data[index] is LSL_Vector)) | ||
5510 | { | ||
5511 | return new LSL_Vector(0, 0, 0); | ||
5512 | } | ||
5469 | else | 5513 | else |
5470 | { | 5514 | { |
5471 | return new LSL_Vector(src.Data[index].ToString()); | 5515 | return new LSL_Vector(src.Data[index].ToString()); |
@@ -5483,7 +5527,19 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
5483 | { | 5527 | { |
5484 | return new LSL_Rotation(0, 0, 0, 1); | 5528 | return new LSL_Rotation(0, 0, 0, 1); |
5485 | } | 5529 | } |
5486 | if (src.Data[index].GetType() == typeof(LSL_Rotation)) | 5530 | |
5531 | // SL spits always out ZERO_ROTATION for anything other than | ||
5532 | // strings or vectors. Although keys always return ZERO_ROTATION, | ||
5533 | // it is currently difficult to make the distinction between | ||
5534 | // a string, a key as string and a string that by coincidence | ||
5535 | // is a string, so we're going to leave that up to the | ||
5536 | // LSL_Rotation constructor. | ||
5537 | else if (!(src.Data[index] is LSL_String || | ||
5538 | src.Data[index] is LSL_Rotation)) | ||
5539 | { | ||
5540 | return new LSL_Rotation(0, 0, 0, 1); | ||
5541 | } | ||
5542 | else if (src.Data[index].GetType() == typeof(LSL_Rotation)) | ||
5487 | { | 5543 | { |
5488 | return (LSL_Rotation)src.Data[index]; | 5544 | return (LSL_Rotation)src.Data[index]; |
5489 | } | 5545 | } |
@@ -6236,7 +6292,6 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
6236 | { | 6292 | { |
6237 | try | 6293 | try |
6238 | { | 6294 | { |
6239 | parts[0].ParentGroup.areUpdatesSuspended = true; | ||
6240 | foreach (var part in parts) | 6295 | foreach (var part in parts) |
6241 | { | 6296 | { |
6242 | SetTextureAnim(part, mode, face, sizex, sizey, start, length, rate); | 6297 | SetTextureAnim(part, mode, face, sizex, sizey, start, length, rate); |
@@ -6244,7 +6299,6 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
6244 | } | 6299 | } |
6245 | finally | 6300 | finally |
6246 | { | 6301 | { |
6247 | parts[0].ParentGroup.areUpdatesSuspended = false; | ||
6248 | } | 6302 | } |
6249 | } | 6303 | } |
6250 | } | 6304 | } |
@@ -7689,7 +7743,8 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7689 | public void llSetPrimitiveParams(LSL_List rules) | 7743 | public void llSetPrimitiveParams(LSL_List rules) |
7690 | { | 7744 | { |
7691 | m_host.AddScriptLPS(1); | 7745 | m_host.AddScriptLPS(1); |
7692 | SetPrimParams(m_host, rules); | 7746 | |
7747 | setLinkPrimParams(ScriptBaseClass.LINK_THIS, rules); | ||
7693 | 7748 | ||
7694 | ScriptSleep(200); | 7749 | ScriptSleep(200); |
7695 | } | 7750 | } |
@@ -7703,26 +7758,47 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7703 | 7758 | ||
7704 | private void setLinkPrimParams(int linknumber, LSL_List rules) | 7759 | private void setLinkPrimParams(int linknumber, LSL_List rules) |
7705 | { | 7760 | { |
7706 | List<SceneObjectPart> parts = GetLinkParts(linknumber); | 7761 | List<object> parts = new List<object>(); |
7762 | List<SceneObjectPart> prims = GetLinkParts(linknumber); | ||
7707 | List<ScenePresence> avatars = GetLinkAvatars(linknumber); | 7763 | List<ScenePresence> avatars = GetLinkAvatars(linknumber); |
7708 | if (parts.Count>0) | 7764 | foreach (SceneObjectPart p in prims) |
7765 | parts.Add(p); | ||
7766 | foreach (ScenePresence p in avatars) | ||
7767 | parts.Add(p); | ||
7768 | |||
7769 | LSL_List remaining = null; | ||
7770 | |||
7771 | if (parts.Count > 0) | ||
7709 | { | 7772 | { |
7710 | try | 7773 | foreach (object part in parts) |
7711 | { | 7774 | { |
7712 | parts[0].ParentGroup.areUpdatesSuspended = true; | 7775 | if (part is SceneObjectPart) |
7713 | foreach (SceneObjectPart part in parts) | 7776 | remaining = SetPrimParams((SceneObjectPart)part, rules); |
7714 | SetPrimParams(part, rules); | 7777 | else |
7778 | remaining = SetPrimParams((ScenePresence)part, rules); | ||
7715 | } | 7779 | } |
7716 | finally | 7780 | |
7781 | while((object)remaining != null && remaining.Length > 2) | ||
7717 | { | 7782 | { |
7718 | parts[0].ParentGroup.areUpdatesSuspended = false; | 7783 | linknumber = remaining.GetLSLIntegerItem(0); |
7784 | rules = remaining.GetSublist(1,-1); | ||
7785 | parts.Clear(); | ||
7786 | prims = GetLinkParts(linknumber); | ||
7787 | avatars = GetLinkAvatars(linknumber); | ||
7788 | foreach (SceneObjectPart p in prims) | ||
7789 | parts.Add(p); | ||
7790 | foreach (ScenePresence p in avatars) | ||
7791 | parts.Add(p); | ||
7792 | |||
7793 | foreach (object part in parts) | ||
7794 | { | ||
7795 | if (part is SceneObjectPart) | ||
7796 | remaining = SetPrimParams((SceneObjectPart)part, rules); | ||
7797 | else | ||
7798 | remaining = SetPrimParams((ScenePresence)part, rules); | ||
7799 | } | ||
7719 | } | 7800 | } |
7720 | } | 7801 | } |
7721 | if (avatars.Count > 0) | ||
7722 | { | ||
7723 | foreach (ScenePresence avatar in avatars) | ||
7724 | SetPrimParams(avatar, rules); | ||
7725 | } | ||
7726 | } | 7802 | } |
7727 | 7803 | ||
7728 | private void SetPhysicsMaterial(SceneObjectPart part, int material_bits, | 7804 | private void SetPhysicsMaterial(SceneObjectPart part, int material_bits, |
@@ -7784,7 +7860,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7784 | return new Vector3((float)x, (float)y, (float)z); | 7860 | return new Vector3((float)x, (float)y, (float)z); |
7785 | } | 7861 | } |
7786 | 7862 | ||
7787 | protected void SetPrimParams(ScenePresence av, LSL_List rules) | 7863 | protected LSL_List SetPrimParams(ScenePresence av, LSL_List rules) |
7788 | { | 7864 | { |
7789 | //This is a special version of SetPrimParams to deal with avatars which are sat on the linkset. | 7865 | //This is a special version of SetPrimParams to deal with avatars which are sat on the linkset. |
7790 | 7866 | ||
@@ -7807,7 +7883,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7807 | case (int)ScriptBaseClass.PRIM_POS_LOCAL: | 7883 | case (int)ScriptBaseClass.PRIM_POS_LOCAL: |
7808 | { | 7884 | { |
7809 | if (remain < 1) | 7885 | if (remain < 1) |
7810 | return; | 7886 | return null; |
7811 | 7887 | ||
7812 | LSL_Vector v; | 7888 | LSL_Vector v; |
7813 | v = rules.GetVector3Item(idx++); | 7889 | v = rules.GetVector3Item(idx++); |
@@ -7841,7 +7917,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7841 | case (int)ScriptBaseClass.PRIM_ROTATION: | 7917 | case (int)ScriptBaseClass.PRIM_ROTATION: |
7842 | { | 7918 | { |
7843 | if (remain < 1) | 7919 | if (remain < 1) |
7844 | return; | 7920 | return null; |
7845 | 7921 | ||
7846 | LSL_Rotation r; | 7922 | LSL_Rotation r; |
7847 | r = rules.GetQuaternionItem(idx++); | 7923 | r = rules.GetQuaternionItem(idx++); |
@@ -7872,7 +7948,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7872 | case (int)ScriptBaseClass.PRIM_NAME: | 7948 | case (int)ScriptBaseClass.PRIM_NAME: |
7873 | case (int)ScriptBaseClass.PRIM_DESC: | 7949 | case (int)ScriptBaseClass.PRIM_DESC: |
7874 | if (remain < 1) | 7950 | if (remain < 1) |
7875 | return; | 7951 | return null; |
7876 | idx++; | 7952 | idx++; |
7877 | break; | 7953 | break; |
7878 | 7954 | ||
@@ -7880,13 +7956,13 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7880 | case (int)ScriptBaseClass.PRIM_FULLBRIGHT: | 7956 | case (int)ScriptBaseClass.PRIM_FULLBRIGHT: |
7881 | case (int)ScriptBaseClass.PRIM_TEXGEN: | 7957 | case (int)ScriptBaseClass.PRIM_TEXGEN: |
7882 | if (remain < 2) | 7958 | if (remain < 2) |
7883 | return; | 7959 | return null; |
7884 | idx += 2; | 7960 | idx += 2; |
7885 | break; | 7961 | break; |
7886 | 7962 | ||
7887 | case (int)ScriptBaseClass.PRIM_TYPE: | 7963 | case (int)ScriptBaseClass.PRIM_TYPE: |
7888 | if (remain < 3) | 7964 | if (remain < 3) |
7889 | return; | 7965 | return null; |
7890 | code = (int)rules.GetLSLIntegerItem(idx++); | 7966 | code = (int)rules.GetLSLIntegerItem(idx++); |
7891 | remain = rules.Length - idx; | 7967 | remain = rules.Length - idx; |
7892 | switch (code) | 7968 | switch (code) |
@@ -7895,13 +7971,13 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7895 | case (int)ScriptBaseClass.PRIM_TYPE_CYLINDER: | 7971 | case (int)ScriptBaseClass.PRIM_TYPE_CYLINDER: |
7896 | case (int)ScriptBaseClass.PRIM_TYPE_PRISM: | 7972 | case (int)ScriptBaseClass.PRIM_TYPE_PRISM: |
7897 | if (remain < 6) | 7973 | if (remain < 6) |
7898 | return; | 7974 | return null; |
7899 | idx += 6; | 7975 | idx += 6; |
7900 | break; | 7976 | break; |
7901 | 7977 | ||
7902 | case (int)ScriptBaseClass.PRIM_TYPE_SPHERE: | 7978 | case (int)ScriptBaseClass.PRIM_TYPE_SPHERE: |
7903 | if (remain < 5) | 7979 | if (remain < 5) |
7904 | return; | 7980 | return null; |
7905 | idx += 5; | 7981 | idx += 5; |
7906 | break; | 7982 | break; |
7907 | 7983 | ||
@@ -7909,13 +7985,13 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7909 | case (int)ScriptBaseClass.PRIM_TYPE_TUBE: | 7985 | case (int)ScriptBaseClass.PRIM_TYPE_TUBE: |
7910 | case (int)ScriptBaseClass.PRIM_TYPE_RING: | 7986 | case (int)ScriptBaseClass.PRIM_TYPE_RING: |
7911 | if (remain < 11) | 7987 | if (remain < 11) |
7912 | return; | 7988 | return null; |
7913 | idx += 11; | 7989 | idx += 11; |
7914 | break; | 7990 | break; |
7915 | 7991 | ||
7916 | case (int)ScriptBaseClass.PRIM_TYPE_SCULPT: | 7992 | case (int)ScriptBaseClass.PRIM_TYPE_SCULPT: |
7917 | if (remain < 2) | 7993 | if (remain < 2) |
7918 | return; | 7994 | return null; |
7919 | idx += 2; | 7995 | idx += 2; |
7920 | break; | 7996 | break; |
7921 | } | 7997 | } |
@@ -7926,7 +8002,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7926 | case (int)ScriptBaseClass.PRIM_BUMP_SHINY: | 8002 | case (int)ScriptBaseClass.PRIM_BUMP_SHINY: |
7927 | case (int)ScriptBaseClass.PRIM_OMEGA: | 8003 | case (int)ScriptBaseClass.PRIM_OMEGA: |
7928 | if (remain < 3) | 8004 | if (remain < 3) |
7929 | return; | 8005 | return null; |
7930 | idx += 3; | 8006 | idx += 3; |
7931 | break; | 8007 | break; |
7932 | 8008 | ||
@@ -7934,33 +8010,22 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7934 | case (int)ScriptBaseClass.PRIM_POINT_LIGHT: | 8010 | case (int)ScriptBaseClass.PRIM_POINT_LIGHT: |
7935 | case (int)ScriptBaseClass.PRIM_PHYSICS_MATERIAL: | 8011 | case (int)ScriptBaseClass.PRIM_PHYSICS_MATERIAL: |
7936 | if (remain < 5) | 8012 | if (remain < 5) |
7937 | return; | 8013 | return null; |
7938 | idx += 5; | 8014 | idx += 5; |
7939 | break; | 8015 | break; |
7940 | 8016 | ||
7941 | case (int)ScriptBaseClass.PRIM_FLEXIBLE: | 8017 | case (int)ScriptBaseClass.PRIM_FLEXIBLE: |
7942 | if (remain < 7) | 8018 | if (remain < 7) |
7943 | return; | 8019 | return null; |
7944 | 8020 | ||
7945 | idx += 7; | 8021 | idx += 7; |
7946 | break; | 8022 | break; |
7947 | 8023 | ||
7948 | case (int)ScriptBaseClass.PRIM_LINK_TARGET: | 8024 | case (int)ScriptBaseClass.PRIM_LINK_TARGET: |
7949 | if (remain < 3) // setting to 3 on the basis that parsing any usage of PRIM_LINK_TARGET that has nothing following it is pointless. | 8025 | if (remain < 3) // setting to 3 on the basis that parsing any usage of PRIM_LINK_TARGET that has nothing following it is pointless. |
7950 | return; | 8026 | return null; |
7951 | 8027 | ||
7952 | if (positionChanged) | 8028 | return rules.GetSublist(idx, -1); |
7953 | { | ||
7954 | positionChanged = false; | ||
7955 | av.OffsetPosition = finalPos; | ||
7956 | // av.SendAvatarDataToAllAgents(); | ||
7957 | av.SendTerseUpdateToAllClients(); | ||
7958 | } | ||
7959 | |||
7960 | LSL_Integer new_linknumber = rules.GetLSLIntegerItem(idx++); | ||
7961 | LSL_List new_rules = rules.GetSublist(idx, -1); | ||
7962 | setLinkPrimParams((int)new_linknumber, new_rules); | ||
7963 | return; | ||
7964 | } | 8029 | } |
7965 | } | 8030 | } |
7966 | } | 8031 | } |
@@ -7975,12 +8040,13 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7975 | positionChanged = false; | 8040 | positionChanged = false; |
7976 | } | 8041 | } |
7977 | } | 8042 | } |
8043 | return null; | ||
7978 | } | 8044 | } |
7979 | 8045 | ||
7980 | protected void SetPrimParams(SceneObjectPart part, LSL_List rules) | 8046 | protected LSL_List SetPrimParams(SceneObjectPart part, LSL_List rules) |
7981 | { | 8047 | { |
7982 | if (part == null || part.ParentGroup == null || part.ParentGroup.IsDeleted) | 8048 | if (part == null || part.ParentGroup == null || part.ParentGroup.IsDeleted) |
7983 | return; | 8049 | return null; |
7984 | 8050 | ||
7985 | int idx = 0; | 8051 | int idx = 0; |
7986 | 8052 | ||
@@ -8005,7 +8071,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8005 | case (int)ScriptBaseClass.PRIM_POSITION: | 8071 | case (int)ScriptBaseClass.PRIM_POSITION: |
8006 | case (int)ScriptBaseClass.PRIM_POS_LOCAL: | 8072 | case (int)ScriptBaseClass.PRIM_POS_LOCAL: |
8007 | if (remain < 1) | 8073 | if (remain < 1) |
8008 | return; | 8074 | return null; |
8009 | 8075 | ||
8010 | v=rules.GetVector3Item(idx++); | 8076 | v=rules.GetVector3Item(idx++); |
8011 | currentPosition = GetSetPosTarget(part, v, currentPosition); | 8077 | currentPosition = GetSetPosTarget(part, v, currentPosition); |
@@ -8014,7 +8080,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8014 | break; | 8080 | break; |
8015 | case (int)ScriptBaseClass.PRIM_SIZE: | 8081 | case (int)ScriptBaseClass.PRIM_SIZE: |
8016 | if (remain < 1) | 8082 | if (remain < 1) |
8017 | return; | 8083 | return null; |
8018 | 8084 | ||
8019 | v=rules.GetVector3Item(idx++); | 8085 | v=rules.GetVector3Item(idx++); |
8020 | SetScale(part, v); | 8086 | SetScale(part, v); |
@@ -8022,7 +8088,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8022 | break; | 8088 | break; |
8023 | case (int)ScriptBaseClass.PRIM_ROTATION: | 8089 | case (int)ScriptBaseClass.PRIM_ROTATION: |
8024 | if (remain < 1) | 8090 | if (remain < 1) |
8025 | return; | 8091 | return null; |
8026 | 8092 | ||
8027 | LSL_Rotation q = rules.GetQuaternionItem(idx++); | 8093 | LSL_Rotation q = rules.GetQuaternionItem(idx++); |
8028 | SceneObjectPart rootPart = parentgrp.RootPart; | 8094 | SceneObjectPart rootPart = parentgrp.RootPart; |
@@ -8043,7 +8109,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8043 | 8109 | ||
8044 | case (int)ScriptBaseClass.PRIM_TYPE: | 8110 | case (int)ScriptBaseClass.PRIM_TYPE: |
8045 | if (remain < 3) | 8111 | if (remain < 3) |
8046 | return; | 8112 | return null; |
8047 | 8113 | ||
8048 | code = (int)rules.GetLSLIntegerItem(idx++); | 8114 | code = (int)rules.GetLSLIntegerItem(idx++); |
8049 | 8115 | ||
@@ -8062,7 +8128,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8062 | { | 8128 | { |
8063 | case (int)ScriptBaseClass.PRIM_TYPE_BOX: | 8129 | case (int)ScriptBaseClass.PRIM_TYPE_BOX: |
8064 | if (remain < 6) | 8130 | if (remain < 6) |
8065 | return; | 8131 | return null; |
8066 | 8132 | ||
8067 | face = (int)rules.GetLSLIntegerItem(idx++); | 8133 | face = (int)rules.GetLSLIntegerItem(idx++); |
8068 | v = rules.GetVector3Item(idx++); // cut | 8134 | v = rules.GetVector3Item(idx++); // cut |
@@ -8077,7 +8143,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8077 | 8143 | ||
8078 | case (int)ScriptBaseClass.PRIM_TYPE_CYLINDER: | 8144 | case (int)ScriptBaseClass.PRIM_TYPE_CYLINDER: |
8079 | if (remain < 6) | 8145 | if (remain < 6) |
8080 | return; | 8146 | return null; |
8081 | 8147 | ||
8082 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape | 8148 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape |
8083 | v = rules.GetVector3Item(idx++); // cut | 8149 | v = rules.GetVector3Item(idx++); // cut |
@@ -8091,7 +8157,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8091 | 8157 | ||
8092 | case (int)ScriptBaseClass.PRIM_TYPE_PRISM: | 8158 | case (int)ScriptBaseClass.PRIM_TYPE_PRISM: |
8093 | if (remain < 6) | 8159 | if (remain < 6) |
8094 | return; | 8160 | return null; |
8095 | 8161 | ||
8096 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape | 8162 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape |
8097 | v = rules.GetVector3Item(idx++); //cut | 8163 | v = rules.GetVector3Item(idx++); //cut |
@@ -8105,7 +8171,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8105 | 8171 | ||
8106 | case (int)ScriptBaseClass.PRIM_TYPE_SPHERE: | 8172 | case (int)ScriptBaseClass.PRIM_TYPE_SPHERE: |
8107 | if (remain < 5) | 8173 | if (remain < 5) |
8108 | return; | 8174 | return null; |
8109 | 8175 | ||
8110 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape | 8176 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape |
8111 | v = rules.GetVector3Item(idx++); // cut | 8177 | v = rules.GetVector3Item(idx++); // cut |
@@ -8118,7 +8184,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8118 | 8184 | ||
8119 | case (int)ScriptBaseClass.PRIM_TYPE_TORUS: | 8185 | case (int)ScriptBaseClass.PRIM_TYPE_TORUS: |
8120 | if (remain < 11) | 8186 | if (remain < 11) |
8121 | return; | 8187 | return null; |
8122 | 8188 | ||
8123 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape | 8189 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape |
8124 | v = rules.GetVector3Item(idx++); //cut | 8190 | v = rules.GetVector3Item(idx++); //cut |
@@ -8137,7 +8203,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8137 | 8203 | ||
8138 | case (int)ScriptBaseClass.PRIM_TYPE_TUBE: | 8204 | case (int)ScriptBaseClass.PRIM_TYPE_TUBE: |
8139 | if (remain < 11) | 8205 | if (remain < 11) |
8140 | return; | 8206 | return null; |
8141 | 8207 | ||
8142 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape | 8208 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape |
8143 | v = rules.GetVector3Item(idx++); //cut | 8209 | v = rules.GetVector3Item(idx++); //cut |
@@ -8156,7 +8222,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8156 | 8222 | ||
8157 | case (int)ScriptBaseClass.PRIM_TYPE_RING: | 8223 | case (int)ScriptBaseClass.PRIM_TYPE_RING: |
8158 | if (remain < 11) | 8224 | if (remain < 11) |
8159 | return; | 8225 | return null; |
8160 | 8226 | ||
8161 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape | 8227 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape |
8162 | v = rules.GetVector3Item(idx++); //cut | 8228 | v = rules.GetVector3Item(idx++); //cut |
@@ -8175,7 +8241,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8175 | 8241 | ||
8176 | case (int)ScriptBaseClass.PRIM_TYPE_SCULPT: | 8242 | case (int)ScriptBaseClass.PRIM_TYPE_SCULPT: |
8177 | if (remain < 2) | 8243 | if (remain < 2) |
8178 | return; | 8244 | return null; |
8179 | 8245 | ||
8180 | string map = rules.Data[idx++].ToString(); | 8246 | string map = rules.Data[idx++].ToString(); |
8181 | face = (int)rules.GetLSLIntegerItem(idx++); // type | 8247 | face = (int)rules.GetLSLIntegerItem(idx++); // type |
@@ -8187,7 +8253,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8187 | 8253 | ||
8188 | case (int)ScriptBaseClass.PRIM_TEXTURE: | 8254 | case (int)ScriptBaseClass.PRIM_TEXTURE: |
8189 | if (remain < 5) | 8255 | if (remain < 5) |
8190 | return; | 8256 | return null; |
8191 | 8257 | ||
8192 | face=(int)rules.GetLSLIntegerItem(idx++); | 8258 | face=(int)rules.GetLSLIntegerItem(idx++); |
8193 | string tex=rules.Data[idx++].ToString(); | 8259 | string tex=rules.Data[idx++].ToString(); |
@@ -8204,7 +8270,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8204 | 8270 | ||
8205 | case (int)ScriptBaseClass.PRIM_COLOR: | 8271 | case (int)ScriptBaseClass.PRIM_COLOR: |
8206 | if (remain < 3) | 8272 | if (remain < 3) |
8207 | return; | 8273 | return null; |
8208 | 8274 | ||
8209 | face=(int)rules.GetLSLIntegerItem(idx++); | 8275 | face=(int)rules.GetLSLIntegerItem(idx++); |
8210 | LSL_Vector color=rules.GetVector3Item(idx++); | 8276 | LSL_Vector color=rules.GetVector3Item(idx++); |
@@ -8217,7 +8283,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8217 | 8283 | ||
8218 | case (int)ScriptBaseClass.PRIM_FLEXIBLE: | 8284 | case (int)ScriptBaseClass.PRIM_FLEXIBLE: |
8219 | if (remain < 7) | 8285 | if (remain < 7) |
8220 | return; | 8286 | return null; |
8221 | 8287 | ||
8222 | bool flexi = rules.GetLSLIntegerItem(idx++); | 8288 | bool flexi = rules.GetLSLIntegerItem(idx++); |
8223 | int softness = rules.GetLSLIntegerItem(idx++); | 8289 | int softness = rules.GetLSLIntegerItem(idx++); |
@@ -8233,7 +8299,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8233 | 8299 | ||
8234 | case (int)ScriptBaseClass.PRIM_POINT_LIGHT: | 8300 | case (int)ScriptBaseClass.PRIM_POINT_LIGHT: |
8235 | if (remain < 5) | 8301 | if (remain < 5) |
8236 | return; | 8302 | return null; |
8237 | bool light = rules.GetLSLIntegerItem(idx++); | 8303 | bool light = rules.GetLSLIntegerItem(idx++); |
8238 | LSL_Vector lightcolor = rules.GetVector3Item(idx++); | 8304 | LSL_Vector lightcolor = rules.GetVector3Item(idx++); |
8239 | float intensity = (float)rules.GetLSLFloatItem(idx++); | 8305 | float intensity = (float)rules.GetLSLFloatItem(idx++); |
@@ -8246,7 +8312,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8246 | 8312 | ||
8247 | case (int)ScriptBaseClass.PRIM_GLOW: | 8313 | case (int)ScriptBaseClass.PRIM_GLOW: |
8248 | if (remain < 2) | 8314 | if (remain < 2) |
8249 | return; | 8315 | return null; |
8250 | face = rules.GetLSLIntegerItem(idx++); | 8316 | face = rules.GetLSLIntegerItem(idx++); |
8251 | float glow = (float)rules.GetLSLFloatItem(idx++); | 8317 | float glow = (float)rules.GetLSLFloatItem(idx++); |
8252 | 8318 | ||
@@ -8256,7 +8322,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8256 | 8322 | ||
8257 | case (int)ScriptBaseClass.PRIM_BUMP_SHINY: | 8323 | case (int)ScriptBaseClass.PRIM_BUMP_SHINY: |
8258 | if (remain < 3) | 8324 | if (remain < 3) |
8259 | return; | 8325 | return null; |
8260 | face = (int)rules.GetLSLIntegerItem(idx++); | 8326 | face = (int)rules.GetLSLIntegerItem(idx++); |
8261 | int shiny = (int)rules.GetLSLIntegerItem(idx++); | 8327 | int shiny = (int)rules.GetLSLIntegerItem(idx++); |
8262 | Bumpiness bump = (Bumpiness)(int)rules.GetLSLIntegerItem(idx++); | 8328 | Bumpiness bump = (Bumpiness)(int)rules.GetLSLIntegerItem(idx++); |
@@ -8267,7 +8333,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8267 | 8333 | ||
8268 | case (int)ScriptBaseClass.PRIM_FULLBRIGHT: | 8334 | case (int)ScriptBaseClass.PRIM_FULLBRIGHT: |
8269 | if (remain < 2) | 8335 | if (remain < 2) |
8270 | return; | 8336 | return null; |
8271 | face = rules.GetLSLIntegerItem(idx++); | 8337 | face = rules.GetLSLIntegerItem(idx++); |
8272 | bool st = rules.GetLSLIntegerItem(idx++); | 8338 | bool st = rules.GetLSLIntegerItem(idx++); |
8273 | SetFullBright(part, face , st); | 8339 | SetFullBright(part, face , st); |
@@ -8275,17 +8341,17 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8275 | 8341 | ||
8276 | case (int)ScriptBaseClass.PRIM_MATERIAL: | 8342 | case (int)ScriptBaseClass.PRIM_MATERIAL: |
8277 | if (remain < 1) | 8343 | if (remain < 1) |
8278 | return; | 8344 | return null; |
8279 | int mat = rules.GetLSLIntegerItem(idx++); | 8345 | int mat = rules.GetLSLIntegerItem(idx++); |
8280 | if (mat < 0 || mat > 7) | 8346 | if (mat < 0 || mat > 7) |
8281 | return; | 8347 | return null; |
8282 | 8348 | ||
8283 | part.Material = Convert.ToByte(mat); | 8349 | part.Material = Convert.ToByte(mat); |
8284 | break; | 8350 | break; |
8285 | 8351 | ||
8286 | case (int)ScriptBaseClass.PRIM_PHANTOM: | 8352 | case (int)ScriptBaseClass.PRIM_PHANTOM: |
8287 | if (remain < 1) | 8353 | if (remain < 1) |
8288 | return; | 8354 | return null; |
8289 | 8355 | ||
8290 | string ph = rules.Data[idx++].ToString(); | 8356 | string ph = rules.Data[idx++].ToString(); |
8291 | parentgrp.ScriptSetPhantomStatus(ph.Equals("1")); | 8357 | parentgrp.ScriptSetPhantomStatus(ph.Equals("1")); |
@@ -8294,7 +8360,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8294 | 8360 | ||
8295 | case (int)ScriptBaseClass.PRIM_PHYSICS: | 8361 | case (int)ScriptBaseClass.PRIM_PHYSICS: |
8296 | if (remain < 1) | 8362 | if (remain < 1) |
8297 | return; | 8363 | return null; |
8298 | string phy = rules.Data[idx++].ToString(); | 8364 | string phy = rules.Data[idx++].ToString(); |
8299 | bool physics; | 8365 | bool physics; |
8300 | 8366 | ||
@@ -8308,7 +8374,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8308 | 8374 | ||
8309 | case (int)ScriptBaseClass.PRIM_PHYSICS_SHAPE_TYPE: | 8375 | case (int)ScriptBaseClass.PRIM_PHYSICS_SHAPE_TYPE: |
8310 | if (remain < 1) | 8376 | if (remain < 1) |
8311 | return; | 8377 | return null; |
8312 | 8378 | ||
8313 | int shape_type = rules.GetLSLIntegerItem(idx++); | 8379 | int shape_type = rules.GetLSLIntegerItem(idx++); |
8314 | 8380 | ||
@@ -8324,7 +8390,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8324 | 8390 | ||
8325 | case (int)ScriptBaseClass.PRIM_PHYSICS_MATERIAL: | 8391 | case (int)ScriptBaseClass.PRIM_PHYSICS_MATERIAL: |
8326 | if (remain < 5) | 8392 | if (remain < 5) |
8327 | return; | 8393 | return null; |
8328 | 8394 | ||
8329 | int material_bits = rules.GetLSLIntegerItem(idx++); | 8395 | int material_bits = rules.GetLSLIntegerItem(idx++); |
8330 | float material_density = (float)rules.GetLSLFloatItem(idx++); | 8396 | float material_density = (float)rules.GetLSLFloatItem(idx++); |
@@ -8338,7 +8404,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8338 | 8404 | ||
8339 | case (int)ScriptBaseClass.PRIM_TEMP_ON_REZ: | 8405 | case (int)ScriptBaseClass.PRIM_TEMP_ON_REZ: |
8340 | if (remain < 1) | 8406 | if (remain < 1) |
8341 | return; | 8407 | return null; |
8342 | string temp = rules.Data[idx++].ToString(); | 8408 | string temp = rules.Data[idx++].ToString(); |
8343 | 8409 | ||
8344 | parentgrp.ScriptSetTemporaryStatus(temp.Equals("1")); | 8410 | parentgrp.ScriptSetTemporaryStatus(temp.Equals("1")); |
@@ -8347,7 +8413,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8347 | 8413 | ||
8348 | case (int)ScriptBaseClass.PRIM_TEXGEN: | 8414 | case (int)ScriptBaseClass.PRIM_TEXGEN: |
8349 | if (remain < 2) | 8415 | if (remain < 2) |
8350 | return; | 8416 | return null; |
8351 | //face,type | 8417 | //face,type |
8352 | face = rules.GetLSLIntegerItem(idx++); | 8418 | face = rules.GetLSLIntegerItem(idx++); |
8353 | int style = rules.GetLSLIntegerItem(idx++); | 8419 | int style = rules.GetLSLIntegerItem(idx++); |
@@ -8355,7 +8421,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8355 | break; | 8421 | break; |
8356 | case (int)ScriptBaseClass.PRIM_TEXT: | 8422 | case (int)ScriptBaseClass.PRIM_TEXT: |
8357 | if (remain < 3) | 8423 | if (remain < 3) |
8358 | return; | 8424 | return null; |
8359 | string primText = rules.GetLSLStringItem(idx++); | 8425 | string primText = rules.GetLSLStringItem(idx++); |
8360 | LSL_Vector primTextColor = rules.GetVector3Item(idx++); | 8426 | LSL_Vector primTextColor = rules.GetVector3Item(idx++); |
8361 | LSL_Float primTextAlpha = rules.GetLSLFloatItem(idx++); | 8427 | LSL_Float primTextAlpha = rules.GetLSLFloatItem(idx++); |
@@ -8367,26 +8433,25 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8367 | break; | 8433 | break; |
8368 | case (int)ScriptBaseClass.PRIM_NAME: | 8434 | case (int)ScriptBaseClass.PRIM_NAME: |
8369 | if (remain < 1) | 8435 | if (remain < 1) |
8370 | return; | 8436 | return null; |
8371 | string primName = rules.GetLSLStringItem(idx++); | 8437 | string primName = rules.GetLSLStringItem(idx++); |
8372 | part.Name = primName; | 8438 | part.Name = primName; |
8373 | break; | 8439 | break; |
8374 | case (int)ScriptBaseClass.PRIM_DESC: | 8440 | case (int)ScriptBaseClass.PRIM_DESC: |
8375 | if (remain < 1) | 8441 | if (remain < 1) |
8376 | return; | 8442 | return null; |
8377 | string primDesc = rules.GetLSLStringItem(idx++); | 8443 | string primDesc = rules.GetLSLStringItem(idx++); |
8378 | part.Description = primDesc; | 8444 | part.Description = primDesc; |
8379 | break; | 8445 | break; |
8380 | case (int)ScriptBaseClass.PRIM_ROT_LOCAL: | 8446 | case (int)ScriptBaseClass.PRIM_ROT_LOCAL: |
8381 | if (remain < 1) | 8447 | if (remain < 1) |
8382 | return; | 8448 | return null; |
8383 | |||
8384 | LSL_Rotation lr = rules.GetQuaternionItem(idx++); | 8449 | LSL_Rotation lr = rules.GetQuaternionItem(idx++); |
8385 | SetRot(part, Rot2Quaternion(lr)); | 8450 | SetRot(part, Rot2Quaternion(lr)); |
8386 | break; | 8451 | break; |
8387 | case (int)ScriptBaseClass.PRIM_OMEGA: | 8452 | case (int)ScriptBaseClass.PRIM_OMEGA: |
8388 | if (remain < 3) | 8453 | if (remain < 3) |
8389 | return; | 8454 | return null; |
8390 | LSL_Vector axis = rules.GetVector3Item(idx++); | 8455 | LSL_Vector axis = rules.GetVector3Item(idx++); |
8391 | LSL_Float spinrate = rules.GetLSLFloatItem(idx++); | 8456 | LSL_Float spinrate = rules.GetLSLFloatItem(idx++); |
8392 | LSL_Float gain = rules.GetLSLFloatItem(idx++); | 8457 | LSL_Float gain = rules.GetLSLFloatItem(idx++); |
@@ -8395,35 +8460,9 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8395 | 8460 | ||
8396 | case (int)ScriptBaseClass.PRIM_LINK_TARGET: | 8461 | case (int)ScriptBaseClass.PRIM_LINK_TARGET: |
8397 | if (remain < 3) // setting to 3 on the basis that parsing any usage of PRIM_LINK_TARGET that has nothing following it is pointless. | 8462 | if (remain < 3) // setting to 3 on the basis that parsing any usage of PRIM_LINK_TARGET that has nothing following it is pointless. |
8398 | return; | 8463 | return null; |
8399 | |||
8400 | // do a pending position change before jumping to other part/avatar | ||
8401 | if (positionChanged) | ||
8402 | { | ||
8403 | positionChanged = false; | ||
8404 | if (parentgrp == null) | ||
8405 | return; | ||
8406 | 8464 | ||
8407 | if (parentgrp.RootPart == part) | 8465 | return rules.GetSublist(idx, -1); |
8408 | { | ||
8409 | |||
8410 | Util.FireAndForget(delegate(object x) | ||
8411 | { | ||
8412 | parentgrp.UpdateGroupPosition(new Vector3((float)currentPosition.x, (float)currentPosition.y, (float)currentPosition.z)); | ||
8413 | }); | ||
8414 | } | ||
8415 | else | ||
8416 | { | ||
8417 | part.OffsetPosition = new Vector3((float)currentPosition.x, (float)currentPosition.y, (float)currentPosition.z); | ||
8418 | parentgrp.HasGroupChanged = true; | ||
8419 | parentgrp.ScheduleGroupForTerseUpdate(); | ||
8420 | } | ||
8421 | } | ||
8422 | |||
8423 | LSL_Integer new_linknumber = rules.GetLSLIntegerItem(idx++); | ||
8424 | LSL_List new_rules = rules.GetSublist(idx, -1); | ||
8425 | setLinkPrimParams((int)new_linknumber, new_rules); | ||
8426 | return; | ||
8427 | } | 8466 | } |
8428 | } | 8467 | } |
8429 | } | 8468 | } |
@@ -8447,6 +8486,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8447 | } | 8486 | } |
8448 | } | 8487 | } |
8449 | } | 8488 | } |
8489 | return null; | ||
8450 | } | 8490 | } |
8451 | 8491 | ||
8452 | public LSL_String llStringToBase64(string str) | 8492 | public LSL_String llStringToBase64(string str) |
@@ -12082,7 +12122,16 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
12082 | if (obj.OwnerID != m_host.OwnerID) | 12122 | if (obj.OwnerID != m_host.OwnerID) |
12083 | return; | 12123 | return; |
12084 | 12124 | ||
12085 | SetPrimParams(obj, rules); | 12125 | LSL_List remaining = SetPrimParams(obj, rules); |
12126 | |||
12127 | while ((object)remaining != null && remaining.Length > 2) | ||
12128 | { | ||
12129 | LSL_Integer newLink = remaining.GetLSLIntegerItem(0); | ||
12130 | LSL_List newrules = remaining.GetSublist(1, -1); | ||
12131 | foreach(SceneObjectPart part in GetLinkParts(obj, newLink)){ | ||
12132 | remaining = SetPrimParams(part, newrules); | ||
12133 | } | ||
12134 | } | ||
12086 | } | 12135 | } |
12087 | 12136 | ||
12088 | public LSL_List GetLinkPrimitiveParamsEx(LSL_Key prim, LSL_List rules) | 12137 | public LSL_List GetLinkPrimitiveParamsEx(LSL_Key prim, LSL_List rules) |
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs index 0bb933c..2f02f1f 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs | |||
@@ -2466,8 +2466,13 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
2466 | if (!npcModule.CheckPermissions(npcId, m_host.OwnerID)) | 2466 | if (!npcModule.CheckPermissions(npcId, m_host.OwnerID)) |
2467 | return new LSL_Vector(0, 0, 0); | 2467 | return new LSL_Vector(0, 0, 0); |
2468 | 2468 | ||
2469 | Vector3 pos = World.GetScenePresence(npcId).AbsolutePosition; | 2469 | ScenePresence sp = World.GetScenePresence(npcId); |
2470 | return new LSL_Vector(pos.X, pos.Y, pos.Z); | 2470 | |
2471 | if (sp != null) | ||
2472 | { | ||
2473 | Vector3 pos = sp.AbsolutePosition; | ||
2474 | return new LSL_Vector(pos.X, pos.Y, pos.Z); | ||
2475 | } | ||
2471 | } | 2476 | } |
2472 | 2477 | ||
2473 | return new LSL_Vector(0, 0, 0); | 2478 | return new LSL_Vector(0, 0, 0); |
@@ -2535,9 +2540,12 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
2535 | return new LSL_Rotation(Quaternion.Identity.X, Quaternion.Identity.Y, Quaternion.Identity.Z, Quaternion.Identity.W); | 2540 | return new LSL_Rotation(Quaternion.Identity.X, Quaternion.Identity.Y, Quaternion.Identity.Z, Quaternion.Identity.W); |
2536 | 2541 | ||
2537 | ScenePresence sp = World.GetScenePresence(npcId); | 2542 | ScenePresence sp = World.GetScenePresence(npcId); |
2538 | Quaternion rot = sp.Rotation; | ||
2539 | 2543 | ||
2540 | return new LSL_Rotation(rot.X, rot.Y, rot.Z, rot.W); | 2544 | if (sp != null) |
2545 | { | ||
2546 | Quaternion rot = sp.Rotation; | ||
2547 | return new LSL_Rotation(rot.X, rot.Y, rot.Z, rot.W); | ||
2548 | } | ||
2541 | } | 2549 | } |
2542 | 2550 | ||
2543 | return new LSL_Rotation(Quaternion.Identity.X, Quaternion.Identity.Y, Quaternion.Identity.Z, Quaternion.Identity.W); | 2551 | return new LSL_Rotation(Quaternion.Identity.X, Quaternion.Identity.Y, Quaternion.Identity.Z, Quaternion.Identity.W); |
@@ -2559,7 +2567,9 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
2559 | return; | 2567 | return; |
2560 | 2568 | ||
2561 | ScenePresence sp = World.GetScenePresence(npcId); | 2569 | ScenePresence sp = World.GetScenePresence(npcId); |
2562 | sp.Rotation = LSL_Api.Rot2Quaternion(rotation); | 2570 | |
2571 | if (sp != null) | ||
2572 | sp.Rotation = LSL_Api.Rot2Quaternion(rotation); | ||
2563 | } | 2573 | } |
2564 | } | 2574 | } |
2565 | 2575 | ||
@@ -2737,6 +2747,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
2737 | { | 2747 | { |
2738 | CheckThreatLevel(ThreatLevel.High, "osNpcTouch"); | 2748 | CheckThreatLevel(ThreatLevel.High, "osNpcTouch"); |
2739 | m_host.AddScriptLPS(1); | 2749 | m_host.AddScriptLPS(1); |
2750 | |||
2740 | INPCModule module = World.RequestModuleInterface<INPCModule>(); | 2751 | INPCModule module = World.RequestModuleInterface<INPCModule>(); |
2741 | int linkNum = link_num.value; | 2752 | int linkNum = link_num.value; |
2742 | if (module != null || (linkNum < 0 && linkNum != ScriptBaseClass.LINK_THIS)) | 2753 | if (module != null || (linkNum < 0 && linkNum != ScriptBaseClass.LINK_THIS)) |
@@ -2744,12 +2755,15 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
2744 | UUID npcId; | 2755 | UUID npcId; |
2745 | if (!UUID.TryParse(npcLSL_Key, out npcId) || !module.CheckPermissions(npcId, m_host.OwnerID)) | 2756 | if (!UUID.TryParse(npcLSL_Key, out npcId) || !module.CheckPermissions(npcId, m_host.OwnerID)) |
2746 | return; | 2757 | return; |
2758 | |||
2747 | SceneObjectPart part = null; | 2759 | SceneObjectPart part = null; |
2748 | UUID objectId; | 2760 | UUID objectId; |
2749 | if (UUID.TryParse(LSL_String.ToString(object_key), out objectId)) | 2761 | if (UUID.TryParse(LSL_String.ToString(object_key), out objectId)) |
2750 | part = World.GetSceneObjectPart(objectId); | 2762 | part = World.GetSceneObjectPart(objectId); |
2763 | |||
2751 | if (part == null) | 2764 | if (part == null) |
2752 | return; | 2765 | return; |
2766 | |||
2753 | if (linkNum != ScriptBaseClass.LINK_THIS) | 2767 | if (linkNum != ScriptBaseClass.LINK_THIS) |
2754 | { | 2768 | { |
2755 | if (linkNum == 0 || linkNum == ScriptBaseClass.LINK_ROOT) | 2769 | if (linkNum == 0 || linkNum == ScriptBaseClass.LINK_ROOT) |
@@ -2764,6 +2778,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
2764 | return; | 2778 | return; |
2765 | } | 2779 | } |
2766 | } | 2780 | } |
2781 | |||
2767 | module.Touch(npcId, part.UUID); | 2782 | module.Touch(npcId, part.UUID); |
2768 | } | 2783 | } |
2769 | } | 2784 | } |
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Runtime/LSL_Constants.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Runtime/LSL_Constants.cs index a08cc42..f989cc6 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Api/Runtime/LSL_Constants.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Api/Runtime/LSL_Constants.cs | |||
@@ -226,6 +226,8 @@ namespace OpenSim.Region.ScriptEngine.Shared.ScriptBase | |||
226 | public const int ATTACH_BELLY = 28; | 226 | public const int ATTACH_BELLY = 28; |
227 | public const int ATTACH_RPEC = 29; | 227 | public const int ATTACH_RPEC = 29; |
228 | public const int ATTACH_LPEC = 30; | 228 | public const int ATTACH_LPEC = 30; |
229 | public const int ATTACH_LEFT_PEC = 29; // Same value as ATTACH_RPEC, see https://jira.secondlife.com/browse/SVC-580 | ||
230 | public const int ATTACH_RIGHT_PEC = 30; // Same value as ATTACH_LPEC, see https://jira.secondlife.com/browse/SVC-580 | ||
229 | public const int ATTACH_HUD_CENTER_2 = 31; | 231 | public const int ATTACH_HUD_CENTER_2 = 31; |
230 | public const int ATTACH_HUD_TOP_RIGHT = 32; | 232 | public const int ATTACH_HUD_TOP_RIGHT = 32; |
231 | public const int ATTACH_HUD_TOP_CENTER = 33; | 233 | public const int ATTACH_HUD_TOP_CENTER = 33; |