From b2b8a6b924a93794821a1a20f4dd965400e53688 Mon Sep 17 00:00:00 2001 From: McCabe Maxsted Date: Wed, 1 Sep 2010 17:34:49 -0700 Subject: Moved chatbar commandline options into their own window, cleaned up more stuff --- linden/indra/newview/CMakeLists.txt | 2 + linden/indra/newview/app_settings/settings.xml | 40 +++---- linden/indra/newview/chatbar_as_cmdline.cpp | 129 ++++++++++----------- linden/indra/newview/floatercommandline.cpp | 84 ++++++++++++++ linden/indra/newview/floatercommandline.h | 55 +++++++++ linden/indra/newview/lggautocorrectfloater.cpp | 9 +- linden/indra/newview/llprefsadvanced.cpp | 111 ++---------------- linden/indra/newview/llprefsadvanced.h | 22 +--- .../default/xui/en-us/floater_command_line.xml | 108 +++++++++++++++++ .../skins/default/xui/en-us/notifications.xml | 12 +- .../xui/en-us/panel_preferences_advanced.xml | 117 ++----------------- 11 files changed, 364 insertions(+), 325 deletions(-) create mode 100644 linden/indra/newview/floatercommandline.cpp create mode 100644 linden/indra/newview/floatercommandline.h create mode 100644 linden/indra/newview/skins/default/xui/en-us/floater_command_line.xml (limited to 'linden/indra') diff --git a/linden/indra/newview/CMakeLists.txt b/linden/indra/newview/CMakeLists.txt index 1a900c4..c047a0f 100644 --- a/linden/indra/newview/CMakeLists.txt +++ b/linden/indra/newview/CMakeLists.txt @@ -78,6 +78,7 @@ set(viewer_SOURCE_FILES emeraldboobutils.cpp floaterao.cpp floaterbusy.cpp + floatercommandline.cpp floatergriddefault.cpp floatergridmanager.cpp floaterlocalassetbrowse.cpp @@ -514,6 +515,7 @@ set(viewer_HEADER_FILES emeraldboobutils.h floaterao.h floaterbusy.h + floatercommandline.h floatergriddefault.h floatergridmanager.h floaterlocalassetbrowse.h diff --git a/linden/indra/newview/app_settings/settings.xml b/linden/indra/newview/app_settings/settings.xml index 7071de2..f096811 100644 --- a/linden/indra/newview/app_settings/settings.xml +++ b/linden/indra/newview/app_settings/settings.xml @@ -1312,7 +1312,7 @@ - EmeraldCmdLine + CmdLineChatbarEnabled Comment Enable usage of chat bar as a command line @@ -1323,7 +1323,7 @@ Value 1 - EmeraldCmdLineMapToKeepPos + CmdLineChatbarMapToKeepPos Comment Whether to use current local pos on tp to the new sim @@ -1334,7 +1334,7 @@ Value 0 - EmeraldCmdLineAO + CmdLineChatbarAO Comment Turn AO on/off @@ -1345,7 +1345,7 @@ Value cao - EmeraldCmdLineAutocorrect + CmdLineChatbarAutocorrect Comment Command for adding new entries to autocorrect @@ -1356,7 +1356,7 @@ Value /addac - EmeraldCmdLineMedia + CmdLineChatbarMedia Comment Chat command for setting a media url @@ -1367,7 +1367,7 @@ Value /media - EmeraldCmdLineMusic + CmdLineChatbarMusic Comment Chat command for setting a music url @@ -1378,7 +1378,7 @@ Value /music - EmeraldCmdLineClearChat + CmdLineChatbarClearChat Comment Clear chat hsitory to stop lag from chat spam @@ -1389,7 +1389,7 @@ Value clrchat - EmeraldCmdLineHeight + CmdLineChatbarHeight Comment Teleport to height function command @@ -1400,7 +1400,7 @@ Value gth - EmeraldCmdLinePos + CmdLineChatbarPos Comment Teleport to position function command @@ -1411,7 +1411,7 @@ Value gtp - EmeraldCmdLineGround + CmdLineChatbarGround Comment Teleport to ground function command @@ -1422,7 +1422,7 @@ Value flr - EmeraldCmdLineTeleportHome + CmdLineChatbarTeleportHome Comment Teleport to home function command @@ -1433,7 +1433,7 @@ Value tph - EmeraldCmdLineRezPlatform + CmdLineChatbarRezPlatform Comment Rez a platform underneath you @@ -1444,7 +1444,7 @@ Value rezplat - EmeraldCmdLinePlatformSize + CmdLineChatbarPlatformSize Comment How wide the rezzed platform will appear to be. @@ -1455,7 +1455,7 @@ Value 30 - EmeraldCmdLineMapTo + CmdLineChatbarMapTo Comment Teleport to a region by name rapidly @@ -1466,7 +1466,7 @@ Value mapto - EmeraldCmdLineDrawDistance + CmdLineChatbarDrawDistance Comment Change draw distance quickly @@ -1477,7 +1477,7 @@ Value dd - EmeraldCmdTeleportToCam + CmdLineChatbarTeleportToCam Comment Teleport to your camera @@ -1488,7 +1488,7 @@ Value tp2cam - EmeraldCmdLineKeyToName + CmdLineChatbarKeyToName Comment Use a fast key to name querry @@ -1499,7 +1499,7 @@ Value key2name - EmeraldCmdLineOfferTp + CmdLineChatbarOfferTp Comment Offer a teleport to target avatar @@ -1510,7 +1510,7 @@ Value offertp - EmeraldCmdLineCalc + CmdLineChatbarCalc Comment Calculates an expression @@ -1521,7 +1521,7 @@ Value calc - EmeraldCmdLineTP2 + CmdLineChatbarTP2 Comment Teleport to a person by name, partials work. diff --git a/linden/indra/newview/chatbar_as_cmdline.cpp b/linden/indra/newview/chatbar_as_cmdline.cpp index 61e4ef4..4e23b8a 100644 --- a/linden/indra/newview/chatbar_as_cmdline.cpp +++ b/linden/indra/newview/chatbar_as_cmdline.cpp @@ -50,7 +50,6 @@ #include "llurldispatcher.h" #include "llworld.h" #include "llworldmap.h" -//KOW #include "floateravatarlist.h" #include "floaterao.h" #include "llviewerobjectlist.h" #include "llviewertexteditor.h" @@ -222,23 +221,23 @@ void invrepair() gInventory.collectDescendents(gAgent.getInventoryRootID(),cats,items,FALSE);//,objectnamematches); } -/*static BOOL *sEmeraldCmdLine; -static std::string *sEmeraldCmdLinePos; -static std::string *sEmeraldCmdLineDrawDistance; -static std::string *sEmeraldCmdTeleportToCam; -static std::string *sEmeraldCmdLineAO; -static std::string *sEmeraldCmdLineKeyToName; -static std::string *sEmeraldCmdLineOfferTp; -static std::string *sEmeraldCmdLineGround; -static std::string *sEmeraldCmdLineHeight; -static std::string *sEmeraldCmdLineTeleportHome; -static std::string *sEmeraldCmdLineRezPlatform; -static std::string *sEmeraldCmdLineMapTo; -static BOOL *sEmeraldCmdLineMapToKeepPos; -static std::string *sEmeraldCmdLineCalc; -static std::string *sEmeraldCmdLineTP2; -static std::string *sEmeraldCmdLineClearChat; -static F32 *sEmeraldCmdLinePlatformSize;*/ +/*static BOOL *sCmdLineChatbarEnabled; +static std::string *sCmdLineChatbarPos; +static std::string *sCmdLineChatbarDrawDistance; +static std::string *sCmdLineChatbarTeleportToCam; +static std::string *sCmdLineChatbarAO; +static std::string *sCmdLineChatbarKeyToName; +static std::string *sCmdLineChatbarOfferTp; +static std::string *sCmdLineChatbarGround; +static std::string *sCmdLineChatbarHeight; +static std::string *sCmdLineChatbarTeleportHome; +static std::string *sCmdLineChatbarRezPlatform; +static std::string *sCmdLineChatbarMapTo; +static BOOL *sCmdLineChatbarMapToKeepPos; +static std::string *sCmdLineChatbarCalc; +static std::string *sCmdLineChatbarTP2; +static std::string *sCmdLineChatbarClearChat; +static F32 *sCmdLineChatbarPlatformSize;*/ /* class another_rebind_group @@ -264,36 +263,36 @@ std::map get_gsaved_calls(); bool cmd_line_chat(std::string revised_text, EChatType type) { - static BOOL *sEmeraldCmdLine = rebind_llcontrol("EmeraldCmdLine", &gSavedSettings, true); - static std::string *sEmeraldCmdLinePos = rebind_llcontrol("EmeraldCmdLinePos", &gSavedSettings, true); - static std::string *sEmeraldCmdLineDrawDistance = rebind_llcontrol("EmeraldCmdLineDrawDistance", &gSavedSettings, true); - static std::string *sEmeraldCmdTeleportToCam = rebind_llcontrol("EmeraldCmdTeleportToCam", &gSavedSettings, true); - static std::string *sEmeraldCmdLineAO = rebind_llcontrol("EmeraldCmdLineAO", &gSavedSettings, true); - static std::string *sEmeraldCmdLineKeyToName = rebind_llcontrol("EmeraldCmdLineKeyToName", &gSavedSettings, true); - static std::string *sEmeraldCmdLineOfferTp = rebind_llcontrol("EmeraldCmdLineOfferTp", &gSavedSettings, true); - static std::string *sEmeraldCmdLineGround = rebind_llcontrol("EmeraldCmdLineGround", &gSavedSettings, true); - static std::string *sEmeraldCmdLineHeight = rebind_llcontrol("EmeraldCmdLineHeight", &gSavedSettings, true); - static std::string *sEmeraldCmdLineTeleportHome = rebind_llcontrol("EmeraldCmdLineTeleportHome", &gSavedSettings, true); - static std::string *sEmeraldCmdLineRezPlatform = rebind_llcontrol("EmeraldCmdLineRezPlatform", &gSavedSettings, true); - static std::string *sEmeraldCmdLineMapTo = rebind_llcontrol("EmeraldCmdLineMapTo", &gSavedSettings, true); - static BOOL *sEmeraldCmdLineMapToKeepPos = rebind_llcontrol("EmeraldCmdLineMapToKeepPos", &gSavedSettings, true); - static std::string *sEmeraldCmdLineCalc = rebind_llcontrol("EmeraldCmdLineCalc", &gSavedSettings, true); - static std::string *sEmeraldCmdLineTP2 = rebind_llcontrol("EmeraldCmdLineTP2", &gSavedSettings, true); - static std::string *sEmeraldCmdLineClearChat = rebind_llcontrol("EmeraldCmdLineClearChat", &gSavedSettings, true); - static std::string *sEmeraldCmdLineMedia = rebind_llcontrol("EmeraldCmdLineMedia", &gSavedSettings, true); - static std::string *sEmeraldCmdLineMusic = rebind_llcontrol("EmeraldCmdLineMusic", &gSavedSettings, true); - static std::string *sEmeraldCmdLineAutocorrect = rebind_llcontrol("EmeraldCmdLineAutocorrect", &gSavedSettings, true); - //static std::string *sEmeraldCmdUndeform = rebind_llcontrol("EmeraldCmdUndeform", &gSavedSettings, true); - //gSavedSettings.getString("EmeraldCmdUndeform") + static BOOL *sCmdLineChatbarEnabled = rebind_llcontrol("CmdLineChatbarEnabled", &gSavedSettings, true); + static std::string *sCmdLineChatbarPos = rebind_llcontrol("CmdLineChatbarPos", &gSavedSettings, true); + static std::string *sCmdLineChatbarDrawDistance = rebind_llcontrol("CmdLineChatbarDrawDistance", &gSavedSettings, true); + static std::string *sCmdLineChatbarTeleportToCam = rebind_llcontrol("CmdLineChatbarTeleportToCam", &gSavedSettings, true); + static std::string *sCmdLineChatbarAO = rebind_llcontrol("CmdLineChatbarAO", &gSavedSettings, true); + static std::string *sCmdLineChatbarKeyToName = rebind_llcontrol("CmdLineChatbarKeyToName", &gSavedSettings, true); + static std::string *sCmdLineChatbarOfferTp = rebind_llcontrol("CmdLineChatbarOfferTp", &gSavedSettings, true); + static std::string *sCmdLineChatbarGround = rebind_llcontrol("CmdLineChatbarGround", &gSavedSettings, true); + static std::string *sCmdLineChatbarHeight = rebind_llcontrol("CmdLineChatbarHeight", &gSavedSettings, true); + static std::string *sCmdLineChatbarTeleportHome = rebind_llcontrol("CmdLineChatbarTeleportHome", &gSavedSettings, true); + static std::string *sCmdLineChatbarRezPlatform = rebind_llcontrol("CmdLineChatbarRezPlatform", &gSavedSettings, true); + static std::string *sCmdLineChatbarMapTo = rebind_llcontrol("CmdLineChatbarMapTo", &gSavedSettings, true); + static BOOL *sCmdLineChatbarMapToKeepPos = rebind_llcontrol("CmdLineChatbarMapToKeepPos", &gSavedSettings, true); + static std::string *sCmdLineChatbarCalc = rebind_llcontrol("CmdLineChatbarCalc", &gSavedSettings, true); + static std::string *sCmdLineChatbarTP2 = rebind_llcontrol("CmdLineChatbarTP2", &gSavedSettings, true); + static std::string *sCmdLineChatbarClearChat = rebind_llcontrol("CmdLineChatbarClearChat", &gSavedSettings, true); + static std::string *sCmdLineChatbarMedia = rebind_llcontrol("CmdLineChatbarMedia", &gSavedSettings, true); + static std::string *sCmdLineChatbarMusic = rebind_llcontrol("CmdLineChatbarMusic", &gSavedSettings, true); + static std::string *sCmdLineChatbarAutocorrect = rebind_llcontrol("CmdLineChatbarAutocorrect", &gSavedSettings, true); + //static std::string *sCmdLineChatbarUndeform = rebind_llcontrol("CmdLineChatbarUndeform", &gSavedSettings, true); + //gSavedSettings.getString("CmdLineChatbarUndeform") - if(*sEmeraldCmdLine) + if(*sCmdLineChatbarEnabled) { std::istringstream i(revised_text); std::string command; i >> command; if(command != "") { - if(command == *sEmeraldCmdLinePos) + if(command == *sCmdLineChatbarPos) { F32 x,y,z; if (i >> x) @@ -316,7 +315,7 @@ bool cmd_line_chat(std::string revised_text, EChatType type) } } } - else if(command == *sEmeraldCmdLineDrawDistance) + else if(command == *sCmdLineChatbarDrawDistance) { int drawDist; if(i >> drawDist) @@ -329,18 +328,18 @@ bool cmd_line_chat(std::string revised_text, EChatType type) return false; } } - else if(command == *sEmeraldCmdTeleportToCam) + else if(command == *sCmdLineChatbarTeleportToCam) { gAgent.teleportViaLocation(gAgent.getCameraPositionGlobal()); return false; } - /*else if(command == *sEmeraldCmdUndeform) + /*else if(command == *sCmdLineChatbarUndeform) { llinfos << "UNDEFORM: Do you feel your bones cracking back into place?" << llendl; gAgent.getAvatarObject()->undeform(); return false; }*/ //what the fuck is this shit, thought it would be something useful like repairing the skeleton but its some shitty playing of inworld anims - else if(command == *sEmeraldCmdLineMedia) + else if(command == *sCmdLineChatbarMedia) { std::string url; std::string type; @@ -358,7 +357,7 @@ bool cmd_line_chat(std::string revised_text, EChatType type) } } } - else if(command == *sEmeraldCmdLineMusic) + else if(command == *sCmdLineChatbarMusic) { std::string status; if(i >> status) @@ -371,7 +370,7 @@ bool cmd_line_chat(std::string revised_text, EChatType type) return false; } } - else if(command == *sEmeraldCmdLineAO) + else if(command == *sCmdLineChatbarAO) { std::string status; if(i >> status) @@ -394,7 +393,7 @@ bool cmd_line_chat(std::string revised_text, EChatType type) } return false; } - else if(command == *sEmeraldCmdLineKeyToName) + else if(command == *sCmdLineChatbarKeyToName) { LLUUID targetKey; if(i >> targetKey) @@ -496,7 +495,7 @@ bool cmd_line_chat(std::string revised_text, EChatType type) cmdline_printchat(std::string("Standing up")); return false; } - else if(command == *sEmeraldCmdLineOfferTp) + else if(command == *sCmdLineChatbarOfferTp) { std::string avatarKey; // llinfos << "CMD DEBUG 0 " << command << " " << avatarName << llendl; @@ -532,7 +531,7 @@ bool cmd_line_chat(std::string revised_text, EChatType type) } } - else if(command == *sEmeraldCmdLineGround) + else if(command == *sCmdLineChatbarGround) { LLVector3 agentPos = gAgent.getPositionAgent(); U64 agentRegion = gAgent.getRegion()->getHandle(); @@ -541,7 +540,7 @@ bool cmd_line_chat(std::string revised_text, EChatType type) pos_global += LLVector3d((F64)targetPos.mV[0],(F64)targetPos.mV[1],(F64)targetPos.mV[2]); gAgent.teleportViaLocation(pos_global); return false; - }else if(command == *sEmeraldCmdLineHeight) + }else if(command == *sCmdLineChatbarHeight) { F32 z; if(i >> z) @@ -554,17 +553,17 @@ bool cmd_line_chat(std::string revised_text, EChatType type) gAgent.teleportViaLocation(pos_global); return false; } - }else if(command == *sEmeraldCmdLineTeleportHome) + }else if(command == *sCmdLineChatbarTeleportHome) { gAgent.teleportHome(); return false; - }else if(command == *sEmeraldCmdLineRezPlatform) + }else if(command == *sCmdLineChatbarRezPlatform) { F32 width; if (i >> width) cmdline_rezplat(false, width); else cmdline_rezplat(); return false; - }else if(command == *sEmeraldCmdLineMapTo) + }else if(command == *sCmdLineChatbarMapTo) { if (revised_text.length() > command.length() + 1) //Typing this command with no argument was causing a crash. -Madgeek { @@ -575,7 +574,7 @@ bool cmd_line_chat(std::string revised_text, EChatType type) std::string region_name = LLWeb::escapeURL(revised_text.substr(command.length()+1)); std::string url; - if(!*sEmeraldCmdLineMapToKeepPos) + if(!*sCmdLineChatbarMapToKeepPos) { agent_x = 128; agent_y = 128; @@ -586,7 +585,7 @@ bool cmd_line_chat(std::string revised_text, EChatType type) LLURLDispatcher::dispatch(url, NULL, true); } return false; - }else if(command == *sEmeraldCmdLineCalc)//Cryogenic Blitz + }else if(command == *sCmdLineChatbarCalc)//Cryogenic Blitz { bool success; F32 result = 0.f; @@ -615,7 +614,7 @@ bool cmd_line_chat(std::string revised_text, EChatType type) cmdline_printchat(out); return false; } - }else if(command == *sEmeraldCmdLineTP2) + }else if(command == *sCmdLineChatbarTP2) { if (revised_text.length() > command.length() + 1) //Typing this command with no argument was causing a crash. -Madgeek { @@ -630,22 +629,22 @@ bool cmd_line_chat(std::string revised_text, EChatType type) cmdline_printchat("Displaying AutoCorrection Floater."); return false; } - else if(command == *sEmeraldCmdLineAutocorrect) + else if(command == *sCmdLineChatbarAutocorrect) { if (revised_text.length() <= command.length() + 1) //KOW: verify that we have params { cmdline_printchat("No parameter specified, correct usage is "+ - *sEmeraldCmdLineAutocorrect+" list Name|wrong word|right word."); + *sCmdLineChatbarAutocorrect+" list Name|wrong word|right word."); return false; } - std::string info = revised_text.substr((*sEmeraldCmdLineAutocorrect).length()+1); + std::string info = revised_text.substr((*sCmdLineChatbarAutocorrect).length()+1); //addac list name|wrong word|right word int bar = info.find("|"); if (bar==std::string::npos) { cmdline_printchat("Wrong usage, correct usage is "+ - *sEmeraldCmdLineAutocorrect+" list name|wrong word|right word."); + *sCmdLineChatbarAutocorrect+" list name|wrong word|right word."); return false; } @@ -657,7 +656,7 @@ bool cmd_line_chat(std::string revised_text, EChatType type) if (bar==std::string::npos) { cmdline_printchat("Wrong usage, correct usage is"+ - *sEmeraldCmdLineAutocorrect+" list name|wrong word|right word."); + *sCmdLineChatbarAutocorrect+" list name|wrong word|right word."); return false; } @@ -683,7 +682,7 @@ bool cmd_line_chat(std::string revised_text, EChatType type) // //gAgent.getAvatarObject()->loadAvatar(); // return false; // } - else if(command == *sEmeraldCmdLineClearChat) + else if(command == *sCmdLineChatbarClearChat) { LLFloaterChat* chat = LLFloaterChat::getInstance(LLSD()); if(chat) @@ -930,9 +929,9 @@ void cmdline_rezplat(bool use_saved_value, F32 visual_radius) //cmdline_rezplat( LLQuaternion rotation; rotation.setQuat(90.f * DEG_TO_RAD, LLVector3::y_axis); - static F32 *sEmeraldCmdLinePlatformSize = rebind_llcontrol("EmeraldCmdLinePlatformSize", &gSavedSettings, true); + static F32 *sCmdLineChatbarPlatformSize = rebind_llcontrol("CmdLineChatbarPlatformSize", &gSavedSettings, true); - if (use_saved_value) visual_radius = *sEmeraldCmdLinePlatformSize; + if (use_saved_value) visual_radius = *sCmdLineChatbarPlatformSize; F32 realsize = visual_radius / 3.0f; if (realsize < 0.01f) realsize = 0.01f; else if (realsize > 10.0f) realsize = 10.0f; diff --git a/linden/indra/newview/floatercommandline.cpp b/linden/indra/newview/floatercommandline.cpp new file mode 100644 index 0000000..a700b62 --- /dev/null +++ b/linden/indra/newview/floatercommandline.cpp @@ -0,0 +1,84 @@ +/** +* @file floatercommandline.cpp +* @brief change chatbar as a commandline preferences in Imprudence +* +* $LicenseInfo:firstyear=2009&license=viewergpl$ +* +* Copyright (c) 2010, McCabe Maxsted +* +* Imprudence Viewer Source Code +* The source code in this file ("Source Code") is provided to you +* under the terms of the GNU General Public License, version 2.0 +* ("GPL"). Terms of the GPL can be found in doc/GPL-license.txt in +* this distribution, or online at +* http://secondlifegrid.net/programs/open_source/licensing/gplv2 +* +* There are special exceptions to the terms and conditions of the GPL as +* it is applied to this Source Code. View the full text of the exception +* in the file doc/FLOSS-exception.txt in this software distribution, or +* online at http://secondlifegrid.net/programs/open_source/licensing/flossexception +* +* By copying, modifying or distributing this software, you acknowledge +* that you have read and understood your obligations described above, +* and agree to abide by those obligations. +* +* ALL SOURCE CODE IS PROVIDED "AS IS." THE AUTHOR MAKES NO +* WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, +* COMPLETENESS OR PERFORMANCE. +* $/LicenseInfo$ +*/ + +#include "llviewerprecompiledheaders.h" + +#include "floatercommandline.h" + +#include "lluictrlfactory.h" +#include "llviewercontrol.h" + +FloaterCommandLine::FloaterCommandLine(const LLSD& seed) : LLFloater("floater_command_line") +{ + LLUICtrlFactory::getInstance()->buildFloater(this, "floater_command_line.xml"); +} + +FloaterCommandLine::~FloaterCommandLine() +{ +} + +BOOL FloaterCommandLine::postBuild() +{ + childSetAction("Help_CmdLine", onClickHelp, this); + + childSetCommitCallback("CmdLineChatbarPos", onCommitApplyControl); + childSetCommitCallback("CmdLineChatbarGround", onCommitApplyControl); + childSetCommitCallback("CmdLineChatbarHeight", onCommitApplyControl); + childSetCommitCallback("CmdLineChatbarTeleportHome", onCommitApplyControl); + childSetCommitCallback("CmdLineChatbarRezPlatform", onCommitApplyControl); + childSetCommitCallback("CmdLineChatbarMapTo", onCommitApplyControl); + childSetCommitCallback("CmdLineChatbarCalc", onCommitApplyControl); + + childSetCommitCallback("CmdLineChatbarDrawDistance", onCommitApplyControl); + childSetCommitCallback("CmdLineChatbarTeleportToCam", onCommitApplyControl); + childSetCommitCallback("CmdLineChatbarKeyToName", onCommitApplyControl); + childSetCommitCallback("CmdLineChatbarOfferTp", onCommitApplyControl); + childSetCommitCallback("CmdLineChatbarTP2", onCommitApplyControl); + childSetCommitCallback("CmdLineChatbarAO", onCommitApplyControl); + childSetCommitCallback("CmdLineChatbarClearChat", onCommitApplyControl); + + return TRUE; +} + +//workaround for lineeditor dumbness in regards to control_name +void FloaterCommandLine::onCommitApplyControl(LLUICtrl* caller, void* user_data) +{ + LLLineEditor* line = (LLLineEditor*)caller; + if(line) + { + LLControlVariable *var = line->findControl(line->getControlName()); + if(var)var->setValue(line->getValue()); + } +} + +void FloaterCommandLine::onClickHelp(void* data) +{ + LLNotifications::instance().add("Help_CmdLine"); +} diff --git a/linden/indra/newview/floatercommandline.h b/linden/indra/newview/floatercommandline.h new file mode 100644 index 0000000..9d140eb --- /dev/null +++ b/linden/indra/newview/floatercommandline.h @@ -0,0 +1,55 @@ +/** +* @file floatercommandline.h +* @brief change chatbar as a commandline preferences in Imprudence +* +* $LicenseInfo:firstyear=2009&license=viewergpl$ +* +* Copyright (c) 2010, McCabe Maxsted +* +* Imprudence Viewer Source Code +* The source code in this file ("Source Code") is provided to you +* under the terms of the GNU General Public License, version 2.0 +* ("GPL"). Terms of the GPL can be found in doc/GPL-license.txt in +* this distribution, or online at +* http://secondlifegrid.net/programs/open_source/licensing/gplv2 +* +* There are special exceptions to the terms and conditions of the GPL as +* it is applied to this Source Code. View the full text of the exception +* in the file doc/FLOSS-exception.txt in this software distribution, or +* online at http://secondlifegrid.net/programs/open_source/licensing/flossexception +* +* By copying, modifying or distributing this software, you acknowledge +* that you have read and understood your obligations described above, +* and agree to abide by those obligations. +* +* ALL SOURCE CODE IS PROVIDED "AS IS." THE AUTHOR MAKES NO +* WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, +* COMPLETENESS OR PERFORMANCE. +* $/LicenseInfo$ +*/ + +#ifndef FLOATERCOMMANDLINE_H +#define FLOATERCOMMANDLINE_H + +#include "llfloater.h" + +class FloaterCommandLine : public LLFloater, public LLFloaterSingleton +{ +public: + FloaterCommandLine(const LLSD& seed); + virtual ~FloaterCommandLine(); + + BOOL postBuild(); + + //void apply(); + //void cancel(); + +private: + //static void onClickOK(void* userdata); + //static void onClickCancel(void* userdata); + static void onCommitApplyControl(LLUICtrl* caller, void* user_data); + + static void onClickHelp(void* data); +}; + +#endif // FLOATERCOMMANDLINE_H diff --git a/linden/indra/newview/lggautocorrectfloater.cpp b/linden/indra/newview/lggautocorrectfloater.cpp index 9d68b25..1690eaf 100644 --- a/linden/indra/newview/lggautocorrectfloater.cpp +++ b/linden/indra/newview/lggautocorrectfloater.cpp @@ -49,6 +49,7 @@ #include "llcheckboxctrl.h" #include "llviewercontrol.h" +#include "floaterbusy.h" // InvDropTarget #include "llui.h" #include "llcontrol.h" #include "llscrolllistctrl.h" @@ -89,7 +90,7 @@ public: LLPrefsAdvanced * empanel; private: static lggAutoCorrectFloater* sInstance; - static JCInvDropTarget* mNotecardDropTarget; + static InvDropTarget* mNotecardDropTarget; static void onBoxCommitEnabled(LLUICtrl* caller, void* user_data); static void onEntrySettingChange(LLUICtrl* caller, void* user_data); static void onSelectName(LLUICtrl* caller, void* user_data); @@ -107,7 +108,7 @@ private: -JCInvDropTarget * lggAutoCorrectFloater::mNotecardDropTarget; +InvDropTarget * lggAutoCorrectFloater::mNotecardDropTarget; lggAutoCorrectFloater* lggAutoCorrectFloater::sInstance; lggAutoCorrectFloater::~lggAutoCorrectFloater() @@ -165,7 +166,7 @@ BOOL lggAutoCorrectFloater::postBuild(void) { delete mNotecardDropTarget; } - mNotecardDropTarget = new JCInvDropTarget("drop target", target_view->getRect(), ResponseItemDrop);//, mAvatarID); + mNotecardDropTarget = new InvDropTarget("drop target", target_view->getRect(), ResponseItemDrop);//, mAvatarID); addChild(mNotecardDropTarget); } return true; @@ -429,7 +430,7 @@ void lggAutoCorrectFloater::addEntry(void* data) { std::string listName= sInstance->namesList->getFirstSelected()->getColumn(0)->getValue().asString(); LLChat chat; - chat.mText = "To add an entry, please type in chat \""+gSavedSettings.getString("EmeraldCmdLineAutocorrect")+" "+listName+"|wrongWord|rightWord\""; + chat.mText = "To add an entry, please type in chat \""+gSavedSettings.getString("CmdLineChatbarAutocorrect")+" "+listName+"|wrongWord|rightWord\""; chat.mSourceType = CHAT_SOURCE_SYSTEM; LLFloaterChat::addChat(chat, FALSE, FALSE); } diff --git a/linden/indra/newview/llprefsadvanced.cpp b/linden/indra/newview/llprefsadvanced.cpp index 4a4b299..7fa694c 100644 --- a/linden/indra/newview/llprefsadvanced.cpp +++ b/linden/indra/newview/llprefsadvanced.cpp @@ -32,6 +32,7 @@ #include "llcombobox.h" +#include "floatercommandline.h" #include "llagent.h" #include "llprefsadvanced.h" #include "llviewercontrol.h" @@ -43,76 +44,6 @@ #include "lluictrlfactory.h" -////////begin drop utility///////////// -//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -// Class JCInvDropTarget -// -// This handy class is a simple way to drop something on another -// view. It handles drop events, always setting itself to the size of -// its parent. -// -// altered to support a callback so i can slap it in things and it just return the item to a func of my choice -//~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - - - - -JCInvDropTarget::JCInvDropTarget(const std::string& name, const LLRect& rect, - void (*callback)(LLViewerInventoryItem*)) : -LLView(name, rect, NOT_MOUSE_OPAQUE, FOLLOWS_ALL), -mDownCallback(callback) -{ -} - -JCInvDropTarget::~JCInvDropTarget() -{ -} - -void JCInvDropTarget::doDrop(EDragAndDropType cargo_type, void* cargo_data) -{ - llinfos << "JCInvDropTarget::doDrop()" << llendl; -} - -BOOL JCInvDropTarget::handleDragAndDrop(S32 x, S32 y, MASK mask, BOOL drop, - EDragAndDropType cargo_type, - void* cargo_data, - EAcceptance* accept, - std::string& tooltip_msg) -{ - BOOL handled = FALSE; - if(getParent()) - { - handled = TRUE; - // check the type - //switch(cargo_type) - //{ - //case DAD_ANIMATION: - //{ - LLViewerInventoryItem* inv_item = (LLViewerInventoryItem*)cargo_data; - if(gInventory.getItem(inv_item->getUUID())) - { - *accept = ACCEPT_YES_COPY_SINGLE; - if(drop) - { - //printchat("accepted"); - mDownCallback(inv_item); - } - } - else - { - *accept = ACCEPT_NO; - } - // break; - //} - //default: - // *accept = ACCEPT_NO; - // break; - //} - } - return handled; -} -////////end drop utility/////////////// - LLPrefsAdvanced* LLPrefsAdvanced::sInstance; LLPrefsAdvanced::LLPrefsAdvanced() @@ -124,6 +55,7 @@ LLPrefsAdvanced::LLPrefsAdvanced() childSetCommitCallback("speed_rez_check", onCommitCheckBox, this); childSetAction("reset_btn", onClickResetPrefs, this); + childSetAction("command_line_btn", onClickCommandLine, this); } LLPrefsAdvanced::~LLPrefsAdvanced() @@ -160,6 +92,7 @@ BOOL LLPrefsAdvanced::postBuild() childSetValue("allow_mupose", gSavedSettings.getBOOL("AllowMUpose")); childSetValue("auto_close_ooc", gSavedSettings.getBOOL("AutoCloseOOC")); childSetValue("shadows_check", gSavedSettings.getBOOL("ShadowsEnabled")); + childSetValue("command_line_check", gSavedSettings.getBOOL("CmdLineChatbarEnabled")); childSetValue("lightshare_combo", LLSD((S32)gSavedSettings.getU32("LightShareAllowed"))); @@ -167,22 +100,6 @@ BOOL LLPrefsAdvanced::postBuild() LLComboBox* crash_behavior_combobox = getChild("crash_behavior_combobox"); crash_behavior_combobox->setCurrentByIndex(gCrashSettings.getS32(CRASH_BEHAVIOR_SETTING)); - childSetCommitCallback("EmeraldCmdLinePos", onCommitApplyControl); - childSetCommitCallback("EmeraldCmdLineGround", onCommitApplyControl); - childSetCommitCallback("EmeraldCmdLineHeight", onCommitApplyControl); - childSetCommitCallback("EmeraldCmdLineTeleportHome", onCommitApplyControl); - childSetCommitCallback("EmeraldCmdLineRezPlatform", onCommitApplyControl); - childSetCommitCallback("EmeraldCmdLineMapTo", onCommitApplyControl); - childSetCommitCallback("EmeraldCmdLineCalc", onCommitApplyControl); - - childSetCommitCallback("EmeraldCmdLineDrawDistance", onCommitApplyControl); - childSetCommitCallback("EmeraldCmdTeleportToCam", onCommitApplyControl); - childSetCommitCallback("EmeraldCmdLineKeyToName", onCommitApplyControl); - childSetCommitCallback("EmeraldCmdLineOfferTp", onCommitApplyControl); - childSetCommitCallback("EmeraldCmdLineTP2", onCommitApplyControl); - childSetCommitCallback("EmeraldCmdLineAO", onCommitApplyControl); - childSetCommitCallback("EmeraldCmdLineClearChat", onCommitApplyControl); - getChild("EmeraldSpellBase")->setCommitCallback(onSpellBaseComboBoxCommit); getChild("EmSpell_EditCustom")->setClickedCallback(onSpellEditCustom, this); getChild("EmSpell_GetMore")->setClickedCallback(onSpellGetMore, this); @@ -191,7 +108,6 @@ BOOL LLPrefsAdvanced::postBuild() getChild("ac_button")->setClickedCallback(onAutoCorrectButton,this); - initHelpBtn("EmeraldHelp_CmdLine", "EmeraldHelp_CmdLine"); initHelpBtn("EmeraldHelp_SpellCheck", "EmeraldHelp_SpellCheck"); refresh(); @@ -277,6 +193,8 @@ void LLPrefsAdvanced::apply() build_pie_menus(); } + gSavedSettings.setBOOL("CmdLineChatbarEnabled", childGetValue("command_line_check").asBoolean()); + LLComboBox* crash_behavior_combobox = getChild("crash_behavior_combobox"); gCrashSettings.setS32(CRASH_BEHAVIOR_SETTING, crash_behavior_combobox->getCurrentIndex()); } @@ -362,17 +280,6 @@ bool LLPrefsAdvanced::callbackReset(const LLSD& notification, const LLSD& respon return false; } -//workaround for lineeditor dumbness in regards to control_name -void LLPrefsAdvanced::onCommitApplyControl(LLUICtrl* caller, void* user_data) -{ - LLLineEditor* line = (LLLineEditor*)caller; - if(line) - { - LLControlVariable *var = line->findControl(line->getControlName()); - if(var)var->setValue(line->getValue()); - } -} - void LLPrefsAdvanced::onSpellAdd(void* data) { LLPrefsAdvanced* panel = (LLPrefsAdvanced*)data; @@ -416,4 +323,10 @@ void LLPrefsAdvanced::onSpellBaseComboBoxCommit(LLUICtrl* ctrl, void* userdata) void LLPrefsAdvanced::onAutoCorrectButton(void * data) { lggAutoCorrectFloaterStart::show(TRUE,data); -} \ No newline at end of file +} + +void LLPrefsAdvanced::onClickCommandLine(void* data) +{ + FloaterCommandLine::getInstance()->open(); + FloaterCommandLine::getInstance()->center(); +} diff --git a/linden/indra/newview/llprefsadvanced.h b/linden/indra/newview/llprefsadvanced.h index 6a15fba..84a7854 100644 --- a/linden/indra/newview/llprefsadvanced.h +++ b/linden/indra/newview/llprefsadvanced.h @@ -34,25 +34,6 @@ #include "llpanel.h" #include "llviewerinventory.h" -class JCInvDropTarget : public LLView -{ -public: - JCInvDropTarget(const std::string& name, const LLRect& rect, void (*callback)(LLViewerInventoryItem*)); - ~JCInvDropTarget(); - - void doDrop(EDragAndDropType cargo_type, void* cargo_data); - - // - // LLView functionality - virtual BOOL handleDragAndDrop(S32 x, S32 y, MASK mask, BOOL drop, - EDragAndDropType cargo_type, - void* cargo_data, - EAcceptance* accept, - std::string& tooltip_msg); -protected: - void (*mDownCallback)(LLViewerInventoryItem*); -}; - class LLPrefsAdvanced : public LLPanel { public: @@ -70,11 +51,10 @@ private: static void onCommitCheckBox(LLUICtrl* ctrl, void* user_data); static void onClickResetPrefs(void* user_data); + static void onClickCommandLine(void* data); static bool callbackReset(const LLSD& notification, const LLSD& response, LLPrefsAdvanced *self); - static void onCommitApplyControl(LLUICtrl* caller, void* user_data); - static void onSpellAdd(void* data); static void onSpellRemove(void* data); static void onSpellGetMore(void* data); diff --git a/linden/indra/newview/skins/default/xui/en-us/floater_command_line.xml b/linden/indra/newview/skins/default/xui/en-us/floater_command_line.xml new file mode 100644 index 0000000..35f47b5 --- /dev/null +++ b/linden/indra/newview/skins/default/xui/en-us/floater_command_line.xml @@ -0,0 +1,108 @@ + + + Teleport within sim (usage: cmd x y z) + + Teleport to ground (usage: cmd) + + Teleport to altitude (usage: cmd z) + + Teleport home (usage: cmd) + + Rez a platform (usage: cmd 0 - 30) + + + Teleport to sim x (usage: cmd simname) + + + Calc. expressions (usage: cmd SIN(2+2)) + + Add autocorrect word(cmd list|bad|good) + + + Change Draw Distance (usage: cmd meters) + + Teleport to cam position (usage: cmd) + + Get avatar name from key (usage: cmd key) + + Offer teleport to avatar (usage: cmd key) + + Teleport to avatar (usage: cmd name) + + Turn AO on/off (usage: cmd on/off) + + Clear the chat history (usage: cmd) + + Set the media url (usage: cmd url type) + + Set the music stream url (usage: cmd url) + +