diff options
Diffstat (limited to 'linden/indra/llui/llfloater.cpp')
-rw-r--r-- | linden/indra/llui/llfloater.cpp | 21 |
1 files changed, 17 insertions, 4 deletions
diff --git a/linden/indra/llui/llfloater.cpp b/linden/indra/llui/llfloater.cpp index 12758b3..1613fd7 100644 --- a/linden/indra/llui/llfloater.cpp +++ b/linden/indra/llui/llfloater.cpp | |||
@@ -696,7 +696,13 @@ void LLFloater::translate(S32 x, S32 y) | |||
696 | 696 | ||
697 | BOOL LLFloater::canSnapTo(LLView* other_view) | 697 | BOOL LLFloater::canSnapTo(LLView* other_view) |
698 | { | 698 | { |
699 | if (other_view && other_view != getParent()) | 699 | if (NULL == other_view) |
700 | { | ||
701 | llwarns << "other_view is NULL" << llendl; | ||
702 | return FALSE; | ||
703 | } | ||
704 | |||
705 | if (other_view != getParent()) | ||
700 | { | 706 | { |
701 | LLFloater* other_floaterp = (LLFloater*)other_view; | 707 | LLFloater* other_floaterp = (LLFloater*)other_view; |
702 | 708 | ||
@@ -1933,7 +1939,11 @@ void LLFloaterView::bringToFront(LLFloater* child, BOOL give_focus) | |||
1933 | LLFloater* floaterp = (LLFloater*)(*view_it); | 1939 | LLFloater* floaterp = (LLFloater*)(*view_it); |
1934 | sendChildToFront(floaterp); | 1940 | sendChildToFront(floaterp); |
1935 | 1941 | ||
1936 | floaterp->setMinimized(FALSE); | 1942 | // always unminimize dependee, but allow dependents to stay minimized |
1943 | if (!floaterp->isDependent()) | ||
1944 | { | ||
1945 | floaterp->setMinimized(FALSE); | ||
1946 | } | ||
1937 | } | 1947 | } |
1938 | floaters_to_move.clear(); | 1948 | floaters_to_move.clear(); |
1939 | 1949 | ||
@@ -1945,7 +1955,9 @@ void LLFloaterView::bringToFront(LLFloater* child, BOOL give_focus) | |||
1945 | if (dependent) | 1955 | if (dependent) |
1946 | { | 1956 | { |
1947 | sendChildToFront(dependent); | 1957 | sendChildToFront(dependent); |
1948 | dependent->setMinimized(FALSE); | 1958 | //don't un-minimize dependent windows automatically |
1959 | // respect user's wishes | ||
1960 | //dependent->setMinimized(FALSE); | ||
1949 | } | 1961 | } |
1950 | ++dependent_it; | 1962 | ++dependent_it; |
1951 | } | 1963 | } |
@@ -2555,6 +2567,7 @@ void LLMultiFloater::addFloater(LLFloater* floaterp, BOOL select_added_floater, | |||
2555 | if (!mTabContainer) | 2567 | if (!mTabContainer) |
2556 | { | 2568 | { |
2557 | llerrs << "Tab Container used without having been initialized." << llendl; | 2569 | llerrs << "Tab Container used without having been initialized." << llendl; |
2570 | return; | ||
2558 | } | 2571 | } |
2559 | 2572 | ||
2560 | if (floaterp->getHost() == this) | 2573 | if (floaterp->getHost() == this) |
@@ -2718,7 +2731,7 @@ void LLMultiFloater::setVisible(BOOL visible) | |||
2718 | BOOL LLMultiFloater::handleKeyHere(KEY key, MASK mask, BOOL called_from_parent) | 2731 | BOOL LLMultiFloater::handleKeyHere(KEY key, MASK mask, BOOL called_from_parent) |
2719 | { | 2732 | { |
2720 | if (getEnabled() | 2733 | if (getEnabled() |
2721 | && mask == (MASK_CONTROL|MASK_SHIFT)) | 2734 | && mask == MASK_CONTROL) |
2722 | { | 2735 | { |
2723 | if (key == 'W') | 2736 | if (key == 'W') |
2724 | { | 2737 | { |