diff options
Diffstat (limited to 'linden/indra/newview/llinventoryview.cpp')
-rw-r--r-- | linden/indra/newview/llinventoryview.cpp | 57 |
1 files changed, 17 insertions, 40 deletions
diff --git a/linden/indra/newview/llinventoryview.cpp b/linden/indra/newview/llinventoryview.cpp index 9eb33ee..afeb3be 100644 --- a/linden/indra/newview/llinventoryview.cpp +++ b/linden/indra/newview/llinventoryview.cpp | |||
@@ -373,19 +373,15 @@ void LLInventoryViewFinder::selectNoTypes(void* user_data) | |||
373 | ///---------------------------------------------------------------------------- | 373 | ///---------------------------------------------------------------------------- |
374 | /// LLInventoryView | 374 | /// LLInventoryView |
375 | ///---------------------------------------------------------------------------- | 375 | ///---------------------------------------------------------------------------- |
376 | class LLSaveFolderState : public LLFolderViewFunctor | 376 | void LLSaveFolderState::setApply(BOOL apply) |
377 | { | 377 | { |
378 | public: | 378 | mApply = apply; |
379 | LLSaveFolderState() : mApply(FALSE) {} | 379 | // before generating new list of open folders, clear the old one |
380 | virtual ~LLSaveFolderState() {} | 380 | if(!apply) |
381 | virtual void doFolder(LLFolderViewFolder* folder); | 381 | { |
382 | virtual void doItem(LLFolderViewItem* item) {} | 382 | clearOpenFolders(); |
383 | void setApply(BOOL apply) { mApply = apply; } | 383 | } |
384 | void clearOpenFolders() { mOpenFolders.clear(); } | 384 | } |
385 | protected: | ||
386 | std::set<LLUUID> mOpenFolders; | ||
387 | BOOL mApply; | ||
388 | }; | ||
389 | 385 | ||
390 | void LLSaveFolderState::doFolder(LLFolderViewFolder* folder) | 386 | void LLSaveFolderState::doFolder(LLFolderViewFolder* folder) |
391 | { | 387 | { |
@@ -512,17 +508,6 @@ LLInventoryView::~LLInventoryView( void ) | |||
512 | 508 | ||
513 | void LLInventoryView::draw() | 509 | void LLInventoryView::draw() |
514 | { | 510 | { |
515 | if (mActivePanel && mActivePanel->getNeedsAutoSelect()) | ||
516 | { | ||
517 | LLOpenFilteredFolders opener; | ||
518 | mActivePanel->getRootFolder()->applyFunctorRecursively(opener); | ||
519 | // select first filtered item | ||
520 | LLSelectFirstFilteredItem filter; | ||
521 | mActivePanel->getRootFolder()->applyFunctorRecursively(filter); | ||
522 | mActivePanel->getRootFolder()->scrollToShowSelection(); | ||
523 | mActivePanel->setNeedsAutoSelect(FALSE); | ||
524 | } | ||
525 | |||
526 | if (LLInventoryModel::isEverythingFetched()) | 511 | if (LLInventoryModel::isEverythingFetched()) |
527 | { | 512 | { |
528 | LLLocale locale(LLLocale::USER_LOCALE); | 513 | LLLocale locale(LLLocale::USER_LOCALE); |
@@ -590,15 +575,6 @@ void LLSelectFirstFilteredItem::doFolder(LLFolderViewFolder* folder) | |||
590 | } | 575 | } |
591 | } | 576 | } |
592 | 577 | ||
593 | class LLOpenFoldersWithSelection : public LLFolderViewFunctor | ||
594 | { | ||
595 | public: | ||
596 | LLOpenFoldersWithSelection() {} | ||
597 | virtual ~LLOpenFoldersWithSelection() {} | ||
598 | virtual void doFolder(LLFolderViewFolder* folder); | ||
599 | virtual void doItem(LLFolderViewItem* item); | ||
600 | }; | ||
601 | |||
602 | void LLOpenFoldersWithSelection::doItem(LLFolderViewItem *item) | 578 | void LLOpenFoldersWithSelection::doItem(LLFolderViewItem *item) |
603 | { | 579 | { |
604 | if (item->getParentFolder() && item->isSelected()) | 580 | if (item->getParentFolder() && item->isSelected()) |
@@ -728,7 +704,7 @@ LLInventoryView* LLInventoryView::showAgentInventory(BOOL take_keyboard_focus) | |||
728 | { | 704 | { |
729 | // Make sure it's in front and it makes a noise | 705 | // Make sure it's in front and it makes a noise |
730 | iv->setTitle("Inventory"); | 706 | iv->setTitle("Inventory"); |
731 | iv->open(); | 707 | iv->open(); /*Flawfinder: ignore*/ |
732 | } | 708 | } |
733 | //if (take_keyboard_focus) | 709 | //if (take_keyboard_focus) |
734 | //{ | 710 | //{ |
@@ -813,7 +789,7 @@ void LLInventoryView::toggleFindOptions() | |||
813 | LLRect(mRect.mLeft - INV_FINDER_WIDTH, mRect.mTop, mRect.mLeft, mRect.mTop - INV_FINDER_HEIGHT), | 789 | LLRect(mRect.mLeft - INV_FINDER_WIDTH, mRect.mTop, mRect.mLeft, mRect.mTop - INV_FINDER_HEIGHT), |
814 | this); | 790 | this); |
815 | mFinderHandle = finder->getHandle(); | 791 | mFinderHandle = finder->getHandle(); |
816 | finder->open(); | 792 | finder->open(); /*Flawfinder: ignore*/ |
817 | addDependentFloater(mFinderHandle); | 793 | addDependentFloater(mFinderHandle); |
818 | 794 | ||
819 | // start background fetch of folders | 795 | // start background fetch of folders |
@@ -894,7 +870,6 @@ void LLInventoryView::onSearchEdit(const LLString& search_string, void* user_dat | |||
894 | // save current folder open state if no filter currently applied | 870 | // save current folder open state if no filter currently applied |
895 | if (!self->mActivePanel->getRootFolder()->isFilterActive()) | 871 | if (!self->mActivePanel->getRootFolder()->isFilterActive()) |
896 | { | 872 | { |
897 | self->mSavedFolderState->clearOpenFolders(); | ||
898 | self->mSavedFolderState->setApply(FALSE); | 873 | self->mSavedFolderState->setApply(FALSE); |
899 | self->mActivePanel->getRootFolder()->applyFunctorRecursively(*self->mSavedFolderState); | 874 | self->mActivePanel->getRootFolder()->applyFunctorRecursively(*self->mSavedFolderState); |
900 | } | 875 | } |
@@ -1107,8 +1082,7 @@ LLInventoryPanel::LLInventoryPanel(const LLString& name, | |||
1107 | mScroller(NULL), | 1082 | mScroller(NULL), |
1108 | mAllowMultiSelect(allow_multi_select), | 1083 | mAllowMultiSelect(allow_multi_select), |
1109 | mSortOrderSetting(sort_order_setting), | 1084 | mSortOrderSetting(sort_order_setting), |
1110 | mSearchFunction(search), | 1085 | mSearchFunction(search) |
1111 | mNeedsAutoSelect(FALSE) | ||
1112 | { | 1086 | { |
1113 | } | 1087 | } |
1114 | 1088 | ||
@@ -1258,8 +1232,10 @@ void LLInventoryPanel::modelChanged(U32 mask) | |||
1258 | { | 1232 | { |
1259 | LLFastTimer t2(LLFastTimer::FTM_REFRESH); | 1233 | LLFastTimer t2(LLFastTimer::FTM_REFRESH); |
1260 | 1234 | ||
1235 | bool handled = false; | ||
1261 | if(mask & LLInventoryObserver::LABEL) | 1236 | if(mask & LLInventoryObserver::LABEL) |
1262 | { | 1237 | { |
1238 | handled = true; | ||
1263 | // label change - empty out the display name for each object | 1239 | // label change - empty out the display name for each object |
1264 | // in this change set. | 1240 | // in this change set. |
1265 | const std::set<LLUUID>& changed_items = gInventory.getChangedIDs(); | 1241 | const std::set<LLUUID>& changed_items = gInventory.getChangedIDs(); |
@@ -1282,11 +1258,11 @@ void LLInventoryPanel::modelChanged(U32 mask) | |||
1282 | } | 1258 | } |
1283 | } | 1259 | } |
1284 | } | 1260 | } |
1285 | else if((mask & (LLInventoryObserver::STRUCTURE | 1261 | if((mask & (LLInventoryObserver::STRUCTURE |
1286 | | LLInventoryObserver::ADD | 1262 | | LLInventoryObserver::ADD |
1287 | | LLInventoryObserver::REMOVE)) != 0) | 1263 | | LLInventoryObserver::REMOVE)) != 0) |
1288 | { | 1264 | { |
1289 | 1265 | handled = true; | |
1290 | // Record which folders are open by uuid. | 1266 | // Record which folders are open by uuid. |
1291 | LLInventoryModel* model = getModel(); | 1267 | LLInventoryModel* model = getModel(); |
1292 | if (model) | 1268 | if (model) |
@@ -1347,7 +1323,8 @@ void LLInventoryPanel::modelChanged(U32 mask) | |||
1347 | } | 1323 | } |
1348 | } | 1324 | } |
1349 | } | 1325 | } |
1350 | else | 1326 | |
1327 | if (!handled) | ||
1351 | { | 1328 | { |
1352 | // it's a small change that only requires a refresh. | 1329 | // it's a small change that only requires a refresh. |
1353 | // *TODO: figure out a more efficient way to do the refresh | 1330 | // *TODO: figure out a more efficient way to do the refresh |