aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llpreviewscript.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llpreviewscript.cpp')
-rw-r--r--linden/indra/newview/llpreviewscript.cpp84
1 files changed, 53 insertions, 31 deletions
diff --git a/linden/indra/newview/llpreviewscript.cpp b/linden/indra/newview/llpreviewscript.cpp
index cce672b..7eac589 100644
--- a/linden/indra/newview/llpreviewscript.cpp
+++ b/linden/indra/newview/llpreviewscript.cpp
@@ -2,6 +2,8 @@
2 * @file llpreviewscript.cpp 2 * @file llpreviewscript.cpp
3 * @brief LLPreviewScript class implementation 3 * @brief LLPreviewScript class implementation
4 * 4 *
5 * $LicenseInfo:firstyear=2002&license=viewergpl$
6 *
5 * Copyright (c) 2002-2007, Linden Research, Inc. 7 * Copyright (c) 2002-2007, Linden Research, Inc.
6 * 8 *
7 * Second Life Viewer Source Code 9 * Second Life Viewer Source Code
@@ -24,6 +26,7 @@
24 * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO 26 * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
25 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, 27 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
26 * COMPLETENESS OR PERFORMANCE. 28 * COMPLETENESS OR PERFORMANCE.
29 * $/LicenseInfo$
27 */ 30 */
28 31
29#include "llviewerprecompiledheaders.h" 32#include "llviewerprecompiledheaders.h"
@@ -100,11 +103,8 @@ const char HELLO_LSL[] =
100 "}\n"; 103 "}\n";
101const char HELP_LSL[] = "lsl_guide.html"; 104const char HELP_LSL[] = "lsl_guide.html";
102 105
103const char DEFAULT_SCRIPT_NAME[] = "New Script"; 106const char DEFAULT_SCRIPT_NAME[] = "New Script"; // *TODO:Translate?
104const char DEFAULT_SCRIPT_DESC[] = "(No Description)"; 107const char DEFAULT_SCRIPT_DESC[] = "(No Description)"; // *TODO:Translate?
105
106const char ENABLED_RUNNING_CHECKBOX_LABEL[] = "Running";
107const char DISABLED_RUNNING_CHECKBOX_LABEL[] = "Public Objects cannot run scripts";
108 108
109// Description and header information 109// Description and header information
110 110
@@ -318,7 +318,6 @@ LLScriptEdCore::LLScriptEdCore(
318 mFunctions = LLUICtrlFactory::getComboBoxByName(this, "Insert..."); 318 mFunctions = LLUICtrlFactory::getComboBoxByName(this, "Insert...");
319 319
320 childSetCommitCallback("Insert...", &LLScriptEdCore::onBtnInsertFunction, this); 320 childSetCommitCallback("Insert...", &LLScriptEdCore::onBtnInsertFunction, this);
321 mFunctions->setLabel("Insert...");
322 321
323 mEditor = LLViewerUICtrlFactory::getViewerTextEditorByName(this, "Script Editor"); 322 mEditor = LLViewerUICtrlFactory::getViewerTextEditorByName(this, "Script Editor");
324 mEditor->setReadOnlyBgColor(gColors.getColor( "ScriptBgReadOnlyColor" ) ); 323 mEditor->setReadOnlyBgColor(gColors.getColor( "ScriptBgReadOnlyColor" ) );
@@ -453,13 +452,13 @@ void LLScriptEdCore::draw()
453 S32 line = 0; 452 S32 line = 0;
454 S32 column = 0; 453 S32 column = 0;
455 mEditor->getCurrentLineAndColumn( &line, &column, FALSE ); // don't include wordwrap 454 mEditor->getCurrentLineAndColumn( &line, &column, FALSE ); // don't include wordwrap
456 char cursor_pos[STD_STRING_BUF_SIZE]; /*Flawfinder: ignore*/ 455 std::string cursor_pos;
457 snprintf( cursor_pos, STD_STRING_BUF_SIZE, "Line %d, Column %d", line, column ); /* Flawfinder: ignore */ 456 cursor_pos = llformat("Line %d, Column %d", line, column );
458 childSetText("line_col", cursor_pos); 457 childSetText("line_col", cursor_pos);
459 } 458 }
460 else 459 else
461 { 460 {
462 childSetText("line_col", ""); 461 childSetText("line_col", LLString::null);
463 } 462 }
464 463
465 updateDynamicHelp(); 464 updateDynamicHelp();
@@ -982,7 +981,7 @@ void LLScriptEdCore::handleReloadFromServerDialog( S32 option, void* userdata )
982 case 0: // "Yes" 981 case 0: // "Yes"
983 if( self->mLoadCallback ) 982 if( self->mLoadCallback )
984 { 983 {
985 self->mEditor->setText( "Loading..." ); 984 self->mEditor->setText( self->childGetText("loading") );
986 self->mLoadCallback( self->mUserdata ); 985 self->mLoadCallback( self->mUserdata );
987 } 986 }
988 break; 987 break;
@@ -1196,7 +1195,7 @@ void LLPreviewLSL::loadAsset()
1196 } 1195 }
1197 else 1196 else
1198 { 1197 {
1199 mScriptEd->mEditor->setText("You are not allowed to view this script."); 1198 mScriptEd->mEditor->setText(mScriptEd->childGetText("can_not_view"));
1200 mScriptEd->mEditor->makePristine(); 1199 mScriptEd->mEditor->makePristine();
1201 mScriptEd->mEditor->setEnabled(FALSE); 1200 mScriptEd->mEditor->setEnabled(FALSE);
1202 mScriptEd->mFunctions->setEnabled(FALSE); 1201 mScriptEd->mFunctions->setEnabled(FALSE);
@@ -1207,7 +1206,7 @@ void LLPreviewLSL::loadAsset()
1207 } 1206 }
1208 else 1207 else
1209 { 1208 {
1210 mScriptEd->mEditor->setText(HELLO_LSL); 1209 mScriptEd->mEditor->setText(LLString(HELLO_LSL));
1211 mAssetStatus = PREVIEW_ASSET_LOADED; 1210 mAssetStatus = PREVIEW_ASSET_LOADED;
1212 } 1211 }
1213} 1212}
@@ -1514,7 +1513,7 @@ void LLPreviewLSL::onLoadComplete( LLVFS *vfs, const LLUUID& asset_uuid, LLAsset
1514 1513
1515 // put a EOS at the end 1514 // put a EOS at the end
1516 buffer[file_length] = 0; 1515 buffer[file_length] = 0;
1517 preview->mScriptEd->mEditor->setText(buffer); 1516 preview->mScriptEd->mEditor->setText(LLStringExplicit(buffer));
1518 preview->mScriptEd->mEditor->makePristine(); 1517 preview->mScriptEd->mEditor->makePristine();
1519 delete [] buffer; 1518 delete [] buffer;
1520 LLInventoryItem* item = gInventory.getItem(*item_uuid); 1519 LLInventoryItem* item = gInventory.getItem(*item_uuid);
@@ -1663,7 +1662,6 @@ LLLiveLSLEditor::LLLiveLSLEditor(const std::string& name,
1663 1662
1664 1663
1665 setTitle(title); 1664 setTitle(title);
1666
1667} 1665}
1668 1666
1669LLLiveLSLEditor::~LLLiveLSLEditor() 1667LLLiveLSLEditor::~LLLiveLSLEditor()
@@ -1715,9 +1713,8 @@ void LLLiveLSLEditor::loadAsset(BOOL is_new)
1715 { 1713 {
1716 // HACK! we "know" that mItemID refers to a LLViewerInventoryItem... 1714 // HACK! we "know" that mItemID refers to a LLViewerInventoryItem...
1717 LLViewerInventoryItem* item = (LLViewerInventoryItem*)object->getInventoryObject(mItemID); 1715 LLViewerInventoryItem* item = (LLViewerInventoryItem*)object->getInventoryObject(mItemID);
1718 if(item 1716 if(item
1719 && (gAgent.allowOperation(PERM_COPY, item->getPermissions(), 1717 && (gAgent.allowOperation(PERM_COPY, item->getPermissions(), GP_OBJECT_MANIPULATE)
1720 GP_OBJECT_MANIPULATE)
1721 || gAgent.isGodlike())) 1718 || gAgent.isGodlike()))
1722 { 1719 {
1723 mItem = new LLViewerInventoryItem(item); 1720 mItem = new LLViewerInventoryItem(item);
@@ -1726,13 +1723,11 @@ void LLLiveLSLEditor::loadAsset(BOOL is_new)
1726 1723
1727 if(!gAgent.isGodlike() 1724 if(!gAgent.isGodlike()
1728 && (item 1725 && (item
1729 && (!gAgent.allowOperation(PERM_COPY, item->getPermissions(), 1726 && (!gAgent.allowOperation(PERM_COPY, item->getPermissions(), GP_OBJECT_MANIPULATE)
1730 GP_OBJECT_MANIPULATE) 1727 || !gAgent.allowOperation(PERM_MODIFY, item->getPermissions(), GP_OBJECT_MANIPULATE))))
1731 || !gAgent.allowOperation(PERM_MODIFY,
1732 item->getPermissions(), GP_OBJECT_MANIPULATE))))
1733
1734 { 1728 {
1735 mScriptEd->mEditor->setText("You are not allowed to view this script."); 1729 mItem = new LLViewerInventoryItem(item);
1730 mScriptEd->mEditor->setText(childGetText("not_allowed"));
1736 mScriptEd->mEditor->makePristine(); 1731 mScriptEd->mEditor->makePristine();
1737 mScriptEd->mEditor->setEnabled(FALSE); 1732 mScriptEd->mEditor->setEnabled(FALSE);
1738 mAssetStatus = PREVIEW_ASSET_LOADED; 1733 mAssetStatus = PREVIEW_ASSET_LOADED;
@@ -1763,7 +1758,7 @@ void LLLiveLSLEditor::loadAsset(BOOL is_new)
1763 } 1758 }
1764 else 1759 else
1765 { 1760 {
1766 mScriptEd->mEditor->setText(""); 1761 mScriptEd->mEditor->setText(LLString::null);
1767 mScriptEd->mEditor->makePristine(); 1762 mScriptEd->mEditor->makePristine();
1768 mAssetStatus = PREVIEW_ASSET_LOADED; 1763 mAssetStatus = PREVIEW_ASSET_LOADED;
1769 } 1764 }
@@ -1789,11 +1784,25 @@ void LLLiveLSLEditor::loadAsset(BOOL is_new)
1789 gMessageSystem->sendReliable(host); 1784 gMessageSystem->sendReliable(host);
1790 */ 1785 */
1791 } 1786 }
1787
1788 // Initialization of the asset failed. Probably the result
1789 // of a bug somewhere else. Set up this editor in a no-go mode.
1790 if(mItem.isNull())
1791 {
1792 // Set the inventory item to an incomplete item.
1793 // This may be better than having a accessible null pointer around,
1794 // though this newly allocated object will most likely be replaced.
1795 mItem = new LLViewerInventoryItem();
1796 mScriptEd->mEditor->setText(LLString::null);
1797 mScriptEd->mEditor->makePristine();
1798 mScriptEd->mEditor->setEnabled(FALSE);
1799 mAssetStatus = PREVIEW_ASSET_LOADED;
1800 }
1792 } 1801 }
1793 else 1802 else
1794 { 1803 {
1795 mScriptEd->mEditor->setText(HELLO_LSL); 1804 mScriptEd->mEditor->setText(LLString(HELLO_LSL));
1796 //mScriptEd->mEditor->setText(""); 1805 //mScriptEd->mEditor->setText(LLString::null);
1797 //mScriptEd->mEditor->makePristine(); 1806 //mScriptEd->mEditor->makePristine();
1798 LLPermissions perm; 1807 LLPermissions perm;
1799 perm.init(gAgent.getID(), gAgent.getID(), LLUUID::null, gAgent.getGroupID()); 1808 perm.init(gAgent.getID(), gAgent.getID(), LLUUID::null, gAgent.getGroupID());
@@ -1880,7 +1889,7 @@ void LLLiveLSLEditor::loadScriptText(const char* filename)
1880 } 1889 }
1881 buffer[nread] = '\0'; 1890 buffer[nread] = '\0';
1882 fclose(file); 1891 fclose(file);
1883 mScriptEd->mEditor->setText(buffer); 1892 mScriptEd->mEditor->setText(LLStringExplicit(buffer));
1884 mScriptEd->mEditor->makePristine(); 1893 mScriptEd->mEditor->makePristine();
1885 delete[] buffer; 1894 delete[] buffer;
1886 } 1895 }
@@ -1905,7 +1914,7 @@ void LLLiveLSLEditor::loadScriptText(LLVFS *vfs, const LLUUID &uuid, LLAssetType
1905 1914
1906 buffer[file_length] = '\0'; 1915 buffer[file_length] = '\0';
1907 1916
1908 mScriptEd->mEditor->setText(buffer); 1917 mScriptEd->mEditor->setText(LLStringExplicit(buffer));
1909 mScriptEd->mEditor->makePristine(); 1918 mScriptEd->mEditor->makePristine();
1910 delete[] buffer; 1919 delete[] buffer;
1911 1920
@@ -1972,12 +1981,12 @@ void LLLiveLSLEditor::draw()
1972 { 1981 {
1973 if(object->permAnyOwner()) 1982 if(object->permAnyOwner())
1974 { 1983 {
1975 runningCheckbox->setLabel(ENABLED_RUNNING_CHECKBOX_LABEL); 1984 runningCheckbox->setLabel(childGetText("script_running"));
1976 runningCheckbox->setEnabled(TRUE); 1985 runningCheckbox->setEnabled(TRUE);
1977 } 1986 }
1978 else 1987 else
1979 { 1988 {
1980 runningCheckbox->setLabel(DISABLED_RUNNING_CHECKBOX_LABEL); 1989 runningCheckbox->setLabel(childGetText("public_objects_can_not_run"));
1981 runningCheckbox->setEnabled(FALSE); 1990 runningCheckbox->setEnabled(FALSE);
1982 // *FIX: Set it to false so that the ui is correct for 1991 // *FIX: Set it to false so that the ui is correct for
1983 // a box that is released to public. It could be 1992 // a box that is released to public. It could be
@@ -2036,6 +2045,14 @@ void LLLiveLSLEditor::saveIfNeeded()
2036 return; 2045 return;
2037 } 2046 }
2038 2047
2048 if(mItem.isNull() || !mItem->isComplete())
2049 {
2050 // $NOTE: While the error message may not be exactly correct,
2051 // it's pretty close.
2052 gViewerWindow->alertXml("SaveScriptFailObjectNotFound");
2053 return;
2054 }
2055
2039 // get the latest info about it. We used to be losing the script 2056 // get the latest info about it. We used to be losing the script
2040 // name on save, because the viewer object version of the item, 2057 // name on save, because the viewer object version of the item,
2041 // and the editor version would get out of synch. Here's a good 2058 // and the editor version would get out of synch. Here's a good
@@ -2217,7 +2234,7 @@ void LLLiveLSLEditor::uploadAssetLegacy(const std::string& filename,
2217 2234
2218 // If we successfully saved it, then we should be able to check/uncheck the running box! 2235 // If we successfully saved it, then we should be able to check/uncheck the running box!
2219 LLCheckBoxCtrl* runningCheckbox = LLUICtrlFactory::getCheckBoxByName(this, "running"); 2236 LLCheckBoxCtrl* runningCheckbox = LLUICtrlFactory::getCheckBoxByName(this, "running");
2220 runningCheckbox->setLabel(ENABLED_RUNNING_CHECKBOX_LABEL); 2237 runningCheckbox->setLabel(childGetText("script_running"));
2221 runningCheckbox->setEnabled(TRUE); 2238 runningCheckbox->setEnabled(TRUE);
2222} 2239}
2223 2240
@@ -2299,6 +2316,11 @@ void LLLiveLSLEditor::onSaveBytecodeComplete(const LLUUID& asset_uuid, void* use
2299 delete data; 2316 delete data;
2300} 2317}
2301 2318
2319void LLLiveLSLEditor::open()
2320{
2321 LLFloater::open(); /*Flawfinder: ignore*/
2322}
2323
2302BOOL LLLiveLSLEditor::canClose() 2324BOOL LLLiveLSLEditor::canClose()
2303{ 2325{
2304 return (mScriptEd->canClose()); 2326 return (mScriptEd->canClose());