aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--OpenSim/Region/ScriptEngine/YEngine/XMRInstRun.cs86
1 files changed, 49 insertions, 37 deletions
diff --git a/OpenSim/Region/ScriptEngine/YEngine/XMRInstRun.cs b/OpenSim/Region/ScriptEngine/YEngine/XMRInstRun.cs
index ce0823d..1e5416f 100644
--- a/OpenSim/Region/ScriptEngine/YEngine/XMRInstRun.cs
+++ b/OpenSim/Region/ScriptEngine/YEngine/XMRInstRun.cs
@@ -444,8 +444,10 @@ namespace OpenSim.Region.ScriptEngine.Yengine
444 */ 444 */
445 private void HandleScriptException(Exception e) 445 private void HandleScriptException(Exception e)
446 { 446 {
447 // The script threw some kind of exception that was not caught at 447 // The script threw some kind of exception that was not caught at
448 // script level, so the script is no longer running an event handler. 448 // script level, so the script is no longer running an event handler.
449
450 ScriptEventCode curevent = eventCode;
449 eventCode = ScriptEventCode.None; 451 eventCode = ScriptEventCode.None;
450 stackFrames = null; 452 stackFrames = null;
451 453
@@ -464,19 +466,60 @@ namespace OpenSim.Region.ScriptEngine.Yengine
464 m_SleepUntil = DateTime.MaxValue; 466 m_SleepUntil = DateTime.MaxValue;
465 m_Engine.World.DeleteSceneObject(m_Part.ParentGroup, false); 467 m_Engine.World.DeleteSceneObject(m_Part.ParentGroup, false);
466 } 468 }
467 else if(e is ScriptResetException) 469 else if (e is ScriptResetException)
468 { 470 {
469 // Script did an llResetScript(). 471 // Script did an llResetScript().
470 m_RunOnePhase = "resetting..."; 472 m_RunOnePhase = "resetting...";
471 ResetLocked("HandleScriptResetException"); 473 ResetLocked("HandleScriptResetException");
472 } 474 }
475 else if (e is ScriptException)
476 {
477 // Some general script error.
478 SendScriptErrorMessage(e, curevent);
479 }
473 else 480 else
474 { 481 {
475 // Some general script error. 482 // Some general script error.
476 SendErrorMessage(e); 483 SendErrorMessage(e);
477 } 484 }
478 } 485 }
479 486
487 private void SendScriptErrorMessage(Exception e, ScriptEventCode ev)
488 {
489 StringBuilder msg = new StringBuilder();
490
491 msg.Append("YEngine: ");
492 if (e.Message != null)
493 msg.Append(e.Message);
494
495 msg.Append(" (prim: ");
496 msg.Append(m_Part.Name);
497
498 msg.Append(" script: ");
499 msg.Append(m_Item.Name);
500 msg.Append(" event: ");
501 msg.Append(ev.ToString());
502 msg.Append(" at: <");
503 Vector3 pos = m_Part.AbsolutePosition;
504 msg.Append((int)Math.Floor(pos.X));
505 msg.Append(',');
506 msg.Append((int)Math.Floor(pos.Y));
507 msg.Append(',');
508 msg.Append((int)Math.Floor(pos.Z));
509 msg.Append(">) Script must be Reset to re-enable.\n");
510
511 string msgst = msg.ToString();
512 if (msgst.Length > 1000)
513 msgst = msgst.Substring(0, 1000);
514
515 m_log.Info(msgst);
516 m_Engine.World.SimChat(Utils.StringToBytes(msgst),
517 ChatTypeEnum.DebugChannel, 2147483647,
518 m_Part.AbsolutePosition,
519 m_Part.Name, m_Part.UUID, false);
520 m_SleepUntil = DateTime.MaxValue;
521 }
522
480 /** 523 /**
481 * @brief There was an exception running script event handler. 524 * @brief There was an exception running script event handler.
482 * Display error message and disable script (in a way 525 * Display error message and disable script (in a way
@@ -536,41 +579,10 @@ namespace OpenSim.Region.ScriptEngine.Yengine
536 continue; 579 continue;
537 } 580 }
538 this.llOwnerSay(line); 581 this.llOwnerSay(line);
539 imstr.Append(line);
540 imstr.Append('\n');
541 }
542
543 // Send as instant message in case user not online.
544 // Code modelled from llInstantMessage().
545 IMessageTransferModule transferModule = m_Engine.World.RequestModuleInterface<IMessageTransferModule>();
546 if(transferModule != null)
547 {
548 UUID friendTransactionID = UUID.Random();
549 GridInstantMessage gim = new GridInstantMessage();
550 gim.fromAgentID = new Guid(m_Part.UUID.ToString());
551 gim.toAgentID = new Guid(m_Part.OwnerID.ToString());
552 gim.imSessionID = new Guid(friendTransactionID.ToString());
553 gim.timestamp = (uint)Util.UnixTimeSinceEpoch();
554 gim.message = imstr.ToString();
555 gim.dialog = (byte)19; // messgage from script
556 gim.fromGroup = false;
557 gim.offline = (byte)0;
558 gim.ParentEstateID = 0;
559 gim.Position = pos;
560 gim.RegionID = m_Engine.World.RegionInfo.RegionID.Guid;
561 gim.binaryBucket = Util.StringToBytes256(
562 "{0}/{1}/{2}/{3}",
563 m_Engine.World.RegionInfo.RegionName,
564 (int)Math.Floor(pos.X),
565 (int)Math.Floor(pos.Y),
566 (int)Math.Floor(pos.Z));
567 transferModule.SendInstantMessage(gim, delegate (bool success)
568 {
569 });
570 } 582 }
571 583
572 // Say script is sleeping for a very long time. 584 // Say script is sleeping for a very long time.
573 // Reset() is able to cancel this sleeping. 585 // Reset() is able to cancel this sleeping.
574 m_SleepUntil = DateTime.MaxValue; 586 m_SleepUntil = DateTime.MaxValue;
575 } 587 }
576 588