summaryrefslogtreecommitdiff
path: root/indra/newview/llfloaterscriptdebug.cpp
diff options
context:
space:
mode:
authorJames Cook <james@lindenlab.com>2007-01-02 08:33:20 +0000
committerJames Cook <james@lindenlab.com>2007-01-02 08:33:20 +0000
commit420b91db29485df39fd6e724e782c449158811cb (patch)
treeb471a94563af914d3ed3edd3e856d21cb1b69945 /indra/newview/llfloaterscriptdebug.cpp
Print done when done.
Diffstat (limited to 'indra/newview/llfloaterscriptdebug.cpp')
-rw-r--r--indra/newview/llfloaterscriptdebug.cpp230
1 files changed, 230 insertions, 0 deletions
diff --git a/indra/newview/llfloaterscriptdebug.cpp b/indra/newview/llfloaterscriptdebug.cpp
new file mode 100644
index 0000000000..d80dbca310
--- /dev/null
+++ b/indra/newview/llfloaterscriptdebug.cpp
@@ -0,0 +1,230 @@
+/**
+ * @file llfloaterscriptdebug.cpp
+ * @brief Chat window for showing script errors and warnings
+ *
+ * Copyright (c) 2006-$CurrentYear$, Linden Research, Inc.
+ * $License$
+ */
+
+#include "llviewerprecompiledheaders.h"
+
+#include "llvieweruictrlfactory.h"
+#include "llfloaterscriptdebug.h"
+
+#include "llfontgl.h"
+#include "llrect.h"
+#include "llerror.h"
+#include "llstring.h"
+#include "message.h"
+
+// project include
+#include "llviewertexteditor.h"
+#include "llviewercontrol.h"
+#include "llviewerobjectlist.h"
+#include "llviewerimagelist.h"
+
+//
+// Statics
+//
+LLFloaterScriptDebug* LLFloaterScriptDebug::sInstance = NULL;
+
+//
+// Member Functions
+//
+LLFloaterScriptDebug::LLFloaterScriptDebug()
+: LLMultiFloater()
+{
+
+}
+
+LLFloaterScriptDebug::~LLFloaterScriptDebug()
+{
+ sInstance = NULL;
+}
+
+void LLFloaterScriptDebug::show(const LLUUID& object_id)
+{
+ LLFloater* floaterp = addOutputWindow(object_id);
+ if (sInstance)
+ {
+ sInstance->open();
+ sInstance->showFloater(floaterp);
+ }
+}
+
+BOOL LLFloaterScriptDebug::postBuild()
+{
+ LLMultiFloater::postBuild();
+
+ if (mTabContainer)
+ {
+ // FIXME: apparantly fails for tab containers?
+// mTabContainer->requires("all_scripts", WIDGET_TYPE_FLOATER);
+// mTabContainer->checkRequirements();
+ return TRUE;
+ }
+
+ return FALSE;
+}
+
+void* getOutputWindow(void* data)
+{
+ return new LLFloaterScriptDebugOutput();
+}
+
+LLFloater* LLFloaterScriptDebug::addOutputWindow(const LLUUID &object_id)
+{
+ if (!sInstance)
+ {
+ sInstance = new LLFloaterScriptDebug();
+ LLCallbackMap::map_t factory_map;
+ factory_map["all_scripts"] = LLCallbackMap(getOutputWindow, NULL);
+ gUICtrlFactory->buildFloater(sInstance, "floater_script_debug.xml", &factory_map);
+ sInstance->setVisible(FALSE);
+ }
+
+ LLFloater* floaterp = NULL;
+ LLFloater::setFloaterHost(sInstance);
+ {
+ floaterp = LLFloaterScriptDebugOutput::show(object_id);
+ }
+ LLFloater::setFloaterHost(NULL);
+
+ return floaterp;
+}
+
+void LLFloaterScriptDebug::addScriptLine(const std::string &utf8mesg, const std::string &user_name, const LLColor4& color, const LLUUID& source_id)
+{
+ LLViewerObject* objectp = gObjectList.findObject(source_id);
+ LLString floater_label;
+
+ if (objectp)
+ {
+ objectp->setIcon(gImageList.getImage(LLUUID(gViewerArt.getString("script_error.tga"))));
+ floater_label = llformat("%s(%.2f, %.2f)", user_name.c_str(), objectp->getPositionRegion().mV[VX], objectp->getPositionRegion().mV[VY]);
+ }
+ else
+ {
+ floater_label = user_name;
+ }
+
+ addOutputWindow(LLUUID::null);
+ addOutputWindow(source_id);
+
+ // add to "All" floater
+ LLFloaterScriptDebugOutput* floaterp = LLFloaterScriptDebugOutput::getFloaterByID(LLUUID::null);
+ floaterp->addLine(utf8mesg, user_name, color);
+
+ // add to specific script instance floater
+ floaterp = LLFloaterScriptDebugOutput::getFloaterByID(source_id);
+ floaterp->addLine(utf8mesg, floater_label, color);
+}
+
+//
+// LLFloaterScriptDebugOutput
+//
+
+std::map<LLUUID, LLFloaterScriptDebugOutput*> LLFloaterScriptDebugOutput::sInstanceMap;
+
+LLFloaterScriptDebugOutput::LLFloaterScriptDebugOutput()
+: mObjectID(LLUUID::null)
+{
+ sInstanceMap[mObjectID] = this;
+}
+
+LLFloaterScriptDebugOutput::LLFloaterScriptDebugOutput(const LLUUID& object_id)
+: LLFloater("script instance floater", LLRect(0, 200, 200, 0), "Script", TRUE), mObjectID(object_id)
+{
+ S32 y = mRect.getHeight() - LLFLOATER_HEADER_SIZE - LLFLOATER_VPAD;
+ S32 x = LLFLOATER_HPAD;
+ // History editor
+ // Give it a border on the top
+ LLRect history_editor_rect(
+ x,
+ y,
+ mRect.getWidth() - LLFLOATER_HPAD,
+ LLFLOATER_VPAD );
+ mHistoryEditor = new LLViewerTextEditor( "Chat History Editor",
+ history_editor_rect, S32_MAX, "", LLFontGL::sSansSerif);
+ mHistoryEditor->setWordWrap( TRUE );
+ mHistoryEditor->setFollowsAll();
+ mHistoryEditor->setEnabled( FALSE );
+ mHistoryEditor->setTakesFocus( TRUE ); // We want to be able to cut or copy from the history.
+ addChild(mHistoryEditor);
+}
+
+void LLFloaterScriptDebugOutput::init(const LLString& title, BOOL resizable,
+ S32 min_width, S32 min_height, BOOL drag_on_left,
+ BOOL minimizable, BOOL close_btn)
+{
+ LLFloater::init(title, resizable, min_width, min_height, drag_on_left, minimizable, close_btn);
+ S32 y = mRect.getHeight() - LLFLOATER_HEADER_SIZE - LLFLOATER_VPAD;
+ S32 x = LLFLOATER_HPAD;
+ // History editor
+ // Give it a border on the top
+ LLRect history_editor_rect(
+ x,
+ y,
+ mRect.getWidth() - LLFLOATER_HPAD,
+ LLFLOATER_VPAD );
+ mHistoryEditor = new LLViewerTextEditor( "Chat History Editor",
+ history_editor_rect, S32_MAX, "", LLFontGL::sSansSerif);
+ mHistoryEditor->setWordWrap( TRUE );
+ mHistoryEditor->setFollowsAll();
+ mHistoryEditor->setEnabled( FALSE );
+ mHistoryEditor->setTakesFocus( TRUE ); // We want to be able to cut or copy from the history.
+ addChild(mHistoryEditor);
+}
+
+LLFloaterScriptDebugOutput::~LLFloaterScriptDebugOutput()
+{
+ sInstanceMap.erase(mObjectID);
+}
+
+void LLFloaterScriptDebugOutput::addLine(const std::string &utf8mesg, const std::string &user_name, const LLColor4& color)
+{
+ if (mObjectID.isNull())
+ {
+ //setTitle("[All scripts]");
+ setCanTearOff(FALSE);
+ setCanClose(FALSE);
+ }
+ else
+ {
+ setTitle(user_name);
+ }
+
+ mHistoryEditor->appendColoredText(utf8mesg, false, true, color);
+}
+
+//static
+LLFloaterScriptDebugOutput* LLFloaterScriptDebugOutput::show(const LLUUID& object_id)
+{
+ LLFloaterScriptDebugOutput* floaterp = NULL;
+ instance_map_t::iterator found_it = sInstanceMap.find(object_id);
+ if (found_it == sInstanceMap.end())
+ {
+ floaterp = new LLFloaterScriptDebugOutput(object_id);
+ sInstanceMap[object_id] = floaterp;
+ floaterp->open();
+ }
+ else
+ {
+ floaterp = found_it->second;
+ }
+
+ return floaterp;
+}
+
+//static
+LLFloaterScriptDebugOutput* LLFloaterScriptDebugOutput::getFloaterByID(const LLUUID& object_id)
+{
+ LLFloaterScriptDebugOutput* floaterp = NULL;
+ instance_map_t::iterator found_it = sInstanceMap.find(object_id);
+ if (found_it != sInstanceMap.end())
+ {
+ floaterp = found_it->second;
+ }
+
+ return floaterp;
+}