diff options
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs | 1616 |
1 files changed, 1409 insertions, 207 deletions
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs index 31ae64f..d0a0b03 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs | |||
@@ -6456,17 +6456,17 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
6456 | 6456 | ||
6457 | foreach (SceneObjectPart part in parts) | 6457 | foreach (SceneObjectPart part in parts) |
6458 | { | 6458 | { |
6459 | SetParticleSystem(part, rules); | 6459 | SetParticleSystem(part, rules, "llLinkParticleSystem"); |
6460 | } | 6460 | } |
6461 | } | 6461 | } |
6462 | 6462 | ||
6463 | public void llParticleSystem(LSL_List rules) | 6463 | public void llParticleSystem(LSL_List rules) |
6464 | { | 6464 | { |
6465 | m_host.AddScriptLPS(1); | 6465 | m_host.AddScriptLPS(1); |
6466 | SetParticleSystem(m_host, rules); | 6466 | SetParticleSystem(m_host, rules, "llParticleSystem"); |
6467 | } | 6467 | } |
6468 | 6468 | ||
6469 | private void SetParticleSystem(SceneObjectPart part, LSL_List rules) | 6469 | private void SetParticleSystem(SceneObjectPart part, LSL_List rules, string originFunc) |
6470 | { | 6470 | { |
6471 | if (rules.Length == 0) | 6471 | if (rules.Length == 0) |
6472 | { | 6472 | { |
@@ -6483,62 +6483,152 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
6483 | 6483 | ||
6484 | for (int i = 0; i < rules.Length; i += 2) | 6484 | for (int i = 0; i < rules.Length; i += 2) |
6485 | { | 6485 | { |
6486 | switch (rules.GetLSLIntegerItem(i)) | 6486 | int psystype; |
6487 | try | ||
6488 | { | ||
6489 | psystype = rules.GetLSLIntegerItem(i); | ||
6490 | } | ||
6491 | catch (InvalidCastException) | ||
6492 | { | ||
6493 | Error(originFunc, string.Format("Error running particle system params index #{0}: particle system parameter type must be integer", i)); | ||
6494 | return; | ||
6495 | } | ||
6496 | switch (psystype) | ||
6487 | { | 6497 | { |
6488 | case (int)ScriptBaseClass.PSYS_PART_FLAGS: | 6498 | case (int)ScriptBaseClass.PSYS_PART_FLAGS: |
6489 | prules.PartDataFlags = (Primitive.ParticleSystem.ParticleDataFlags)(uint)rules.GetLSLIntegerItem(i + 1); | 6499 | try |
6500 | { | ||
6501 | prules.PartDataFlags = (Primitive.ParticleSystem.ParticleDataFlags)(uint)rules.GetLSLIntegerItem(i + 1); | ||
6502 | } | ||
6503 | catch(InvalidCastException) | ||
6504 | { | ||
6505 | Error(originFunc, string.Format("Error running rule PSYS_PART_FLAGS: arg #{0} - parameter 1 must be integer", i + 1)); | ||
6506 | return; | ||
6507 | } | ||
6490 | break; | 6508 | break; |
6491 | 6509 | ||
6492 | case (int)ScriptBaseClass.PSYS_PART_START_COLOR: | 6510 | case (int)ScriptBaseClass.PSYS_PART_START_COLOR: |
6493 | tempv = rules.GetVector3Item(i + 1); | 6511 | try |
6512 | { | ||
6513 | tempv = rules.GetVector3Item(i + 1); | ||
6514 | } | ||
6515 | catch(InvalidCastException) | ||
6516 | { | ||
6517 | Error(originFunc, string.Format("Error running rule PSYS_PART_START_COLOR: arg #{0} - parameter 1 must be vector", i + 1)); | ||
6518 | return; | ||
6519 | } | ||
6494 | prules.PartStartColor.R = (float)tempv.x; | 6520 | prules.PartStartColor.R = (float)tempv.x; |
6495 | prules.PartStartColor.G = (float)tempv.y; | 6521 | prules.PartStartColor.G = (float)tempv.y; |
6496 | prules.PartStartColor.B = (float)tempv.z; | 6522 | prules.PartStartColor.B = (float)tempv.z; |
6497 | break; | 6523 | break; |
6498 | 6524 | ||
6499 | case (int)ScriptBaseClass.PSYS_PART_START_ALPHA: | 6525 | case (int)ScriptBaseClass.PSYS_PART_START_ALPHA: |
6500 | tempf = (float)rules.GetLSLFloatItem(i + 1); | 6526 | try |
6527 | { | ||
6528 | tempf = (float)rules.GetLSLFloatItem(i + 1); | ||
6529 | } | ||
6530 | catch(InvalidCastException) | ||
6531 | { | ||
6532 | Error(originFunc, string.Format("Error running rule PSYS_PART_START_ALPHA: arg #{0} - parameter 1 must be float", i + 1)); | ||
6533 | return; | ||
6534 | } | ||
6501 | prules.PartStartColor.A = tempf; | 6535 | prules.PartStartColor.A = tempf; |
6502 | break; | 6536 | break; |
6503 | 6537 | ||
6504 | case (int)ScriptBaseClass.PSYS_PART_END_COLOR: | 6538 | case (int)ScriptBaseClass.PSYS_PART_END_COLOR: |
6505 | tempv = rules.GetVector3Item(i + 1); | 6539 | try |
6540 | { | ||
6541 | tempv = rules.GetVector3Item(i + 1); | ||
6542 | } | ||
6543 | catch(InvalidCastException) | ||
6544 | { | ||
6545 | Error(originFunc, string.Format("Error running rule PSYS_PART_END_COLOR: arg #{0} - parameter 1 must be vector", i + 1)); | ||
6546 | return; | ||
6547 | } | ||
6506 | prules.PartEndColor.R = (float)tempv.x; | 6548 | prules.PartEndColor.R = (float)tempv.x; |
6507 | prules.PartEndColor.G = (float)tempv.y; | 6549 | prules.PartEndColor.G = (float)tempv.y; |
6508 | prules.PartEndColor.B = (float)tempv.z; | 6550 | prules.PartEndColor.B = (float)tempv.z; |
6509 | break; | 6551 | break; |
6510 | 6552 | ||
6511 | case (int)ScriptBaseClass.PSYS_PART_END_ALPHA: | 6553 | case (int)ScriptBaseClass.PSYS_PART_END_ALPHA: |
6512 | tempf = (float)rules.GetLSLFloatItem(i + 1); | 6554 | try |
6555 | { | ||
6556 | tempf = (float)rules.GetLSLFloatItem(i + 1); | ||
6557 | } | ||
6558 | catch(InvalidCastException) | ||
6559 | { | ||
6560 | Error(originFunc, string.Format("Error running rule PSYS_PART_END_ALPHA: arg #{0} - parameter 1 must be float", i + 1)); | ||
6561 | return; | ||
6562 | } | ||
6513 | prules.PartEndColor.A = tempf; | 6563 | prules.PartEndColor.A = tempf; |
6514 | break; | 6564 | break; |
6515 | 6565 | ||
6516 | case (int)ScriptBaseClass.PSYS_PART_START_SCALE: | 6566 | case (int)ScriptBaseClass.PSYS_PART_START_SCALE: |
6517 | tempv = rules.GetVector3Item(i + 1); | 6567 | try |
6568 | { | ||
6569 | tempv = rules.GetVector3Item(i + 1); | ||
6570 | } | ||
6571 | catch(InvalidCastException) | ||
6572 | { | ||
6573 | Error(originFunc, string.Format("Error running rule PSYS_PART_START_SCALE: arg #{0} - parameter 1 must be vector", i + 1)); | ||
6574 | return; | ||
6575 | } | ||
6518 | prules.PartStartScaleX = validParticleScale((float)tempv.x); | 6576 | prules.PartStartScaleX = validParticleScale((float)tempv.x); |
6519 | prules.PartStartScaleY = validParticleScale((float)tempv.y); | 6577 | prules.PartStartScaleY = validParticleScale((float)tempv.y); |
6520 | break; | 6578 | break; |
6521 | 6579 | ||
6522 | case (int)ScriptBaseClass.PSYS_PART_END_SCALE: | 6580 | case (int)ScriptBaseClass.PSYS_PART_END_SCALE: |
6523 | tempv = rules.GetVector3Item(i + 1); | 6581 | try |
6582 | { | ||
6583 | tempv = rules.GetVector3Item(i + 1); | ||
6584 | } | ||
6585 | catch(InvalidCastException) | ||
6586 | { | ||
6587 | Error(originFunc, string.Format("Error running rule PSYS_PART_END_SCALE: arg #{0} - parameter 1 must be vector", i + 1)); | ||
6588 | return; | ||
6589 | } | ||
6524 | prules.PartEndScaleX = validParticleScale((float)tempv.x); | 6590 | prules.PartEndScaleX = validParticleScale((float)tempv.x); |
6525 | prules.PartEndScaleY = validParticleScale((float)tempv.y); | 6591 | prules.PartEndScaleY = validParticleScale((float)tempv.y); |
6526 | break; | 6592 | break; |
6527 | 6593 | ||
6528 | case (int)ScriptBaseClass.PSYS_PART_MAX_AGE: | 6594 | case (int)ScriptBaseClass.PSYS_PART_MAX_AGE: |
6529 | tempf = (float)rules.GetLSLFloatItem(i + 1); | 6595 | try |
6596 | { | ||
6597 | tempf = (float)rules.GetLSLFloatItem(i + 1); | ||
6598 | } | ||
6599 | catch(InvalidCastException) | ||
6600 | { | ||
6601 | Error(originFunc, string.Format("Error running rule PSYS_PART_MAX_AGE: arg #{0} - parameter 1 must be float", i + 1)); | ||
6602 | return; | ||
6603 | } | ||
6530 | prules.PartMaxAge = tempf; | 6604 | prules.PartMaxAge = tempf; |
6531 | break; | 6605 | break; |
6532 | 6606 | ||
6533 | case (int)ScriptBaseClass.PSYS_SRC_ACCEL: | 6607 | case (int)ScriptBaseClass.PSYS_SRC_ACCEL: |
6534 | tempv = rules.GetVector3Item(i + 1); | 6608 | try |
6609 | { | ||
6610 | tempv = rules.GetVector3Item(i + 1); | ||
6611 | } | ||
6612 | catch(InvalidCastException) | ||
6613 | { | ||
6614 | Error(originFunc, string.Format("Error running rule PSYS_SRC_ACCEL: arg #{0} - parameter 1 must be vector", i + 1)); | ||
6615 | return; | ||
6616 | } | ||
6535 | prules.PartAcceleration.X = (float)tempv.x; | 6617 | prules.PartAcceleration.X = (float)tempv.x; |
6536 | prules.PartAcceleration.Y = (float)tempv.y; | 6618 | prules.PartAcceleration.Y = (float)tempv.y; |
6537 | prules.PartAcceleration.Z = (float)tempv.z; | 6619 | prules.PartAcceleration.Z = (float)tempv.z; |
6538 | break; | 6620 | break; |
6539 | 6621 | ||
6540 | case (int)ScriptBaseClass.PSYS_SRC_PATTERN: | 6622 | case (int)ScriptBaseClass.PSYS_SRC_PATTERN: |
6541 | tmpi = (int)rules.GetLSLIntegerItem(i + 1); | 6623 | try |
6624 | { | ||
6625 | tmpi = (int)rules.GetLSLIntegerItem(i + 1); | ||
6626 | } | ||
6627 | catch(InvalidCastException) | ||
6628 | { | ||
6629 | Error(originFunc, string.Format("Error running rule PSYS_SRC_PATTERN: arg #{0} - parameter 1 must be integer", i + 1)); | ||
6630 | return; | ||
6631 | } | ||
6542 | prules.Pattern = (Primitive.ParticleSystem.SourcePattern)tmpi; | 6632 | prules.Pattern = (Primitive.ParticleSystem.SourcePattern)tmpi; |
6543 | break; | 6633 | break; |
6544 | 6634 | ||
@@ -6547,67 +6637,171 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
6547 | // client tells the difference between the two by looking at the 0x02 bit in | 6637 | // client tells the difference between the two by looking at the 0x02 bit in |
6548 | // the PartFlags variable. | 6638 | // the PartFlags variable. |
6549 | case (int)ScriptBaseClass.PSYS_SRC_INNERANGLE: | 6639 | case (int)ScriptBaseClass.PSYS_SRC_INNERANGLE: |
6550 | tempf = (float)rules.GetLSLFloatItem(i + 1); | 6640 | try |
6641 | { | ||
6642 | tempf = (float)rules.GetLSLFloatItem(i + 1); | ||
6643 | } | ||
6644 | catch(InvalidCastException) | ||
6645 | { | ||
6646 | Error(originFunc, string.Format("Error running rule PSYS_SRC_INNERANGLE: arg #{0} - parameter 1 must be float", i + 1)); | ||
6647 | return; | ||
6648 | } | ||
6551 | prules.InnerAngle = (float)tempf; | 6649 | prules.InnerAngle = (float)tempf; |
6552 | prules.PartFlags &= 0xFFFFFFFD; // Make sure new angle format is off. | 6650 | prules.PartFlags &= 0xFFFFFFFD; // Make sure new angle format is off. |
6553 | break; | 6651 | break; |
6554 | 6652 | ||
6555 | case (int)ScriptBaseClass.PSYS_SRC_OUTERANGLE: | 6653 | case (int)ScriptBaseClass.PSYS_SRC_OUTERANGLE: |
6556 | tempf = (float)rules.GetLSLFloatItem(i + 1); | 6654 | try |
6655 | { | ||
6656 | tempf = (float)rules.GetLSLFloatItem(i + 1); | ||
6657 | } | ||
6658 | catch(InvalidCastException) | ||
6659 | { | ||
6660 | Error(originFunc, string.Format("Error running rule PSYS_SRC_OUTERANGLE: arg #{0} - parameter 1 must be float", i + 1)); | ||
6661 | return; | ||
6662 | } | ||
6557 | prules.OuterAngle = (float)tempf; | 6663 | prules.OuterAngle = (float)tempf; |
6558 | prules.PartFlags &= 0xFFFFFFFD; // Make sure new angle format is off. | 6664 | prules.PartFlags &= 0xFFFFFFFD; // Make sure new angle format is off. |
6559 | break; | 6665 | break; |
6560 | 6666 | ||
6561 | case (int)ScriptBaseClass.PSYS_PART_BLEND_FUNC_SOURCE: | 6667 | case (int)ScriptBaseClass.PSYS_PART_BLEND_FUNC_SOURCE: |
6562 | tmpi = (int)rules.GetLSLIntegerItem(i + 1); | 6668 | try |
6669 | { | ||
6670 | tmpi = (int)rules.GetLSLIntegerItem(i + 1); | ||
6671 | } | ||
6672 | catch(InvalidCastException) | ||
6673 | { | ||
6674 | Error(originFunc, string.Format("Error running rule PSYS_PART_BLEND_FUNC_SOURCE: arg #{0} - parameter 1 must be integer", i + 1)); | ||
6675 | return; | ||
6676 | } | ||
6563 | prules.BlendFuncSource = (byte)tmpi; | 6677 | prules.BlendFuncSource = (byte)tmpi; |
6564 | break; | 6678 | break; |
6565 | 6679 | ||
6566 | case (int)ScriptBaseClass.PSYS_PART_BLEND_FUNC_DEST: | 6680 | case (int)ScriptBaseClass.PSYS_PART_BLEND_FUNC_DEST: |
6567 | tmpi = (int)rules.GetLSLIntegerItem(i + 1); | 6681 | try |
6682 | { | ||
6683 | tmpi = (int)rules.GetLSLIntegerItem(i + 1); | ||
6684 | } | ||
6685 | catch(InvalidCastException) | ||
6686 | { | ||
6687 | Error(originFunc, string.Format("Error running rule PSYS_PART_BLEND_FUNC_DEST: arg #{0} - parameter 1 must be integer", i + 1)); | ||
6688 | return; | ||
6689 | } | ||
6568 | prules.BlendFuncDest = (byte)tmpi; | 6690 | prules.BlendFuncDest = (byte)tmpi; |
6569 | break; | 6691 | break; |
6570 | 6692 | ||
6571 | case (int)ScriptBaseClass.PSYS_PART_START_GLOW: | 6693 | case (int)ScriptBaseClass.PSYS_PART_START_GLOW: |
6572 | tempf = (float)rules.GetLSLFloatItem(i + 1); | 6694 | try |
6695 | { | ||
6696 | tempf = (float)rules.GetLSLFloatItem(i + 1); | ||
6697 | } | ||
6698 | catch(InvalidCastException) | ||
6699 | { | ||
6700 | Error(originFunc, string.Format("Error running rule PSYS_PART_START_GLOW: arg #{0} - parameter 1 must be float", i + 1)); | ||
6701 | return; | ||
6702 | } | ||
6573 | prules.PartStartGlow = (float)tempf; | 6703 | prules.PartStartGlow = (float)tempf; |
6574 | break; | 6704 | break; |
6575 | 6705 | ||
6576 | case (int)ScriptBaseClass.PSYS_PART_END_GLOW: | 6706 | case (int)ScriptBaseClass.PSYS_PART_END_GLOW: |
6577 | tempf = (float)rules.GetLSLFloatItem(i + 1); | 6707 | try |
6708 | { | ||
6709 | tempf = (float)rules.GetLSLFloatItem(i + 1); | ||
6710 | } | ||
6711 | catch(InvalidCastException) | ||
6712 | { | ||
6713 | Error(originFunc, string.Format("Error running rule PSYS_PART_END_GLOW: arg #{0} - parameter 1 must be float", i + 1)); | ||
6714 | return; | ||
6715 | } | ||
6578 | prules.PartEndGlow = (float)tempf; | 6716 | prules.PartEndGlow = (float)tempf; |
6579 | break; | 6717 | break; |
6580 | 6718 | ||
6581 | case (int)ScriptBaseClass.PSYS_SRC_TEXTURE: | 6719 | case (int)ScriptBaseClass.PSYS_SRC_TEXTURE: |
6582 | prules.Texture = ScriptUtils.GetAssetIdFromKeyOrItemName(m_host, rules.GetLSLStringItem(i + 1)); | 6720 | try |
6721 | { | ||
6722 | prules.Texture = ScriptUtils.GetAssetIdFromKeyOrItemName(m_host, rules.GetLSLStringItem(i + 1)); | ||
6723 | } | ||
6724 | catch(InvalidCastException) | ||
6725 | { | ||
6726 | Error(originFunc, string.Format("Error running rule PSYS_SRC_TEXTURE: arg #{0} - parameter 1 must be string or key", i + 1)); | ||
6727 | return; | ||
6728 | } | ||
6583 | break; | 6729 | break; |
6584 | 6730 | ||
6585 | case (int)ScriptBaseClass.PSYS_SRC_BURST_RATE: | 6731 | case (int)ScriptBaseClass.PSYS_SRC_BURST_RATE: |
6586 | tempf = (float)rules.GetLSLFloatItem(i + 1); | 6732 | try |
6733 | { | ||
6734 | tempf = (float)rules.GetLSLFloatItem(i + 1); | ||
6735 | } | ||
6736 | catch(InvalidCastException) | ||
6737 | { | ||
6738 | Error(originFunc, string.Format("Error running rule PSYS_SRC_BURST_RATE: arg #{0} - parameter 1 must be float", i + 1)); | ||
6739 | return; | ||
6740 | } | ||
6587 | prules.BurstRate = (float)tempf; | 6741 | prules.BurstRate = (float)tempf; |
6588 | break; | 6742 | break; |
6589 | 6743 | ||
6590 | case (int)ScriptBaseClass.PSYS_SRC_BURST_PART_COUNT: | 6744 | case (int)ScriptBaseClass.PSYS_SRC_BURST_PART_COUNT: |
6591 | prules.BurstPartCount = (byte)(int)rules.GetLSLIntegerItem(i + 1); | 6745 | try |
6746 | { | ||
6747 | prules.BurstPartCount = (byte)(int)rules.GetLSLIntegerItem(i + 1); | ||
6748 | } | ||
6749 | catch(InvalidCastException) | ||
6750 | { | ||
6751 | Error(originFunc, string.Format("Error running rule PSYS_SRC_BURST_PART_COUNT: arg #{0} - parameter 1 must be integer", i + 1)); | ||
6752 | return; | ||
6753 | } | ||
6592 | break; | 6754 | break; |
6593 | 6755 | ||
6594 | case (int)ScriptBaseClass.PSYS_SRC_BURST_RADIUS: | 6756 | case (int)ScriptBaseClass.PSYS_SRC_BURST_RADIUS: |
6595 | tempf = (float)rules.GetLSLFloatItem(i + 1); | 6757 | try |
6758 | { | ||
6759 | tempf = (float)rules.GetLSLFloatItem(i + 1); | ||
6760 | } | ||
6761 | catch(InvalidCastException) | ||
6762 | { | ||
6763 | Error(originFunc, string.Format("Error running rule PSYS_SRC_BURST_RADIUS: arg #{0} - parameter 1 must be float", i + 1)); | ||
6764 | return; | ||
6765 | } | ||
6596 | prules.BurstRadius = (float)tempf; | 6766 | prules.BurstRadius = (float)tempf; |
6597 | break; | 6767 | break; |
6598 | 6768 | ||
6599 | case (int)ScriptBaseClass.PSYS_SRC_BURST_SPEED_MIN: | 6769 | case (int)ScriptBaseClass.PSYS_SRC_BURST_SPEED_MIN: |
6600 | tempf = (float)rules.GetLSLFloatItem(i + 1); | 6770 | try |
6771 | { | ||
6772 | tempf = (float)rules.GetLSLFloatItem(i + 1); | ||
6773 | } | ||
6774 | catch(InvalidCastException) | ||
6775 | { | ||
6776 | Error(originFunc, string.Format("Error running rule PSYS_SRC_BURST_SPEED_MIN: arg #{0} - parameter 1 must be float", i + 1)); | ||
6777 | return; | ||
6778 | } | ||
6601 | prules.BurstSpeedMin = (float)tempf; | 6779 | prules.BurstSpeedMin = (float)tempf; |
6602 | break; | 6780 | break; |
6603 | 6781 | ||
6604 | case (int)ScriptBaseClass.PSYS_SRC_BURST_SPEED_MAX: | 6782 | case (int)ScriptBaseClass.PSYS_SRC_BURST_SPEED_MAX: |
6605 | tempf = (float)rules.GetLSLFloatItem(i + 1); | 6783 | try |
6784 | { | ||
6785 | tempf = (float)rules.GetLSLFloatItem(i + 1); | ||
6786 | } | ||
6787 | catch(InvalidCastException) | ||
6788 | { | ||
6789 | Error(originFunc, string.Format("Error running rule PSYS_SRC_BURST_SPEED_MAX: arg #{0} - parameter 1 must be float", i + 1)); | ||
6790 | return; | ||
6791 | } | ||
6606 | prules.BurstSpeedMax = (float)tempf; | 6792 | prules.BurstSpeedMax = (float)tempf; |
6607 | break; | 6793 | break; |
6608 | 6794 | ||
6609 | case (int)ScriptBaseClass.PSYS_SRC_MAX_AGE: | 6795 | case (int)ScriptBaseClass.PSYS_SRC_MAX_AGE: |
6610 | tempf = (float)rules.GetLSLFloatItem(i + 1); | 6796 | try |
6797 | { | ||
6798 | tempf = (float)rules.GetLSLFloatItem(i + 1); | ||
6799 | } | ||
6800 | catch(InvalidCastException) | ||
6801 | { | ||
6802 | Error(originFunc, string.Format("Error running rule PSYS_SRC_MAX_AGE: arg #{0} - parameter 1 must be float", i + 1)); | ||
6803 | return; | ||
6804 | } | ||
6611 | prules.MaxAge = (float)tempf; | 6805 | prules.MaxAge = (float)tempf; |
6612 | break; | 6806 | break; |
6613 | 6807 | ||
@@ -6625,20 +6819,44 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
6625 | 6819 | ||
6626 | case (int)ScriptBaseClass.PSYS_SRC_OMEGA: | 6820 | case (int)ScriptBaseClass.PSYS_SRC_OMEGA: |
6627 | // AL: This is an assumption, since it is the only thing that would match. | 6821 | // AL: This is an assumption, since it is the only thing that would match. |
6628 | tempv = rules.GetVector3Item(i + 1); | 6822 | try |
6823 | { | ||
6824 | tempv = rules.GetVector3Item(i + 1); | ||
6825 | } | ||
6826 | catch(InvalidCastException) | ||
6827 | { | ||
6828 | Error(originFunc, string.Format("Error running rule PSYS_SRC_OMEGA: arg #{0} - parameter 1 must be vector", i + 1)); | ||
6829 | return; | ||
6830 | } | ||
6629 | prules.AngularVelocity.X = (float)tempv.x; | 6831 | prules.AngularVelocity.X = (float)tempv.x; |
6630 | prules.AngularVelocity.Y = (float)tempv.y; | 6832 | prules.AngularVelocity.Y = (float)tempv.y; |
6631 | prules.AngularVelocity.Z = (float)tempv.z; | 6833 | prules.AngularVelocity.Z = (float)tempv.z; |
6632 | break; | 6834 | break; |
6633 | 6835 | ||
6634 | case (int)ScriptBaseClass.PSYS_SRC_ANGLE_BEGIN: | 6836 | case (int)ScriptBaseClass.PSYS_SRC_ANGLE_BEGIN: |
6635 | tempf = (float)rules.GetLSLFloatItem(i + 1); | 6837 | try |
6838 | { | ||
6839 | tempf = (float)rules.GetLSLFloatItem(i + 1); | ||
6840 | } | ||
6841 | catch(InvalidCastException) | ||
6842 | { | ||
6843 | Error(originFunc, string.Format("Error running rule PSYS_SRC_ANGLE_BEGIN: arg #{0} - parameter 1 must be float", i + 1)); | ||
6844 | return; | ||
6845 | } | ||
6636 | prules.InnerAngle = (float)tempf; | 6846 | prules.InnerAngle = (float)tempf; |
6637 | prules.PartFlags |= 0x02; // Set new angle format. | 6847 | prules.PartFlags |= 0x02; // Set new angle format. |
6638 | break; | 6848 | break; |
6639 | 6849 | ||
6640 | case (int)ScriptBaseClass.PSYS_SRC_ANGLE_END: | 6850 | case (int)ScriptBaseClass.PSYS_SRC_ANGLE_END: |
6641 | tempf = (float)rules.GetLSLFloatItem(i + 1); | 6851 | try |
6852 | { | ||
6853 | tempf = (float)rules.GetLSLFloatItem(i + 1); | ||
6854 | } | ||
6855 | catch (InvalidCastException) | ||
6856 | { | ||
6857 | Error(originFunc, string.Format("Error running rule PSYS_SRC_ANGLE_END: arg #{0} - parameter 1 must be float", i + 1)); | ||
6858 | return; | ||
6859 | } | ||
6642 | prules.OuterAngle = (float)tempf; | 6860 | prules.OuterAngle = (float)tempf; |
6643 | prules.PartFlags |= 0x02; // Set new angle format. | 6861 | prules.PartFlags |= 0x02; // Set new angle format. |
6644 | break; | 6862 | break; |
@@ -7581,7 +7799,17 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7581 | 7799 | ||
7582 | while (remaining != null && remaining.Length > 2) | 7800 | while (remaining != null && remaining.Length > 2) |
7583 | { | 7801 | { |
7584 | int linknumber = remaining.GetLSLIntegerItem(0); | 7802 | int linknumber; |
7803 | try | ||
7804 | { | ||
7805 | linknumber = remaining.GetLSLIntegerItem(0); | ||
7806 | } | ||
7807 | catch(InvalidCastException) | ||
7808 | { | ||
7809 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_LINK_TARGET: parameter 2 must be integer", rulesParsed)); | ||
7810 | return; | ||
7811 | } | ||
7812 | |||
7585 | rules = remaining.GetSublist(1, -1); | 7813 | rules = remaining.GetSublist(1, -1); |
7586 | entities = GetLinkEntities(linknumber); | 7814 | entities = GetLinkEntities(linknumber); |
7587 | 7815 | ||
@@ -7755,17 +7983,28 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7755 | 7983 | ||
7756 | switch (code) | 7984 | switch (code) |
7757 | { | 7985 | { |
7758 | case (int)ScriptBaseClass.PRIM_POSITION: | 7986 | case ScriptBaseClass.PRIM_POSITION: |
7759 | case (int)ScriptBaseClass.PRIM_POS_LOCAL: | 7987 | case ScriptBaseClass.PRIM_POS_LOCAL: |
7760 | if (remain < 1) | 7988 | if (remain < 1) |
7761 | return null; | 7989 | return null; |
7762 | 7990 | ||
7763 | v=rules.GetVector3Item(idx++); | 7991 | try |
7992 | { | ||
7993 | v = rules.GetVector3Item(idx++); | ||
7994 | } | ||
7995 | catch(InvalidCastException) | ||
7996 | { | ||
7997 | if(code == ScriptBaseClass.PRIM_POSITION) | ||
7998 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_POSITION: arg #{1} - parameter 1 must be vector", rulesParsed, idx - idxStart - 1)); | ||
7999 | else | ||
8000 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_POS_LOCAL: arg #{1} - parameter 1 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8001 | return null; | ||
8002 | } | ||
7764 | positionChanged = true; | 8003 | positionChanged = true; |
7765 | currentPosition = GetSetPosTarget(part, v, currentPosition); | 8004 | currentPosition = GetSetPosTarget(part, v, currentPosition); |
7766 | 8005 | ||
7767 | break; | 8006 | break; |
7768 | case (int)ScriptBaseClass.PRIM_SIZE: | 8007 | case ScriptBaseClass.PRIM_SIZE: |
7769 | if (remain < 1) | 8008 | if (remain < 1) |
7770 | return null; | 8009 | return null; |
7771 | 8010 | ||
@@ -7773,11 +8012,19 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7773 | SetScale(part, v); | 8012 | SetScale(part, v); |
7774 | 8013 | ||
7775 | break; | 8014 | break; |
7776 | case (int)ScriptBaseClass.PRIM_ROTATION: | 8015 | case ScriptBaseClass.PRIM_ROTATION: |
7777 | if (remain < 1) | 8016 | if (remain < 1) |
7778 | return null; | 8017 | return null; |
7779 | 8018 | LSL_Rotation q; | |
7780 | LSL_Rotation q = rules.GetQuaternionItem(idx++); | 8019 | try |
8020 | { | ||
8021 | q = rules.GetQuaternionItem(idx++); | ||
8022 | } | ||
8023 | catch(InvalidCastException) | ||
8024 | { | ||
8025 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_ROTATION: arg #{1} - parameter 1 must be rotation", rulesParsed, idx - idxStart - 1)); | ||
8026 | return null; | ||
8027 | } | ||
7781 | // try to let this work as in SL... | 8028 | // try to let this work as in SL... |
7782 | if (part.ParentID == 0) | 8029 | if (part.ParentID == 0) |
7783 | { | 8030 | { |
@@ -7793,11 +8040,19 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7793 | 8040 | ||
7794 | break; | 8041 | break; |
7795 | 8042 | ||
7796 | case (int)ScriptBaseClass.PRIM_TYPE: | 8043 | case ScriptBaseClass.PRIM_TYPE: |
7797 | if (remain < 3) | 8044 | if (remain < 3) |
7798 | return null; | 8045 | return null; |
7799 | 8046 | ||
7800 | code = (int)rules.GetLSLIntegerItem(idx++); | 8047 | try |
8048 | { | ||
8049 | code = (int)rules.GetLSLIntegerItem(idx++); | ||
8050 | } | ||
8051 | catch(InvalidCastException) | ||
8052 | { | ||
8053 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE: arg #{1} - parameter 1 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8054 | return null; | ||
8055 | } | ||
7801 | 8056 | ||
7802 | remain = rules.Length - idx; | 8057 | remain = rules.Length - idx; |
7803 | float hollow; | 8058 | float hollow; |
@@ -7812,140 +8067,625 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7812 | 8067 | ||
7813 | switch (code) | 8068 | switch (code) |
7814 | { | 8069 | { |
7815 | case (int)ScriptBaseClass.PRIM_TYPE_BOX: | 8070 | case ScriptBaseClass.PRIM_TYPE_BOX: |
7816 | if (remain < 6) | 8071 | if (remain < 6) |
7817 | return null; | 8072 | return null; |
7818 | 8073 | ||
7819 | face = (int)rules.GetLSLIntegerItem(idx++); | 8074 | try |
7820 | v = rules.GetVector3Item(idx++); // cut | 8075 | { |
7821 | hollow = (float)rules.GetLSLFloatItem(idx++); | 8076 | face = (int)rules.GetLSLIntegerItem(idx++); |
7822 | twist = rules.GetVector3Item(idx++); | 8077 | } |
7823 | taper_b = rules.GetVector3Item(idx++); | 8078 | catch(InvalidCastException) |
7824 | topshear = rules.GetVector3Item(idx++); | 8079 | { |
8080 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_BOX: arg #{1} - parameter 2 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8081 | return null; | ||
8082 | } | ||
8083 | try | ||
8084 | { | ||
8085 | v = rules.GetVector3Item(idx++); // cut | ||
8086 | } | ||
8087 | catch(InvalidCastException) | ||
8088 | { | ||
8089 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_BOX: arg #{1} - parameter 3 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8090 | return null; | ||
8091 | } | ||
8092 | try | ||
8093 | { | ||
8094 | hollow = (float)rules.GetLSLFloatItem(idx++); | ||
8095 | } | ||
8096 | catch(InvalidCastException) | ||
8097 | { | ||
8098 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_BOX: arg #{1} - parameter 4 must be float", rulesParsed, idx - idxStart - 1)); | ||
8099 | return null; | ||
8100 | } | ||
8101 | try | ||
8102 | { | ||
8103 | twist = rules.GetVector3Item(idx++); | ||
8104 | } | ||
8105 | catch(InvalidCastException) | ||
8106 | { | ||
8107 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_BOX: arg #{1} - parameter 5 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8108 | return null; | ||
8109 | } | ||
8110 | try | ||
8111 | { | ||
8112 | taper_b = rules.GetVector3Item(idx++); | ||
8113 | } | ||
8114 | catch(InvalidCastException) | ||
8115 | { | ||
8116 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_BOX: arg #{1} - parameter 6 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8117 | return null; | ||
8118 | } | ||
8119 | try | ||
8120 | { | ||
8121 | topshear = rules.GetVector3Item(idx++); | ||
8122 | } | ||
8123 | catch(InvalidCastException) | ||
8124 | { | ||
8125 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_BOX: arg #{1} - parameter 7 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8126 | return null; | ||
8127 | } | ||
7825 | 8128 | ||
7826 | SetPrimitiveShapeParams(part, face, v, hollow, twist, taper_b, topshear, | 8129 | SetPrimitiveShapeParams(part, face, v, hollow, twist, taper_b, topshear, |
7827 | (byte)ProfileShape.Square, (byte)Extrusion.Straight); | 8130 | (byte)ProfileShape.Square, (byte)Extrusion.Straight); |
7828 | break; | 8131 | break; |
7829 | 8132 | ||
7830 | case (int)ScriptBaseClass.PRIM_TYPE_CYLINDER: | 8133 | case ScriptBaseClass.PRIM_TYPE_CYLINDER: |
7831 | if (remain < 6) | 8134 | if (remain < 6) |
7832 | return null; | 8135 | return null; |
7833 | 8136 | ||
7834 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape | 8137 | try |
7835 | v = rules.GetVector3Item(idx++); // cut | 8138 | { |
7836 | hollow = (float)rules.GetLSLFloatItem(idx++); | 8139 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape |
7837 | twist = rules.GetVector3Item(idx++); | 8140 | } |
7838 | taper_b = rules.GetVector3Item(idx++); | 8141 | catch(InvalidCastException) |
7839 | topshear = rules.GetVector3Item(idx++); | 8142 | { |
8143 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_CYLINDER: arg #{1} - parameter 3 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8144 | return null; | ||
8145 | } | ||
8146 | try | ||
8147 | { | ||
8148 | v = rules.GetVector3Item(idx++); // cut | ||
8149 | } | ||
8150 | catch(InvalidCastException) | ||
8151 | { | ||
8152 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_CYLINDER: arg #{1} - parameter 4 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8153 | return null; | ||
8154 | } | ||
8155 | try | ||
8156 | { | ||
8157 | hollow = (float)rules.GetLSLFloatItem(idx++); | ||
8158 | } | ||
8159 | catch(InvalidCastException) | ||
8160 | { | ||
8161 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_CYLINDER: arg #{1} - parameter 5 must be float", rulesParsed, idx - idxStart - 1)); | ||
8162 | return null; | ||
8163 | } | ||
8164 | try | ||
8165 | { | ||
8166 | twist = rules.GetVector3Item(idx++); | ||
8167 | } | ||
8168 | catch(InvalidCastException) | ||
8169 | { | ||
8170 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_CYLINDER: arg #{1} - parameter 6 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8171 | return null; | ||
8172 | } | ||
8173 | try | ||
8174 | { | ||
8175 | taper_b = rules.GetVector3Item(idx++); | ||
8176 | } | ||
8177 | catch(InvalidCastException) | ||
8178 | { | ||
8179 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_CYLINDER: arg #{1} - parameter 7 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8180 | return null; | ||
8181 | } | ||
8182 | try | ||
8183 | { | ||
8184 | topshear = rules.GetVector3Item(idx++); | ||
8185 | } | ||
8186 | catch(InvalidCastException) | ||
8187 | { | ||
8188 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_CYLINDER: arg #{1} - parameter 8 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8189 | return null; | ||
8190 | } | ||
7840 | SetPrimitiveShapeParams(part, face, v, hollow, twist, taper_b, topshear, | 8191 | SetPrimitiveShapeParams(part, face, v, hollow, twist, taper_b, topshear, |
7841 | (byte)ProfileShape.Circle, (byte)Extrusion.Straight); | 8192 | (byte)ProfileShape.Circle, (byte)Extrusion.Straight); |
7842 | break; | 8193 | break; |
7843 | 8194 | ||
7844 | case (int)ScriptBaseClass.PRIM_TYPE_PRISM: | 8195 | case ScriptBaseClass.PRIM_TYPE_PRISM: |
7845 | if (remain < 6) | 8196 | if (remain < 6) |
7846 | return null; | 8197 | return null; |
7847 | 8198 | ||
7848 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape | 8199 | try |
7849 | v = rules.GetVector3Item(idx++); //cut | 8200 | { |
7850 | hollow = (float)rules.GetLSLFloatItem(idx++); | 8201 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape |
7851 | twist = rules.GetVector3Item(idx++); | 8202 | } |
7852 | taper_b = rules.GetVector3Item(idx++); | 8203 | catch(InvalidCastException) |
7853 | topshear = rules.GetVector3Item(idx++); | 8204 | { |
8205 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_PRISM: arg #{1} - parameter 3 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8206 | return null; | ||
8207 | } | ||
8208 | try | ||
8209 | { | ||
8210 | v = rules.GetVector3Item(idx++); //cut | ||
8211 | } | ||
8212 | catch(InvalidCastException) | ||
8213 | { | ||
8214 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_PRISM: arg #{1} - parameter 4 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8215 | return null; | ||
8216 | } | ||
8217 | try | ||
8218 | { | ||
8219 | hollow = (float)rules.GetLSLFloatItem(idx++); | ||
8220 | } | ||
8221 | catch(InvalidCastException) | ||
8222 | { | ||
8223 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_PRISM: arg #{1} - parameter 5 must be float", rulesParsed, idx - idxStart - 1)); | ||
8224 | return null; | ||
8225 | } | ||
8226 | try | ||
8227 | { | ||
8228 | twist = rules.GetVector3Item(idx++); | ||
8229 | } | ||
8230 | catch(InvalidCastException) | ||
8231 | { | ||
8232 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_PRISM: arg #{1} - parameter 6 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8233 | return null; | ||
8234 | } | ||
8235 | try | ||
8236 | { | ||
8237 | taper_b = rules.GetVector3Item(idx++); | ||
8238 | } | ||
8239 | catch(InvalidCastException) | ||
8240 | { | ||
8241 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_PRISM: arg #{1} - parameter 7 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8242 | return null; | ||
8243 | } | ||
8244 | try | ||
8245 | { | ||
8246 | topshear = rules.GetVector3Item(idx++); | ||
8247 | } | ||
8248 | catch(InvalidCastException) | ||
8249 | { | ||
8250 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_PRISM: arg #{1} - parameter 8 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8251 | return null; | ||
8252 | } | ||
7854 | SetPrimitiveShapeParams(part, face, v, hollow, twist, taper_b, topshear, | 8253 | SetPrimitiveShapeParams(part, face, v, hollow, twist, taper_b, topshear, |
7855 | (byte)ProfileShape.EquilateralTriangle, (byte)Extrusion.Straight); | 8254 | (byte)ProfileShape.EquilateralTriangle, (byte)Extrusion.Straight); |
7856 | break; | 8255 | break; |
7857 | 8256 | ||
7858 | case (int)ScriptBaseClass.PRIM_TYPE_SPHERE: | 8257 | case ScriptBaseClass.PRIM_TYPE_SPHERE: |
7859 | if (remain < 5) | 8258 | if (remain < 5) |
7860 | return null; | 8259 | return null; |
7861 | 8260 | ||
7862 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape | 8261 | try |
7863 | v = rules.GetVector3Item(idx++); // cut | 8262 | { |
7864 | hollow = (float)rules.GetLSLFloatItem(idx++); | 8263 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape |
7865 | twist = rules.GetVector3Item(idx++); | 8264 | } |
7866 | taper_b = rules.GetVector3Item(idx++); // dimple | 8265 | catch(InvalidCastException) |
8266 | { | ||
8267 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_SPHERE: arg #{1} - parameter 3 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8268 | return null; | ||
8269 | } | ||
8270 | try | ||
8271 | { | ||
8272 | v = rules.GetVector3Item(idx++); // cut | ||
8273 | } | ||
8274 | catch(InvalidCastException) | ||
8275 | { | ||
8276 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_SPHERE: arg #{1} - parameter 4 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8277 | return null; | ||
8278 | } | ||
8279 | try | ||
8280 | { | ||
8281 | hollow = (float)rules.GetLSLFloatItem(idx++); | ||
8282 | } | ||
8283 | catch(InvalidCastException) | ||
8284 | { | ||
8285 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_SPHERE: arg #{1} - parameter 5 must be float", rulesParsed, idx - idxStart - 1)); | ||
8286 | return null; | ||
8287 | } | ||
8288 | try | ||
8289 | { | ||
8290 | twist = rules.GetVector3Item(idx++); | ||
8291 | } | ||
8292 | catch(InvalidCastException) | ||
8293 | { | ||
8294 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_SPHERE: arg #{1} - parameter 6 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8295 | return null; | ||
8296 | } | ||
8297 | try | ||
8298 | { | ||
8299 | taper_b = rules.GetVector3Item(idx++); // dimple | ||
8300 | } | ||
8301 | catch(InvalidCastException) | ||
8302 | { | ||
8303 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_SPHERE: arg #{1} - parameter 7 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8304 | return null; | ||
8305 | } | ||
7867 | SetPrimitiveShapeParams(part, face, v, hollow, twist, taper_b, | 8306 | SetPrimitiveShapeParams(part, face, v, hollow, twist, taper_b, |
7868 | (byte)ProfileShape.HalfCircle, (byte)Extrusion.Curve1); | 8307 | (byte)ProfileShape.HalfCircle, (byte)Extrusion.Curve1); |
7869 | break; | 8308 | break; |
7870 | 8309 | ||
7871 | case (int)ScriptBaseClass.PRIM_TYPE_TORUS: | 8310 | case ScriptBaseClass.PRIM_TYPE_TORUS: |
7872 | if (remain < 11) | 8311 | if (remain < 11) |
7873 | return null; | 8312 | return null; |
7874 | 8313 | ||
7875 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape | 8314 | try |
7876 | v = rules.GetVector3Item(idx++); //cut | 8315 | { |
7877 | hollow = (float)rules.GetLSLFloatItem(idx++); | 8316 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape |
7878 | twist = rules.GetVector3Item(idx++); | 8317 | } |
7879 | holesize = rules.GetVector3Item(idx++); | 8318 | catch(InvalidCastException) |
7880 | topshear = rules.GetVector3Item(idx++); | 8319 | { |
7881 | profilecut = rules.GetVector3Item(idx++); | 8320 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TORUS: arg #{1} - parameter 3 must be integer", rulesParsed, idx - idxStart - 1)); |
7882 | taper_b = rules.GetVector3Item(idx++); // taper_a | 8321 | return null; |
7883 | revolutions = (float)rules.GetLSLFloatItem(idx++); | 8322 | } |
7884 | radiusoffset = (float)rules.GetLSLFloatItem(idx++); | 8323 | try |
7885 | skew = (float)rules.GetLSLFloatItem(idx++); | 8324 | { |
8325 | v = rules.GetVector3Item(idx++); //cut | ||
8326 | } | ||
8327 | catch(InvalidCastException) | ||
8328 | { | ||
8329 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TORUS: arg #{1} - parameter 4 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8330 | return null; | ||
8331 | } | ||
8332 | try | ||
8333 | { | ||
8334 | hollow = (float)rules.GetLSLFloatItem(idx++); | ||
8335 | } | ||
8336 | catch(InvalidCastException) | ||
8337 | { | ||
8338 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TORUS: arg #{1} - parameter 5 must be float", rulesParsed, idx - idxStart - 1)); | ||
8339 | return null; | ||
8340 | } | ||
8341 | try | ||
8342 | { | ||
8343 | twist = rules.GetVector3Item(idx++); | ||
8344 | } | ||
8345 | catch(InvalidCastException) | ||
8346 | { | ||
8347 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TORUS: arg #{1} - parameter 6 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8348 | return null; | ||
8349 | } | ||
8350 | try | ||
8351 | { | ||
8352 | holesize = rules.GetVector3Item(idx++); | ||
8353 | } | ||
8354 | catch(InvalidCastException) | ||
8355 | { | ||
8356 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TORUS: arg #{1} - parameter 7 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8357 | return null; | ||
8358 | } | ||
8359 | try | ||
8360 | { | ||
8361 | topshear = rules.GetVector3Item(idx++); | ||
8362 | } | ||
8363 | catch(InvalidCastException) | ||
8364 | { | ||
8365 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TORUS: arg #{1} - parameter 8 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8366 | return null; | ||
8367 | } | ||
8368 | try | ||
8369 | { | ||
8370 | profilecut = rules.GetVector3Item(idx++); | ||
8371 | } | ||
8372 | catch(InvalidCastException) | ||
8373 | { | ||
8374 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TORUS: arg #{1} - parameter 9 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8375 | return null; | ||
8376 | } | ||
8377 | try | ||
8378 | { | ||
8379 | taper_b = rules.GetVector3Item(idx++); // taper_a | ||
8380 | } | ||
8381 | catch(InvalidCastException) | ||
8382 | { | ||
8383 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TORUS: arg #{1} - parameter 10 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8384 | return null; | ||
8385 | } | ||
8386 | try | ||
8387 | { | ||
8388 | revolutions = (float)rules.GetLSLFloatItem(idx++); | ||
8389 | } | ||
8390 | catch(InvalidCastException) | ||
8391 | { | ||
8392 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TORUS: arg #{1} - parameter 11 must be float", rulesParsed, idx - idxStart - 1)); | ||
8393 | return null; | ||
8394 | } | ||
8395 | try | ||
8396 | { | ||
8397 | radiusoffset = (float)rules.GetLSLFloatItem(idx++); | ||
8398 | } | ||
8399 | catch(InvalidCastException) | ||
8400 | { | ||
8401 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TORUS: arg #{1} - parameter 12 must be float", rulesParsed, idx - idxStart - 1)); | ||
8402 | return null; | ||
8403 | } | ||
8404 | try | ||
8405 | { | ||
8406 | skew = (float)rules.GetLSLFloatItem(idx++); | ||
8407 | } | ||
8408 | catch(InvalidCastException) | ||
8409 | { | ||
8410 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TORUS: arg #{1} - parameter 13 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8411 | return null; | ||
8412 | } | ||
7886 | SetPrimitiveShapeParams(part, face, v, hollow, twist, holesize, topshear, profilecut, taper_b, | 8413 | SetPrimitiveShapeParams(part, face, v, hollow, twist, holesize, topshear, profilecut, taper_b, |
7887 | revolutions, radiusoffset, skew, (byte)ProfileShape.Circle, (byte)Extrusion.Curve1); | 8414 | revolutions, radiusoffset, skew, (byte)ProfileShape.Circle, (byte)Extrusion.Curve1); |
7888 | break; | 8415 | break; |
7889 | 8416 | ||
7890 | case (int)ScriptBaseClass.PRIM_TYPE_TUBE: | 8417 | case ScriptBaseClass.PRIM_TYPE_TUBE: |
7891 | if (remain < 11) | 8418 | if (remain < 11) |
7892 | return null; | 8419 | return null; |
7893 | 8420 | ||
7894 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape | 8421 | try |
7895 | v = rules.GetVector3Item(idx++); //cut | 8422 | { |
7896 | hollow = (float)rules.GetLSLFloatItem(idx++); | 8423 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape |
7897 | twist = rules.GetVector3Item(idx++); | 8424 | } |
7898 | holesize = rules.GetVector3Item(idx++); | 8425 | catch(InvalidCastException) |
7899 | topshear = rules.GetVector3Item(idx++); | 8426 | { |
7900 | profilecut = rules.GetVector3Item(idx++); | 8427 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TUBE: arg #{1} - parameter 3 must be integer", rulesParsed, idx - idxStart - 1)); |
7901 | taper_b = rules.GetVector3Item(idx++); // taper_a | 8428 | return null; |
7902 | revolutions = (float)rules.GetLSLFloatItem(idx++); | 8429 | } |
7903 | radiusoffset = (float)rules.GetLSLFloatItem(idx++); | 8430 | try |
7904 | skew = (float)rules.GetLSLFloatItem(idx++); | 8431 | { |
8432 | v = rules.GetVector3Item(idx++); //cut | ||
8433 | } | ||
8434 | catch(InvalidCastException) | ||
8435 | { | ||
8436 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TUBE: arg #{1} - parameter 4 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8437 | return null; | ||
8438 | } | ||
8439 | try | ||
8440 | { | ||
8441 | hollow = (float)rules.GetLSLFloatItem(idx++); | ||
8442 | } | ||
8443 | catch(InvalidCastException) | ||
8444 | { | ||
8445 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TUBE: arg #{1} - parameter 5 must be float", rulesParsed, idx - idxStart - 1)); | ||
8446 | return null; | ||
8447 | } | ||
8448 | try | ||
8449 | { | ||
8450 | twist = rules.GetVector3Item(idx++); | ||
8451 | } | ||
8452 | catch(InvalidCastException) | ||
8453 | { | ||
8454 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TUBE: arg #{1} - parameter 6 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8455 | return null; | ||
8456 | } | ||
8457 | try | ||
8458 | { | ||
8459 | holesize = rules.GetVector3Item(idx++); | ||
8460 | } | ||
8461 | catch(InvalidCastException) | ||
8462 | { | ||
8463 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TUBE: arg #{1} - parameter 7 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8464 | return null; | ||
8465 | } | ||
8466 | try | ||
8467 | { | ||
8468 | topshear = rules.GetVector3Item(idx++); | ||
8469 | } | ||
8470 | catch(InvalidCastException) | ||
8471 | { | ||
8472 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TUBE: arg #{1} - parameter 8 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8473 | return null; | ||
8474 | } | ||
8475 | try | ||
8476 | { | ||
8477 | profilecut = rules.GetVector3Item(idx++); | ||
8478 | } | ||
8479 | catch(InvalidCastException) | ||
8480 | { | ||
8481 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TUBE: arg #{1} - parameter 9 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8482 | return null; | ||
8483 | } | ||
8484 | try | ||
8485 | { | ||
8486 | taper_b = rules.GetVector3Item(idx++); // taper_a | ||
8487 | } | ||
8488 | catch(InvalidCastException) | ||
8489 | { | ||
8490 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TUBE: arg #{1} - parameter 10 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8491 | return null; | ||
8492 | } | ||
8493 | try | ||
8494 | { | ||
8495 | revolutions = (float)rules.GetLSLFloatItem(idx++); | ||
8496 | } | ||
8497 | catch(InvalidCastException) | ||
8498 | { | ||
8499 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TUBE: arg #{1} - parameter 11 must be float", rulesParsed, idx - idxStart - 1)); | ||
8500 | return null; | ||
8501 | } | ||
8502 | try | ||
8503 | { | ||
8504 | radiusoffset = (float)rules.GetLSLFloatItem(idx++); | ||
8505 | } | ||
8506 | catch(InvalidCastException) | ||
8507 | { | ||
8508 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TUBE: arg #{1} - parameter 12 must be float", rulesParsed, idx - idxStart - 1)); | ||
8509 | return null; | ||
8510 | } | ||
8511 | try | ||
8512 | { | ||
8513 | skew = (float)rules.GetLSLFloatItem(idx++); | ||
8514 | } | ||
8515 | catch(InvalidCastException) | ||
8516 | { | ||
8517 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_TUBE: arg #{1} - parameter 13 must be float", rulesParsed, idx - idxStart - 1)); | ||
8518 | return null; | ||
8519 | } | ||
7905 | SetPrimitiveShapeParams(part, face, v, hollow, twist, holesize, topshear, profilecut, taper_b, | 8520 | SetPrimitiveShapeParams(part, face, v, hollow, twist, holesize, topshear, profilecut, taper_b, |
7906 | revolutions, radiusoffset, skew, (byte)ProfileShape.Square, (byte)Extrusion.Curve1); | 8521 | revolutions, radiusoffset, skew, (byte)ProfileShape.Square, (byte)Extrusion.Curve1); |
7907 | break; | 8522 | break; |
7908 | 8523 | ||
7909 | case (int)ScriptBaseClass.PRIM_TYPE_RING: | 8524 | case ScriptBaseClass.PRIM_TYPE_RING: |
7910 | if (remain < 11) | 8525 | if (remain < 11) |
7911 | return null; | 8526 | return null; |
7912 | 8527 | ||
7913 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape | 8528 | try |
7914 | v = rules.GetVector3Item(idx++); //cut | 8529 | { |
7915 | hollow = (float)rules.GetLSLFloatItem(idx++); | 8530 | face = (int)rules.GetLSLIntegerItem(idx++); // holeshape |
7916 | twist = rules.GetVector3Item(idx++); | 8531 | } |
7917 | holesize = rules.GetVector3Item(idx++); | 8532 | catch(InvalidCastException) |
7918 | topshear = rules.GetVector3Item(idx++); | 8533 | { |
7919 | profilecut = rules.GetVector3Item(idx++); | 8534 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_RING: arg #{1} - parameter 3 must be integer", rulesParsed, idx - idxStart - 1)); |
7920 | taper_b = rules.GetVector3Item(idx++); // taper_a | 8535 | return null; |
7921 | revolutions = (float)rules.GetLSLFloatItem(idx++); | 8536 | } |
7922 | radiusoffset = (float)rules.GetLSLFloatItem(idx++); | 8537 | try |
7923 | skew = (float)rules.GetLSLFloatItem(idx++); | 8538 | { |
8539 | v = rules.GetVector3Item(idx++); //cut | ||
8540 | } | ||
8541 | catch(InvalidCastException) | ||
8542 | { | ||
8543 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_RING: arg #{1} - parameter 4 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8544 | return null; | ||
8545 | } | ||
8546 | try | ||
8547 | { | ||
8548 | hollow = (float)rules.GetLSLFloatItem(idx++); | ||
8549 | } | ||
8550 | catch(InvalidCastException) | ||
8551 | { | ||
8552 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_RING: arg #{1} - parameter 5 must be float", rulesParsed, idx - idxStart - 1)); | ||
8553 | return null; | ||
8554 | } | ||
8555 | try | ||
8556 | { | ||
8557 | twist = rules.GetVector3Item(idx++); | ||
8558 | } | ||
8559 | catch(InvalidCastException) | ||
8560 | { | ||
8561 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_RING: arg #{1} - parameter 6 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8562 | return null; | ||
8563 | } | ||
8564 | try | ||
8565 | { | ||
8566 | holesize = rules.GetVector3Item(idx++); | ||
8567 | } | ||
8568 | catch(InvalidCastException) | ||
8569 | { | ||
8570 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_RING: arg #{1} - parameter 7 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8571 | return null; | ||
8572 | } | ||
8573 | try | ||
8574 | { | ||
8575 | topshear = rules.GetVector3Item(idx++); | ||
8576 | } | ||
8577 | catch(InvalidCastException) | ||
8578 | { | ||
8579 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_RING: arg #{1} - parameter 8 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8580 | return null; | ||
8581 | } | ||
8582 | try | ||
8583 | { | ||
8584 | profilecut = rules.GetVector3Item(idx++); | ||
8585 | } | ||
8586 | catch(InvalidCastException) | ||
8587 | { | ||
8588 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_RING: arg #{1} - parameter 9 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8589 | return null; | ||
8590 | } | ||
8591 | try | ||
8592 | { | ||
8593 | taper_b = rules.GetVector3Item(idx++); // taper_a | ||
8594 | } | ||
8595 | catch(InvalidCastException) | ||
8596 | { | ||
8597 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_RING: arg #{1} - parameter 10 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8598 | return null; | ||
8599 | } | ||
8600 | try | ||
8601 | { | ||
8602 | revolutions = (float)rules.GetLSLFloatItem(idx++); | ||
8603 | } | ||
8604 | catch(InvalidCastException) | ||
8605 | { | ||
8606 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_RING: arg #{1} - parameter 11 must be float", rulesParsed, idx - idxStart - 1)); | ||
8607 | return null; | ||
8608 | } | ||
8609 | try | ||
8610 | { | ||
8611 | radiusoffset = (float)rules.GetLSLFloatItem(idx++); | ||
8612 | } | ||
8613 | catch(InvalidCastException) | ||
8614 | { | ||
8615 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_RING: arg #{1} - parameter 12 must be float", rulesParsed, idx - idxStart - 1)); | ||
8616 | return null; | ||
8617 | } | ||
8618 | try | ||
8619 | { | ||
8620 | skew = (float)rules.GetLSLFloatItem(idx++); | ||
8621 | } | ||
8622 | catch(InvalidCastException) | ||
8623 | { | ||
8624 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_RING: arg #{1} - parameter 13 must be float", rulesParsed, idx - idxStart - 1)); | ||
8625 | return null; | ||
8626 | } | ||
7924 | SetPrimitiveShapeParams(part, face, v, hollow, twist, holesize, topshear, profilecut, taper_b, | 8627 | SetPrimitiveShapeParams(part, face, v, hollow, twist, holesize, topshear, profilecut, taper_b, |
7925 | revolutions, radiusoffset, skew, (byte)ProfileShape.EquilateralTriangle, (byte)Extrusion.Curve1); | 8628 | revolutions, radiusoffset, skew, (byte)ProfileShape.EquilateralTriangle, (byte)Extrusion.Curve1); |
7926 | break; | 8629 | break; |
7927 | 8630 | ||
7928 | case (int)ScriptBaseClass.PRIM_TYPE_SCULPT: | 8631 | case ScriptBaseClass.PRIM_TYPE_SCULPT: |
7929 | if (remain < 2) | 8632 | if (remain < 2) |
7930 | return null; | 8633 | return null; |
7931 | 8634 | ||
7932 | string map = rules.Data[idx++].ToString(); | 8635 | string map = rules.Data[idx++].ToString(); |
7933 | face = (int)rules.GetLSLIntegerItem(idx++); // type | 8636 | try |
8637 | { | ||
8638 | face = (int)rules.GetLSLIntegerItem(idx++); // type | ||
8639 | } | ||
8640 | catch(InvalidCastException) | ||
8641 | { | ||
8642 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TYPE, PRIM_TYPE_SCULPT: arg #{1} - parameter 4 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8643 | return null; | ||
8644 | } | ||
7934 | SetPrimitiveShapeParams(part, map, face, (byte)Extrusion.Curve1); | 8645 | SetPrimitiveShapeParams(part, map, face, (byte)Extrusion.Curve1); |
7935 | break; | 8646 | break; |
7936 | } | 8647 | } |
7937 | 8648 | ||
7938 | break; | 8649 | break; |
7939 | 8650 | ||
7940 | case (int)ScriptBaseClass.PRIM_TEXTURE: | 8651 | case ScriptBaseClass.PRIM_TEXTURE: |
7941 | if (remain < 5) | 8652 | if (remain < 5) |
7942 | return null; | 8653 | return null; |
7943 | 8654 | ||
7944 | face=(int)rules.GetLSLIntegerItem(idx++); | 8655 | face=(int)rules.GetLSLIntegerItem(idx++); |
7945 | string tex=rules.Data[idx++].ToString(); | 8656 | string tex; |
7946 | LSL_Vector repeats=rules.GetVector3Item(idx++); | 8657 | LSL_Vector repeats; |
7947 | LSL_Vector offsets=rules.GetVector3Item(idx++); | 8658 | LSL_Vector offsets; |
7948 | double rotation=(double)rules.GetLSLFloatItem(idx++); | 8659 | double rotation; |
8660 | |||
8661 | tex = rules.Data[idx++].ToString(); | ||
8662 | try | ||
8663 | { | ||
8664 | repeats = rules.GetVector3Item(idx++); | ||
8665 | } | ||
8666 | catch(InvalidCastException) | ||
8667 | { | ||
8668 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TEXTURE: arg #{1} - parameter 3 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8669 | return null; | ||
8670 | } | ||
8671 | try | ||
8672 | { | ||
8673 | offsets = rules.GetVector3Item(idx++); | ||
8674 | } | ||
8675 | catch(InvalidCastException) | ||
8676 | { | ||
8677 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TEXTURE: arg #{1} - parameter 4 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8678 | return null; | ||
8679 | } | ||
8680 | try | ||
8681 | { | ||
8682 | rotation = (double)rules.GetLSLFloatItem(idx++); | ||
8683 | } | ||
8684 | catch(InvalidCastException) | ||
8685 | { | ||
8686 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TEXTURE: arg #{1} - parameter 5 must be float", rulesParsed, idx - idxStart - 1)); | ||
8687 | return null; | ||
8688 | } | ||
7949 | 8689 | ||
7950 | SetTexture(part, tex, face); | 8690 | SetTexture(part, tex, face); |
7951 | ScaleTexture(part, repeats.x, repeats.y, face); | 8691 | ScaleTexture(part, repeats.x, repeats.y, face); |
@@ -7954,114 +8694,328 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
7954 | 8694 | ||
7955 | break; | 8695 | break; |
7956 | 8696 | ||
7957 | case (int)ScriptBaseClass.PRIM_COLOR: | 8697 | case ScriptBaseClass.PRIM_COLOR: |
7958 | if (remain < 3) | 8698 | if (remain < 3) |
7959 | return null; | 8699 | return null; |
7960 | 8700 | ||
7961 | face=(int)rules.GetLSLIntegerItem(idx++); | 8701 | LSL_Vector color; |
7962 | LSL_Vector color=rules.GetVector3Item(idx++); | 8702 | double alpha; |
7963 | double alpha=(double)rules.GetLSLFloatItem(idx++); | 8703 | |
8704 | try | ||
8705 | { | ||
8706 | face = (int)rules.GetLSLIntegerItem(idx++); | ||
8707 | } | ||
8708 | catch(InvalidCastException) | ||
8709 | { | ||
8710 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_COLOR: arg #{1} - parameter 2 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8711 | return null; | ||
8712 | } | ||
8713 | try | ||
8714 | { | ||
8715 | color = rules.GetVector3Item(idx++); | ||
8716 | } | ||
8717 | catch(InvalidCastException) | ||
8718 | { | ||
8719 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_COLOR: arg #{1} - parameter 3 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8720 | return null; | ||
8721 | } | ||
8722 | try | ||
8723 | { | ||
8724 | alpha = (double)rules.GetLSLFloatItem(idx++); | ||
8725 | } | ||
8726 | catch(InvalidCastException) | ||
8727 | { | ||
8728 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_COLOR: arg #{1} - parameter 4 must be float", rulesParsed, idx - idxStart - 1)); | ||
8729 | return null; | ||
8730 | } | ||
7964 | 8731 | ||
7965 | part.SetFaceColorAlpha(face, color, alpha); | 8732 | part.SetFaceColorAlpha(face, color, alpha); |
7966 | 8733 | ||
7967 | break; | 8734 | break; |
7968 | 8735 | ||
7969 | case (int)ScriptBaseClass.PRIM_FLEXIBLE: | 8736 | case ScriptBaseClass.PRIM_FLEXIBLE: |
7970 | if (remain < 7) | 8737 | if (remain < 7) |
7971 | return null; | 8738 | return null; |
7972 | 8739 | bool flexi; | |
7973 | bool flexi = rules.GetLSLIntegerItem(idx++); | 8740 | int softness; |
7974 | int softness = rules.GetLSLIntegerItem(idx++); | 8741 | float gravity; |
7975 | float gravity = (float)rules.GetLSLFloatItem(idx++); | 8742 | float friction; |
7976 | float friction = (float)rules.GetLSLFloatItem(idx++); | 8743 | float wind; |
7977 | float wind = (float)rules.GetLSLFloatItem(idx++); | 8744 | float tension; |
7978 | float tension = (float)rules.GetLSLFloatItem(idx++); | 8745 | LSL_Vector force; |
7979 | LSL_Vector force = rules.GetVector3Item(idx++); | 8746 | |
8747 | try | ||
8748 | { | ||
8749 | flexi = rules.GetLSLIntegerItem(idx++); | ||
8750 | } | ||
8751 | catch(InvalidCastException) | ||
8752 | { | ||
8753 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_FLEXIBLE: arg #{1} - parameter 2 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8754 | return null; | ||
8755 | } | ||
8756 | try | ||
8757 | { | ||
8758 | softness = rules.GetLSLIntegerItem(idx++); | ||
8759 | } | ||
8760 | catch(InvalidCastException) | ||
8761 | { | ||
8762 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_FLEXIBLE: arg #{1} - parameter 3 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8763 | return null; | ||
8764 | } | ||
8765 | try | ||
8766 | { | ||
8767 | gravity = (float)rules.GetLSLFloatItem(idx++); | ||
8768 | } | ||
8769 | catch(InvalidCastException) | ||
8770 | { | ||
8771 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_FLEXIBLE: arg #{1} - parameter 4 must be float", rulesParsed, idx - idxStart - 1)); | ||
8772 | return null; | ||
8773 | } | ||
8774 | try | ||
8775 | { | ||
8776 | friction = (float)rules.GetLSLFloatItem(idx++); | ||
8777 | } | ||
8778 | catch(InvalidCastException) | ||
8779 | { | ||
8780 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_FLEXIBLE: arg #{1} - parameter 5 must be float", rulesParsed, idx - idxStart - 1)); | ||
8781 | return null; | ||
8782 | } | ||
8783 | try | ||
8784 | { | ||
8785 | wind = (float)rules.GetLSLFloatItem(idx++); | ||
8786 | } | ||
8787 | catch(InvalidCastException) | ||
8788 | { | ||
8789 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_FLEXIBLE: arg #{1} - parameter 6 must be float", rulesParsed, idx - idxStart - 1)); | ||
8790 | return null; | ||
8791 | } | ||
8792 | try | ||
8793 | { | ||
8794 | tension = (float)rules.GetLSLFloatItem(idx++); | ||
8795 | } | ||
8796 | catch(InvalidCastException) | ||
8797 | { | ||
8798 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_FLEXIBLE: arg #{1} - parameter 7 must be float", rulesParsed, idx - idxStart - 1)); | ||
8799 | return null; | ||
8800 | } | ||
8801 | try | ||
8802 | { | ||
8803 | force = rules.GetVector3Item(idx++); | ||
8804 | } | ||
8805 | catch(InvalidCastException) | ||
8806 | { | ||
8807 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_FLEXIBLE: arg #{1} - parameter 8 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8808 | return null; | ||
8809 | } | ||
7980 | 8810 | ||
7981 | SetFlexi(part, flexi, softness, gravity, friction, wind, tension, force); | 8811 | SetFlexi(part, flexi, softness, gravity, friction, wind, tension, force); |
7982 | 8812 | ||
7983 | break; | 8813 | break; |
7984 | 8814 | ||
7985 | case (int)ScriptBaseClass.PRIM_POINT_LIGHT: | 8815 | case ScriptBaseClass.PRIM_POINT_LIGHT: |
7986 | if (remain < 5) | 8816 | if (remain < 5) |
7987 | return null; | 8817 | return null; |
7988 | bool light = rules.GetLSLIntegerItem(idx++); | 8818 | bool light; |
7989 | LSL_Vector lightcolor = rules.GetVector3Item(idx++); | 8819 | LSL_Vector lightcolor; |
7990 | float intensity = (float)rules.GetLSLFloatItem(idx++); | 8820 | float intensity; |
7991 | float radius = (float)rules.GetLSLFloatItem(idx++); | 8821 | float radius; |
7992 | float falloff = (float)rules.GetLSLFloatItem(idx++); | 8822 | float falloff; |
8823 | |||
8824 | try | ||
8825 | { | ||
8826 | light = rules.GetLSLIntegerItem(idx++); | ||
8827 | } | ||
8828 | catch(InvalidCastException) | ||
8829 | { | ||
8830 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_POINT_LIGHT: arg #{1} - parameter 2 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8831 | return null; | ||
8832 | } | ||
8833 | try | ||
8834 | { | ||
8835 | lightcolor = rules.GetVector3Item(idx++); | ||
8836 | } | ||
8837 | catch(InvalidCastException) | ||
8838 | { | ||
8839 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_POINT_LIGHT: arg #{1} - parameter 3 must be vector", rulesParsed, idx - idxStart - 1)); | ||
8840 | return null; | ||
8841 | } | ||
8842 | try | ||
8843 | { | ||
8844 | intensity = (float)rules.GetLSLFloatItem(idx++); | ||
8845 | } | ||
8846 | catch(InvalidCastException) | ||
8847 | { | ||
8848 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_POINT_LIGHT: arg #{1} - parameter 4 must be float", rulesParsed, idx - idxStart - 1)); | ||
8849 | return null; | ||
8850 | } | ||
8851 | try | ||
8852 | { | ||
8853 | radius = (float)rules.GetLSLFloatItem(idx++); | ||
8854 | } | ||
8855 | catch(InvalidCastException) | ||
8856 | { | ||
8857 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_POINT_LIGHT: arg #{1} - parameter 5 must be float", rulesParsed, idx - idxStart - 1)); | ||
8858 | return null; | ||
8859 | } | ||
8860 | try | ||
8861 | { | ||
8862 | falloff = (float)rules.GetLSLFloatItem(idx++); | ||
8863 | } | ||
8864 | catch(InvalidCastException) | ||
8865 | { | ||
8866 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_POINT_LIGHT: arg #{1} - parameter 6 must be float", rulesParsed, idx - idxStart - 1)); | ||
8867 | return null; | ||
8868 | } | ||
7993 | 8869 | ||
7994 | SetPointLight(part, light, lightcolor, intensity, radius, falloff); | 8870 | SetPointLight(part, light, lightcolor, intensity, radius, falloff); |
7995 | 8871 | ||
7996 | break; | 8872 | break; |
7997 | 8873 | ||
7998 | case (int)ScriptBaseClass.PRIM_GLOW: | 8874 | case ScriptBaseClass.PRIM_GLOW: |
7999 | if (remain < 2) | 8875 | if (remain < 2) |
8000 | return null; | 8876 | return null; |
8001 | face = rules.GetLSLIntegerItem(idx++); | 8877 | |
8002 | float glow = (float)rules.GetLSLFloatItem(idx++); | 8878 | float glow; |
8879 | |||
8880 | try | ||
8881 | { | ||
8882 | face = rules.GetLSLIntegerItem(idx++); | ||
8883 | } | ||
8884 | catch(InvalidCastException) | ||
8885 | { | ||
8886 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_GLOW: arg #{1} - parameter 2 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8887 | return null; | ||
8888 | } | ||
8889 | try | ||
8890 | { | ||
8891 | glow = (float)rules.GetLSLFloatItem(idx++); | ||
8892 | } | ||
8893 | catch(InvalidCastException) | ||
8894 | { | ||
8895 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_GLOW: arg #{1} - parameter 3 must be float", rulesParsed, idx - idxStart - 1)); | ||
8896 | return null; | ||
8897 | } | ||
8003 | 8898 | ||
8004 | SetGlow(part, face, glow); | 8899 | SetGlow(part, face, glow); |
8005 | 8900 | ||
8006 | break; | 8901 | break; |
8007 | 8902 | ||
8008 | case (int)ScriptBaseClass.PRIM_BUMP_SHINY: | 8903 | case ScriptBaseClass.PRIM_BUMP_SHINY: |
8009 | if (remain < 3) | 8904 | if (remain < 3) |
8010 | return null; | 8905 | return null; |
8011 | face = (int)rules.GetLSLIntegerItem(idx++); | 8906 | |
8012 | int shiny = (int)rules.GetLSLIntegerItem(idx++); | 8907 | int shiny; |
8013 | Bumpiness bump = (Bumpiness)(int)rules.GetLSLIntegerItem(idx++); | 8908 | Bumpiness bump; |
8909 | |||
8910 | try | ||
8911 | { | ||
8912 | face = (int)rules.GetLSLIntegerItem(idx++); | ||
8913 | } | ||
8914 | catch(InvalidCastException) | ||
8915 | { | ||
8916 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_BUMP_SHINY: arg #{1} - parameter 2 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8917 | return null; | ||
8918 | } | ||
8919 | try | ||
8920 | { | ||
8921 | shiny = (int)rules.GetLSLIntegerItem(idx++); | ||
8922 | } | ||
8923 | catch(InvalidCastException) | ||
8924 | { | ||
8925 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_BUMP_SHINY: arg #{1} - parameter 3 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8926 | return null; | ||
8927 | } | ||
8928 | try | ||
8929 | { | ||
8930 | bump = (Bumpiness)(int)rules.GetLSLIntegerItem(idx++); | ||
8931 | } | ||
8932 | catch(InvalidCastException) | ||
8933 | { | ||
8934 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_BUMP_SHINY: arg #{1} - parameter 4 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8935 | return null; | ||
8936 | } | ||
8014 | 8937 | ||
8015 | SetShiny(part, face, shiny, bump); | 8938 | SetShiny(part, face, shiny, bump); |
8016 | 8939 | ||
8017 | break; | 8940 | break; |
8018 | 8941 | ||
8019 | case (int)ScriptBaseClass.PRIM_FULLBRIGHT: | 8942 | case ScriptBaseClass.PRIM_FULLBRIGHT: |
8020 | if (remain < 2) | 8943 | if (remain < 2) |
8021 | return null; | 8944 | return null; |
8022 | face = rules.GetLSLIntegerItem(idx++); | 8945 | bool st; |
8023 | bool st = rules.GetLSLIntegerItem(idx++); | ||
8024 | SetFullBright(part, face , st); | ||
8025 | break; | ||
8026 | |||
8027 | case (int)ScriptBaseClass.PRIM_MATERIAL: | ||
8028 | if (remain < 1) | ||
8029 | return null; | ||
8030 | int mat = rules.GetLSLIntegerItem(idx++); | ||
8031 | if (mat < 0 || mat > 7) | ||
8032 | return null; | ||
8033 | 8946 | ||
8034 | part.Material = Convert.ToByte(mat); | 8947 | try |
8035 | break; | 8948 | { |
8949 | face = rules.GetLSLIntegerItem(idx++); | ||
8950 | } | ||
8951 | catch(InvalidCastException) | ||
8952 | { | ||
8953 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_FULLBRIGHT: arg #{1} - parameter 2 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8954 | return null; | ||
8955 | } | ||
8956 | try | ||
8957 | { | ||
8958 | st = rules.GetLSLIntegerItem(idx++); | ||
8959 | } | ||
8960 | catch(InvalidCastException) | ||
8961 | { | ||
8962 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_FULLBRIGHT: arg #{1} - parameter 4 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8963 | return null; | ||
8964 | } | ||
8965 | SetFullBright(part, face , st); | ||
8966 | break; | ||
8036 | 8967 | ||
8037 | case (int)ScriptBaseClass.PRIM_PHANTOM: | 8968 | case ScriptBaseClass.PRIM_MATERIAL: |
8038 | if (remain < 1) | 8969 | if (remain < 1) |
8039 | return null; | 8970 | return null; |
8971 | int mat; | ||
8040 | 8972 | ||
8041 | string ph = rules.Data[idx++].ToString(); | 8973 | try |
8042 | part.ParentGroup.ScriptSetPhantomStatus(ph.Equals("1")); | 8974 | { |
8975 | mat = rules.GetLSLIntegerItem(idx++); | ||
8976 | } | ||
8977 | catch(InvalidCastException) | ||
8978 | { | ||
8979 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_MATERIAL: arg #{1} - parameter 2 must be integer", rulesParsed, idx - idxStart - 1)); | ||
8980 | return null; | ||
8981 | } | ||
8982 | if (mat < 0 || mat > 7) | ||
8983 | return null; | ||
8043 | 8984 | ||
8044 | break; | 8985 | part.Material = Convert.ToByte(mat); |
8986 | break; | ||
8045 | 8987 | ||
8046 | case (int)ScriptBaseClass.PRIM_PHYSICS: | 8988 | case ScriptBaseClass.PRIM_PHANTOM: |
8047 | if (remain < 1) | 8989 | if (remain < 1) |
8048 | return null; | 8990 | return null; |
8049 | string phy = rules.Data[idx++].ToString(); | ||
8050 | bool physics; | ||
8051 | 8991 | ||
8052 | if (phy.Equals("1")) | 8992 | string ph = rules.Data[idx++].ToString(); |
8053 | physics = true; | 8993 | part.ParentGroup.ScriptSetPhantomStatus(ph.Equals("1")); |
8054 | else | ||
8055 | physics = false; | ||
8056 | 8994 | ||
8057 | part.ScriptSetPhysicsStatus(physics); | 8995 | break; |
8058 | break; | ||
8059 | 8996 | ||
8060 | case (int)ScriptBaseClass.PRIM_PHYSICS_SHAPE_TYPE: | 8997 | case ScriptBaseClass.PRIM_PHYSICS: |
8998 | if (remain < 1) | ||
8999 | return null; | ||
9000 | string phy = rules.Data[idx++].ToString(); | ||
9001 | part.ScriptSetPhysicsStatus(phy.Equals("1")); | ||
9002 | break; | ||
9003 | |||
9004 | case ScriptBaseClass.PRIM_PHYSICS_SHAPE_TYPE: | ||
8061 | if (remain < 1) | 9005 | if (remain < 1) |
8062 | return null; | 9006 | return null; |
8063 | 9007 | ||
8064 | int shape_type = rules.GetLSLIntegerItem(idx++); | 9008 | int shape_type; |
9009 | |||
9010 | try | ||
9011 | { | ||
9012 | shape_type = rules.GetLSLIntegerItem(idx++); | ||
9013 | } | ||
9014 | catch(InvalidCastException) | ||
9015 | { | ||
9016 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_PHYSICS_SHAPE_TYPE: arg #{1} - parameter 2 must be integer", rulesParsed, idx - idxStart - 1)); | ||
9017 | return null; | ||
9018 | } | ||
8065 | 9019 | ||
8066 | ExtraPhysicsData physdata = new ExtraPhysicsData(); | 9020 | ExtraPhysicsData physdata = new ExtraPhysicsData(); |
8067 | physdata.Density = part.Density; | 9021 | physdata.Density = part.Density; |
@@ -8073,7 +9027,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8073 | 9027 | ||
8074 | break; | 9028 | break; |
8075 | 9029 | ||
8076 | case (int)ScriptBaseClass.PRIM_TEMP_ON_REZ: | 9030 | case ScriptBaseClass.PRIM_TEMP_ON_REZ: |
8077 | if (remain < 1) | 9031 | if (remain < 1) |
8078 | return null; | 9032 | return null; |
8079 | string temp = rules.Data[idx++].ToString(); | 9033 | string temp = rules.Data[idx++].ToString(); |
@@ -8082,60 +9036,177 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8082 | 9036 | ||
8083 | break; | 9037 | break; |
8084 | 9038 | ||
8085 | case (int)ScriptBaseClass.PRIM_TEXGEN: | 9039 | case ScriptBaseClass.PRIM_TEXGEN: |
8086 | if (remain < 2) | 9040 | if (remain < 2) |
8087 | return null; | 9041 | return null; |
8088 | //face,type | 9042 | //face,type |
8089 | face = rules.GetLSLIntegerItem(idx++); | 9043 | int style; |
8090 | int style = rules.GetLSLIntegerItem(idx++); | 9044 | |
9045 | try | ||
9046 | { | ||
9047 | face = rules.GetLSLIntegerItem(idx++); | ||
9048 | } | ||
9049 | catch(InvalidCastException) | ||
9050 | { | ||
9051 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TEXGEN: arg #{1} - parameter 2 must be integer", rulesParsed, idx - idxStart - 1)); | ||
9052 | return null; | ||
9053 | } | ||
9054 | try | ||
9055 | { | ||
9056 | style = rules.GetLSLIntegerItem(idx++); | ||
9057 | } | ||
9058 | catch(InvalidCastException) | ||
9059 | { | ||
9060 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TEXGEN: arg #{1} - parameter 3 must be integer", rulesParsed, idx - idxStart - 1)); | ||
9061 | return null; | ||
9062 | } | ||
8091 | SetTexGen(part, face, style); | 9063 | SetTexGen(part, face, style); |
8092 | break; | 9064 | break; |
8093 | case (int)ScriptBaseClass.PRIM_TEXT: | 9065 | case ScriptBaseClass.PRIM_TEXT: |
8094 | if (remain < 3) | 9066 | if (remain < 3) |
8095 | return null; | 9067 | return null; |
8096 | string primText = rules.GetLSLStringItem(idx++); | 9068 | string primText; |
8097 | LSL_Vector primTextColor = rules.GetVector3Item(idx++); | 9069 | LSL_Vector primTextColor; |
8098 | LSL_Float primTextAlpha = rules.GetLSLFloatItem(idx++); | 9070 | LSL_Float primTextAlpha; |
9071 | |||
9072 | try | ||
9073 | { | ||
9074 | primText = rules.GetLSLStringItem(idx++); | ||
9075 | } | ||
9076 | catch(InvalidCastException) | ||
9077 | { | ||
9078 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TEXT: arg #{1} - parameter 2 must be string", rulesParsed, idx - idxStart - 1)); | ||
9079 | return null; | ||
9080 | } | ||
9081 | try | ||
9082 | { | ||
9083 | primTextColor = rules.GetVector3Item(idx++); | ||
9084 | } | ||
9085 | catch(InvalidCastException) | ||
9086 | { | ||
9087 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TEXT: arg #{1} - parameter 3 must be vector", rulesParsed, idx - idxStart - 1)); | ||
9088 | return null; | ||
9089 | } | ||
9090 | try | ||
9091 | { | ||
9092 | primTextAlpha = rules.GetLSLFloatItem(idx++); | ||
9093 | } | ||
9094 | catch(InvalidCastException) | ||
9095 | { | ||
9096 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_TEXT: arg #{1} - parameter 4 must be float", rulesParsed, idx - idxStart - 1)); | ||
9097 | return null; | ||
9098 | } | ||
8099 | Vector3 av3 = Util.Clip(primTextColor, 0.0f, 1.0f); | 9099 | Vector3 av3 = Util.Clip(primTextColor, 0.0f, 1.0f); |
8100 | part.SetText(primText, av3, Util.Clip((float)primTextAlpha, 0.0f, 1.0f)); | 9100 | part.SetText(primText, av3, Util.Clip((float)primTextAlpha, 0.0f, 1.0f)); |
8101 | 9101 | ||
8102 | break; | 9102 | break; |
8103 | case (int)ScriptBaseClass.PRIM_NAME: | 9103 | |
9104 | case ScriptBaseClass.PRIM_NAME: | ||
8104 | if (remain < 1) | 9105 | if (remain < 1) |
8105 | return null; | 9106 | return null; |
8106 | string primName = rules.GetLSLStringItem(idx++); | 9107 | try |
8107 | part.Name = primName; | 9108 | { |
9109 | string primName = rules.GetLSLStringItem(idx++); | ||
9110 | part.Name = primName; | ||
9111 | } | ||
9112 | catch(InvalidCastException) | ||
9113 | { | ||
9114 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_NAME: arg #{1} - parameter 2 must be string", rulesParsed, idx - idxStart - 1)); | ||
9115 | return null; | ||
9116 | } | ||
8108 | break; | 9117 | break; |
8109 | case (int)ScriptBaseClass.PRIM_DESC: | 9118 | case ScriptBaseClass.PRIM_DESC: |
8110 | if (remain < 1) | 9119 | if (remain < 1) |
8111 | return null; | 9120 | return null; |
8112 | string primDesc = rules.GetLSLStringItem(idx++); | 9121 | try |
8113 | part.Description = primDesc; | 9122 | { |
9123 | string primDesc = rules.GetLSLStringItem(idx++); | ||
9124 | part.Description = primDesc; | ||
9125 | } | ||
9126 | catch(InvalidCastException) | ||
9127 | { | ||
9128 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_DESC: arg #{1} - parameter 2 must be string", rulesParsed, idx - idxStart - 1)); | ||
9129 | return null; | ||
9130 | } | ||
8114 | break; | 9131 | break; |
8115 | case (int)ScriptBaseClass.PRIM_ROT_LOCAL: | 9132 | case ScriptBaseClass.PRIM_ROT_LOCAL: |
8116 | if (remain < 1) | 9133 | if (remain < 1) |
8117 | return null; | 9134 | return null; |
8118 | SetRot(part, rules.GetQuaternionItem(idx++)); | 9135 | LSL_Rotation rot; |
9136 | try | ||
9137 | { | ||
9138 | rot = rules.GetQuaternionItem(idx++); | ||
9139 | } | ||
9140 | catch(InvalidCastException) | ||
9141 | { | ||
9142 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_ROT_LOCAL: arg #{1} - parameter 2 must be rotation", rulesParsed, idx - idxStart - 1)); | ||
9143 | return null; | ||
9144 | } | ||
9145 | SetRot(part, rot); | ||
8119 | break; | 9146 | break; |
8120 | case (int)ScriptBaseClass.PRIM_OMEGA: | 9147 | |
9148 | case ScriptBaseClass.PRIM_OMEGA: | ||
8121 | if (remain < 3) | 9149 | if (remain < 3) |
8122 | return null; | 9150 | return null; |
8123 | LSL_Vector axis = rules.GetVector3Item(idx++); | 9151 | LSL_Vector axis; |
8124 | LSL_Float spinrate = rules.GetLSLFloatItem(idx++); | 9152 | LSL_Float spinrate; |
8125 | LSL_Float gain = rules.GetLSLFloatItem(idx++); | 9153 | LSL_Float gain; |
9154 | |||
9155 | try | ||
9156 | { | ||
9157 | axis = rules.GetVector3Item(idx++); | ||
9158 | } | ||
9159 | catch(InvalidCastException) | ||
9160 | { | ||
9161 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_OMEGA: arg #{1} - parameter 2 must be vector", rulesParsed, idx - idxStart - 1)); | ||
9162 | return null; | ||
9163 | } | ||
9164 | try | ||
9165 | { | ||
9166 | spinrate = rules.GetLSLFloatItem(idx++); | ||
9167 | } | ||
9168 | catch(InvalidCastException) | ||
9169 | { | ||
9170 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_OMEGA: arg #{1} - parameter 3 must be float", rulesParsed, idx - idxStart - 1)); | ||
9171 | return null; | ||
9172 | } | ||
9173 | try | ||
9174 | { | ||
9175 | gain = rules.GetLSLFloatItem(idx++); | ||
9176 | } | ||
9177 | catch(InvalidCastException) | ||
9178 | { | ||
9179 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_OMEGA: arg #{1} - parameter 4 must be float", rulesParsed, idx - idxStart - 1)); | ||
9180 | return null; | ||
9181 | } | ||
8126 | TargetOmega(part, axis, (double)spinrate, (double)gain); | 9182 | TargetOmega(part, axis, (double)spinrate, (double)gain); |
8127 | break; | 9183 | break; |
8128 | case (int)ScriptBaseClass.PRIM_SLICE: | 9184 | |
9185 | case ScriptBaseClass.PRIM_SLICE: | ||
8129 | if (remain < 1) | 9186 | if (remain < 1) |
8130 | return null; | 9187 | return null; |
8131 | LSL_Vector slice = rules.GetVector3Item(idx++); | 9188 | LSL_Vector slice; |
9189 | try | ||
9190 | { | ||
9191 | slice = rules.GetVector3Item(idx++); | ||
9192 | } | ||
9193 | catch(InvalidCastException) | ||
9194 | { | ||
9195 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_SLICE: arg #{1} - parameter 2 must be vector", rulesParsed, idx - idxStart - 1)); | ||
9196 | return null; | ||
9197 | } | ||
8132 | part.UpdateSlice((float)slice.x, (float)slice.y); | 9198 | part.UpdateSlice((float)slice.x, (float)slice.y); |
8133 | break; | 9199 | break; |
8134 | case (int)ScriptBaseClass.PRIM_LINK_TARGET: | 9200 | |
9201 | case ScriptBaseClass.PRIM_LINK_TARGET: | ||
8135 | if (remain < 3) // setting to 3 on the basis that parsing any usage of PRIM_LINK_TARGET that has nothing following it is pointless. | 9202 | if (remain < 3) // setting to 3 on the basis that parsing any usage of PRIM_LINK_TARGET that has nothing following it is pointless. |
8136 | return null; | 9203 | return null; |
8137 | 9204 | ||
8138 | return rules.GetSublist(idx, -1); | 9205 | return rules.GetSublist(idx, -1); |
9206 | |||
9207 | default: | ||
9208 | Error(originFunc, string.Format("Error running rule #{0}: arg #{1} - unsupported parameter", rulesParsed, idx - idxStart)); | ||
9209 | return null; | ||
8139 | } | 9210 | } |
8140 | } | 9211 | } |
8141 | } | 9212 | } |
@@ -8182,19 +9253,44 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8182 | 9253 | ||
8183 | switch (code) | 9254 | switch (code) |
8184 | { | 9255 | { |
8185 | case (int)ScriptBaseClass.PRIM_POSITION: | 9256 | case ScriptBaseClass.PRIM_POSITION: |
8186 | case (int)ScriptBaseClass.PRIM_POS_LOCAL: | 9257 | case ScriptBaseClass.PRIM_POS_LOCAL: |
8187 | if (remain < 1) | 9258 | if (remain < 1) |
8188 | return null; | 9259 | return null; |
8189 | 9260 | ||
8190 | sp.OffsetPosition = rules.GetVector3Item(idx++); | 9261 | try |
9262 | { | ||
9263 | sp.OffsetPosition = rules.GetVector3Item(idx++); | ||
9264 | } | ||
9265 | catch(InvalidCastException) | ||
9266 | { | ||
9267 | if (code == ScriptBaseClass.PRIM_POSITION) | ||
9268 | { | ||
9269 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_POSITION: arg #{1} - parameter 2 must be vector", rulesParsed, idx - idxStart - 1)); | ||
9270 | } | ||
9271 | else | ||
9272 | { | ||
9273 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_POS_LOCAL: arg #{1} - parameter 2 must be vector", rulesParsed, idx - idxStart - 1)); | ||
9274 | } | ||
9275 | return null; | ||
9276 | } | ||
8191 | break; | 9277 | break; |
8192 | 9278 | ||
8193 | case (int)ScriptBaseClass.PRIM_ROTATION: | 9279 | case ScriptBaseClass.PRIM_ROTATION: |
8194 | if (remain < 1) | 9280 | if (remain < 1) |
8195 | return null; | 9281 | return null; |
8196 | 9282 | ||
8197 | Quaternion inRot = rules.GetQuaternionItem(idx++); | 9283 | Quaternion inRot; |
9284 | |||
9285 | try | ||
9286 | { | ||
9287 | inRot = rules.GetQuaternionItem(idx++); | ||
9288 | } | ||
9289 | catch(InvalidCastException) | ||
9290 | { | ||
9291 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_ROTATION: arg #{1} - parameter 2 must be rotation", rulesParsed, idx - idxStart - 1)); | ||
9292 | return null; | ||
9293 | } | ||
8198 | 9294 | ||
8199 | SceneObjectPart parentPart = sp.ParentPart; | 9295 | SceneObjectPart parentPart = sp.ParentPart; |
8200 | 9296 | ||
@@ -8203,13 +9299,40 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8203 | 9299 | ||
8204 | break; | 9300 | break; |
8205 | 9301 | ||
8206 | case (int)ScriptBaseClass.PRIM_ROT_LOCAL: | 9302 | case ScriptBaseClass.PRIM_ROT_LOCAL: |
8207 | if (remain < 1) | 9303 | if (remain < 1) |
8208 | return null; | 9304 | return null; |
8209 | 9305 | ||
8210 | sp.Rotation = rules.GetQuaternionItem(idx++); | 9306 | try |
9307 | { | ||
9308 | sp.Rotation = rules.GetQuaternionItem(idx++); | ||
9309 | } | ||
9310 | catch(InvalidCastException) | ||
9311 | { | ||
9312 | Error(originFunc, string.Format("Error running rule #{0} -> PRIM_ROT_LOCAL: arg #{1} - parameter 2 must be rotation", rulesParsed, idx - idxStart - 1)); | ||
9313 | return null; | ||
9314 | } | ||
8211 | 9315 | ||
8212 | break; | 9316 | break; |
9317 | |||
9318 | case ScriptBaseClass.PRIM_TYPE: | ||
9319 | Error(originFunc, "PRIM_TYPE disallowed on agent"); | ||
9320 | return null; | ||
9321 | |||
9322 | case ScriptBaseClass.PRIM_OMEGA: | ||
9323 | Error(originFunc, "PRIM_OMEGA disallowed on agent"); | ||
9324 | return null; | ||
9325 | |||
9326 | case ScriptBaseClass.PRIM_LINK_TARGET: | ||
9327 | if (remain < 3) // setting to 3 on the basis that parsing any usage of PRIM_LINK_TARGET that has nothing following it is pointless. | ||
9328 | return null; | ||
9329 | |||
9330 | return rules.GetSublist(idx, -1); | ||
9331 | |||
9332 | default: | ||
9333 | Error(originFunc, | ||
9334 | string.Format("Error running rule #{0} on agent: arg #{1} - disallowed on agent", rulesParsed, idx - idxStart)); | ||
9335 | return null; | ||
8213 | } | 9336 | } |
8214 | } | 9337 | } |
8215 | } | 9338 | } |
@@ -8744,6 +9867,10 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8744 | res.Add(GetPartRot(part)); | 9867 | res.Add(GetPartRot(part)); |
8745 | break; | 9868 | break; |
8746 | 9869 | ||
9870 | case (int)ScriptBaseClass.PRIM_PHYSICS_SHAPE_TYPE: | ||
9871 | res.Add(new LSL_Integer((int)part.PhysicsShapeType)); | ||
9872 | break; | ||
9873 | |||
8747 | case (int)ScriptBaseClass.PRIM_TYPE: | 9874 | case (int)ScriptBaseClass.PRIM_TYPE: |
8748 | // implementing box | 9875 | // implementing box |
8749 | PrimitiveBaseShape Shape = part.Shape; | 9876 | PrimitiveBaseShape Shape = part.Shape; |
@@ -10797,19 +11924,84 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
10797 | 11924 | ||
10798 | SortedDictionary<int, float> parameters = new SortedDictionary<int, float>(); | 11925 | SortedDictionary<int, float> parameters = new SortedDictionary<int, float>(); |
10799 | object[] data = rules.Data; | 11926 | object[] data = rules.Data; |
10800 | for (int i = 0; i < data.Length; ++i) { | 11927 | for (int i = 0; i < data.Length; ++i) |
10801 | int type = Convert.ToInt32(data[i++].ToString()); | 11928 | { |
11929 | int type; | ||
11930 | try | ||
11931 | { | ||
11932 | type = Convert.ToInt32(data[i++].ToString()); | ||
11933 | } | ||
11934 | catch | ||
11935 | { | ||
11936 | Error("llSetCameraParams", string.Format("Invalid camera param type {0}", data[i - 1])); | ||
11937 | return; | ||
11938 | } | ||
10802 | if (i >= data.Length) break; // odd number of entries => ignore the last | 11939 | if (i >= data.Length) break; // odd number of entries => ignore the last |
10803 | 11940 | ||
10804 | // some special cases: Vector parameters are split into 3 float parameters (with type+1, type+2, type+3) | 11941 | // some special cases: Vector parameters are split into 3 float parameters (with type+1, type+2, type+3) |
10805 | switch (type) { | 11942 | switch (type) |
11943 | { | ||
10806 | case ScriptBaseClass.CAMERA_FOCUS: | 11944 | case ScriptBaseClass.CAMERA_FOCUS: |
10807 | case ScriptBaseClass.CAMERA_FOCUS_OFFSET: | 11945 | case ScriptBaseClass.CAMERA_FOCUS_OFFSET: |
10808 | case ScriptBaseClass.CAMERA_POSITION: | 11946 | case ScriptBaseClass.CAMERA_POSITION: |
10809 | LSL_Vector v = (LSL_Vector)data[i]; | 11947 | LSL_Vector v = (LSL_Vector)data[i]; |
10810 | parameters.Add(type + 1, (float)v.x); | 11948 | try |
10811 | parameters.Add(type + 2, (float)v.y); | 11949 | { |
10812 | parameters.Add(type + 3, (float)v.z); | 11950 | parameters.Add(type + 1, (float)v.x); |
11951 | } | ||
11952 | catch | ||
11953 | { | ||
11954 | switch(type) | ||
11955 | { | ||
11956 | case ScriptBaseClass.CAMERA_FOCUS: | ||
11957 | Error("llSetCameraParams", "CAMERA_FOCUS: Parameter x is invalid"); | ||
11958 | return; | ||
11959 | case ScriptBaseClass.CAMERA_FOCUS_OFFSET: | ||
11960 | Error("llSetCameraParams", "CAMERA_FOCUS_OFFSET: Parameter x is invalid"); | ||
11961 | return; | ||
11962 | case ScriptBaseClass.CAMERA_POSITION: | ||
11963 | Error("llSetCameraParams", "CAMERA_POSITION: Parameter x is invalid"); | ||
11964 | return; | ||
11965 | } | ||
11966 | } | ||
11967 | try | ||
11968 | { | ||
11969 | parameters.Add(type + 2, (float)v.y); | ||
11970 | } | ||
11971 | catch | ||
11972 | { | ||
11973 | switch(type) | ||
11974 | { | ||
11975 | case ScriptBaseClass.CAMERA_FOCUS: | ||
11976 | Error("llSetCameraParams", "CAMERA_FOCUS: Parameter y is invalid"); | ||
11977 | return; | ||
11978 | case ScriptBaseClass.CAMERA_FOCUS_OFFSET: | ||
11979 | Error("llSetCameraParams", "CAMERA_FOCUS_OFFSET: Parameter y is invalid"); | ||
11980 | return; | ||
11981 | case ScriptBaseClass.CAMERA_POSITION: | ||
11982 | Error("llSetCameraParams", "CAMERA_POSITION: Parameter y is invalid"); | ||
11983 | return; | ||
11984 | } | ||
11985 | } | ||
11986 | try | ||
11987 | { | ||
11988 | parameters.Add(type + 3, (float)v.z); | ||
11989 | } | ||
11990 | catch | ||
11991 | { | ||
11992 | switch(type) | ||
11993 | { | ||
11994 | case ScriptBaseClass.CAMERA_FOCUS: | ||
11995 | Error("llSetCameraParams", "CAMERA_FOCUS: Parameter z is invalid"); | ||
11996 | return; | ||
11997 | case ScriptBaseClass.CAMERA_FOCUS_OFFSET: | ||
11998 | Error("llSetCameraParams", "CAMERA_FOCUS_OFFSET: Parameter z is invalid"); | ||
11999 | return; | ||
12000 | case ScriptBaseClass.CAMERA_POSITION: | ||
12001 | Error("llSetCameraParams", "CAMERA_POSITION: Parameter z is invalid"); | ||
12002 | return; | ||
12003 | } | ||
12004 | } | ||
10813 | break; | 12005 | break; |
10814 | default: | 12006 | default: |
10815 | // TODO: clean that up as soon as the implicit casts are in | 12007 | // TODO: clean that up as soon as the implicit casts are in |
@@ -10817,7 +12009,17 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
10817 | parameters.Add(type, (float)((LSL_Float)data[i]).value); | 12009 | parameters.Add(type, (float)((LSL_Float)data[i]).value); |
10818 | else if (data[i] is LSL_Integer) | 12010 | else if (data[i] is LSL_Integer) |
10819 | parameters.Add(type, (float)((LSL_Integer)data[i]).value); | 12011 | parameters.Add(type, (float)((LSL_Integer)data[i]).value); |
10820 | else parameters.Add(type, Convert.ToSingle(data[i])); | 12012 | else |
12013 | { | ||
12014 | try | ||
12015 | { | ||
12016 | parameters.Add(type, Convert.ToSingle(data[i])); | ||
12017 | } | ||
12018 | catch | ||
12019 | { | ||
12020 | Error("llSetCameraParams", string.Format("{0}: Parameter is invalid", type)); | ||
12021 | } | ||
12022 | } | ||
10821 | break; | 12023 | break; |
10822 | } | 12024 | } |
10823 | } | 12025 | } |