diff options
| -rw-r--r-- | indra/llplugin/llpluginprocesschild.cpp | 10 | ||||
| -rw-r--r-- | indra/newview/llfolderview.cpp | 4 | ||||
| -rw-r--r-- | indra/newview/llinventorybridge.cpp | 7 | ||||
| -rw-r--r-- | indra/newview/llinventorypanel.cpp | 21 | ||||
| -rw-r--r-- | indra/newview/llinventorypanel.h | 2 | ||||
| -rw-r--r-- | indra/newview/llpaneloutfitsinventory.cpp | 6 | ||||
| -rw-r--r-- | indra/newview/llsidepanelappearance.cpp | 2 | ||||
| -rw-r--r-- | indra/newview/skins/default/xui/en/panel_outfits_inventory.xml | 4 | 
8 files changed, 36 insertions, 20 deletions
diff --git a/indra/llplugin/llpluginprocesschild.cpp b/indra/llplugin/llpluginprocesschild.cpp index ccf6dab942..07fc82c770 100644 --- a/indra/llplugin/llpluginprocesschild.cpp +++ b/indra/llplugin/llpluginprocesschild.cpp @@ -54,8 +54,14 @@ LLPluginProcessChild::~LLPluginProcessChild()  	if(mInstance != NULL)  	{  		sendMessageToPlugin(LLPluginMessage("base", "cleanup")); -		delete mInstance; -		mInstance = NULL; + +		// IMPORTANT: under some (unknown) circumstances the apr_dso_unload() triggered when mInstance is deleted  +		// appears to fail and lock up which means that a given instance of the slplugin process never exits.  +		// This is bad, especially when users try to update their version of SL - it fails because the slplugin  +		// process as well as a bunch of plugin specific files are locked and cannot be overwritten. +		exit( 0 ); +		//delete mInstance; +		//mInstance = NULL;  	}  } diff --git a/indra/newview/llfolderview.cpp b/indra/newview/llfolderview.cpp index 112b23d2df..41f4d1a663 100644 --- a/indra/newview/llfolderview.cpp +++ b/indra/newview/llfolderview.cpp @@ -569,6 +569,8 @@ LLFolderViewItem* LLFolderView::getCurSelectedItem( void )  BOOL LLFolderView::setSelection(LLFolderViewItem* selection, BOOL openitem,  								BOOL take_keyboard_focus)  { +	mSignalSelectCallback = take_keyboard_focus ? SIGNAL_KEYBOARD_FOCUS : SIGNAL_NO_KEYBOARD_FOCUS; +  	if( selection == this )  	{  		return FALSE; @@ -596,8 +598,6 @@ BOOL LLFolderView::setSelection(LLFolderViewItem* selection, BOOL openitem,  	llassert(mSelectedItems.size() <= 1); -	mSignalSelectCallback = take_keyboard_focus ? SIGNAL_KEYBOARD_FOCUS : SIGNAL_NO_KEYBOARD_FOCUS; -  	return rv;  } diff --git a/indra/newview/llinventorybridge.cpp b/indra/newview/llinventorybridge.cpp index d70221b22a..4c868baa92 100644 --- a/indra/newview/llinventorybridge.cpp +++ b/indra/newview/llinventorybridge.cpp @@ -2614,6 +2614,13 @@ void LLFolderBridge::buildContextMenu(LLMenuGL& menu, U32 flags)  			{  				mItems.push_back(std::string("Rename"));  				mItems.push_back(std::string("Delete")); + +				// EXT-4030: disallow deletion of currently worn outfit +				const LLViewerInventoryItem *base_outfit_link = LLAppearanceManager::instance().getBaseOutfitLink(); +				if (base_outfit_link && (cat == base_outfit_link->getLinkedCategory())) +				{ +					mDisabledItems.push_back(std::string("Delete")); +				}  			}  		} diff --git a/indra/newview/llinventorypanel.cpp b/indra/newview/llinventorypanel.cpp index 164e72e621..b363e917d7 100644 --- a/indra/newview/llinventorypanel.cpp +++ b/indra/newview/llinventorypanel.cpp @@ -433,11 +433,10 @@ void LLInventoryPanel::initializeViews()  	{  		mStartFolderID = (preferred_type != LLFolderType::FT_NONE ? gInventory.findCategoryUUIDForType(preferred_type) : LLUUID::null);  	} -	llinfos << this << " Generating views for start folder " << mStartFolderString << llendl;  	rebuildViewsFor(mStartFolderID);  	mViewsInitialized = true; -	defaultOpenInventory(); +	openStartFolderOrMyInventory();  }  void LLInventoryPanel::rebuildViewsFor(const LLUUID& id) @@ -575,7 +574,7 @@ void LLInventoryPanel::buildNewViews(const LLUUID& id)  }  // bit of a hack to make sure the inventory is open. -void LLInventoryPanel::defaultOpenInventory() +void LLInventoryPanel::openStartFolderOrMyInventory()  {  	if (mStartFolderString != "")  	{ @@ -583,13 +582,17 @@ void LLInventoryPanel::defaultOpenInventory()  	}  	else  	{ -		// Get the first child (it should be "My Inventory") and -		// open it up by name (just to make sure the first child is actually a folder). -		LLView* first_child = mFolders->getFirstChild(); -		if (first_child) +		// Find My Inventory folder and open it up by name +		for (LLView *child = mFolders->getFirstChild(); child; child = mFolders->findNextSibling(child))  		{ -			const std::string& first_child_name = first_child->getName(); -			mFolders->openFolder(first_child_name); +			LLFolderViewFolder *fchild = dynamic_cast<LLFolderViewFolder*>(child); +			if (fchild && fchild->getListener() && +				(fchild->getListener()->getUUID() == gInventory.getRootFolderID())) +			{ +				const std::string& child_name = child->getName(); +				mFolders->openFolder(child_name); +				break; +			}  		}  	}  } diff --git a/indra/newview/llinventorypanel.h b/indra/newview/llinventorypanel.h index 4f7f0a79f6..09533b52f1 100644 --- a/indra/newview/llinventorypanel.h +++ b/indra/newview/llinventorypanel.h @@ -167,7 +167,7 @@ public:  	static LLInventoryPanel *getActiveInventoryPanel(BOOL auto_open = TRUE);  protected: -	void defaultOpenInventory(); // open the first level of inventory +	void openStartFolderOrMyInventory(); // open the first level of inventory  	LLInventoryModel*			mInventory;  	LLInventoryObserver*		mInventoryObserver; diff --git a/indra/newview/llpaneloutfitsinventory.cpp b/indra/newview/llpaneloutfitsinventory.cpp index 29fa4b319c..a1c12412b5 100644 --- a/indra/newview/llpaneloutfitsinventory.cpp +++ b/indra/newview/llpaneloutfitsinventory.cpp @@ -415,7 +415,7 @@ BOOL LLPanelOutfitsInventory::isActionEnabled(const LLSD& userdata)  	if (command_name == "wear" ||  		command_name == "make_outfit")  	{ -		const BOOL is_my_outfits = (mActivePanel->getName() == "outfitslist_accordionpanel"); +		const BOOL is_my_outfits = (mActivePanel->getName() == "outfitslist_tab");  		if (!is_my_outfits)  		{  			return FALSE; @@ -468,11 +468,11 @@ void LLPanelOutfitsInventory::initTabPanels()  {  	mTabPanels.resize(2); -	LLInventoryPanel *cof_panel = getChild<LLInventoryPanel>("cof_accordionpanel"); +	LLInventoryPanel *cof_panel = getChild<LLInventoryPanel>("cof_tab");  	cof_panel->setShowFolderState(LLInventoryFilter::SHOW_NON_EMPTY_FOLDERS);  	mTabPanels[0] = cof_panel; -	LLInventoryPanel *myoutfits_panel = getChild<LLInventoryPanel>("outfitslist_accordionpanel"); +	LLInventoryPanel *myoutfits_panel = getChild<LLInventoryPanel>("outfitslist_tab");  	myoutfits_panel->setFilterTypes(1LL << LLFolderType::FT_OUTFIT, LLInventoryFilter::FILTERTYPE_CATEGORY);  	myoutfits_panel->setShowFolderState(LLInventoryFilter::SHOW_NON_EMPTY_FOLDERS);  	mTabPanels[1] = myoutfits_panel; diff --git a/indra/newview/llsidepanelappearance.cpp b/indra/newview/llsidepanelappearance.cpp index 0aefebce10..d870009e4f 100644 --- a/indra/newview/llsidepanelappearance.cpp +++ b/indra/newview/llsidepanelappearance.cpp @@ -213,7 +213,7 @@ void LLSidepanelAppearance::onOpenOutfitButtonClicked()  	if (tab_outfits)  	{  		tab_outfits->changeOpenClose(FALSE); -		LLInventoryPanel *inventory_panel = tab_outfits->findChild<LLInventoryPanel>("outfitslist_accordionpanel"); +		LLInventoryPanel *inventory_panel = tab_outfits->findChild<LLInventoryPanel>("outfitslist_tab");  		if (inventory_panel)  		{  			LLFolderView *folder = inventory_panel->getRootFolder(); diff --git a/indra/newview/skins/default/xui/en/panel_outfits_inventory.xml b/indra/newview/skins/default/xui/en/panel_outfits_inventory.xml index 7e512f9594..a65bddd1db 100644 --- a/indra/newview/skins/default/xui/en/panel_outfits_inventory.xml +++ b/indra/newview/skins/default/xui/en/panel_outfits_inventory.xml @@ -31,7 +31,7 @@          left="0"          top="0"          mouse_opaque="true" -        name="cof_accordionpanel" +        name="cof_tab"          start_folder="Current Outfit" />           <inventory_panel             label="MY OUTFITS" @@ -44,7 +44,7 @@             height="500"             width="290"             mouse_opaque="true" -           name="outfitslist_accordionpanel" +           name="outfitslist_tab"             start_folder="My Outfits" />      </tab_container>  	<panel  | 
