diff options
Diffstat (limited to 'linden/indra/llui')
31 files changed, 1501 insertions, 794 deletions
diff --git a/linden/indra/llui/llalertdialog.cpp b/linden/indra/llui/llalertdialog.cpp index 861bbc6..6523e44 100644 --- a/linden/indra/llui/llalertdialog.cpp +++ b/linden/indra/llui/llalertdialog.cpp | |||
@@ -218,7 +218,7 @@ bool LLAlertDialog::show() | |||
218 | } | 218 | } |
219 | startModal(); | 219 | startModal(); |
220 | gFloaterView->adjustToFitScreen(this, FALSE); | 220 | gFloaterView->adjustToFitScreen(this, FALSE); |
221 | open(); | 221 | open(); /* Flawfinder: ignore */ |
222 | setFocus(TRUE); | 222 | setFocus(TRUE); |
223 | if (mLineEditor) | 223 | if (mLineEditor) |
224 | { | 224 | { |
diff --git a/linden/indra/llui/llbutton.cpp b/linden/indra/llui/llbutton.cpp index 736bc59..41c2269 100644 --- a/linden/indra/llui/llbutton.cpp +++ b/linden/indra/llui/llbutton.cpp | |||
@@ -603,7 +603,7 @@ void LLButton::draw() | |||
603 | else | 603 | else |
604 | { | 604 | { |
605 | // no image | 605 | // no image |
606 | llalerts << "No image for button " << mName << llendl; | 606 | llwarns << "No image for button " << mName << llendl; |
607 | // draw it in pink so we can find it | 607 | // draw it in pink so we can find it |
608 | gl_rect_2d(0, mRect.getHeight(), mRect.getWidth(), 0, LLColor4::pink1, FALSE); | 608 | gl_rect_2d(0, mRect.getHeight(), mRect.getWidth(), 0, LLColor4::pink1, FALSE); |
609 | } | 609 | } |
diff --git a/linden/indra/llui/llcombobox.cpp b/linden/indra/llui/llcombobox.cpp index b19be9a..7c3755a 100644 --- a/linden/indra/llui/llcombobox.cpp +++ b/linden/indra/llui/llcombobox.cpp | |||
@@ -62,6 +62,7 @@ LLComboBox::LLComboBox( const LLString& name, const LLRect &rect, const LLString | |||
62 | mDrawButton(TRUE), | 62 | mDrawButton(TRUE), |
63 | mTextEntry(NULL), | 63 | mTextEntry(NULL), |
64 | mArrowImage(NULL), | 64 | mArrowImage(NULL), |
65 | mArrowImageWidth(8), | ||
65 | mAllowTextEntry(FALSE), | 66 | mAllowTextEntry(FALSE), |
66 | mMaxChars(20), | 67 | mMaxChars(20), |
67 | mTextEntryTentative(TRUE), | 68 | mTextEntryTentative(TRUE), |
@@ -118,6 +119,7 @@ LLComboBox::LLComboBox( const LLString& name, const LLRect &rect, const LLString | |||
118 | 119 | ||
119 | LLUUID arrow_image_id( LLUI::sAssetsGroup->getString("combobox_arrow.tga") ); | 120 | LLUUID arrow_image_id( LLUI::sAssetsGroup->getString("combobox_arrow.tga") ); |
120 | mArrowImage = LLUI::sImageProvider->getUIImageByID(arrow_image_id); | 121 | mArrowImage = LLUI::sImageProvider->getUIImageByID(arrow_image_id); |
122 | mArrowImageWidth = llmax(8,mArrowImage->getWidth()); // In case image hasn't loaded yet | ||
121 | } | 123 | } |
122 | 124 | ||
123 | 125 | ||
@@ -521,7 +523,7 @@ void LLComboBox::setButtonVisible(BOOL visible) | |||
521 | LLRect text_entry_rect(0, mRect.getHeight(), mRect.getWidth(), 0); | 523 | LLRect text_entry_rect(0, mRect.getHeight(), mRect.getWidth(), 0); |
522 | if (visible) | 524 | if (visible) |
523 | { | 525 | { |
524 | text_entry_rect.mRight -= mArrowImage->getWidth() + 2 * LLUI::sConfigGroup->getS32("DropShadowButton"); | 526 | text_entry_rect.mRight -= mArrowImageWidth + 2 * LLUI::sConfigGroup->getS32("DropShadowButton"); |
525 | } | 527 | } |
526 | //mTextEntry->setRect(text_entry_rect); | 528 | //mTextEntry->setRect(text_entry_rect); |
527 | mTextEntry->reshape(text_entry_rect.getWidth(), text_entry_rect.getHeight(), TRUE); | 529 | mTextEntry->reshape(text_entry_rect.getWidth(), text_entry_rect.getHeight(), TRUE); |
@@ -544,7 +546,7 @@ void LLComboBox::draw() | |||
544 | // Paste the graphic on the right edge | 546 | // Paste the graphic on the right edge |
545 | if (!mArrowImage.isNull()) | 547 | if (!mArrowImage.isNull()) |
546 | { | 548 | { |
547 | S32 left = mRect.getWidth() - mArrowImage->getWidth() - LLUI::sConfigGroup->getS32("DropShadowButton"); | 549 | S32 left = mRect.getWidth() - mArrowImageWidth - LLUI::sConfigGroup->getS32("DropShadowButton"); |
548 | 550 | ||
549 | gl_draw_image( left, 0, mArrowImage, | 551 | gl_draw_image( left, 0, mArrowImage, |
550 | LLColor4::white); | 552 | LLColor4::white); |
@@ -844,7 +846,7 @@ void LLComboBox::setAllowTextEntry(BOOL allow, S32 max_chars, BOOL set_tentative | |||
844 | if (allow && !mAllowTextEntry) | 846 | if (allow && !mAllowTextEntry) |
845 | { | 847 | { |
846 | S32 shadow_size = LLUI::sConfigGroup->getS32("DropShadowButton"); | 848 | S32 shadow_size = LLUI::sConfigGroup->getS32("DropShadowButton"); |
847 | mButton->setRect(LLRect( mRect.getWidth() - mArrowImage->getWidth() - 2 * shadow_size, | 849 | mButton->setRect(LLRect( mRect.getWidth() - mArrowImageWidth - 2 * shadow_size, |
848 | rect.mTop, rect.mRight, rect.mBottom)); | 850 | rect.mTop, rect.mRight, rect.mBottom)); |
849 | mButton->setTabStop(FALSE); | 851 | mButton->setTabStop(FALSE); |
850 | 852 | ||
@@ -854,7 +856,7 @@ void LLComboBox::setAllowTextEntry(BOOL allow, S32 max_chars, BOOL set_tentative | |||
854 | if (!mTextEntry) | 856 | if (!mTextEntry) |
855 | { | 857 | { |
856 | LLRect text_entry_rect(0, mRect.getHeight(), mRect.getWidth(), 0); | 858 | LLRect text_entry_rect(0, mRect.getHeight(), mRect.getWidth(), 0); |
857 | text_entry_rect.mRight -= mArrowImage->getWidth() + 2 * LLUI::sConfigGroup->getS32("DropShadowButton"); | 859 | text_entry_rect.mRight -= mArrowImageWidth + 2 * LLUI::sConfigGroup->getS32("DropShadowButton"); |
858 | mTextEntry = new LLLineEditor("combo_text_entry", | 860 | mTextEntry = new LLLineEditor("combo_text_entry", |
859 | text_entry_rect, | 861 | text_entry_rect, |
860 | "", | 862 | "", |
diff --git a/linden/indra/llui/llcombobox.h b/linden/indra/llui/llcombobox.h index b1dd468..5de9463 100644 --- a/linden/indra/llui/llcombobox.h +++ b/linden/indra/llui/llcombobox.h | |||
@@ -186,8 +186,9 @@ protected: | |||
186 | BOOL mDrawButton; | 186 | BOOL mDrawButton; |
187 | LLLineEditor* mTextEntry; | 187 | LLLineEditor* mTextEntry; |
188 | LLPointer<LLImageGL> mArrowImage; | 188 | LLPointer<LLImageGL> mArrowImage; |
189 | S32 mArrowImageWidth; | ||
189 | BOOL mAllowTextEntry; | 190 | BOOL mAllowTextEntry; |
190 | S32 mMaxChars; | 191 | S32 mMaxChars; |
191 | BOOL mTextEntryTentative; | 192 | BOOL mTextEntryTentative; |
192 | void (*mPrearrangeCallback)(LLUICtrl*,void*); | 193 | void (*mPrearrangeCallback)(LLUICtrl*,void*); |
193 | void (*mTextEntryCallback)(LLLineEditor*, void*); | 194 | void (*mTextEntryCallback)(LLLineEditor*, void*); |
diff --git a/linden/indra/llui/llctrlselectioninterface.cpp b/linden/indra/llui/llctrlselectioninterface.cpp index 5478d61..446eb63 100644 --- a/linden/indra/llui/llctrlselectioninterface.cpp +++ b/linden/indra/llui/llctrlselectioninterface.cpp | |||
@@ -1,8 +1,8 @@ | |||
1 | /** | 1 | /** |
2 | * @file llctrlselectioninterface.cpp | 2 | * @file llctrlselectioninterface.cpp |
3 | * @brief Programmatic selection of items in a list. | 3 | * @brief Programmatic selection of items in a list. |
4 | * | 4 | * |
5 | * Copyright (c) 2006-2007, Linden Research, Inc. | 5 | * Copyright (c) 2006-2007, Linden Research, Inc. |
6 | * | 6 | * |
7 | * The source code in this file ("Source Code") is provided by Linden Lab | 7 | * The source code in this file ("Source Code") is provided by Linden Lab |
8 | * to you under the terms of the GNU General Public License, version 2.0 | 8 | * to you under the terms of the GNU General Public License, version 2.0 |
@@ -22,42 +22,42 @@ | |||
22 | * | 22 | * |
23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | 23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO |
24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | 24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, |
25 | * COMPLETENESS OR PERFORMANCE. | 25 | * COMPLETENESS OR PERFORMANCE. |
26 | */ | 26 | */ |
27 | 27 | ||
28 | #include "llctrlselectioninterface.h" | 28 | #include "llctrlselectioninterface.h" |
29 | 29 | ||
30 | #include "llsd.h" | 30 | #include "llsd.h" |
31 | 31 | ||
32 | // virtual | 32 | // virtual |
33 | LLCtrlSelectionInterface::~LLCtrlSelectionInterface() | 33 | LLCtrlSelectionInterface::~LLCtrlSelectionInterface() |
34 | { } | 34 | { } |
35 | 35 | ||
36 | BOOL LLCtrlSelectionInterface::selectByValue(LLSD value) | 36 | BOOL LLCtrlSelectionInterface::selectByValue(LLSD value) |
37 | { | 37 | { |
38 | return setSelectedByValue(value, TRUE); | 38 | return setSelectedByValue(value, TRUE); |
39 | } | 39 | } |
40 | 40 | ||
41 | BOOL LLCtrlSelectionInterface::deselectByValue(LLSD value) | 41 | BOOL LLCtrlSelectionInterface::deselectByValue(LLSD value) |
42 | { | 42 | { |
43 | return setSelectedByValue(value, FALSE); | 43 | return setSelectedByValue(value, FALSE); |
44 | } | 44 | } |
45 | 45 | ||
46 | 46 | ||
47 | // virtual | 47 | // virtual |
48 | LLCtrlListInterface::~LLCtrlListInterface() | 48 | LLCtrlListInterface::~LLCtrlListInterface() |
49 | { } | 49 | { } |
50 | 50 | ||
51 | LLScrollListItem* LLCtrlListInterface::addSimpleElement(const LLString& value) | 51 | LLScrollListItem* LLCtrlListInterface::addSimpleElement(const LLString& value) |
52 | { | 52 | { |
53 | return addSimpleElement(value, ADD_BOTTOM, LLSD()); | 53 | return addSimpleElement(value, ADD_BOTTOM, LLSD()); |
54 | } | 54 | } |
55 | 55 | ||
56 | LLScrollListItem* LLCtrlListInterface::addSimpleElement(const LLString& value, EAddPosition pos) | 56 | LLScrollListItem* LLCtrlListInterface::addSimpleElement(const LLString& value, EAddPosition pos) |
57 | { | 57 | { |
58 | return addSimpleElement(value, pos, LLSD()); | 58 | return addSimpleElement(value, pos, LLSD()); |
59 | } | 59 | } |
60 | 60 | ||
61 | // virtual | 61 | // virtual |
62 | LLCtrlScrollInterface::~LLCtrlScrollInterface() | 62 | LLCtrlScrollInterface::~LLCtrlScrollInterface() |
63 | { } | 63 | { } |
diff --git a/linden/indra/llui/llctrlselectioninterface.h b/linden/indra/llui/llctrlselectioninterface.h index 8f422f4..189d2e1 100644 --- a/linden/indra/llui/llctrlselectioninterface.h +++ b/linden/indra/llui/llctrlselectioninterface.h | |||
@@ -1,8 +1,8 @@ | |||
1 | /** | 1 | /** |
2 | * @file llctrlselectioninterface.h | 2 | * @file llctrlselectioninterface.h |
3 | * @brief Programmatic selection of items in a list. | 3 | * @brief Programmatic selection of items in a list. |
4 | * | 4 | * |
5 | * Copyright (c) 2006-2007, Linden Research, Inc. | 5 | * Copyright (c) 2006-2007, Linden Research, Inc. |
6 | * | 6 | * |
7 | * The source code in this file ("Source Code") is provided by Linden Lab | 7 | * The source code in this file ("Source Code") is provided by Linden Lab |
8 | * to you under the terms of the GNU General Public License, version 2.0 | 8 | * to you under the terms of the GNU General Public License, version 2.0 |
@@ -22,82 +22,82 @@ | |||
22 | * | 22 | * |
23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | 23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO |
24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | 24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, |
25 | * COMPLETENESS OR PERFORMANCE. | 25 | * COMPLETENESS OR PERFORMANCE. |
26 | */ | 26 | */ |
27 | 27 | ||
28 | #ifndef LLCTRLSELECTIONINTERFACE_H | 28 | #ifndef LLCTRLSELECTIONINTERFACE_H |
29 | #define LLCTRLSELECTIONINTERFACE_H | 29 | #define LLCTRLSELECTIONINTERFACE_H |
30 | 30 | ||
31 | #include "stdtypes.h" | 31 | #include "stdtypes.h" |
32 | #include "stdenums.h" | 32 | #include "stdenums.h" |
33 | #include "llstring.h" | 33 | #include "llstring.h" |
34 | 34 | ||
35 | class LLSD; | 35 | class LLSD; |
36 | class LLUUID; | 36 | class LLUUID; |
37 | class LLScrollListItem; | 37 | class LLScrollListItem; |
38 | 38 | ||
39 | class LLCtrlSelectionInterface | 39 | class LLCtrlSelectionInterface |
40 | { | 40 | { |
41 | public: | 41 | public: |
42 | virtual ~LLCtrlSelectionInterface(); | 42 | virtual ~LLCtrlSelectionInterface(); |
43 | 43 | ||
44 | enum EOperation | 44 | enum EOperation |
45 | { | 45 | { |
46 | OP_DELETE = 1, | 46 | OP_DELETE = 1, |
47 | OP_SELECT, | 47 | OP_SELECT, |
48 | OP_DESELECT, | 48 | OP_DESELECT, |
49 | }; | 49 | }; |
50 | 50 | ||
51 | virtual BOOL getCanSelect() const = 0; | 51 | virtual BOOL getCanSelect() const = 0; |
52 | 52 | ||
53 | virtual BOOL selectFirstItem() = 0; | 53 | virtual BOOL selectFirstItem() = 0; |
54 | virtual BOOL selectNthItem( S32 index ) = 0; | 54 | virtual BOOL selectNthItem( S32 index ) = 0; |
55 | 55 | ||
56 | virtual S32 getFirstSelectedIndex() = 0; | 56 | virtual S32 getFirstSelectedIndex() = 0; |
57 | 57 | ||
58 | // TomY TODO: Simply cast the UUIDs to LLSDs, using the selectByValue function | 58 | // TomY TODO: Simply cast the UUIDs to LLSDs, using the selectByValue function |
59 | virtual BOOL setCurrentByID( const LLUUID& id ) = 0; | 59 | virtual BOOL setCurrentByID( const LLUUID& id ) = 0; |
60 | virtual LLUUID getCurrentID() = 0; | 60 | virtual LLUUID getCurrentID() = 0; |
61 | 61 | ||
62 | BOOL selectByValue(LLSD value); | 62 | BOOL selectByValue(LLSD value); |
63 | BOOL deselectByValue(LLSD value); | 63 | BOOL deselectByValue(LLSD value); |
64 | virtual BOOL setSelectedByValue(LLSD value, BOOL selected) = 0; | 64 | virtual BOOL setSelectedByValue(LLSD value, BOOL selected) = 0; |
65 | virtual LLSD getSimpleSelectedValue() = 0; | 65 | virtual LLSD getSimpleSelectedValue() = 0; |
66 | 66 | ||
67 | virtual BOOL isSelected(LLSD value) = 0; | 67 | virtual BOOL isSelected(LLSD value) = 0; |
68 | 68 | ||
69 | virtual BOOL operateOnSelection(EOperation op) = 0; | 69 | virtual BOOL operateOnSelection(EOperation op) = 0; |
70 | virtual BOOL operateOnAll(EOperation op) = 0; | 70 | virtual BOOL operateOnAll(EOperation op) = 0; |
71 | }; | 71 | }; |
72 | 72 | ||
73 | class LLCtrlListInterface : public LLCtrlSelectionInterface | 73 | class LLCtrlListInterface : public LLCtrlSelectionInterface |
74 | { | 74 | { |
75 | public: | 75 | public: |
76 | virtual ~LLCtrlListInterface(); | 76 | virtual ~LLCtrlListInterface(); |
77 | 77 | ||
78 | virtual S32 getItemCount() const = 0; | 78 | virtual S32 getItemCount() const = 0; |
79 | virtual void addColumn(const LLSD& column, EAddPosition pos = ADD_BOTTOM) = 0; | 79 | virtual void addColumn(const LLSD& column, EAddPosition pos = ADD_BOTTOM) = 0; |
80 | virtual void clearColumns() = 0; | 80 | virtual void clearColumns() = 0; |
81 | virtual void setColumnLabel(const LLString& column, const LLString& label) = 0; | 81 | virtual void setColumnLabel(const LLString& column, const LLString& label) = 0; |
82 | // TomY TODO: Document this | 82 | // TomY TODO: Document this |
83 | virtual LLScrollListItem* addElement(const LLSD& value, EAddPosition pos = ADD_BOTTOM, void* userdata = NULL) = 0; | 83 | virtual LLScrollListItem* addElement(const LLSD& value, EAddPosition pos = ADD_BOTTOM, void* userdata = NULL) = 0; |
84 | 84 | ||
85 | LLScrollListItem* addSimpleElement(const LLString& value); // defaults to bottom | 85 | LLScrollListItem* addSimpleElement(const LLString& value); // defaults to bottom |
86 | LLScrollListItem* addSimpleElement(const LLString& value, EAddPosition pos); // defaults to no LLSD() id | 86 | LLScrollListItem* addSimpleElement(const LLString& value, EAddPosition pos); // defaults to no LLSD() id |
87 | virtual LLScrollListItem* addSimpleElement(const LLString& value, EAddPosition pos, const LLSD& id) = 0; | 87 | virtual LLScrollListItem* addSimpleElement(const LLString& value, EAddPosition pos, const LLSD& id) = 0; |
88 | 88 | ||
89 | virtual void clearRows() = 0; | 89 | virtual void clearRows() = 0; |
90 | virtual void sortByColumn(LLString name, BOOL ascending) = 0; | 90 | virtual void sortByColumn(LLString name, BOOL ascending) = 0; |
91 | }; | 91 | }; |
92 | 92 | ||
93 | class LLCtrlScrollInterface | 93 | class LLCtrlScrollInterface |
94 | { | 94 | { |
95 | public: | 95 | public: |
96 | virtual ~LLCtrlScrollInterface(); | 96 | virtual ~LLCtrlScrollInterface(); |
97 | 97 | ||
98 | virtual S32 getScrollPos() = 0; | 98 | virtual S32 getScrollPos() = 0; |
99 | virtual void setScrollPos( S32 pos ) = 0; | 99 | virtual void setScrollPos( S32 pos ) = 0; |
100 | virtual void scrollToShowSelected() = 0; | 100 | virtual void scrollToShowSelected() = 0; |
101 | }; | 101 | }; |
102 | 102 | ||
103 | #endif | 103 | #endif |
diff --git a/linden/indra/llui/llfloater.cpp b/linden/indra/llui/llfloater.cpp index bc5f197..02a410e 100644 --- a/linden/indra/llui/llfloater.cpp +++ b/linden/indra/llui/llfloater.cpp | |||
@@ -506,26 +506,25 @@ void LLFloater::setVisible( BOOL visible ) | |||
506 | } | 506 | } |
507 | } | 507 | } |
508 | 508 | ||
509 | LLView* LLFloater::getRootMostFastFrameView() | 509 | void LLFloater::open() /* Flawfinder: ignore */ |
510 | { | 510 | { |
511 | // trying to render a background floater in a fast frame, abort!!! | 511 | if (mSoundFlags != SILENT |
512 | //if (!isFrontmost()) | 512 | // don't play open sound for hosted (tabbed) windows |
513 | //{ | 513 | && !getHost() |
514 | // gViewerWindow->finishFastFrame(); | 514 | && !sHostp |
515 | //} | 515 | && (!getVisible() || isMinimized())) |
516 | 516 | { | |
517 | return LLView::getRootMostFastFrameView(); | 517 | make_ui_sound("UISndWindowOpen"); |
518 | } | 518 | } |
519 | 519 | ||
520 | void LLFloater::open() | ||
521 | { | ||
522 | //RN: for now, we don't allow rehosting from one multifloater to another | 520 | //RN: for now, we don't allow rehosting from one multifloater to another |
523 | // just need to fix the bugs | 521 | // just need to fix the bugs |
524 | LLMultiFloater* hostp = getHost(); | 522 | LLMultiFloater* hostp = getHost(); |
525 | if (sHostp != NULL && hostp == NULL) | 523 | if (sHostp != NULL && hostp == NULL) |
526 | { | 524 | { |
527 | // needs a host | 525 | // needs a host |
528 | sHostp->addFloater(this, TRUE); | 526 | // only select tabs if window they are hosted in is visible |
527 | sHostp->addFloater(this, sHostp->getVisible()); | ||
529 | } | 528 | } |
530 | else if (hostp != NULL) | 529 | else if (hostp != NULL) |
531 | { | 530 | { |
@@ -538,13 +537,7 @@ void LLFloater::open() | |||
538 | setVisibleAndFrontmost(mAutoFocus); | 537 | setVisibleAndFrontmost(mAutoFocus); |
539 | } | 538 | } |
540 | 539 | ||
541 | if (mSoundFlags != SILENT) | 540 | onOpen(); |
542 | { | ||
543 | if (!getVisible() || isMinimized()) | ||
544 | { | ||
545 | make_ui_sound("UISndWindowOpen"); | ||
546 | } | ||
547 | } | ||
548 | } | 541 | } |
549 | 542 | ||
550 | void LLFloater::close(bool app_quitting) | 543 | void LLFloater::close(bool app_quitting) |
@@ -562,6 +555,7 @@ void LLFloater::close(bool app_quitting) | |||
562 | 555 | ||
563 | if (mSoundFlags != SILENT | 556 | if (mSoundFlags != SILENT |
564 | && getVisible() | 557 | && getVisible() |
558 | && !getHost() | ||
565 | && !app_quitting) | 559 | && !app_quitting) |
566 | { | 560 | { |
567 | make_ui_sound("UISndWindowClose"); | 561 | make_ui_sound("UISndWindowClose"); |
@@ -689,7 +683,7 @@ const LLString& LLFloater::getTitle() const | |||
689 | 683 | ||
690 | void LLFloater::translate(S32 x, S32 y) | 684 | void LLFloater::translate(S32 x, S32 y) |
691 | { | 685 | { |
692 | LLView::translate(x, y); | 686 | LLPanel::translate(x, y); |
693 | 687 | ||
694 | if (x != 0 || y != 0) | 688 | if (x != 0 || y != 0) |
695 | { | 689 | { |
@@ -719,7 +713,7 @@ BOOL LLFloater::canSnapTo(LLView* other_view) | |||
719 | } | 713 | } |
720 | } | 714 | } |
721 | 715 | ||
722 | return LLView::canSnapTo(other_view); | 716 | return LLPanel::canSnapTo(other_view); |
723 | } | 717 | } |
724 | 718 | ||
725 | void LLFloater::snappedTo(LLView* snap_view) | 719 | void LLFloater::snappedTo(LLView* snap_view) |
@@ -783,8 +777,6 @@ void LLFloater::setMinimized(BOOL minimize) | |||
783 | 777 | ||
784 | if (minimize) | 778 | if (minimize) |
785 | { | 779 | { |
786 | mMinimized = TRUE; | ||
787 | |||
788 | mPreviousRect = mRect; | 780 | mPreviousRect = mRect; |
789 | 781 | ||
790 | reshape( MINIMIZED_WIDTH, LLFLOATER_HEADER_SIZE, TRUE); | 782 | reshape( MINIMIZED_WIDTH, LLFLOATER_HEADER_SIZE, TRUE); |
@@ -830,6 +822,8 @@ void LLFloater::setMinimized(BOOL minimize) | |||
830 | ++dependent_it; | 822 | ++dependent_it; |
831 | } | 823 | } |
832 | 824 | ||
825 | mMinimized = TRUE; | ||
826 | |||
833 | // Lose keyboard focus when minimized | 827 | // Lose keyboard focus when minimized |
834 | releaseFocus(); | 828 | releaseFocus(); |
835 | } | 829 | } |
@@ -1207,12 +1201,12 @@ void LLFloater::onClickTearOff(void *userdata) | |||
1207 | 1201 | ||
1208 | new_rect.setLeftTopAndSize(host_floater->getRect().mLeft + 5, host_floater->getRect().mTop - LLFLOATER_HEADER_SIZE - 5, self->mRect.getWidth(), self->mRect.getHeight()); | 1202 | new_rect.setLeftTopAndSize(host_floater->getRect().mLeft + 5, host_floater->getRect().mTop - LLFLOATER_HEADER_SIZE - 5, self->mRect.getWidth(), self->mRect.getHeight()); |
1209 | 1203 | ||
1210 | self->open(); | 1204 | self->open(); /* Flawfinder: ignore */ |
1211 | self->setRect(new_rect); | 1205 | self->setRect(new_rect); |
1212 | gFloaterView->adjustToFitScreen(self, FALSE); | 1206 | gFloaterView->adjustToFitScreen(self, FALSE); |
1213 | self->setCanDrag(TRUE); | 1207 | self->setCanDrag(TRUE); |
1214 | self->setCanResize(TRUE); | 1208 | // give focus to new window to keep continuity for the user |
1215 | self->setCanMinimize(TRUE); | 1209 | self->setFocus(TRUE); |
1216 | } | 1210 | } |
1217 | else //Attach to parent. | 1211 | else //Attach to parent. |
1218 | { | 1212 | { |
@@ -1234,24 +1228,36 @@ void LLFloater::onClickEdit(void *userdata) | |||
1234 | } | 1228 | } |
1235 | 1229 | ||
1236 | // static | 1230 | // static |
1237 | void LLFloater::closeByMenu( void* userdata ) | 1231 | void LLFloater::closeFocusedFloater() |
1238 | { | 1232 | { |
1239 | LLFloater* self = (LLFloater*) userdata; | 1233 | LLFloater* focused_floater = NULL; |
1240 | if (!self || self->getHost()) return; | ||
1241 | 1234 | ||
1242 | LLFloaterView* parent = (LLFloaterView*) self->getParent(); | 1235 | std::map<LLViewHandle, LLFloater*>::iterator iter; |
1236 | for(iter = sFloaterMap.begin(); iter != sFloaterMap.end(); ++iter) | ||
1237 | { | ||
1238 | focused_floater = iter->second; | ||
1239 | if (focused_floater->hasFocus()) | ||
1240 | { | ||
1241 | break; | ||
1242 | } | ||
1243 | } | ||
1243 | 1244 | ||
1244 | // grab focus status before close just in case floater is deleted | 1245 | if (iter == sFloaterMap.end()) |
1245 | BOOL has_focus = gFocusMgr.childHasKeyboardFocus(self); | 1246 | { |
1246 | self->close(); | 1247 | // nothing found, return |
1248 | return; | ||
1249 | } | ||
1250 | |||
1251 | focused_floater->close(); | ||
1247 | 1252 | ||
1248 | // if this floater used to have focus and now nothing took focus | 1253 | // if nothing took focus after closing focused floater |
1249 | // give it to next floater (to allow closing multiple windows via keyboard in rapid succession) | 1254 | // give it to next floater (to allow closing multiple windows via keyboard in rapid succession) |
1250 | if (has_focus && gFocusMgr.getKeyboardFocus() == NULL) | 1255 | if (gFocusMgr.getKeyboardFocus() == NULL) |
1251 | { | 1256 | { |
1252 | parent->focusFrontFloater(); | 1257 | // HACK: use gFloaterView directly in case we are using Ctrl-W to close snapshot window |
1258 | // which sits in gSnapshotFloaterView, and needs to pass focus on to normal floater view | ||
1259 | gFloaterView->focusFrontFloater(); | ||
1253 | } | 1260 | } |
1254 | |||
1255 | } | 1261 | } |
1256 | 1262 | ||
1257 | 1263 | ||
@@ -1351,10 +1357,26 @@ void LLFloater::draw() | |||
1351 | focused_child->setVisible(TRUE); | 1357 | focused_child->setVisible(TRUE); |
1352 | } | 1358 | } |
1353 | drawChild(focused_child); | 1359 | drawChild(focused_child); |
1360 | |||
1361 | // update tearoff button for torn off floaters | ||
1362 | // when last host goes away | ||
1363 | if (mCanTearOff && !getHost()) | ||
1364 | { | ||
1365 | LLFloater* old_host = gFloaterView->getFloaterByHandle(mLastHostHandle); | ||
1366 | if (!old_host) | ||
1367 | { | ||
1368 | setCanTearOff(FALSE); | ||
1369 | } | ||
1370 | } | ||
1354 | } | 1371 | } |
1355 | } | 1372 | } |
1356 | 1373 | ||
1357 | // virtual | 1374 | // virtual |
1375 | void LLFloater::onOpen() | ||
1376 | { | ||
1377 | } | ||
1378 | |||
1379 | // virtual | ||
1358 | void LLFloater::onClose(bool app_quitting) | 1380 | void LLFloater::onClose(bool app_quitting) |
1359 | { | 1381 | { |
1360 | destroy(); | 1382 | destroy(); |
@@ -2018,23 +2040,52 @@ void LLFloaterView::focusFrontFloater() | |||
2018 | 2040 | ||
2019 | void LLFloaterView::getMinimizePosition(S32 *left, S32 *bottom) | 2041 | void LLFloaterView::getMinimizePosition(S32 *left, S32 *bottom) |
2020 | { | 2042 | { |
2021 | // count the number of minimized children | 2043 | S32 col = 0; |
2022 | S32 count = 0; | 2044 | LLRect snap_rect_local = getSnapRect(); |
2023 | for ( child_list_const_iter_t child_it = getChildList()->begin(); child_it != getChildList()->end(); ++child_it) | 2045 | snap_rect_local.translate(-mRect.mLeft, -mRect.mBottom); |
2024 | { | 2046 | for(S32 row = snap_rect_local.mBottom; |
2025 | LLView* viewp = *child_it; | 2047 | row < snap_rect_local.getHeight() - LLFLOATER_HEADER_SIZE; |
2026 | LLFloater *floater = (LLFloater *)viewp; | 2048 | row += LLFLOATER_HEADER_SIZE ) //loop rows |
2027 | if (floater->isMinimized()) | 2049 | { |
2028 | { | 2050 | for(col = snap_rect_local.mLeft; |
2029 | count++; | 2051 | col < snap_rect_local.getWidth() - MINIMIZED_WIDTH; |
2030 | } | 2052 | col += MINIMIZED_WIDTH) |
2053 | { | ||
2054 | bool foundGap = TRUE; | ||
2055 | for(child_list_const_iter_t child_it = getChildList()->begin(); | ||
2056 | child_it != getChildList()->end(); | ||
2057 | ++child_it) //loop floaters | ||
2058 | { | ||
2059 | // Examine minimized children. | ||
2060 | LLFloater* floater = (LLFloater*)((LLView*)*child_it); | ||
2061 | if(floater->isMinimized()) | ||
2062 | { | ||
2063 | LLRect r = floater->getRect(); | ||
2064 | if((r.mBottom < (row + LLFLOATER_HEADER_SIZE)) | ||
2065 | && (r.mBottom > (row - LLFLOATER_HEADER_SIZE)) | ||
2066 | && (r.mLeft < (col + MINIMIZED_WIDTH)) | ||
2067 | && (r.mLeft > (col - MINIMIZED_WIDTH))) | ||
2068 | { | ||
2069 | // needs the check for off grid. can't drag, | ||
2070 | // but window resize makes them off | ||
2071 | foundGap = FALSE; | ||
2072 | break; | ||
2073 | } | ||
2074 | } | ||
2075 | } //done floaters | ||
2076 | if(foundGap) | ||
2077 | { | ||
2078 | *left = col; | ||
2079 | *bottom = row; | ||
2080 | return; //done | ||
2081 | } | ||
2082 | } //done this col | ||
2031 | } | 2083 | } |
2032 | 2084 | ||
2033 | // space over for that many and up if necessary | 2085 | // crude - stack'em all at 0,0 when screen is full of minimized |
2034 | S32 tiles_per_row = mRect.getWidth() / MINIMIZED_WIDTH; | 2086 | // floaters. |
2035 | 2087 | *left = snap_rect_local.mLeft; | |
2036 | *left = (count % tiles_per_row) * MINIMIZED_WIDTH; | 2088 | *bottom = snap_rect_local.mBottom; |
2037 | *bottom = (count / tiles_per_row) * LLFLOATER_HEADER_SIZE; | ||
2038 | } | 2089 | } |
2039 | 2090 | ||
2040 | 2091 | ||
@@ -2211,7 +2262,7 @@ LLFloater *LLFloaterView::getFrontmost() | |||
2211 | for ( child_list_const_iter_t child_it = getChildList()->begin(); child_it != getChildList()->end(); ++child_it) | 2262 | for ( child_list_const_iter_t child_it = getChildList()->begin(); child_it != getChildList()->end(); ++child_it) |
2212 | { | 2263 | { |
2213 | LLView* viewp = *child_it; | 2264 | LLView* viewp = *child_it; |
2214 | if ( viewp->getVisible() ) | 2265 | if ( viewp->getVisible() && !viewp->isDead()) |
2215 | { | 2266 | { |
2216 | return (LLFloater *)viewp; | 2267 | return (LLFloater *)viewp; |
2217 | } | 2268 | } |
@@ -2423,31 +2474,11 @@ LLString LLMultiFloater::getWidgetTag() const | |||
2423 | return LL_MULTI_FLOATER_TAG; | 2474 | return LL_MULTI_FLOATER_TAG; |
2424 | } | 2475 | } |
2425 | 2476 | ||
2426 | void LLMultiFloater::init(const LLString& title, BOOL resizable, | 2477 | void LLMultiFloater::open() /* Flawfinder: ignore */ |
2427 | S32 min_width, S32 min_height, BOOL drag_on_left, | ||
2428 | BOOL minimizable, BOOL close_btn) | ||
2429 | { | ||
2430 | LLFloater::init(title, resizable, min_width, min_height, drag_on_left, minimizable, close_btn); | ||
2431 | |||
2432 | /*mTabContainer = new LLTabContainer("Preview Tabs", | ||
2433 | LLRect(LLPANEL_BORDER_WIDTH, mRect.getHeight() - LLFLOATER_HEADER_SIZE, mRect.getWidth() - LLPANEL_BORDER_WIDTH, 0), | ||
2434 | mTabPos, | ||
2435 | NULL, | ||
2436 | NULL); | ||
2437 | mTabContainer->setFollowsAll(); | ||
2438 | if (mResizable && mTabPos == LLTabContainerCommon::BOTTOM) | ||
2439 | { | ||
2440 | mTabContainer->setRightTabBtnOffset(RESIZE_HANDLE_WIDTH); | ||
2441 | } | ||
2442 | |||
2443 | addChild(mTabContainer);*/ | ||
2444 | } | ||
2445 | |||
2446 | void LLMultiFloater::open() | ||
2447 | { | 2478 | { |
2448 | if (mTabContainer->getTabCount() > 0) | 2479 | if (mTabContainer->getTabCount() > 0) |
2449 | { | 2480 | { |
2450 | LLFloater::open(); | 2481 | LLFloater::open(); /* Flawfinder: ignore */ |
2451 | } | 2482 | } |
2452 | else | 2483 | else |
2453 | { | 2484 | { |
@@ -2519,16 +2550,9 @@ void LLMultiFloater::growToFit(LLFloater* floaterp, S32 width, S32 height) | |||
2519 | // store new width and height with this floater so that it will keep its size when detached | 2550 | // store new width and height with this floater so that it will keep its size when detached |
2520 | found_data_it->second.mWidth = width; | 2551 | found_data_it->second.mWidth = width; |
2521 | found_data_it->second.mHeight = height; | 2552 | found_data_it->second.mHeight = height; |
2522 | |||
2523 | S32 cur_height = mRect.getHeight(); | ||
2524 | reshape(llmax(mRect.getWidth(), width + LLPANEL_BORDER_WIDTH * 2), llmax(mRect.getHeight(), height + LLFLOATER_HEADER_SIZE + TABCNTR_HEADER_HEIGHT + (LLPANEL_BORDER_WIDTH * 2))); | ||
2525 | |||
2526 | // make sure upper left corner doesn't move | ||
2527 | translate(0, mRect.getHeight() - cur_height); | ||
2528 | |||
2529 | // Try to keep whole view onscreen, don't allow partial offscreen. | ||
2530 | gFloaterView->adjustToFitScreen(this, FALSE); | ||
2531 | } | 2553 | } |
2554 | |||
2555 | resizeToContents(); | ||
2532 | } | 2556 | } |
2533 | 2557 | ||
2534 | /** | 2558 | /** |
@@ -2597,8 +2621,6 @@ void LLMultiFloater::addFloater(LLFloater* floaterp, BOOL select_added_floater, | |||
2597 | if ( select_added_floater ) | 2621 | if ( select_added_floater ) |
2598 | { | 2622 | { |
2599 | mTabContainer->selectLastTab(); | 2623 | mTabContainer->selectLastTab(); |
2600 | // explicitly call tabopen to load preview assets, etc. | ||
2601 | tabOpen((LLFloater*)mTabContainer->getCurrentPanel(), true); | ||
2602 | } | 2624 | } |
2603 | 2625 | ||
2604 | floaterp->setHost(this); | 2626 | floaterp->setHost(this); |
@@ -2671,24 +2693,7 @@ void LLMultiFloater::removeFloater(LLFloater* floaterp) | |||
2671 | 2693 | ||
2672 | if (mAutoResize) | 2694 | if (mAutoResize) |
2673 | { | 2695 | { |
2674 | floater_data_map_t::iterator floater_it; | 2696 | resizeToContents(); |
2675 | S32 new_width = 0; | ||
2676 | S32 new_height = 0; | ||
2677 | for (floater_it = mFloaterDataMap.begin(); floater_it != mFloaterDataMap.end(); ++floater_it) | ||
2678 | { | ||
2679 | new_width = llmax(new_width, floater_it->second.mWidth + LLPANEL_BORDER_WIDTH * 2); | ||
2680 | new_height = llmax(new_height, floater_it->second.mHeight + LLFLOATER_HEADER_SIZE + TABCNTR_HEADER_HEIGHT); | ||
2681 | } | ||
2682 | |||
2683 | S32 cur_height = mRect.getHeight(); | ||
2684 | |||
2685 | reshape(new_width, new_height); | ||
2686 | |||
2687 | // make sure upper left corner doesn't move | ||
2688 | translate(0, cur_height - new_height); | ||
2689 | |||
2690 | // Try to keep whole view onscreen, don't allow partial offscreen. | ||
2691 | gFloaterView->adjustToFitScreen(this, FALSE); | ||
2692 | } | 2697 | } |
2693 | 2698 | ||
2694 | tabOpen((LLFloater*)mTabContainer->getCurrentPanel(), false); | 2699 | tabOpen((LLFloater*)mTabContainer->getCurrentPanel(), false); |
@@ -2721,6 +2726,13 @@ void LLMultiFloater::setVisible(BOOL visible) | |||
2721 | { | 2726 | { |
2722 | cur_floaterp->setVisible(visible); | 2727 | cur_floaterp->setVisible(visible); |
2723 | } | 2728 | } |
2729 | |||
2730 | // if no tab selected, and we're being shown, | ||
2731 | // select last tab to be added | ||
2732 | if (visible && !cur_floaterp) | ||
2733 | { | ||
2734 | mTabContainer->selectLastTab(); | ||
2735 | } | ||
2724 | } | 2736 | } |
2725 | } | 2737 | } |
2726 | 2738 | ||
@@ -2823,6 +2835,43 @@ BOOL LLMultiFloater::postBuild() | |||
2823 | return FALSE; | 2835 | return FALSE; |
2824 | } | 2836 | } |
2825 | 2837 | ||
2838 | void LLMultiFloater::resizeToContents() | ||
2839 | { | ||
2840 | // we're already in the middle of a reshape, don't interrupt it | ||
2841 | floater_data_map_t::iterator floater_it; | ||
2842 | S32 new_width = 0; | ||
2843 | S32 new_height = 0; | ||
2844 | for (floater_it = mFloaterDataMap.begin(); floater_it != mFloaterDataMap.end(); ++floater_it) | ||
2845 | { | ||
2846 | new_width = llmax(new_width, floater_it->second.mWidth + LLPANEL_BORDER_WIDTH * 2); | ||
2847 | new_height = llmax(new_height, floater_it->second.mHeight + LLFLOATER_HEADER_SIZE + TABCNTR_HEADER_HEIGHT); | ||
2848 | } | ||
2849 | |||
2850 | S32 new_min_width = 0; | ||
2851 | S32 new_min_height = 0; | ||
2852 | S32 tab_idx; | ||
2853 | for (tab_idx = 0; tab_idx < mTabContainer->getTabCount(); ++tab_idx) | ||
2854 | { | ||
2855 | LLFloater* floaterp = (LLFloater*)mTabContainer->getPanelByIndex(tab_idx); | ||
2856 | if (floaterp) | ||
2857 | { | ||
2858 | new_min_width = llmax(new_min_width, floaterp->getMinWidth() + LLPANEL_BORDER_WIDTH * 2); | ||
2859 | new_min_height = llmax(new_min_height, floaterp->getMinHeight() + LLFLOATER_HEADER_SIZE + TABCNTR_HEADER_HEIGHT); | ||
2860 | } | ||
2861 | } | ||
2862 | setResizeLimits(new_min_width, new_min_height); | ||
2863 | |||
2864 | S32 cur_height = mRect.getHeight(); | ||
2865 | |||
2866 | reshape(new_width, new_height); | ||
2867 | |||
2868 | // make sure upper left corner doesn't move | ||
2869 | translate(0, cur_height - new_height); | ||
2870 | |||
2871 | // Try to keep whole view onscreen, don't allow partial offscreen. | ||
2872 | gFloaterView->adjustToFitScreen(this, FALSE); | ||
2873 | } | ||
2874 | |||
2826 | // virtual | 2875 | // virtual |
2827 | LLXMLNodePtr LLFloater::getXML(bool save_children) const | 2876 | LLXMLNodePtr LLFloater::getXML(bool save_children) const |
2828 | { | 2877 | { |
@@ -2872,7 +2921,7 @@ LLView* LLFloater::fromXML(LLXMLNodePtr node, LLView *parent, LLUICtrlFactory *f | |||
2872 | return floaterp; | 2921 | return floaterp; |
2873 | } | 2922 | } |
2874 | 2923 | ||
2875 | void LLFloater::initFloaterXML(LLXMLNodePtr node, LLView *parent, LLUICtrlFactory *factory, BOOL open) | 2924 | void LLFloater::initFloaterXML(LLXMLNodePtr node, LLView *parent, LLUICtrlFactory *factory, BOOL open) /* Flawfinder: ignore */ |
2876 | { | 2925 | { |
2877 | LLString name(getName()); | 2926 | LLString name(getName()); |
2878 | LLString title(getTitle()); | 2927 | LLString title(getTitle()); |
@@ -2946,8 +2995,8 @@ void LLFloater::initFloaterXML(LLXMLNodePtr node, LLView *parent, LLUICtrlFactor | |||
2946 | } | 2995 | } |
2947 | 2996 | ||
2948 | applyRectControl(); | 2997 | applyRectControl(); |
2949 | if (open) | 2998 | if (open) /* Flawfinder: ignore */ |
2950 | { | 2999 | { |
2951 | this->open(); | 3000 | this->open(); /* Flawfinder: ignore */ |
2952 | } | 3001 | } |
2953 | } | 3002 | } |
diff --git a/linden/indra/llui/llfloater.h b/linden/indra/llui/llfloater.h index 4826648..25b2697 100644 --- a/linden/indra/llui/llfloater.h +++ b/linden/indra/llui/llfloater.h | |||
@@ -122,7 +122,7 @@ public: | |||
122 | virtual EWidgetType getWidgetType() const; | 122 | virtual EWidgetType getWidgetType() const; |
123 | virtual LLString getWidgetTag() const; | 123 | virtual LLString getWidgetTag() const; |
124 | 124 | ||
125 | virtual void open(); | 125 | virtual void open(); /* Flawfinder: ignore */ |
126 | 126 | ||
127 | // If allowed, close the floater cleanly, releasing focus. | 127 | // If allowed, close the floater cleanly, releasing focus. |
128 | // app_quitting is passed to onClose() below. | 128 | // app_quitting is passed to onClose() below. |
@@ -176,6 +176,9 @@ public: | |||
176 | 176 | ||
177 | virtual void draw(); | 177 | virtual void draw(); |
178 | 178 | ||
179 | // does nothing by default | ||
180 | virtual void onOpen(); | ||
181 | |||
179 | // Call destroy() to free memory, or setVisible(FALSE) to keep it | 182 | // Call destroy() to free memory, or setVisible(FALSE) to keep it |
180 | // If app_quitting, you might not want to save your visibility. | 183 | // If app_quitting, you might not want to save your visibility. |
181 | // Defaults to destroy(). | 184 | // Defaults to destroy(). |
@@ -197,9 +200,8 @@ public: | |||
197 | void clearSnapTarget() { mSnappedTo.markDead(); } | 200 | void clearSnapTarget() { mSnappedTo.markDead(); } |
198 | LLViewHandle getSnapTarget() { return mSnappedTo; } | 201 | LLViewHandle getSnapTarget() { return mSnappedTo; } |
199 | 202 | ||
200 | /*virtual*/ LLView* getRootMostFastFrameView(); | 203 | static void closeFocusedFloater(); |
201 | 204 | ||
202 | static void closeByMenu(void *userdata); | ||
203 | static void onClickClose(void *userdata); | 205 | static void onClickClose(void *userdata); |
204 | static void onClickMinimize(void *userdata); | 206 | static void onClickMinimize(void *userdata); |
205 | static void onClickTearOff(void *userdata); | 207 | static void onClickTearOff(void *userdata); |
@@ -356,12 +358,8 @@ public: | |||
356 | LLMultiFloater(const LLString& name, const LLString& rect_control, LLTabContainer::TabPosition tab_pos = LLTabContainer::TOP, BOOL auto_resize = FALSE); | 358 | LLMultiFloater(const LLString& name, const LLString& rect_control, LLTabContainer::TabPosition tab_pos = LLTabContainer::TOP, BOOL auto_resize = FALSE); |
357 | virtual ~LLMultiFloater(); | 359 | virtual ~LLMultiFloater(); |
358 | 360 | ||
359 | virtual void init(const LLString& title, BOOL resizable, | ||
360 | S32 min_width, S32 min_height, BOOL drag_on_left, | ||
361 | BOOL minimizable, BOOL close_btn); | ||
362 | |||
363 | virtual BOOL postBuild(); | 361 | virtual BOOL postBuild(); |
364 | /*virtual*/ void open(); | 362 | /*virtual*/ void open(); /* Flawfinder: ignore */ |
365 | /*virtual*/ void onClose(bool app_quitting); | 363 | /*virtual*/ void onClose(bool app_quitting); |
366 | /*virtual*/ void draw(); | 364 | /*virtual*/ void draw(); |
367 | /*virtual*/ void setVisible(BOOL visible); | 365 | /*virtual*/ void setVisible(BOOL visible); |
@@ -393,6 +391,8 @@ public: | |||
393 | void setTabContainer(LLTabContainerCommon* tab_container) { if (!mTabContainer) mTabContainer = tab_container; } | 391 | void setTabContainer(LLTabContainerCommon* tab_container) { if (!mTabContainer) mTabContainer = tab_container; } |
394 | static void onTabSelected(void* userdata, bool); | 392 | static void onTabSelected(void* userdata, bool); |
395 | 393 | ||
394 | virtual void resizeToContents(); | ||
395 | |||
396 | protected: | 396 | protected: |
397 | struct LLFloaterData | 397 | struct LLFloaterData |
398 | { | 398 | { |
diff --git a/linden/indra/llui/llkeywords.cpp b/linden/indra/llui/llkeywords.cpp index fd224d8..05ec652 100644 --- a/linden/indra/llui/llkeywords.cpp +++ b/linden/indra/llui/llkeywords.cpp | |||
@@ -73,10 +73,10 @@ BOOL LLKeywords::loadFromFile( const LLString& filename ) | |||
73 | // File header | 73 | // File header |
74 | 74 | ||
75 | const S32 BUFFER_SIZE = 1024; | 75 | const S32 BUFFER_SIZE = 1024; |
76 | char buffer[BUFFER_SIZE]; | 76 | char buffer[BUFFER_SIZE]; /* Flawfinder: ignore */ |
77 | 77 | ||
78 | llifstream file; | 78 | llifstream file; |
79 | file.open(filename.c_str()); | 79 | file.open(filename.c_str()); /* Flawfinder: ignore */ |
80 | if( file.fail() ) | 80 | if( file.fail() ) |
81 | { | 81 | { |
82 | llinfos << "LLKeywords::loadFromFile() Unable to open file: " << filename << llendl; | 82 | llinfos << "LLKeywords::loadFromFile() Unable to open file: " << filename << llendl; |
@@ -114,34 +114,34 @@ BOOL LLKeywords::loadFromFile( const LLString& filename ) | |||
114 | while (!file.eof()) | 114 | while (!file.eof()) |
115 | { | 115 | { |
116 | file.getline( buffer, BUFFER_SIZE ); | 116 | file.getline( buffer, BUFFER_SIZE ); |
117 | if( !strncmp( buffer, SOL_COMMENT, strlen(SOL_COMMENT) ) ) | 117 | if( !strncmp( buffer, SOL_COMMENT, strlen(SOL_COMMENT) ) ) /* Flawfinder: ignore */ |
118 | { | 118 | { |
119 | continue; | 119 | continue; |
120 | } | 120 | } |
121 | else | 121 | else |
122 | if( !strncmp( buffer, SOL_WORD, strlen(SOL_WORD) ) ) | 122 | if( !strncmp( buffer, SOL_WORD, strlen(SOL_WORD) ) ) /* Flawfinder: ignore */ |
123 | { | 123 | { |
124 | cur_color = readColor( buffer + strlen(SOL_WORD) ); | 124 | cur_color = readColor( buffer + strlen(SOL_WORD) ); /* Flawfinder: ignore */ |
125 | cur_type = LLKeywordToken::WORD; | 125 | cur_type = LLKeywordToken::WORD; |
126 | continue; | 126 | continue; |
127 | } | 127 | } |
128 | else | 128 | else |
129 | if( !strncmp( buffer, SOL_LINE, strlen(SOL_LINE) ) ) | 129 | if( !strncmp( buffer, SOL_LINE, strlen(SOL_LINE) ) ) /* Flawfinder: ignore */ |
130 | { | 130 | { |
131 | cur_color = readColor( buffer + strlen(SOL_LINE) ); | 131 | cur_color = readColor( buffer + strlen(SOL_LINE) ); /* Flawfinder: ignore */ |
132 | cur_type = LLKeywordToken::LINE; | 132 | cur_type = LLKeywordToken::LINE; |
133 | continue; | 133 | continue; |
134 | } | 134 | } |
135 | else | 135 | else |
136 | if( !strncmp( buffer, SOL_TWO_SIDED_DELIMITER, strlen(SOL_TWO_SIDED_DELIMITER) ) ) | 136 | if( !strncmp( buffer, SOL_TWO_SIDED_DELIMITER, strlen(SOL_TWO_SIDED_DELIMITER) ) ) /* Flawfinder: ignore */ |
137 | { | 137 | { |
138 | cur_color = readColor( buffer + strlen(SOL_TWO_SIDED_DELIMITER) ); | 138 | cur_color = readColor( buffer + strlen(SOL_TWO_SIDED_DELIMITER) ); /* Flawfinder: ignore */ |
139 | cur_type = LLKeywordToken::TWO_SIDED_DELIMITER; | 139 | cur_type = LLKeywordToken::TWO_SIDED_DELIMITER; |
140 | continue; | 140 | continue; |
141 | } | 141 | } |
142 | if( !strncmp( buffer, SOL_ONE_SIDED_DELIMITER, strlen(SOL_ONE_SIDED_DELIMITER) ) ) | 142 | if( !strncmp( buffer, SOL_ONE_SIDED_DELIMITER, strlen(SOL_ONE_SIDED_DELIMITER) ) ) /* Flawfinder: ignore */ |
143 | { | 143 | { |
144 | cur_color = readColor( buffer + strlen(SOL_ONE_SIDED_DELIMITER) ); | 144 | cur_color = readColor( buffer + strlen(SOL_ONE_SIDED_DELIMITER) ); /* Flawfinder: ignore */ |
145 | cur_type = LLKeywordToken::ONE_SIDED_DELIMITER; | 145 | cur_type = LLKeywordToken::ONE_SIDED_DELIMITER; |
146 | continue; | 146 | continue; |
147 | } | 147 | } |
@@ -220,7 +220,7 @@ LLColor3 LLKeywords::readColor( const LLString& s ) | |||
220 | F32 r, g, b; | 220 | F32 r, g, b; |
221 | r = g = b = 0.0f; | 221 | r = g = b = 0.0f; |
222 | S32 read = sscanf(s.c_str(), "%f, %f, %f]", &r, &g, &b ); | 222 | S32 read = sscanf(s.c_str(), "%f, %f, %f]", &r, &g, &b ); |
223 | if( read != 3 ) | 223 | if( read != 3 ) /* Flawfinder: ignore */ |
224 | { | 224 | { |
225 | llinfos << " poorly formed color in keyword file" << llendl; | 225 | llinfos << " poorly formed color in keyword file" << llendl; |
226 | } | 226 | } |
diff --git a/linden/indra/llui/llmenugl.cpp b/linden/indra/llui/llmenugl.cpp index 97069fa..1748956 100644 --- a/linden/indra/llui/llmenugl.cpp +++ b/linden/indra/llui/llmenugl.cpp | |||
@@ -62,7 +62,7 @@ | |||
62 | #include <boost/tokenizer.hpp> | 62 | #include <boost/tokenizer.hpp> |
63 | 63 | ||
64 | // static | 64 | // static |
65 | LLView *LLMenuGL::sDefaultMenuContainer = NULL; | 65 | LLMenuHolderGL *LLMenuGL::sMenuContainer = NULL; |
66 | 66 | ||
67 | S32 MENU_BAR_HEIGHT = 0; | 67 | S32 MENU_BAR_HEIGHT = 0; |
68 | S32 MENU_BAR_WIDTH = 0; | 68 | S32 MENU_BAR_WIDTH = 0; |
@@ -404,14 +404,10 @@ void LLMenuItemGL::doIt( void ) | |||
404 | { | 404 | { |
405 | // close all open menus by default | 405 | // close all open menus by default |
406 | // if parent menu is actually visible (and we are not triggering menu item via accelerator) | 406 | // if parent menu is actually visible (and we are not triggering menu item via accelerator) |
407 | // HACK: do not call hidemenus() from a pie menu item, as most pie menu operations | 407 | if (!getMenu()->getTornOff() |
408 | // assume that the thing you clicked on stays selected (parcel and/or object) after the | ||
409 | // pie menu is gone --RN | ||
410 | if (getMenu()->getWidgetType() != WIDGET_TYPE_PIE_MENU | ||
411 | && !getMenu()->getTornOff() | ||
412 | && getMenu()->getVisible()) | 408 | && getMenu()->getVisible()) |
413 | { | 409 | { |
414 | ((LLMenuHolderGL*)getMenu()->getParent())->hideMenus(); | 410 | LLMenuGL::sMenuContainer->hideMenus(); |
415 | } | 411 | } |
416 | } | 412 | } |
417 | 413 | ||
@@ -473,18 +469,28 @@ BOOL LLMenuItemGL::handleKeyHere( KEY key, MASK mask, BOOL called_from_parent ) | |||
473 | 469 | ||
474 | BOOL LLMenuItemGL::handleMouseUp( S32 x, S32 y, MASK ) | 470 | BOOL LLMenuItemGL::handleMouseUp( S32 x, S32 y, MASK ) |
475 | { | 471 | { |
476 | //llinfos << mLabel.c_str() << " handleMouseUp " << x << "," << y | ||
477 | // << llendl; | ||
478 | if (mEnabled) | 472 | if (mEnabled) |
479 | { | 473 | { |
480 | // switch to mouse navigation mode | 474 | // switch to mouse navigation mode |
481 | LLMenuGL::setKeyboardMode(FALSE); | 475 | LLMenuGL::setKeyboardMode(FALSE); |
482 | 476 | ||
483 | doIt(); | 477 | doIt(); |
484 | setHighlight(FALSE); | ||
485 | make_ui_sound("UISndClickRelease"); | 478 | make_ui_sound("UISndClickRelease"); |
486 | return TRUE; | 479 | return TRUE; |
487 | } | 480 | } |
481 | return FALSE; | ||
482 | } | ||
483 | |||
484 | BOOL LLMenuItemGL::handleMouseDown( S32 x, S32 y, MASK ) | ||
485 | { | ||
486 | if (mEnabled) | ||
487 | { | ||
488 | // switch to mouse navigation mode | ||
489 | LLMenuGL::setKeyboardMode(FALSE); | ||
490 | |||
491 | setHighlight(TRUE); | ||
492 | return TRUE; | ||
493 | } | ||
488 | else | 494 | else |
489 | { | 495 | { |
490 | return FALSE; | 496 | return FALSE; |
@@ -1168,70 +1174,6 @@ void LLMenuItemToggleGL::doIt( void ) | |||
1168 | } | 1174 | } |
1169 | 1175 | ||
1170 | 1176 | ||
1171 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
1172 | // Class LLMenuItemBranchGL | ||
1173 | // | ||
1174 | // The LLMenuItemBranchGL represents a menu item that has a | ||
1175 | // sub-menu. This is used to make cascading menus. | ||
1176 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
1177 | |||
1178 | class LLMenuItemBranchGL : public LLMenuItemGL | ||
1179 | { | ||
1180 | protected: | ||
1181 | LLMenuGL* mBranch; | ||
1182 | |||
1183 | public: | ||
1184 | LLMenuItemBranchGL( const LLString& name, const LLString& label, LLMenuGL* branch, | ||
1185 | KEY key = KEY_NONE, MASK mask = MASK_NONE ); | ||
1186 | virtual LLXMLNodePtr getXML(bool save_children = true) const; | ||
1187 | |||
1188 | virtual LLView* getChildByName(const LLString& name, BOOL recurse) const; | ||
1189 | |||
1190 | virtual LLString getType() const { return "menu"; } | ||
1191 | |||
1192 | virtual EWidgetType getWidgetType() const; | ||
1193 | virtual LLString getWidgetTag() const; | ||
1194 | |||
1195 | virtual BOOL handleMouseUp(S32 x, S32 y, MASK mask); | ||
1196 | |||
1197 | virtual BOOL handleAcceleratorKey(KEY key, MASK mask); | ||
1198 | |||
1199 | // check if we've used these accelerators already | ||
1200 | virtual BOOL addToAcceleratorList(std::list <LLKeyBinding*> *listp); | ||
1201 | |||
1202 | // called to rebuild the draw label | ||
1203 | virtual void buildDrawLabel( void ); | ||
1204 | |||
1205 | // doIt() - do the primary funcationality of the menu item. | ||
1206 | virtual void doIt( void ); | ||
1207 | |||
1208 | virtual BOOL handleKey(KEY key, MASK mask, BOOL called_from_parent); | ||
1209 | virtual BOOL handleUnicodeChar(llwchar uni_char, BOOL called_from_parent); | ||
1210 | |||
1211 | // set the hover status (called by it's menu) and if the object is | ||
1212 | // active. This is used for behavior transfer. | ||
1213 | virtual void setHighlight( BOOL highlight ); | ||
1214 | |||
1215 | virtual BOOL handleKeyHere(KEY key, MASK mask, BOOL called_from_parent); | ||
1216 | |||
1217 | virtual BOOL isActive() const; | ||
1218 | |||
1219 | virtual BOOL isOpen() const; | ||
1220 | |||
1221 | LLMenuGL *getBranch() const { return mBranch; } | ||
1222 | |||
1223 | virtual void updateBranchParent( LLView* parentp ); | ||
1224 | |||
1225 | // LLView Functionality | ||
1226 | virtual void onVisibilityChange( BOOL curVisibilityIn ); | ||
1227 | |||
1228 | virtual void draw(); | ||
1229 | |||
1230 | virtual void setEnabledSubMenus(BOOL enabled); | ||
1231 | |||
1232 | virtual void openMenu(); | ||
1233 | }; | ||
1234 | |||
1235 | LLMenuItemBranchGL::LLMenuItemBranchGL( const LLString& name, const LLString& label, LLMenuGL* branch, | 1177 | LLMenuItemBranchGL::LLMenuItemBranchGL( const LLString& name, const LLString& label, LLMenuGL* branch, |
1236 | KEY key, MASK mask ) : | 1178 | KEY key, MASK mask ) : |
1237 | LLMenuItemGL( name, label, key, mask ), | 1179 | LLMenuItemGL( name, label, key, mask ), |
@@ -1502,6 +1444,9 @@ void LLMenuItemBranchGL::openMenu() | |||
1502 | } | 1444 | } |
1503 | else if( !mBranch->getVisible() ) | 1445 | else if( !mBranch->getVisible() ) |
1504 | { | 1446 | { |
1447 | // get valid rectangle for menus | ||
1448 | const LLRect menu_region_rect = LLMenuGL::sMenuContainer->getMenuRect(); | ||
1449 | |||
1505 | mBranch->arrange(); | 1450 | mBranch->arrange(); |
1506 | 1451 | ||
1507 | LLRect rect = mBranch->getRect(); | 1452 | LLRect rect = mBranch->getRect(); |
@@ -1524,13 +1469,13 @@ void LLMenuItemBranchGL::openMenu() | |||
1524 | mBranch->localPointToOtherView( 0, 0, &x, &y, mBranch->getParent() ); | 1469 | mBranch->localPointToOtherView( 0, 0, &x, &y, mBranch->getParent() ); |
1525 | S32 delta_x = 0; | 1470 | S32 delta_x = 0; |
1526 | S32 delta_y = 0; | 1471 | S32 delta_y = 0; |
1527 | if( y < 0 ) | 1472 | if( y < menu_region_rect.mBottom ) |
1528 | { | 1473 | { |
1529 | delta_y = -y; | 1474 | delta_y = menu_region_rect.mBottom - y; |
1530 | } | 1475 | } |
1531 | 1476 | ||
1532 | S32 window_width = mBranch->getParent()->getRect().getWidth(); | 1477 | S32 menu_region_width = menu_region_rect.getWidth(); |
1533 | if( x > window_width - rect.getWidth() ) | 1478 | if( x - menu_region_rect.mLeft > menu_region_width - rect.getWidth() ) |
1534 | { | 1479 | { |
1535 | // move sub-menu over to left side | 1480 | // move sub-menu over to left side |
1536 | delta_x = llmax(-x, (-1 * (rect.getWidth() + mRect.getWidth()))); | 1481 | delta_x = llmax(-x, (-1 * (rect.getWidth() + mRect.getWidth()))); |
@@ -1709,7 +1654,7 @@ BOOL LLMenuItemBranchDownGL::handleAcceleratorKey(KEY key, MASK mask) | |||
1709 | { | 1654 | { |
1710 | BOOL branch_visible = mBranch->getVisible(); | 1655 | BOOL branch_visible = mBranch->getVisible(); |
1711 | BOOL handled = mBranch->handleAcceleratorKey(key, mask); | 1656 | BOOL handled = mBranch->handleAcceleratorKey(key, mask); |
1712 | if (handled && !branch_visible) | 1657 | if (handled && !branch_visible && getVisible()) |
1713 | { | 1658 | { |
1714 | // flash this menu entry because we triggered an invisible menu item | 1659 | // flash this menu entry because we triggered an invisible menu item |
1715 | LLMenuHolderGL::setActivatedItem(this); | 1660 | LLMenuHolderGL::setActivatedItem(this); |
@@ -1721,7 +1666,8 @@ BOOL LLMenuItemBranchDownGL::handleAcceleratorKey(KEY key, MASK mask) | |||
1721 | BOOL LLMenuItemBranchDownGL::handleKeyHere(KEY key, MASK mask, BOOL called_from_parent) | 1666 | BOOL LLMenuItemBranchDownGL::handleKeyHere(KEY key, MASK mask, BOOL called_from_parent) |
1722 | { | 1667 | { |
1723 | BOOL menu_open = mBranch->getVisible(); | 1668 | BOOL menu_open = mBranch->getVisible(); |
1724 | if (getHighlight() && getMenu()->getVisible()) | 1669 | // don't do keyboard navigation of top-level menus unless in keyboard mode, or menu expanded |
1670 | if (getHighlight() && getMenu()->getVisible() && (isActive() || LLMenuGL::getKeyboardMode())) | ||
1725 | { | 1671 | { |
1726 | if (key == KEY_LEFT) | 1672 | if (key == KEY_LEFT) |
1727 | { | 1673 | { |
@@ -1961,9 +1907,9 @@ void LLMenuGL::parseChildXML(LLXMLNodePtr child, LLView *parent, LLUICtrlFactory | |||
1961 | // SUBMENU | 1907 | // SUBMENU |
1962 | LLMenuGL *submenu = (LLMenuGL*)LLMenuGL::fromXML(child, parent, factory); | 1908 | LLMenuGL *submenu = (LLMenuGL*)LLMenuGL::fromXML(child, parent, factory); |
1963 | appendMenu(submenu); | 1909 | appendMenu(submenu); |
1964 | if (LLMenuGL::sDefaultMenuContainer != NULL) | 1910 | if (LLMenuGL::sMenuContainer != NULL) |
1965 | { | 1911 | { |
1966 | submenu->updateParent(LLMenuGL::sDefaultMenuContainer); | 1912 | submenu->updateParent(LLMenuGL::sMenuContainer); |
1967 | } | 1913 | } |
1968 | else | 1914 | else |
1969 | { | 1915 | { |
@@ -2337,6 +2283,12 @@ void LLMenuGL::setBackgroundColor( const LLColor4& color ) | |||
2337 | mBackgroundColor = color; | 2283 | mBackgroundColor = color; |
2338 | } | 2284 | } |
2339 | 2285 | ||
2286 | LLColor4 LLMenuGL::getBackgroundColor() | ||
2287 | { | ||
2288 | return mBackgroundColor; | ||
2289 | } | ||
2290 | |||
2291 | |||
2340 | // rearrange the child rects so they fit the shape of the menu. | 2292 | // rearrange the child rects so they fit the shape of the menu. |
2341 | void LLMenuGL::arrange( void ) | 2293 | void LLMenuGL::arrange( void ) |
2342 | { | 2294 | { |
@@ -2350,8 +2302,10 @@ void LLMenuGL::arrange( void ) | |||
2350 | 2302 | ||
2351 | if( mItems.size() ) | 2303 | if( mItems.size() ) |
2352 | { | 2304 | { |
2353 | U32 max_width = (getParent() != NULL) ? getParent()->getRect().getWidth() : U32_MAX; | 2305 | const LLRect menu_region_rect = LLMenuGL::sMenuContainer ? LLMenuGL::sMenuContainer->getMenuRect() : LLRect(0, S32_MAX, S32_MAX, 0); |
2354 | U32 max_height = (getParent() != NULL) ? getParent()->getRect().getHeight() : U32_MAX; | 2306 | |
2307 | U32 max_width = menu_region_rect.getWidth(); | ||
2308 | U32 max_height = menu_region_rect.getHeight(); | ||
2355 | // *FIX: create the item first and then ask for its dimensions? | 2309 | // *FIX: create the item first and then ask for its dimensions? |
2356 | S32 spillover_item_width = PLAIN_PAD_PIXELS + LLFontGL::sSansSerif->getWidth( "More" ); | 2310 | S32 spillover_item_width = PLAIN_PAD_PIXELS + LLFontGL::sSansSerif->getWidth( "More" ); |
2357 | S32 spillover_item_height = llround(LLFontGL::sSansSerif->getLineHeight()) + MENU_ITEM_PADDING; | 2311 | S32 spillover_item_height = llround(LLFontGL::sSansSerif->getLineHeight()) + MENU_ITEM_PADDING; |
@@ -2472,7 +2426,7 @@ void LLMenuGL::createSpilloverBranch() | |||
2472 | // technically, you can't tear off spillover menus, but we're passing the handle | 2426 | // technically, you can't tear off spillover menus, but we're passing the handle |
2473 | // along just to be safe | 2427 | // along just to be safe |
2474 | mSpilloverMenu = new LLMenuGL("More", "More", mParentFloaterHandle); | 2428 | mSpilloverMenu = new LLMenuGL("More", "More", mParentFloaterHandle); |
2475 | mSpilloverMenu->updateParent(getParent()); | 2429 | mSpilloverMenu->updateParent(LLMenuGL::sMenuContainer); |
2476 | // Inherit colors | 2430 | // Inherit colors |
2477 | mSpilloverMenu->setBackgroundColor( mBackgroundColor ); | 2431 | mSpilloverMenu->setBackgroundColor( mBackgroundColor ); |
2478 | mSpilloverMenu->setCanTearOff(FALSE); | 2432 | mSpilloverMenu->setCanTearOff(FALSE); |
@@ -3110,7 +3064,6 @@ void LLMenuGL::setVisible(BOOL visible) | |||
3110 | mFadeTimer.stop(); | 3064 | mFadeTimer.stop(); |
3111 | } | 3065 | } |
3112 | 3066 | ||
3113 | //gViewerWindow->finishFastFrame(); | ||
3114 | LLView::setVisible(visible); | 3067 | LLView::setVisible(visible); |
3115 | } | 3068 | } |
3116 | } | 3069 | } |
@@ -3157,6 +3110,8 @@ void hide_top_view( LLView* view ) | |||
3157 | // static | 3110 | // static |
3158 | void LLMenuGL::showPopup(LLView* spawning_view, LLMenuGL* menu, S32 x, S32 y) | 3111 | void LLMenuGL::showPopup(LLView* spawning_view, LLMenuGL* menu, S32 x, S32 y) |
3159 | { | 3112 | { |
3113 | const LLRect menu_region_rect = LLMenuGL::sMenuContainer->getMenuRect(); | ||
3114 | |||
3160 | const S32 HPAD = 2; | 3115 | const S32 HPAD = 2; |
3161 | LLRect rect = menu->getRect(); | 3116 | LLRect rect = menu->getRect(); |
3162 | //LLView* cur_view = spawning_view; | 3117 | //LLView* cur_view = spawning_view; |
@@ -3177,13 +3132,15 @@ void LLMenuGL::showPopup(LLView* spawning_view, LLMenuGL* menu, S32 x, S32 y) | |||
3177 | // &left, &bottom ); | 3132 | // &left, &bottom ); |
3178 | S32 delta_x = 0; | 3133 | S32 delta_x = 0; |
3179 | S32 delta_y = 0; | 3134 | S32 delta_y = 0; |
3180 | if( bottom < 0 ) | 3135 | if( bottom < menu_region_rect.mBottom ) |
3181 | { | 3136 | { |
3182 | delta_y = -bottom; | 3137 | // At this point, we need to move the context menu to the |
3138 | // other side of the mouse. | ||
3139 | //delta_y = menu_region_rect.mBottom - bottom; | ||
3140 | delta_y = (rect.getHeight() + 2 * HPAD); | ||
3183 | } | 3141 | } |
3184 | 3142 | ||
3185 | S32 parent_width = menu->getParent()->getRect().getWidth(); | 3143 | if( left > menu_region_rect.mRight - rect.getWidth() ) |
3186 | if( left > parent_width - rect.getWidth() ) | ||
3187 | { | 3144 | { |
3188 | // At this point, we need to move the context menu to the | 3145 | // At this point, we need to move the context menu to the |
3189 | // other side of the mouse. | 3146 | // other side of the mouse. |
@@ -3283,7 +3240,7 @@ void LLPieMenuBranch::doIt( void ) | |||
3283 | S32 center_y; | 3240 | S32 center_y; |
3284 | parent->localPointToScreen(rect.getWidth() / 2, rect.getHeight() / 2, ¢er_x, ¢er_y); | 3241 | parent->localPointToScreen(rect.getWidth() / 2, rect.getHeight() / 2, ¢er_x, ¢er_y); |
3285 | 3242 | ||
3286 | parent->hide(TRUE); | 3243 | parent->hide(FALSE); |
3287 | mBranch->show( center_x, center_y, FALSE ); | 3244 | mBranch->show( center_x, center_y, FALSE ); |
3288 | } | 3245 | } |
3289 | 3246 | ||
@@ -3473,6 +3430,11 @@ BOOL LLPieMenu::handleMouseDown( S32 x, S32 y, MASK mask ) | |||
3473 | // to make sure it's within the item's rectangle | 3430 | // to make sure it's within the item's rectangle |
3474 | handled = item->handleMouseDown( 0, 0, mask ); | 3431 | handled = item->handleMouseDown( 0, 0, mask ); |
3475 | } | 3432 | } |
3433 | else if (!mRightMouseDown) | ||
3434 | { | ||
3435 | // call hidemenus to make sure transient selections get cleared | ||
3436 | ((LLMenuHolderGL*)getParent())->hideMenus(); | ||
3437 | } | ||
3476 | 3438 | ||
3477 | // always handle mouse down as mouse up will close open menus | 3439 | // always handle mouse down as mouse up will close open menus |
3478 | return handled; | 3440 | return handled; |
@@ -3546,6 +3508,11 @@ BOOL LLPieMenu::handleMouseUp( S32 x, S32 y, MASK mask ) | |||
3546 | hide(TRUE); | 3508 | hide(TRUE); |
3547 | } | 3509 | } |
3548 | } | 3510 | } |
3511 | else if (!mRightMouseDown) | ||
3512 | { | ||
3513 | // call hidemenus to make sure transient selections get cleared | ||
3514 | ((LLMenuHolderGL*)getParent())->hideMenus(); | ||
3515 | } | ||
3549 | 3516 | ||
3550 | if (handled) | 3517 | if (handled) |
3551 | { | 3518 | { |
@@ -3555,7 +3522,7 @@ BOOL LLPieMenu::handleMouseUp( S32 x, S32 y, MASK mask ) | |||
3555 | if (!handled && !mUseInfiniteRadius) | 3522 | if (!handled && !mUseInfiniteRadius) |
3556 | { | 3523 | { |
3557 | // call hidemenus to make sure transient selections get cleared | 3524 | // call hidemenus to make sure transient selections get cleared |
3558 | ((LLMenuHolderGL*)getParent())->hideMenus(); | 3525 | sMenuContainer->hideMenus(); |
3559 | } | 3526 | } |
3560 | 3527 | ||
3561 | if (mFirstMouseDown) | 3528 | if (mFirstMouseDown) |
@@ -3866,10 +3833,9 @@ void LLPieMenu::show(S32 x, S32 y, BOOL mouse_down) | |||
3866 | S32 width = mRect.getWidth(); | 3833 | S32 width = mRect.getWidth(); |
3867 | S32 height = mRect.getHeight(); | 3834 | S32 height = mRect.getHeight(); |
3868 | 3835 | ||
3869 | LLView* parent_view = getParent(); | 3836 | const LLRect menu_region_rect = LLMenuGL::sMenuContainer->getMenuRect(); |
3870 | S32 menu_region_width = parent_view->getRect().getWidth(); | ||
3871 | S32 menu_region_height = parent_view->getRect().getHeight(); | ||
3872 | 3837 | ||
3838 | LLView* parent_view = getParent(); | ||
3873 | BOOL moved = FALSE; | 3839 | BOOL moved = FALSE; |
3874 | 3840 | ||
3875 | S32 local_x, local_y; | 3841 | S32 local_x, local_y; |
@@ -3879,36 +3845,36 @@ void LLPieMenu::show(S32 x, S32 y, BOOL mouse_down) | |||
3879 | arrange(); | 3845 | arrange(); |
3880 | 3846 | ||
3881 | // Adjust the pie rectangle to keep it on screen | 3847 | // Adjust the pie rectangle to keep it on screen |
3882 | if (mRect.mLeft < 0) | 3848 | if (mRect.mLeft < menu_region_rect.mLeft) |
3883 | { | 3849 | { |
3884 | //mShiftHoriz = 0 - mRect.mLeft; | 3850 | //mShiftHoriz = menu_region_rect.mLeft - mRect.mLeft; |
3885 | //mRect.translate( mShiftHoriz, 0 ); | 3851 | //mRect.translate( mShiftHoriz, 0 ); |
3886 | mRect.translate( 0 - mRect.mLeft, 0 ); | 3852 | mRect.translate( menu_region_rect.mLeft - mRect.mLeft, 0 ); |
3887 | moved = TRUE; | 3853 | moved = TRUE; |
3888 | } | 3854 | } |
3889 | 3855 | ||
3890 | if (mRect.mRight > menu_region_width) | 3856 | if (mRect.mRight > menu_region_rect.mRight) |
3891 | { | 3857 | { |
3892 | //mShiftHoriz = menu_region_width - mRect.mRight; | 3858 | //mShiftHoriz = menu_region_rect.mRight - mRect.mRight; |
3893 | //mRect.translate( mShiftHoriz, 0); | 3859 | //mRect.translate( mShiftHoriz, 0); |
3894 | mRect.translate( menu_region_width - mRect.mRight, 0 ); | 3860 | mRect.translate( menu_region_rect.mRight - mRect.mRight, 0 ); |
3895 | moved = TRUE; | 3861 | moved = TRUE; |
3896 | } | 3862 | } |
3897 | 3863 | ||
3898 | if (mRect.mBottom < 0) | 3864 | if (mRect.mBottom < menu_region_rect.mBottom) |
3899 | { | 3865 | { |
3900 | //mShiftVert = -mRect.mBottom; | 3866 | //mShiftVert = menu_region_rect.mBottom - mRect.mBottom; |
3901 | //mRect.translate( 0, mShiftVert ); | 3867 | //mRect.translate( 0, mShiftVert ); |
3902 | mRect.translate( 0, 0 - mRect.mBottom ); | 3868 | mRect.translate( 0, menu_region_rect.mBottom - mRect.mBottom ); |
3903 | moved = TRUE; | 3869 | moved = TRUE; |
3904 | } | 3870 | } |
3905 | 3871 | ||
3906 | 3872 | ||
3907 | if (mRect.mTop > menu_region_height) | 3873 | if (mRect.mTop > menu_region_rect.mTop) |
3908 | { | 3874 | { |
3909 | //mShiftVert = menu_region_height - mRect.mTop; | 3875 | //mShiftVert = menu_region_rect.mTop - mRect.mTop; |
3910 | //mRect.translate( 0, mShiftVert ); | 3876 | //mRect.translate( 0, mShiftVert ); |
3911 | mRect.translate( 0, menu_region_height - mRect.mTop ); | 3877 | mRect.translate( 0, menu_region_rect.mTop - mRect.mTop ); |
3912 | moved = TRUE; | 3878 | moved = TRUE; |
3913 | } | 3879 | } |
3914 | 3880 | ||
@@ -4067,9 +4033,9 @@ LLView* LLMenuBarGL::fromXML(LLXMLNodePtr node, LLView *parent, LLUICtrlFactory | |||
4067 | menu->setCanTearOff(TRUE, parent_handle); | 4033 | menu->setCanTearOff(TRUE, parent_handle); |
4068 | } | 4034 | } |
4069 | menubar->appendMenu(menu); | 4035 | menubar->appendMenu(menu); |
4070 | if (LLMenuGL::sDefaultMenuContainer != NULL) | 4036 | if (LLMenuGL::sMenuContainer != NULL) |
4071 | { | 4037 | { |
4072 | menu->updateParent(LLMenuGL::sDefaultMenuContainer); | 4038 | menu->updateParent(LLMenuGL::sMenuContainer); |
4073 | } | 4039 | } |
4074 | else | 4040 | else |
4075 | { | 4041 | { |
@@ -4198,9 +4164,9 @@ void LLMenuBarGL::checkMenuTrigger() | |||
4198 | 4164 | ||
4199 | BOOL LLMenuBarGL::jumpKeysActive() | 4165 | BOOL LLMenuBarGL::jumpKeysActive() |
4200 | { | 4166 | { |
4201 | // require item to be highlighted to activate key triggers | 4167 | // require user to be in keyboard navigation mode to activate key triggers |
4202 | // as menu bars are always visible | 4168 | // as menu bars are always visible and it is easy to leave the mouse cursor over them |
4203 | return getHighlightedItem() && LLMenuGL::jumpKeysActive(); | 4169 | return LLMenuGL::getKeyboardMode() && getHighlightedItem() && LLMenuGL::jumpKeysActive(); |
4204 | } | 4170 | } |
4205 | 4171 | ||
4206 | // rearrange the child rects so they fit the shape of the menu bar. | 4172 | // rearrange the child rects so they fit the shape of the menu bar. |
@@ -4218,6 +4184,7 @@ void LLMenuBarGL::arrange( void ) | |||
4218 | item->setRect( rect ); | 4184 | item->setRect( rect ); |
4219 | item->buildDrawLabel(); | 4185 | item->buildDrawLabel(); |
4220 | } | 4186 | } |
4187 | reshape(rect.mRight, rect.getHeight()); | ||
4221 | } | 4188 | } |
4222 | 4189 | ||
4223 | 4190 | ||
@@ -4430,12 +4397,12 @@ void LLMenuHolderGL::reshape(S32 width, S32 height, BOOL called_from_parent) | |||
4430 | LLView::reshape(width, height, called_from_parent); | 4397 | LLView::reshape(width, height, called_from_parent); |
4431 | } | 4398 | } |
4432 | 4399 | ||
4433 | BOOL LLMenuHolderGL::hasVisibleMenu() | 4400 | BOOL LLMenuHolderGL::hasVisibleMenu() const |
4434 | { | 4401 | { |
4435 | for ( child_list_const_iter_t child_it = getChildList()->begin(); child_it != getChildList()->end(); ++child_it) | 4402 | for ( child_list_const_iter_t child_it = getChildList()->begin(); child_it != getChildList()->end(); ++child_it) |
4436 | { | 4403 | { |
4437 | LLView* viewp = *child_it; | 4404 | LLView* viewp = *child_it; |
4438 | if (viewp->getVisible()) | 4405 | if (viewp->getVisible() && viewp->getWidgetType() != WIDGET_TYPE_MENU_BAR) |
4439 | { | 4406 | { |
4440 | return TRUE; | 4407 | return TRUE; |
4441 | } | 4408 | } |
@@ -4443,6 +4410,11 @@ BOOL LLMenuHolderGL::hasVisibleMenu() | |||
4443 | return FALSE; | 4410 | return FALSE; |
4444 | } | 4411 | } |
4445 | 4412 | ||
4413 | const LLRect LLMenuHolderGL::getMenuRect() const | ||
4414 | { | ||
4415 | return getLocalRect(); | ||
4416 | } | ||
4417 | |||
4446 | BOOL LLMenuHolderGL::hideMenus() | 4418 | BOOL LLMenuHolderGL::hideMenus() |
4447 | { | 4419 | { |
4448 | if (!mCanHide) | 4420 | if (!mCanHide) |
@@ -4452,11 +4424,13 @@ BOOL LLMenuHolderGL::hideMenus() | |||
4452 | BOOL menu_visible = hasVisibleMenu(); | 4424 | BOOL menu_visible = hasVisibleMenu(); |
4453 | if (menu_visible) | 4425 | if (menu_visible) |
4454 | { | 4426 | { |
4427 | LLMenuGL::setKeyboardMode(FALSE); | ||
4455 | // clicked off of menu, hide them all | 4428 | // clicked off of menu, hide them all |
4456 | for ( child_list_const_iter_t child_it = getChildList()->begin(); child_it != getChildList()->end(); ++child_it) | 4429 | for ( child_list_const_iter_t child_it = getChildList()->begin(); child_it != getChildList()->end(); ++child_it) |
4457 | { | 4430 | { |
4458 | LLView* viewp = *child_it; | 4431 | LLView* viewp = *child_it; |
4459 | if (viewp->getVisible()) | 4432 | // clicks off of menu do not hide menu bar |
4433 | if (viewp->getWidgetType() != WIDGET_TYPE_MENU_BAR && viewp->getVisible()) | ||
4460 | { | 4434 | { |
4461 | viewp->setVisible(FALSE); | 4435 | viewp->setVisible(FALSE); |
4462 | } | 4436 | } |
@@ -4598,7 +4572,7 @@ LLTearOffMenu* LLTearOffMenu::create(LLMenuGL* menup) | |||
4598 | LLTearOffMenu* tearoffp = new LLTearOffMenu(menup); | 4572 | LLTearOffMenu* tearoffp = new LLTearOffMenu(menup); |
4599 | // keep onscreen | 4573 | // keep onscreen |
4600 | gFloaterView->adjustToFitScreen(tearoffp, FALSE); | 4574 | gFloaterView->adjustToFitScreen(tearoffp, FALSE); |
4601 | tearoffp->open(); | 4575 | tearoffp->open(); /* Flawfinder: ignore */ |
4602 | return tearoffp; | 4576 | return tearoffp; |
4603 | } | 4577 | } |
4604 | 4578 | ||
diff --git a/linden/indra/llui/llmenugl.h b/linden/indra/llui/llmenugl.h index 77e2b31..c4a0043 100644 --- a/linden/indra/llui/llmenugl.h +++ b/linden/indra/llui/llmenugl.h | |||
@@ -41,6 +41,7 @@ | |||
41 | #include "llview.h" | 41 | #include "llview.h" |
42 | 42 | ||
43 | class LLMenuItemGL; | 43 | class LLMenuItemGL; |
44 | class LLMenuHolderGL; | ||
44 | 45 | ||
45 | extern S32 MENU_BAR_HEIGHT; | 46 | extern S32 MENU_BAR_HEIGHT; |
46 | extern S32 MENU_BAR_WIDTH; | 47 | extern S32 MENU_BAR_WIDTH; |
@@ -163,6 +164,7 @@ public: | |||
163 | 164 | ||
164 | // LLView Functionality | 165 | // LLView Functionality |
165 | virtual BOOL handleKeyHere( KEY key, MASK mask, BOOL called_from_parent ); | 166 | virtual BOOL handleKeyHere( KEY key, MASK mask, BOOL called_from_parent ); |
167 | virtual BOOL handleMouseDown( S32 x, S32 y, MASK mask ); | ||
166 | virtual BOOL handleMouseUp( S32 x, S32 y, MASK mask ); | 168 | virtual BOOL handleMouseUp( S32 x, S32 y, MASK mask ); |
167 | virtual void draw( void ); | 169 | virtual void draw( void ); |
168 | 170 | ||
@@ -441,6 +443,7 @@ public: | |||
441 | 443 | ||
442 | static void setDefaultBackgroundColor( const LLColor4& color ); | 444 | static void setDefaultBackgroundColor( const LLColor4& color ); |
443 | void setBackgroundColor( const LLColor4& color ); | 445 | void setBackgroundColor( const LLColor4& color ); |
446 | LLColor4 getBackgroundColor(); | ||
444 | void setBackgroundVisible( BOOL b ) { mBgVisible = b; } | 447 | void setBackgroundVisible( BOOL b ) { mBgVisible = b; } |
445 | void setCanTearOff(BOOL tear_off, LLViewHandle parent_floater_handle = LLViewHandle::sDeadHandle); | 448 | void setCanTearOff(BOOL tear_off, LLViewHandle parent_floater_handle = LLViewHandle::sDeadHandle); |
446 | 449 | ||
@@ -523,7 +526,8 @@ public: | |||
523 | static BOOL getKeyboardMode() { return sKeyboardMode; } | 526 | static BOOL getKeyboardMode() { return sKeyboardMode; } |
524 | 527 | ||
525 | static void onFocusLost(LLView* old_focus); | 528 | static void onFocusLost(LLView* old_focus); |
526 | static LLView *sDefaultMenuContainer; | 529 | |
530 | static LLMenuHolderGL* sMenuContainer; | ||
527 | 531 | ||
528 | protected: | 532 | protected: |
529 | void createSpilloverBranch(); | 533 | void createSpilloverBranch(); |
@@ -558,6 +562,75 @@ protected: | |||
558 | KEY mJumpKey; | 562 | KEY mJumpKey; |
559 | }; | 563 | }; |
560 | 564 | ||
565 | |||
566 | |||
567 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
568 | // Class LLMenuItemBranchGL | ||
569 | // | ||
570 | // The LLMenuItemBranchGL represents a menu item that has a | ||
571 | // sub-menu. This is used to make cascading menus. | ||
572 | //~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||
573 | |||
574 | class LLMenuItemBranchGL : public LLMenuItemGL | ||
575 | { | ||
576 | protected: | ||
577 | LLMenuGL* mBranch; | ||
578 | |||
579 | public: | ||
580 | LLMenuItemBranchGL( const LLString& name, const LLString& label, LLMenuGL* branch, | ||
581 | KEY key = KEY_NONE, MASK mask = MASK_NONE ); | ||
582 | virtual LLXMLNodePtr getXML(bool save_children = true) const; | ||
583 | |||
584 | virtual LLView* getChildByName(const LLString& name, BOOL recurse) const; | ||
585 | |||
586 | virtual LLString getType() const { return "menu"; } | ||
587 | |||
588 | virtual EWidgetType getWidgetType() const; | ||
589 | virtual LLString getWidgetTag() const; | ||
590 | |||
591 | virtual BOOL handleMouseUp(S32 x, S32 y, MASK mask); | ||
592 | |||
593 | virtual BOOL handleAcceleratorKey(KEY key, MASK mask); | ||
594 | |||
595 | // check if we've used these accelerators already | ||
596 | virtual BOOL addToAcceleratorList(std::list <LLKeyBinding*> *listp); | ||
597 | |||
598 | // called to rebuild the draw label | ||
599 | virtual void buildDrawLabel( void ); | ||
600 | |||
601 | // doIt() - do the primary funcationality of the menu item. | ||
602 | virtual void doIt( void ); | ||
603 | |||
604 | virtual BOOL handleKey(KEY key, MASK mask, BOOL called_from_parent); | ||
605 | virtual BOOL handleUnicodeChar(llwchar uni_char, BOOL called_from_parent); | ||
606 | |||
607 | // set the hover status (called by it's menu) and if the object is | ||
608 | // active. This is used for behavior transfer. | ||
609 | virtual void setHighlight( BOOL highlight ); | ||
610 | |||
611 | virtual BOOL handleKeyHere(KEY key, MASK mask, BOOL called_from_parent); | ||
612 | |||
613 | virtual BOOL isActive() const; | ||
614 | |||
615 | virtual BOOL isOpen() const; | ||
616 | |||
617 | LLMenuGL *getBranch() const { return mBranch; } | ||
618 | |||
619 | virtual void updateBranchParent( LLView* parentp ); | ||
620 | |||
621 | // LLView Functionality | ||
622 | virtual void onVisibilityChange( BOOL curVisibilityIn ); | ||
623 | |||
624 | virtual void draw(); | ||
625 | |||
626 | virtual void setEnabledSubMenus(BOOL enabled); | ||
627 | |||
628 | virtual void openMenu(); | ||
629 | }; | ||
630 | |||
631 | |||
632 | |||
633 | |||
561 | //----------------------------------------------------------------------------- | 634 | //----------------------------------------------------------------------------- |
562 | // class LLPieMenu | 635 | // class LLPieMenu |
563 | // A circular menu of items, icons, etc. | 636 | // A circular menu of items, icons, etc. |
@@ -698,8 +771,10 @@ public: | |||
698 | virtual BOOL handleMouseDown( S32 x, S32 y, MASK mask ); | 771 | virtual BOOL handleMouseDown( S32 x, S32 y, MASK mask ); |
699 | virtual BOOL handleRightMouseDown( S32 x, S32 y, MASK mask ); | 772 | virtual BOOL handleRightMouseDown( S32 x, S32 y, MASK mask ); |
700 | 773 | ||
774 | virtual const LLRect getMenuRect() const; | ||
775 | virtual BOOL hasVisibleMenu() const; | ||
776 | |||
701 | static void setActivatedItem(LLMenuItemGL* item); | 777 | static void setActivatedItem(LLMenuItemGL* item); |
702 | BOOL hasVisibleMenu(); | ||
703 | 778 | ||
704 | protected: | 779 | protected: |
705 | static LLViewHandle sItemLastSelectedHandle; | 780 | static LLViewHandle sItemLastSelectedHandle; |
diff --git a/linden/indra/llui/llpanel.cpp b/linden/indra/llui/llpanel.cpp index c2c29bb..8d3fba6 100644 --- a/linden/indra/llui/llpanel.cpp +++ b/linden/indra/llui/llpanel.cpp | |||
@@ -183,10 +183,11 @@ void LLPanel::draw() | |||
183 | // draw background | 183 | // draw background |
184 | if( mBgVisible ) | 184 | if( mBgVisible ) |
185 | { | 185 | { |
186 | S32 left = LLPANEL_BORDER_WIDTH; | 186 | //RN: I don't see the point of this |
187 | S32 top = mRect.getHeight() - LLPANEL_BORDER_WIDTH; | 187 | S32 left = 0;//LLPANEL_BORDER_WIDTH; |
188 | S32 right = mRect.getWidth() - LLPANEL_BORDER_WIDTH; | 188 | S32 top = mRect.getHeight();// - LLPANEL_BORDER_WIDTH; |
189 | S32 bottom = LLPANEL_BORDER_WIDTH; | 189 | S32 right = mRect.getWidth();// - LLPANEL_BORDER_WIDTH; |
190 | S32 bottom = 0;//LLPANEL_BORDER_WIDTH; | ||
190 | 191 | ||
191 | if (mBgOpaque ) | 192 | if (mBgOpaque ) |
192 | { | 193 | { |
@@ -357,16 +358,6 @@ BOOL LLPanel::handleKeyHere( KEY key, MASK mask, BOOL called_from_parent ) | |||
357 | gFocusMgr.childHasKeyboardFocus(this) && !called_from_parent ) | 358 | gFocusMgr.childHasKeyboardFocus(this) && !called_from_parent ) |
358 | { | 359 | { |
359 | LLUICtrl* cur_focus = gFocusMgr.getKeyboardFocus(); | 360 | LLUICtrl* cur_focus = gFocusMgr.getKeyboardFocus(); |
360 | if (key == KEY_RETURN && mask == MASK_NONE) | ||
361 | { | ||
362 | // set keyboard focus to self to trigger commitOnFocusLost behavior on current ctrl | ||
363 | if (cur_focus && cur_focus->acceptsTextInput()) | ||
364 | { | ||
365 | cur_focus->onCommit(); | ||
366 | handled = TRUE; | ||
367 | } | ||
368 | } | ||
369 | |||
370 | // If we have a default button, click it when | 361 | // If we have a default button, click it when |
371 | // return is pressed, unless current focus is a return-capturing button | 362 | // return is pressed, unless current focus is a return-capturing button |
372 | // in which case *that* button will handle the return key | 363 | // in which case *that* button will handle the return key |
@@ -382,6 +373,16 @@ BOOL LLPanel::handleKeyHere( KEY key, MASK mask, BOOL called_from_parent ) | |||
382 | handled = TRUE; | 373 | handled = TRUE; |
383 | } | 374 | } |
384 | } | 375 | } |
376 | |||
377 | if (key == KEY_RETURN && mask == MASK_NONE) | ||
378 | { | ||
379 | // set keyboard focus to self to trigger commitOnFocusLost behavior on current ctrl | ||
380 | if (cur_focus && cur_focus->acceptsTextInput()) | ||
381 | { | ||
382 | cur_focus->onCommit(); | ||
383 | handled = TRUE; | ||
384 | } | ||
385 | } | ||
385 | } | 386 | } |
386 | 387 | ||
387 | return handled; | 388 | return handled; |
@@ -478,6 +479,11 @@ void LLPanel::setBackgroundColor(const LLColor4& color) | |||
478 | mBgColorOpaque = color; | 479 | mBgColorOpaque = color; |
479 | } | 480 | } |
480 | 481 | ||
482 | LLColor4 LLPanel::getBackgroundColor() | ||
483 | { | ||
484 | return mBgColorOpaque; | ||
485 | } | ||
486 | |||
481 | void LLPanel::setTransparentColor(const LLColor4& color) | 487 | void LLPanel::setTransparentColor(const LLColor4& color) |
482 | { | 488 | { |
483 | mBgColorAlpha = color; | 489 | mBgColorAlpha = color; |
diff --git a/linden/indra/llui/llpanel.h b/linden/indra/llui/llpanel.h index 975c747..d9bd19c 100644 --- a/linden/indra/llui/llpanel.h +++ b/linden/indra/llui/llpanel.h | |||
@@ -36,6 +36,7 @@ | |||
36 | #include "llviewborder.h" | 36 | #include "llviewborder.h" |
37 | #include "v4color.h" | 37 | #include "v4color.h" |
38 | #include <list> | 38 | #include <list> |
39 | #include <queue> | ||
39 | 40 | ||
40 | const S32 LLPANEL_BORDER_WIDTH = 1; | 41 | const S32 LLPANEL_BORDER_WIDTH = 1; |
41 | const BOOL BORDER_YES = TRUE; | 42 | const BOOL BORDER_YES = TRUE; |
@@ -105,6 +106,7 @@ public: | |||
105 | static BOOL nextAlert(LLAlertInfo &alert); | 106 | static BOOL nextAlert(LLAlertInfo &alert); |
106 | 107 | ||
107 | void setBackgroundColor( const LLColor4& color ); | 108 | void setBackgroundColor( const LLColor4& color ); |
109 | LLColor4 getBackgroundColor(); | ||
108 | void setTransparentColor(const LLColor4& color); | 110 | void setTransparentColor(const LLColor4& color); |
109 | void setBackgroundVisible( BOOL b ) { mBgVisible = b; } | 111 | void setBackgroundVisible( BOOL b ) { mBgVisible = b; } |
110 | void setBackgroundOpaque(BOOL b) { mBgOpaque = b; } | 112 | void setBackgroundOpaque(BOOL b) { mBgOpaque = b; } |
diff --git a/linden/indra/llui/llresmgr.cpp b/linden/indra/llui/llresmgr.cpp index 3c54cf6..a73b487 100644 --- a/linden/indra/llui/llresmgr.cpp +++ b/linden/indra/llui/llresmgr.cpp | |||
@@ -321,8 +321,8 @@ void LLResMgr::getMonetaryString( LLString& output, S32 input ) const | |||
321 | } | 321 | } |
322 | S32 group_count = cur_group; | 322 | S32 group_count = cur_group; |
323 | 323 | ||
324 | char reversed_output[20] = ""; | 324 | char reversed_output[20] = ""; /* Flawfinder: ignore */ |
325 | char forward_output[20] = ""; | 325 | char forward_output[20] = ""; /* Flawfinder: ignore */ |
326 | S32 output_pos = 0; | 326 | S32 output_pos = 0; |
327 | 327 | ||
328 | cur_group = 0; | 328 | cur_group = 0; |
diff --git a/linden/indra/llui/llrootview.cpp b/linden/indra/llui/llrootview.cpp index 699a2f6..49e512c 100644 --- a/linden/indra/llui/llrootview.cpp +++ b/linden/indra/llui/llrootview.cpp | |||
@@ -1,8 +1,8 @@ | |||
1 | /** | 1 | /** |
2 | * @file llrootview.cpp | 2 | * @file llrootview.cpp |
3 | * @brief Container for all other views in an application | 3 | * @brief Container for all other views in an application |
4 | * | 4 | * |
5 | * Copyright (c) 2006-2007, Linden Research, Inc. | 5 | * Copyright (c) 2006-2007, Linden Research, Inc. |
6 | * | 6 | * |
7 | * The source code in this file ("Source Code") is provided by Linden Lab | 7 | * The source code in this file ("Source Code") is provided by Linden Lab |
8 | * to you under the terms of the GNU General Public License, version 2.0 | 8 | * to you under the terms of the GNU General Public License, version 2.0 |
@@ -22,23 +22,23 @@ | |||
22 | * | 22 | * |
23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | 23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO |
24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | 24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, |
25 | * COMPLETENESS OR PERFORMANCE. | 25 | * COMPLETENESS OR PERFORMANCE. |
26 | */ | 26 | */ |
27 | 27 | ||
28 | #include "llrootview.h" | 28 | #include "llrootview.h" |
29 | 29 | ||
30 | LLRootView::LLRootView(const LLString& name, const LLRect& rect, BOOL mouse_opaque, U32 follows) | 30 | LLRootView::LLRootView(const LLString& name, const LLRect& rect, BOOL mouse_opaque, U32 follows) |
31 | : LLView(name,rect,mouse_opaque,follows) | 31 | : LLView(name,rect,mouse_opaque,follows) |
32 | { } | 32 | { } |
33 | 33 | ||
34 | // virtual | 34 | // virtual |
35 | EWidgetType LLRootView::getWidgetType() const | 35 | EWidgetType LLRootView::getWidgetType() const |
36 | { | 36 | { |
37 | return WIDGET_TYPE_ROOT_VIEW; | 37 | return WIDGET_TYPE_ROOT_VIEW; |
38 | } | 38 | } |
39 | 39 | ||
40 | // virtual | 40 | // virtual |
41 | LLString LLRootView::getWidgetTag() const | 41 | LLString LLRootView::getWidgetTag() const |
42 | { | 42 | { |
43 | return LL_ROOT_VIEW_TAG; | 43 | return LL_ROOT_VIEW_TAG; |
44 | } | 44 | } |
diff --git a/linden/indra/llui/llrootview.h b/linden/indra/llui/llrootview.h index 212b93b..84a989b 100644 --- a/linden/indra/llui/llrootview.h +++ b/linden/indra/llui/llrootview.h | |||
@@ -1,8 +1,8 @@ | |||
1 | /** | 1 | /** |
2 | * @file llrootview.h | 2 | * @file llrootview.h |
3 | * @brief Container for all other views in an application | 3 | * @brief Container for all other views in an application |
4 | * | 4 | * |
5 | * Copyright (c) 2006-2007, Linden Research, Inc. | 5 | * Copyright (c) 2006-2007, Linden Research, Inc. |
6 | * | 6 | * |
7 | * The source code in this file ("Source Code") is provided by Linden Lab | 7 | * The source code in this file ("Source Code") is provided by Linden Lab |
8 | * to you under the terms of the GNU General Public License, version 2.0 | 8 | * to you under the terms of the GNU General Public License, version 2.0 |
@@ -22,21 +22,21 @@ | |||
22 | * | 22 | * |
23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | 23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO |
24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | 24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, |
25 | * COMPLETENESS OR PERFORMANCE. | 25 | * COMPLETENESS OR PERFORMANCE. |
26 | */ | 26 | */ |
27 | 27 | ||
28 | #ifndef LLROOTVIEW_H | 28 | #ifndef LLROOTVIEW_H |
29 | #define LLROOTVIEW_H | 29 | #define LLROOTVIEW_H |
30 | 30 | ||
31 | #include "llview.h" | 31 | #include "llview.h" |
32 | 32 | ||
33 | class LLRootView : public LLView | 33 | class LLRootView : public LLView |
34 | { | 34 | { |
35 | public: | 35 | public: |
36 | LLRootView(const LLString& name, const LLRect& rect, BOOL mouse_opaque, U32 follows=FOLLOWS_NONE); | 36 | LLRootView(const LLString& name, const LLRect& rect, BOOL mouse_opaque, U32 follows=FOLLOWS_NONE); |
37 | 37 | ||
38 | /*virtual*/ EWidgetType getWidgetType() const; | 38 | /*virtual*/ EWidgetType getWidgetType() const; |
39 | /*virtual*/ LLString getWidgetTag() const; | 39 | /*virtual*/ LLString getWidgetTag() const; |
40 | }; | 40 | }; |
41 | 41 | ||
42 | #endif | 42 | #endif |
diff --git a/linden/indra/llui/llscrollbar.cpp b/linden/indra/llui/llscrollbar.cpp index da3e472..578fdb1 100644 --- a/linden/indra/llui/llscrollbar.cpp +++ b/linden/indra/llui/llscrollbar.cpp | |||
@@ -405,21 +405,23 @@ BOOL LLScrollbar::handleScrollWheel(S32 x, S32 y, S32 clicks) | |||
405 | BOOL LLScrollbar::handleDragAndDrop(S32 x, S32 y, MASK mask, BOOL drop, | 405 | BOOL LLScrollbar::handleDragAndDrop(S32 x, S32 y, MASK mask, BOOL drop, |
406 | EDragAndDropType cargo_type, void *carge_data, EAcceptance *accept, LLString &tooltip_msg) | 406 | EDragAndDropType cargo_type, void *carge_data, EAcceptance *accept, LLString &tooltip_msg) |
407 | { | 407 | { |
408 | if (!drop) | 408 | // enable this to get drag and drop to control scrollbars |
409 | { | 409 | //if (!drop) |
410 | //TODO: refactor this | 410 | //{ |
411 | S32 variable_lines = getDocPosMax(); | 411 | // //TODO: refactor this |
412 | S32 pos = (VERTICAL == mOrientation) ? y : x; | 412 | // S32 variable_lines = getDocPosMax(); |
413 | S32 thumb_length = (VERTICAL == mOrientation) ? mThumbRect.getHeight() : mThumbRect.getWidth(); | 413 | // S32 pos = (VERTICAL == mOrientation) ? y : x; |
414 | S32 thumb_track_length = (VERTICAL == mOrientation) ? (mRect.getHeight() - 2 * SCROLLBAR_SIZE) : (mRect.getWidth() - 2 * SCROLLBAR_SIZE); | 414 | // S32 thumb_length = (VERTICAL == mOrientation) ? mThumbRect.getHeight() : mThumbRect.getWidth(); |
415 | S32 usable_track_length = thumb_track_length - thumb_length; | 415 | // S32 thumb_track_length = (VERTICAL == mOrientation) ? (mRect.getHeight() - 2 * SCROLLBAR_SIZE) : (mRect.getWidth() - 2 * SCROLLBAR_SIZE); |
416 | F32 ratio = (VERTICAL == mOrientation) ? F32(pos - SCROLLBAR_SIZE - thumb_length) / usable_track_length | 416 | // S32 usable_track_length = thumb_track_length - thumb_length; |
417 | : F32(pos - SCROLLBAR_SIZE) / usable_track_length; | 417 | // F32 ratio = (VERTICAL == mOrientation) ? F32(pos - SCROLLBAR_SIZE - thumb_length) / usable_track_length |
418 | S32 new_pos = (VERTICAL == mOrientation) ? llclamp( S32(variable_lines - ratio * variable_lines + 0.5f), 0, variable_lines ) | 418 | // : F32(pos - SCROLLBAR_SIZE) / usable_track_length; |
419 | : llclamp( S32(ratio * variable_lines + 0.5f), 0, variable_lines ); | 419 | // S32 new_pos = (VERTICAL == mOrientation) ? llclamp( S32(variable_lines - ratio * variable_lines + 0.5f), 0, variable_lines ) |
420 | changeLine( new_pos - mDocPos, TRUE ); | 420 | // : llclamp( S32(ratio * variable_lines + 0.5f), 0, variable_lines ); |
421 | } | 421 | // changeLine( new_pos - mDocPos, TRUE ); |
422 | return TRUE; | 422 | //} |
423 | //return TRUE; | ||
424 | return FALSE; | ||
423 | } | 425 | } |
424 | 426 | ||
425 | BOOL LLScrollbar::handleMouseUp(S32 x, S32 y, MASK mask) | 427 | BOOL LLScrollbar::handleMouseUp(S32 x, S32 y, MASK mask) |
diff --git a/linden/indra/llui/llscrolllistctrl.cpp b/linden/indra/llui/llscrolllistctrl.cpp index df4ca64..4d5c49f 100644 --- a/linden/indra/llui/llscrolllistctrl.cpp +++ b/linden/indra/llui/llscrolllistctrl.cpp | |||
@@ -95,7 +95,7 @@ protected: | |||
95 | // LLScrollListIcon | 95 | // LLScrollListIcon |
96 | // | 96 | // |
97 | LLScrollListIcon::LLScrollListIcon(LLImageGL* icon, S32 width, LLUUID image_id) : | 97 | LLScrollListIcon::LLScrollListIcon(LLImageGL* icon, S32 width, LLUUID image_id) : |
98 | mIcon(icon), mImageUUID(image_id.getString()) | 98 | mIcon(icon), mImageUUID(image_id.asString()) |
99 | { | 99 | { |
100 | if (width) | 100 | if (width) |
101 | { | 101 | { |
@@ -156,13 +156,15 @@ BOOL LLScrollListCheck::handleClick() | |||
156 | // | 156 | // |
157 | U32 LLScrollListText::sCount = 0; | 157 | U32 LLScrollListText::sCount = 0; |
158 | 158 | ||
159 | LLScrollListText::LLScrollListText( const LLString& text, const LLFontGL* font, S32 width, U8 font_style, LLColor4& color, BOOL use_color, BOOL visible) | 159 | LLScrollListText::LLScrollListText( const LLString& text, const LLFontGL* font, S32 width, U8 font_style, LLFontGL::HAlign font_alignment, LLColor4& color, BOOL use_color, BOOL visible) |
160 | : mText( text ), | 160 | : mText( text ), |
161 | mFont( font ), | 161 | mFont( font ), |
162 | mFontStyle( font_style ), | 162 | mFontStyle( font_style ), |
163 | mFontAlignment( font_alignment ), | ||
163 | mWidth( width ), | 164 | mWidth( width ), |
164 | mVisible( visible ), | 165 | mVisible( visible ), |
165 | mHighlightChars( 0 ) | 166 | mHighlightCount( 0 ), |
167 | mHighlightOffset( 0 ) | ||
166 | { | 168 | { |
167 | if (use_color) | 169 | if (use_color) |
168 | { | 170 | { |
@@ -181,10 +183,6 @@ LLScrollListText::LLScrollListText( const LLString& text, const LLFontGL* font, | |||
181 | { | 183 | { |
182 | mRoundedRectImage = LLUI::sImageProvider->getUIImageByID(LLUUID(LLUI::sAssetsGroup->getString("rounded_square.tga"))); | 184 | mRoundedRectImage = LLUI::sImageProvider->getUIImageByID(LLUUID(LLUI::sAssetsGroup->getString("rounded_square.tga"))); |
183 | } | 185 | } |
184 | |||
185 | // Yes, that's four dots, because we want it to have a little | ||
186 | // padding, in proportion to the font size. | ||
187 | mEllipsisWidth = (S32)mFont->getWidth("...."); | ||
188 | } | 186 | } |
189 | 187 | ||
190 | LLScrollListText::~LLScrollListText() | 188 | LLScrollListText::~LLScrollListText() |
@@ -216,13 +214,26 @@ void LLScrollListText::drawToWidth(S32 width, const LLColor4& color, const LLCol | |||
216 | display_color = &color; | 214 | display_color = &color; |
217 | } | 215 | } |
218 | 216 | ||
219 | if (mHighlightChars > 0) | 217 | if (mHighlightCount > 0) |
220 | { | 218 | { |
221 | mRoundedRectImage->bind(); | 219 | mRoundedRectImage->bind(); |
222 | glColor4fv(highlight_color.mV); | 220 | glColor4fv(highlight_color.mV); |
223 | gl_segmented_rect_2d_tex(-2, | 221 | S32 left = 0; |
222 | switch(mFontAlignment) | ||
223 | { | ||
224 | case LLFontGL::LEFT: | ||
225 | left = mFont->getWidth(mText.getString(), 0, mHighlightOffset); | ||
226 | break; | ||
227 | case LLFontGL::RIGHT: | ||
228 | left = width - mFont->getWidth(mText.getString(), mHighlightOffset, S32_MAX); | ||
229 | break; | ||
230 | case LLFontGL::HCENTER: | ||
231 | left = (width - mFont->getWidth(mText.getString())) / 2; | ||
232 | break; | ||
233 | } | ||
234 | gl_segmented_rect_2d_tex(left - 2, | ||
224 | llround(mFont->getLineHeight()) + 1, | 235 | llround(mFont->getLineHeight()) + 1, |
225 | mFont->getWidth(mText.getString(), 0, mHighlightChars) + 1, | 236 | left + mFont->getWidth(mText.getString(), mHighlightOffset, mHighlightCount) + 1, |
226 | 1, | 237 | 1, |
227 | mRoundedRectImage->getWidth(), | 238 | mRoundedRectImage->getWidth(), |
228 | mRoundedRectImage->getHeight(), | 239 | mRoundedRectImage->getHeight(), |
@@ -232,21 +243,28 @@ void LLScrollListText::drawToWidth(S32 width, const LLColor4& color, const LLCol | |||
232 | // Try to draw the entire string | 243 | // Try to draw the entire string |
233 | F32 right_x; | 244 | F32 right_x; |
234 | U32 string_chars = mText.length(); | 245 | U32 string_chars = mText.length(); |
235 | U32 drawn_chars = mFont->render(mText.getWString(), 0, 0, 2, | 246 | F32 start_x = 0.f; |
236 | *display_color, | 247 | switch(mFontAlignment) |
237 | LLFontGL::LEFT, | 248 | { |
238 | LLFontGL::BOTTOM, | 249 | case LLFontGL::LEFT: |
239 | mFontStyle, | 250 | start_x = 0.f; |
240 | string_chars, | 251 | break; |
241 | width - mEllipsisWidth, | 252 | case LLFontGL::RIGHT: |
242 | &right_x, FALSE); | 253 | start_x = (F32)width; |
243 | 254 | break; | |
244 | // If we didn't get the whole string, abbreviate | 255 | case LLFontGL::HCENTER: |
245 | if (drawn_chars < string_chars && drawn_chars) | 256 | start_x = (F32)width * 0.5f; |
246 | { | 257 | break; |
247 | mFont->renderUTF8("...", 0, right_x, 0.f, color, LLFontGL::LEFT, LLFontGL::BOTTOM, mFontStyle, | 258 | } |
248 | S32_MAX, S32_MAX, NULL, FALSE); | 259 | mFont->render(mText.getWString(), 0, |
249 | } | 260 | start_x, 2.f, |
261 | *display_color, | ||
262 | mFontAlignment, | ||
263 | LLFontGL::BOTTOM, | ||
264 | mFontStyle, | ||
265 | string_chars, | ||
266 | width, | ||
267 | &right_x, FALSE, TRUE); | ||
250 | } | 268 | } |
251 | 269 | ||
252 | 270 | ||
@@ -378,20 +396,21 @@ LLScrollListCtrl::LLScrollListCtrl(const LLString& name, const LLRect& rect, | |||
378 | mFgUnselectedColor( LLUI::sColorsGroup->getColor("ScrollUnselectedColor") ), | 396 | mFgUnselectedColor( LLUI::sColorsGroup->getColor("ScrollUnselectedColor") ), |
379 | mFgDisabledColor( LLUI::sColorsGroup->getColor("ScrollDisabledColor") ), | 397 | mFgDisabledColor( LLUI::sColorsGroup->getColor("ScrollDisabledColor") ), |
380 | mHighlightedColor( LLUI::sColorsGroup->getColor("ScrollHighlightedColor") ), | 398 | mHighlightedColor( LLUI::sColorsGroup->getColor("ScrollHighlightedColor") ), |
381 | mHighlightedItem(-1), | ||
382 | mBorderThickness( 2 ), | 399 | mBorderThickness( 2 ), |
383 | mOnDoubleClickCallback( NULL ), | 400 | mOnDoubleClickCallback( NULL ), |
384 | mOnMaximumSelectCallback( NULL ), | 401 | mOnMaximumSelectCallback( NULL ), |
385 | mOnSortChangedCallback( NULL ), | 402 | mOnSortChangedCallback( NULL ), |
386 | mDrewSelected(FALSE), | 403 | mHighlightedItem(-1), |
387 | mBorder(NULL), | 404 | mBorder(NULL), |
388 | mSearchColumn(0), | ||
389 | mDefaultColumn("SIMPLE"), | 405 | mDefaultColumn("SIMPLE"), |
406 | mSearchColumn(0), | ||
390 | 407 | ||
391 | mNumDynamicWidthColumns(0), | 408 | mNumDynamicWidthColumns(0), |
392 | mTotalStaticColumnWidth(0), | 409 | mTotalStaticColumnWidth(0), |
393 | mSortColumn(0), | 410 | mSortColumn(0), |
394 | mSortAscending(TRUE) | 411 | mSortAscending(TRUE), |
412 | |||
413 | mDrewSelected(FALSE) | ||
395 | { | 414 | { |
396 | mItemListRect.setOriginAndSize( | 415 | mItemListRect.setOriginAndSize( |
397 | mBorderThickness + LIST_BORDER_PAD, | 416 | mBorderThickness + LIST_BORDER_PAD, |
@@ -1160,11 +1179,17 @@ BOOL LLScrollListCtrl::selectSimpleItemByPrefix(const LLWString& target, BOOL ca | |||
1160 | { | 1179 | { |
1161 | LLWString::toLower(item_label); | 1180 | LLWString::toLower(item_label); |
1162 | } | 1181 | } |
1182 | // remove extraneous whitespace from searchable label | ||
1183 | LLWString trimmed_label = item_label; | ||
1184 | LLWString::trim(trimmed_label); | ||
1163 | 1185 | ||
1164 | BOOL select = item->getEnabled() && !item_label.compare(0, target_len, target_trimmed); | 1186 | BOOL select = item->getEnabled() && trimmed_label.compare(0, target_trimmed.size(), target_trimmed) == 0; |
1165 | 1187 | ||
1166 | if (select) | 1188 | if (select) |
1167 | { | 1189 | { |
1190 | // find offset of matching text (might have leading whitespace) | ||
1191 | S32 offset = item_label.find(target_trimmed); | ||
1192 | cellp->highlightText(offset, target_trimmed.size()); | ||
1168 | selectItem(item); | 1193 | selectItem(item); |
1169 | found = TRUE; | 1194 | found = TRUE; |
1170 | break; | 1195 | break; |
@@ -1466,6 +1491,9 @@ BOOL LLScrollListCtrl::handleMouseDown(S32 x, S32 y, MASK mask) | |||
1466 | { | 1491 | { |
1467 | BOOL handled = LLView::childrenHandleMouseDown(x, y, mask) != NULL; | 1492 | BOOL handled = LLView::childrenHandleMouseDown(x, y, mask) != NULL; |
1468 | 1493 | ||
1494 | // set keyboard focus first, in case click action wants to move focus elsewhere | ||
1495 | setFocus(TRUE); | ||
1496 | |||
1469 | if( !handled && mCanSelect) | 1497 | if( !handled && mCanSelect) |
1470 | { | 1498 | { |
1471 | LLScrollListItem* hit_item = hitItem(x, y); | 1499 | LLScrollListItem* hit_item = hitItem(x, y); |
@@ -1558,8 +1586,6 @@ BOOL LLScrollListCtrl::handleMouseDown(S32 x, S32 y, MASK mask) | |||
1558 | } | 1586 | } |
1559 | } | 1587 | } |
1560 | 1588 | ||
1561 | gFocusMgr.setKeyboardFocus(this, NULL); | ||
1562 | |||
1563 | return TRUE; | 1589 | return TRUE; |
1564 | } | 1590 | } |
1565 | 1591 | ||
@@ -1758,7 +1784,7 @@ BOOL LLScrollListCtrl::handleKeyHere(KEY key,MASK mask, BOOL called_from_parent | |||
1758 | LLScrollListCell* cellp = getFirstSelected()->getColumn(mSearchColumn); | 1784 | LLScrollListCell* cellp = getFirstSelected()->getColumn(mSearchColumn); |
1759 | if (cellp) | 1785 | if (cellp) |
1760 | { | 1786 | { |
1761 | cellp->highlightText(0); | 1787 | cellp->highlightText(0, 0); |
1762 | } | 1788 | } |
1763 | } | 1789 | } |
1764 | } | 1790 | } |
@@ -1767,13 +1793,6 @@ BOOL LLScrollListCtrl::handleKeyHere(KEY key,MASK mask, BOOL called_from_parent | |||
1767 | // update search string only on successful match | 1793 | // update search string only on successful match |
1768 | mSearchTimer.reset(); | 1794 | mSearchTimer.reset(); |
1769 | 1795 | ||
1770 | // highlight current search on matching item | ||
1771 | LLScrollListCell* cellp = getFirstSelected()->getColumn(mSearchColumn); | ||
1772 | if (cellp) | ||
1773 | { | ||
1774 | cellp->highlightText(mSearchString.size()); | ||
1775 | } | ||
1776 | |||
1777 | if (mCommitOnKeyboardMovement | 1796 | if (mCommitOnKeyboardMovement |
1778 | && !mCommitOnSelectionChange) | 1797 | && !mCommitOnSelectionChange) |
1779 | { | 1798 | { |
@@ -1813,13 +1832,6 @@ BOOL LLScrollListCtrl::handleUnicodeCharHere(llwchar uni_char, BOOL called_from_ | |||
1813 | mSearchString += uni_char; | 1832 | mSearchString += uni_char; |
1814 | mSearchTimer.reset(); | 1833 | mSearchTimer.reset(); |
1815 | 1834 | ||
1816 | // highlight current search on matching item | ||
1817 | LLScrollListCell* cellp = getFirstSelected()->getColumn(mSearchColumn); | ||
1818 | if (cellp) | ||
1819 | { | ||
1820 | cellp->highlightText(mSearchString.size()); | ||
1821 | } | ||
1822 | |||
1823 | if (mCommitOnKeyboardMovement | 1835 | if (mCommitOnKeyboardMovement |
1824 | && !mCommitOnSelectionChange) | 1836 | && !mCommitOnSelectionChange) |
1825 | { | 1837 | { |
@@ -1862,7 +1874,7 @@ BOOL LLScrollListCtrl::handleUnicodeCharHere(llwchar uni_char, BOOL called_from_ | |||
1862 | if (item->getEnabled() && LLStringOps::toLower(item_label[0]) == uni_char) | 1874 | if (item->getEnabled() && LLStringOps::toLower(item_label[0]) == uni_char) |
1863 | { | 1875 | { |
1864 | selectItem(item); | 1876 | selectItem(item); |
1865 | cellp->highlightText(1); | 1877 | cellp->highlightText(0, 1); |
1866 | mSearchTimer.reset(); | 1878 | mSearchTimer.reset(); |
1867 | 1879 | ||
1868 | if (mCommitOnKeyboardMovement | 1880 | if (mCommitOnKeyboardMovement |
@@ -1925,7 +1937,7 @@ void LLScrollListCtrl::selectItem(LLScrollListItem* itemp, BOOL select_single_it | |||
1925 | LLScrollListCell* cellp = mLastSelected->getColumn(mSearchColumn); | 1937 | LLScrollListCell* cellp = mLastSelected->getColumn(mSearchColumn); |
1926 | if (cellp) | 1938 | if (cellp) |
1927 | { | 1939 | { |
1928 | cellp->highlightText(0); | 1940 | cellp->highlightText(0, 0); |
1929 | } | 1941 | } |
1930 | } | 1942 | } |
1931 | if (select_single_item) | 1943 | if (select_single_item) |
@@ -1953,7 +1965,7 @@ void LLScrollListCtrl::deselectItem(LLScrollListItem* itemp) | |||
1953 | LLScrollListCell* cellp = itemp->getColumn(mSearchColumn); | 1965 | LLScrollListCell* cellp = itemp->getColumn(mSearchColumn); |
1954 | if (cellp) | 1966 | if (cellp) |
1955 | { | 1967 | { |
1956 | cellp->highlightText(0); | 1968 | cellp->highlightText(0, 0); |
1957 | } | 1969 | } |
1958 | mSelectionChanged = TRUE; | 1970 | mSelectionChanged = TRUE; |
1959 | } | 1971 | } |
@@ -2195,7 +2207,7 @@ LLView* LLScrollListCtrl::fromXML(LLXMLNodePtr node, LLView *parent, LLUICtrlFac | |||
2195 | NULL, | 2207 | NULL, |
2196 | multi_select, | 2208 | multi_select, |
2197 | draw_border); | 2209 | draw_border); |
2198 | 2210 | ||
2199 | scroll_list->setDisplayHeading(draw_heading); | 2211 | scroll_list->setDisplayHeading(draw_heading); |
2200 | if (node->hasAttribute("heading_height")) | 2212 | if (node->hasAttribute("heading_height")) |
2201 | { | 2213 | { |
@@ -2250,6 +2262,8 @@ LLView* LLScrollListCtrl::fromXML(LLXMLNodePtr node, LLView *parent, LLUICtrlFac | |||
2250 | F32 columnrelwidth = 0.f; | 2262 | F32 columnrelwidth = 0.f; |
2251 | child->getAttributeF32("relwidth", columnrelwidth); | 2263 | child->getAttributeF32("relwidth", columnrelwidth); |
2252 | 2264 | ||
2265 | LLFontGL::HAlign h_align = LLFontGL::LEFT; | ||
2266 | h_align = LLView::selectFontHAlign(child); | ||
2253 | 2267 | ||
2254 | columns[index]["name"] = columnname; | 2268 | columns[index]["name"] = columnname; |
2255 | columns[index]["sort"] = sortname; | 2269 | columns[index]["sort"] = sortname; |
@@ -2258,6 +2272,7 @@ LLView* LLScrollListCtrl::fromXML(LLXMLNodePtr node, LLView *parent, LLUICtrlFac | |||
2258 | columns[index]["width"] = columnwidth; | 2272 | columns[index]["width"] = columnwidth; |
2259 | columns[index]["relwidth"] = columnrelwidth; | 2273 | columns[index]["relwidth"] = columnrelwidth; |
2260 | columns[index]["dynamicwidth"] = columndynamicwidth; | 2274 | columns[index]["dynamicwidth"] = columndynamicwidth; |
2275 | columns[index]["halign"] = (S32)h_align; | ||
2261 | index++; | 2276 | index++; |
2262 | } | 2277 | } |
2263 | } | 2278 | } |
@@ -2604,6 +2619,7 @@ LLScrollListItem* LLScrollListCtrl::addElement(const LLSD& value, EAddPosition p | |||
2604 | 2619 | ||
2605 | S32 index = column_itor->second.mIndex; | 2620 | S32 index = column_itor->second.mIndex; |
2606 | S32 width = column_itor->second.mWidth; | 2621 | S32 width = column_itor->second.mWidth; |
2622 | LLFontGL::HAlign font_alignment = column_itor->second.mFontAlignment; | ||
2607 | 2623 | ||
2608 | LLSD value = (*itor)["value"]; | 2624 | LLSD value = (*itor)["value"]; |
2609 | LLString fontname = (*itor)["font"].asString(); | 2625 | LLString fontname = (*itor)["font"].asString(); |
@@ -2631,7 +2647,7 @@ LLScrollListItem* LLScrollListCtrl::addElement(const LLSD& value, EAddPosition p | |||
2631 | } | 2647 | } |
2632 | else | 2648 | else |
2633 | { | 2649 | { |
2634 | new_item->setColumn(index, new LLScrollListText(value.asString(), font, width, font_style)); | 2650 | new_item->setColumn(index, new LLScrollListText(value.asString(), font, width, font_style, font_alignment)); |
2635 | } | 2651 | } |
2636 | } | 2652 | } |
2637 | 2653 | ||
@@ -2724,7 +2740,7 @@ void LLScrollListCtrl::setFocus(BOOL b) | |||
2724 | if (!getFirstSelected()) | 2740 | if (!getFirstSelected()) |
2725 | { | 2741 | { |
2726 | selectFirstItem(); | 2742 | selectFirstItem(); |
2727 | onCommit(); | 2743 | //onCommit(); // SJB: selectFirstItem() will call onCommit() if appropriate |
2728 | } | 2744 | } |
2729 | LLUICtrl::setFocus(b); | 2745 | LLUICtrl::setFocus(b); |
2730 | } | 2746 | } |
@@ -2739,3 +2755,4 @@ void LLScrollListCtrl::onFocusLost() | |||
2739 | } | 2755 | } |
2740 | } | 2756 | } |
2741 | } | 2757 | } |
2758 | |||
diff --git a/linden/indra/llui/llscrolllistctrl.h b/linden/indra/llui/llscrolllistctrl.h index d097cb5..a1c4853 100644 --- a/linden/indra/llui/llscrolllistctrl.h +++ b/linden/indra/llui/llscrolllistctrl.h | |||
@@ -57,7 +57,7 @@ public: | |||
57 | virtual const LLString& getTextLower() const { return LLString::null; } | 57 | virtual const LLString& getTextLower() const { return LLString::null; } |
58 | virtual const BOOL getVisible() const { return TRUE; } | 58 | virtual const BOOL getVisible() const { return TRUE; } |
59 | virtual void setWidth(S32 width) = 0; | 59 | virtual void setWidth(S32 width) = 0; |
60 | virtual void highlightText(S32 num_chars) {} | 60 | virtual void highlightText(S32 offset, S32 num_chars) {} |
61 | 61 | ||
62 | virtual BOOL handleClick() { return FALSE; } | 62 | virtual BOOL handleClick() { return FALSE; } |
63 | virtual void setEnabled(BOOL enable) { } | 63 | virtual void setEnabled(BOOL enable) { } |
@@ -65,9 +65,8 @@ public: | |||
65 | 65 | ||
66 | class LLScrollListText : public LLScrollListCell | 66 | class LLScrollListText : public LLScrollListCell |
67 | { | 67 | { |
68 | static U32 sCount; | ||
69 | public: | 68 | public: |
70 | LLScrollListText( const LLString& text, const LLFontGL* font, S32 width = 0, U8 font_style = LLFontGL::NORMAL, LLColor4& color = LLColor4::black, BOOL use_color = FALSE, BOOL visible = TRUE); | 69 | LLScrollListText( const LLString& text, const LLFontGL* font, S32 width = 0, U8 font_style = LLFontGL::NORMAL, LLFontGL::HAlign font_alignment = LLFontGL::LEFT, LLColor4& color = LLColor4::black, BOOL use_color = FALSE, BOOL visible = TRUE); |
71 | /*virtual*/ ~LLScrollListText(); | 70 | /*virtual*/ ~LLScrollListText(); |
72 | 71 | ||
73 | virtual void drawToWidth(S32 width, const LLColor4& color, const LLColor4& highlight_color) const; | 72 | virtual void drawToWidth(S32 width, const LLColor4& color, const LLColor4& highlight_color) const; |
@@ -76,7 +75,7 @@ public: | |||
76 | virtual S32 getHeight() const { return llround(mFont->getLineHeight()); } | 75 | virtual S32 getHeight() const { return llround(mFont->getLineHeight()); } |
77 | virtual const LLString& getText() const { return mText.getString(); } | 76 | virtual const LLString& getText() const { return mText.getString(); } |
78 | virtual const BOOL getVisible() const { return mVisible; } | 77 | virtual const BOOL getVisible() const { return mVisible; } |
79 | virtual void highlightText(S32 num_chars) {mHighlightChars = num_chars;} | 78 | virtual void highlightText(S32 offset, S32 num_chars) {mHighlightOffset = offset; mHighlightCount = num_chars;} |
80 | void setText(const LLString& text); | 79 | void setText(const LLString& text); |
81 | 80 | ||
82 | private: | 81 | private: |
@@ -84,12 +83,15 @@ private: | |||
84 | const LLFontGL* mFont; | 83 | const LLFontGL* mFont; |
85 | LLColor4* mColor; | 84 | LLColor4* mColor; |
86 | const U8 mFontStyle; | 85 | const U8 mFontStyle; |
86 | LLFontGL::HAlign mFontAlignment; | ||
87 | S32 mWidth; | 87 | S32 mWidth; |
88 | S32 mEllipsisWidth; // in pixels, of "..." | ||
89 | BOOL mVisible; | 88 | BOOL mVisible; |
90 | S32 mHighlightChars; | 89 | S32 mHighlightCount; |
90 | S32 mHighlightOffset; | ||
91 | 91 | ||
92 | LLPointer<LLImageGL> mRoundedRectImage; | 92 | LLPointer<LLImageGL> mRoundedRectImage; |
93 | |||
94 | static U32 sCount; | ||
93 | }; | 95 | }; |
94 | 96 | ||
95 | class LLScrollListIcon : public LLScrollListCell | 97 | class LLScrollListIcon : public LLScrollListCell |
@@ -134,9 +136,10 @@ class LLScrollListColumn | |||
134 | { | 136 | { |
135 | public: | 137 | public: |
136 | // Default constructor | 138 | // Default constructor |
137 | LLScrollListColumn() : mName(""), mSortingColumn(""), mLabel(""), mWidth(-1), mRelWidth(-1.0), mDynamicWidth(FALSE), mIndex(-1), mParentCtrl(NULL), mButton(NULL) { } | 139 | LLScrollListColumn() : mName(""), mSortingColumn(""), mLabel(""), mWidth(-1), mRelWidth(-1.0), mDynamicWidth(FALSE), mIndex(-1), mParentCtrl(NULL), mButton(NULL), mFontAlignment(LLFontGL::LEFT) |
140 | { } | ||
138 | 141 | ||
139 | LLScrollListColumn(LLString name, LLString label, S32 width, F32 relwidth) | 142 | LLScrollListColumn(LLString name, LLString label, S32 width, F32 relwidth) |
140 | : mName(name), mSortingColumn(name), mLabel(label), mWidth(width), mRelWidth(relwidth), mDynamicWidth(FALSE), mIndex(-1), mParentCtrl(NULL), mButton(NULL) { } | 143 | : mName(name), mSortingColumn(name), mLabel(label), mWidth(width), mRelWidth(relwidth), mDynamicWidth(FALSE), mIndex(-1), mParentCtrl(NULL), mButton(NULL) { } |
141 | 144 | ||
142 | LLScrollListColumn(const LLSD &sd) | 145 | LLScrollListColumn(const LLSD &sd) |
@@ -168,20 +171,27 @@ public: | |||
168 | mDynamicWidth = FALSE; | 171 | mDynamicWidth = FALSE; |
169 | mRelWidth = -1; | 172 | mRelWidth = -1; |
170 | } | 173 | } |
174 | |||
175 | if (sd.has("halign")) | ||
176 | { | ||
177 | mFontAlignment = (LLFontGL::HAlign)llclamp(sd.get("halign").asInteger(), (S32)LLFontGL::LEFT, (S32)LLFontGL::HCENTER); | ||
178 | } | ||
179 | |||
171 | mIndex = -1; | 180 | mIndex = -1; |
172 | mParentCtrl = NULL; | 181 | mParentCtrl = NULL; |
173 | mButton = NULL; | 182 | mButton = NULL; |
174 | } | 183 | } |
175 | 184 | ||
176 | LLString mName; | 185 | LLString mName; |
177 | LLString mSortingColumn; | 186 | LLString mSortingColumn; |
178 | LLString mLabel; | 187 | LLString mLabel; |
179 | S32 mWidth; | 188 | S32 mWidth; |
180 | F32 mRelWidth; | 189 | F32 mRelWidth; |
181 | BOOL mDynamicWidth; | 190 | BOOL mDynamicWidth; |
182 | S32 mIndex; | 191 | S32 mIndex; |
183 | LLScrollListCtrl *mParentCtrl; | 192 | LLScrollListCtrl* mParentCtrl; |
184 | LLButton *mButton; | 193 | LLButton* mButton; |
194 | LLFontGL::HAlign mFontAlignment; | ||
185 | }; | 195 | }; |
186 | 196 | ||
187 | class LLScrollListItem | 197 | class LLScrollListItem |
@@ -208,8 +218,8 @@ public: | |||
208 | 218 | ||
209 | // If width = 0, just use the width of the text. Otherwise override with | 219 | // If width = 0, just use the width of the text. Otherwise override with |
210 | // specified width in pixels. | 220 | // specified width in pixels. |
211 | void addColumn( const LLString& text, const LLFontGL* font, S32 width = 0 , U8 font_style = LLFontGL::NORMAL, BOOL visible = TRUE) | 221 | void addColumn( const LLString& text, const LLFontGL* font, S32 width = 0 , U8 font_style = LLFontGL::NORMAL, LLFontGL::HAlign font_alignment = LLFontGL::LEFT, BOOL visible = TRUE) |
212 | { mColumns.push_back( new LLScrollListText(text, font, width, font_style, LLColor4::black, FALSE, visible) ); } | 222 | { mColumns.push_back( new LLScrollListText(text, font, width, font_style, font_alignment, LLColor4::black, FALSE, visible) ); } |
213 | 223 | ||
214 | void addColumn( LLImageGL* icon, S32 width = 0 ) | 224 | void addColumn( LLImageGL* icon, S32 width = 0 ) |
215 | { mColumns.push_back( new LLScrollListIcon(icon, width) ); } | 225 | { mColumns.push_back( new LLScrollListIcon(icon, width) ); } |
diff --git a/linden/indra/llui/llsliderctrl.cpp b/linden/indra/llui/llsliderctrl.cpp index ca8f3ad..c62ec9a 100644 --- a/linden/indra/llui/llsliderctrl.cpp +++ b/linden/indra/llui/llsliderctrl.cpp | |||
@@ -215,7 +215,7 @@ void LLSliderCtrl::updateText() | |||
215 | LLLocale locale(LLLocale::USER_LOCALE); | 215 | LLLocale locale(LLLocale::USER_LOCALE); |
216 | 216 | ||
217 | // Don't display very small negative values as -0.000 | 217 | // Don't display very small negative values as -0.000 |
218 | F32 displayed_value = (F32)(floor(getValueF32() * pow(10, mPrecision) + 0.5) / pow(10, mPrecision)); | 218 | F32 displayed_value = (F32)(floor(getValueF32() * pow(10.0, (F64)mPrecision) + 0.5) / pow(10.0, (F64)mPrecision)); |
219 | 219 | ||
220 | LLString format = llformat("%%.%df", mPrecision); | 220 | LLString format = llformat("%%.%df", mPrecision); |
221 | LLString text = llformat(format.c_str(), displayed_value); | 221 | LLString text = llformat(format.c_str(), displayed_value); |
diff --git a/linden/indra/llui/llspinctrl.cpp b/linden/indra/llui/llspinctrl.cpp index b93ed02..1f33279 100644 --- a/linden/indra/llui/llspinctrl.cpp +++ b/linden/indra/llui/llspinctrl.cpp | |||
@@ -248,7 +248,7 @@ void LLSpinCtrl::updateEditor() | |||
248 | LLLocale locale(LLLocale::USER_LOCALE); | 248 | LLLocale locale(LLLocale::USER_LOCALE); |
249 | 249 | ||
250 | // Don't display very small negative values as -0.000 | 250 | // Don't display very small negative values as -0.000 |
251 | F32 displayed_value = (F32)floor(getValue().asReal() * pow(10, mPrecision) + 0.5) / (F32)pow(10, mPrecision); | 251 | F32 displayed_value = (F32)floor(getValue().asReal() * pow(10.0, (F64)mPrecision) + 0.5) / (F32)pow(10.0, (F64)mPrecision); |
252 | 252 | ||
253 | // if( S32( displayed_value * pow( 10, mPrecision ) ) == 0 ) | 253 | // if( S32( displayed_value * pow( 10, mPrecision ) ) == 0 ) |
254 | // { | 254 | // { |
diff --git a/linden/indra/llui/lltexteditor.cpp b/linden/indra/llui/lltexteditor.cpp index b0f8b5a..8f22545 100644 --- a/linden/indra/llui/lltexteditor.cpp +++ b/linden/indra/llui/lltexteditor.cpp | |||
@@ -3782,7 +3782,7 @@ BOOL LLTextEditor::importBuffer(const LLString& buffer ) | |||
3782 | // <text without \0> (text may contain ext_char_values) | 3782 | // <text without \0> (text may contain ext_char_values) |
3783 | // }\n | 3783 | // }\n |
3784 | 3784 | ||
3785 | char tbuf[MAX_STRING]; | 3785 | char tbuf[MAX_STRING]; /* Flawfinder: ignore */ |
3786 | 3786 | ||
3787 | S32 version = 0; | 3787 | S32 version = 0; |
3788 | instream.getline(tbuf, MAX_STRING); | 3788 | instream.getline(tbuf, MAX_STRING); |
@@ -3822,11 +3822,16 @@ BOOL LLTextEditor::importBuffer(const LLString& buffer ) | |||
3822 | BOOL success = TRUE; | 3822 | BOOL success = TRUE; |
3823 | 3823 | ||
3824 | char* text = new char[ text_len + 1]; | 3824 | char* text = new char[ text_len + 1]; |
3825 | if (text == NULL) | ||
3826 | { | ||
3827 | llerrs << "Memory allocation failure." << llendl; | ||
3828 | return FALSE; | ||
3829 | } | ||
3825 | instream.get(text, text_len + 1, '\0'); | 3830 | instream.get(text, text_len + 1, '\0'); |
3826 | text[text_len] = '\0'; | 3831 | text[text_len] = '\0'; |
3827 | if( text_len != (S32)strlen(text) ) | 3832 | if( text_len != (S32)strlen(text) )/* Flawfinder: ignore */ |
3828 | { | 3833 | { |
3829 | llwarns << llformat("Invalid text length: %d != %d ",strlen(text),text_len) << llendl; | 3834 | llwarns << llformat("Invalid text length: %d != %d ",strlen(text),text_len) << llendl;/* Flawfinder: ignore */ |
3830 | success = FALSE; | 3835 | success = FALSE; |
3831 | } | 3836 | } |
3832 | 3837 | ||
@@ -3948,6 +3953,8 @@ LLXMLNodePtr LLTextEditor::getXML(bool save_children) const | |||
3948 | 3953 | ||
3949 | node->createChild("word_wrap", TRUE)->setBoolValue(mWordWrap); | 3954 | node->createChild("word_wrap", TRUE)->setBoolValue(mWordWrap); |
3950 | 3955 | ||
3956 | node->createChild("hide_scrollbar", TRUE)->setBoolValue(mHideScrollbarForShortDocs); | ||
3957 | |||
3951 | addColorXML(node, mCursorColor, "cursor_color", "TextCursorColor"); | 3958 | addColorXML(node, mCursorColor, "cursor_color", "TextCursorColor"); |
3952 | addColorXML(node, mFgColor, "text_color", "TextFgColor"); | 3959 | addColorXML(node, mFgColor, "text_color", "TextFgColor"); |
3953 | addColorXML(node, mReadOnlyFgColor, "text_readonly_color", "TextFgReadOnlyColor"); | 3960 | addColorXML(node, mReadOnlyFgColor, "text_readonly_color", "TextFgReadOnlyColor"); |
diff --git a/linden/indra/llui/llui.cpp b/linden/indra/llui/llui.cpp index c62f353..61dede2 100644 --- a/linden/indra/llui/llui.cpp +++ b/linden/indra/llui/llui.cpp | |||
@@ -1497,7 +1497,7 @@ void load_tr(const LLString& lang) | |||
1497 | LLString filename = gDirUtilp->getExpandedFilename(LL_PATH_SKINS, inname.c_str()); | 1497 | LLString filename = gDirUtilp->getExpandedFilename(LL_PATH_SKINS, inname.c_str()); |
1498 | 1498 | ||
1499 | llifstream file; | 1499 | llifstream file; |
1500 | file.open(filename.c_str(), std::ios_base::binary); | 1500 | file.open(filename.c_str(), std::ios_base::binary); /* Flawfinder: ignore */ |
1501 | if (!file) | 1501 | if (!file) |
1502 | { | 1502 | { |
1503 | llinfos << "No translation dictionary for: " << filename << llendl; | 1503 | llinfos << "No translation dictionary for: " << filename << llendl; |
@@ -1510,7 +1510,7 @@ void load_tr(const LLString& lang) | |||
1510 | gUntranslated.clear(); | 1510 | gUntranslated.clear(); |
1511 | 1511 | ||
1512 | const S32 MAX_LINE_LEN = 1024; | 1512 | const S32 MAX_LINE_LEN = 1024; |
1513 | char buffer[MAX_LINE_LEN]; | 1513 | char buffer[MAX_LINE_LEN]; /* Flawfinder: ignore */ |
1514 | while (!file.eof()) | 1514 | while (!file.eof()) |
1515 | { | 1515 | { |
1516 | file.getline(buffer, MAX_LINE_LEN); | 1516 | file.getline(buffer, MAX_LINE_LEN); |
@@ -1550,7 +1550,7 @@ void cleanup_tr() | |||
1550 | LLString outname = "untranslated_" + gLanguage + ".txt"; | 1550 | LLString outname = "untranslated_" + gLanguage + ".txt"; |
1551 | LLString outfilename = gDirUtilp->getExpandedFilename(LL_PATH_SKINS, outname.c_str()); | 1551 | LLString outfilename = gDirUtilp->getExpandedFilename(LL_PATH_SKINS, outname.c_str()); |
1552 | llofstream outfile; | 1552 | llofstream outfile; |
1553 | outfile.open(outfilename.c_str()); | 1553 | outfile.open(outfilename.c_str()); /* Flawfinder: ignore */ |
1554 | if (!outfile) | 1554 | if (!outfile) |
1555 | { | 1555 | { |
1556 | return; | 1556 | return; |
diff --git a/linden/indra/llui/llui_vc8.vcproj b/linden/indra/llui/llui_vc8.vcproj new file mode 100644 index 0000000..a78c71c --- /dev/null +++ b/linden/indra/llui/llui_vc8.vcproj | |||
@@ -0,0 +1,588 @@ | |||
1 | <?xml version="1.0" encoding="Windows-1252"?> | ||
2 | <VisualStudioProject | ||
3 | ProjectType="Visual C++" | ||
4 | Version="8.00" | ||
5 | Name="llui" | ||
6 | ProjectGUID="{DE55D666-6A3D-476C-937F-109269B83681}" | ||
7 | Keyword="Win32Proj" | ||
8 | > | ||
9 | <Platforms> | ||
10 | <Platform | ||
11 | Name="Win32" | ||
12 | /> | ||
13 | </Platforms> | ||
14 | <ToolFiles> | ||
15 | </ToolFiles> | ||
16 | <Configurations> | ||
17 | <Configuration | ||
18 | Name="Debug|Win32" | ||
19 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
20 | IntermediateDirectory="Debug" | ||
21 | ConfigurationType="4" | ||
22 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
23 | CharacterSet="1" | ||
24 | > | ||
25 | <Tool | ||
26 | Name="VCPreBuildEventTool" | ||
27 | /> | ||
28 | <Tool | ||
29 | Name="VCCustomBuildTool" | ||
30 | /> | ||
31 | <Tool | ||
32 | Name="VCXMLDataGeneratorTool" | ||
33 | /> | ||
34 | <Tool | ||
35 | Name="VCWebServiceProxyGeneratorTool" | ||
36 | /> | ||
37 | <Tool | ||
38 | Name="VCMIDLTool" | ||
39 | /> | ||
40 | <Tool | ||
41 | Name="VCCLCompilerTool" | ||
42 | Optimization="0" | ||
43 | AdditionalIncludeDirectories="..\llmath;..\llvfs;..\llcommon;..\llprimitive;..\llwindow;..\llrender;..\llimage;..\llaudio;..\llxml;..\llmessage;"..\..\libraries\i686-win32\include";..\..\libraries\include\" | ||
44 | PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_DEBUG" | ||
45 | MinimalRebuild="true" | ||
46 | BasicRuntimeChecks="3" | ||
47 | RuntimeLibrary="1" | ||
48 | StructMemberAlignment="4" | ||
49 | TreatWChar_tAsBuiltInType="false" | ||
50 | ForceConformanceInForLoopScope="true" | ||
51 | UsePrecompiledHeader="0" | ||
52 | WarningLevel="3" | ||
53 | WarnAsError="true" | ||
54 | Detect64BitPortabilityProblems="false" | ||
55 | DebugInformationFormat="4" | ||
56 | /> | ||
57 | <Tool | ||
58 | Name="VCManagedResourceCompilerTool" | ||
59 | /> | ||
60 | <Tool | ||
61 | Name="VCResourceCompilerTool" | ||
62 | /> | ||
63 | <Tool | ||
64 | Name="VCPreLinkEventTool" | ||
65 | /> | ||
66 | <Tool | ||
67 | Name="VCLibrarianTool" | ||
68 | OutputFile="$(OutDir)/llui.lib" | ||
69 | /> | ||
70 | <Tool | ||
71 | Name="VCALinkTool" | ||
72 | /> | ||
73 | <Tool | ||
74 | Name="VCXDCMakeTool" | ||
75 | /> | ||
76 | <Tool | ||
77 | Name="VCBscMakeTool" | ||
78 | /> | ||
79 | <Tool | ||
80 | Name="VCFxCopTool" | ||
81 | /> | ||
82 | <Tool | ||
83 | Name="VCPostBuildEventTool" | ||
84 | /> | ||
85 | </Configuration> | ||
86 | <Configuration | ||
87 | Name="Release|Win32" | ||
88 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
89 | IntermediateDirectory="Release" | ||
90 | ConfigurationType="4" | ||
91 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
92 | CharacterSet="1" | ||
93 | > | ||
94 | <Tool | ||
95 | Name="VCPreBuildEventTool" | ||
96 | /> | ||
97 | <Tool | ||
98 | Name="VCCustomBuildTool" | ||
99 | /> | ||
100 | <Tool | ||
101 | Name="VCXMLDataGeneratorTool" | ||
102 | /> | ||
103 | <Tool | ||
104 | Name="VCWebServiceProxyGeneratorTool" | ||
105 | /> | ||
106 | <Tool | ||
107 | Name="VCMIDLTool" | ||
108 | /> | ||
109 | <Tool | ||
110 | Name="VCCLCompilerTool" | ||
111 | AdditionalIncludeDirectories="..\llmath;..\llvfs;..\llcommon;..\llprimitive;..\llwindow;..\llrender;..\llimage;..\llaudio;..\llxml;..\llmessage;"..\..\libraries\i686-win32\include";..\..\libraries\include\" | ||
112 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_RELEASE" | ||
113 | RuntimeLibrary="0" | ||
114 | StructMemberAlignment="0" | ||
115 | TreatWChar_tAsBuiltInType="false" | ||
116 | ForceConformanceInForLoopScope="true" | ||
117 | UsePrecompiledHeader="0" | ||
118 | WarningLevel="3" | ||
119 | WarnAsError="true" | ||
120 | Detect64BitPortabilityProblems="false" | ||
121 | DebugInformationFormat="3" | ||
122 | /> | ||
123 | <Tool | ||
124 | Name="VCManagedResourceCompilerTool" | ||
125 | /> | ||
126 | <Tool | ||
127 | Name="VCResourceCompilerTool" | ||
128 | /> | ||
129 | <Tool | ||
130 | Name="VCPreLinkEventTool" | ||
131 | /> | ||
132 | <Tool | ||
133 | Name="VCLibrarianTool" | ||
134 | OutputFile="$(OutDir)/llui.lib" | ||
135 | /> | ||
136 | <Tool | ||
137 | Name="VCALinkTool" | ||
138 | /> | ||
139 | <Tool | ||
140 | Name="VCXDCMakeTool" | ||
141 | /> | ||
142 | <Tool | ||
143 | Name="VCBscMakeTool" | ||
144 | /> | ||
145 | <Tool | ||
146 | Name="VCFxCopTool" | ||
147 | /> | ||
148 | <Tool | ||
149 | Name="VCPostBuildEventTool" | ||
150 | /> | ||
151 | </Configuration> | ||
152 | <Configuration | ||
153 | Name="ReleaseNoOpt|Win32" | ||
154 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
155 | IntermediateDirectory="$(ConfigurationName)" | ||
156 | ConfigurationType="4" | ||
157 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
158 | CharacterSet="1" | ||
159 | > | ||
160 | <Tool | ||
161 | Name="VCPreBuildEventTool" | ||
162 | /> | ||
163 | <Tool | ||
164 | Name="VCCustomBuildTool" | ||
165 | /> | ||
166 | <Tool | ||
167 | Name="VCXMLDataGeneratorTool" | ||
168 | /> | ||
169 | <Tool | ||
170 | Name="VCWebServiceProxyGeneratorTool" | ||
171 | /> | ||
172 | <Tool | ||
173 | Name="VCMIDLTool" | ||
174 | /> | ||
175 | <Tool | ||
176 | Name="VCCLCompilerTool" | ||
177 | Optimization="0" | ||
178 | AdditionalIncludeDirectories="..\llmath;..\llvfs;..\llcommon;..\llprimitive;..\llwindow;..\llrender;..\llimage;..\llaudio;..\llxml;..\llmessage;"..\..\libraries\i686-win32\include";..\..\libraries\include\" | ||
179 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_RELEASE" | ||
180 | RuntimeLibrary="0" | ||
181 | StructMemberAlignment="0" | ||
182 | TreatWChar_tAsBuiltInType="false" | ||
183 | ForceConformanceInForLoopScope="true" | ||
184 | UsePrecompiledHeader="0" | ||
185 | WarningLevel="3" | ||
186 | WarnAsError="true" | ||
187 | Detect64BitPortabilityProblems="false" | ||
188 | DebugInformationFormat="3" | ||
189 | /> | ||
190 | <Tool | ||
191 | Name="VCManagedResourceCompilerTool" | ||
192 | /> | ||
193 | <Tool | ||
194 | Name="VCResourceCompilerTool" | ||
195 | /> | ||
196 | <Tool | ||
197 | Name="VCPreLinkEventTool" | ||
198 | /> | ||
199 | <Tool | ||
200 | Name="VCLibrarianTool" | ||
201 | OutputFile="$(OutDir)/llui.lib" | ||
202 | /> | ||
203 | <Tool | ||
204 | Name="VCALinkTool" | ||
205 | /> | ||
206 | <Tool | ||
207 | Name="VCXDCMakeTool" | ||
208 | /> | ||
209 | <Tool | ||
210 | Name="VCBscMakeTool" | ||
211 | /> | ||
212 | <Tool | ||
213 | Name="VCFxCopTool" | ||
214 | /> | ||
215 | <Tool | ||
216 | Name="VCPostBuildEventTool" | ||
217 | /> | ||
218 | </Configuration> | ||
219 | </Configurations> | ||
220 | <References> | ||
221 | </References> | ||
222 | <Files> | ||
223 | <Filter | ||
224 | Name="Source Files" | ||
225 | Filter="cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx" | ||
226 | UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}" | ||
227 | > | ||
228 | <File | ||
229 | RelativePath=".\llalertdialog.cpp" | ||
230 | > | ||
231 | </File> | ||
232 | <File | ||
233 | RelativePath=".\llbutton.cpp" | ||
234 | > | ||
235 | </File> | ||
236 | <File | ||
237 | RelativePath=".\llcheckboxctrl.cpp" | ||
238 | > | ||
239 | </File> | ||
240 | <File | ||
241 | RelativePath=".\llclipboard.cpp" | ||
242 | > | ||
243 | </File> | ||
244 | <File | ||
245 | RelativePath=".\llcombobox.cpp" | ||
246 | > | ||
247 | </File> | ||
248 | <File | ||
249 | RelativePath=".\llctrlselectioninterface.cpp" | ||
250 | > | ||
251 | </File> | ||
252 | <File | ||
253 | RelativePath=".\lldraghandle.cpp" | ||
254 | > | ||
255 | </File> | ||
256 | <File | ||
257 | RelativePath=".\lleditmenuhandler.cpp" | ||
258 | > | ||
259 | </File> | ||
260 | <File | ||
261 | RelativePath=".\llfloater.cpp" | ||
262 | > | ||
263 | </File> | ||
264 | <File | ||
265 | RelativePath=".\llfocusmgr.cpp" | ||
266 | > | ||
267 | </File> | ||
268 | <File | ||
269 | RelativePath=".\lliconctrl.cpp" | ||
270 | > | ||
271 | </File> | ||
272 | <File | ||
273 | RelativePath=".\llkeywords.cpp" | ||
274 | > | ||
275 | </File> | ||
276 | <File | ||
277 | RelativePath=".\lllineeditor.cpp" | ||
278 | > | ||
279 | </File> | ||
280 | <File | ||
281 | RelativePath=".\llmenugl.cpp" | ||
282 | > | ||
283 | </File> | ||
284 | <File | ||
285 | RelativePath=".\llmodaldialog.cpp" | ||
286 | > | ||
287 | </File> | ||
288 | <File | ||
289 | RelativePath=".\llpanel.cpp" | ||
290 | > | ||
291 | </File> | ||
292 | <File | ||
293 | RelativePath=".\llradiogroup.cpp" | ||
294 | > | ||
295 | </File> | ||
296 | <File | ||
297 | RelativePath=".\llresizebar.cpp" | ||
298 | > | ||
299 | </File> | ||
300 | <File | ||
301 | RelativePath=".\llresizehandle.cpp" | ||
302 | > | ||
303 | </File> | ||
304 | <File | ||
305 | RelativePath=".\llresmgr.cpp" | ||
306 | > | ||
307 | </File> | ||
308 | <File | ||
309 | RelativePath=".\llrootview.cpp" | ||
310 | > | ||
311 | </File> | ||
312 | <File | ||
313 | RelativePath=".\llscrollbar.cpp" | ||
314 | > | ||
315 | </File> | ||
316 | <File | ||
317 | RelativePath=".\llscrollcontainer.cpp" | ||
318 | > | ||
319 | </File> | ||
320 | <File | ||
321 | RelativePath=".\llscrollingpanellist.cpp" | ||
322 | > | ||
323 | </File> | ||
324 | <File | ||
325 | RelativePath=".\llscrolllistctrl.cpp" | ||
326 | > | ||
327 | </File> | ||
328 | <File | ||
329 | RelativePath=".\llslider.cpp" | ||
330 | > | ||
331 | </File> | ||
332 | <File | ||
333 | RelativePath=".\llsliderctrl.cpp" | ||
334 | > | ||
335 | </File> | ||
336 | <File | ||
337 | RelativePath=".\llspinctrl.cpp" | ||
338 | > | ||
339 | </File> | ||
340 | <File | ||
341 | RelativePath=".\llstyle.cpp" | ||
342 | > | ||
343 | </File> | ||
344 | <File | ||
345 | RelativePath=".\lltabcontainer.cpp" | ||
346 | > | ||
347 | </File> | ||
348 | <File | ||
349 | RelativePath=".\lltabcontainervertical.cpp" | ||
350 | > | ||
351 | </File> | ||
352 | <File | ||
353 | RelativePath=".\lltextbox.cpp" | ||
354 | > | ||
355 | </File> | ||
356 | <File | ||
357 | RelativePath=".\lltexteditor.cpp" | ||
358 | > | ||
359 | </File> | ||
360 | <File | ||
361 | RelativePath=".\llui.cpp" | ||
362 | > | ||
363 | </File> | ||
364 | <File | ||
365 | RelativePath=".\lluictrl.cpp" | ||
366 | > | ||
367 | </File> | ||
368 | <File | ||
369 | RelativePath=".\lluictrlfactory.cpp" | ||
370 | > | ||
371 | </File> | ||
372 | <File | ||
373 | RelativePath=".\lluistring.cpp" | ||
374 | > | ||
375 | </File> | ||
376 | <File | ||
377 | RelativePath=".\llundo.cpp" | ||
378 | > | ||
379 | </File> | ||
380 | <File | ||
381 | RelativePath=".\llview.cpp" | ||
382 | > | ||
383 | </File> | ||
384 | <File | ||
385 | RelativePath=".\llviewborder.cpp" | ||
386 | > | ||
387 | </File> | ||
388 | <File | ||
389 | RelativePath=".\llviewquery.cpp" | ||
390 | > | ||
391 | </File> | ||
392 | </Filter> | ||
393 | <Filter | ||
394 | Name="Header Files" | ||
395 | Filter="h;hpp;hxx;hm;inl;inc;xsd" | ||
396 | UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}" | ||
397 | > | ||
398 | <File | ||
399 | RelativePath=".\llalertdialog.h" | ||
400 | > | ||
401 | </File> | ||
402 | <File | ||
403 | RelativePath=".\llbutton.h" | ||
404 | > | ||
405 | </File> | ||
406 | <File | ||
407 | RelativePath=".\llcallbackmap.h" | ||
408 | > | ||
409 | </File> | ||
410 | <File | ||
411 | RelativePath=".\llcheckboxctrl.h" | ||
412 | > | ||
413 | </File> | ||
414 | <File | ||
415 | RelativePath=".\llclipboard.h" | ||
416 | > | ||
417 | </File> | ||
418 | <File | ||
419 | RelativePath=".\llcombobox.h" | ||
420 | > | ||
421 | </File> | ||
422 | <File | ||
423 | RelativePath=".\llctrlselectioninterface.h" | ||
424 | > | ||
425 | </File> | ||
426 | <File | ||
427 | RelativePath=".\lldraghandle.h" | ||
428 | > | ||
429 | </File> | ||
430 | <File | ||
431 | RelativePath=".\lleditmenuhandler.h" | ||
432 | > | ||
433 | </File> | ||
434 | <File | ||
435 | RelativePath=".\llfloater.h" | ||
436 | > | ||
437 | </File> | ||
438 | <File | ||
439 | RelativePath=".\llfocusmgr.h" | ||
440 | > | ||
441 | </File> | ||
442 | <File | ||
443 | RelativePath=".\lliconctrl.h" | ||
444 | > | ||
445 | </File> | ||
446 | <File | ||
447 | RelativePath=".\llkeywords.h" | ||
448 | > | ||
449 | </File> | ||
450 | <File | ||
451 | RelativePath=".\lllineeditor.h" | ||
452 | > | ||
453 | </File> | ||
454 | <File | ||
455 | RelativePath=".\llmemberlistener.h" | ||
456 | > | ||
457 | </File> | ||
458 | <File | ||
459 | RelativePath=".\llmenugl.h" | ||
460 | > | ||
461 | </File> | ||
462 | <File | ||
463 | RelativePath=".\llmodaldialog.h" | ||
464 | > | ||
465 | </File> | ||
466 | <File | ||
467 | RelativePath=".\llpanel.h" | ||
468 | > | ||
469 | </File> | ||
470 | <File | ||
471 | RelativePath=".\llradiogroup.h" | ||
472 | > | ||
473 | </File> | ||
474 | <File | ||
475 | RelativePath=".\llresizebar.h" | ||
476 | > | ||
477 | </File> | ||
478 | <File | ||
479 | RelativePath=".\llresizehandle.h" | ||
480 | > | ||
481 | </File> | ||
482 | <File | ||
483 | RelativePath=".\llresmgr.h" | ||
484 | > | ||
485 | </File> | ||
486 | <File | ||
487 | RelativePath=".\llrootview.h" | ||
488 | > | ||
489 | </File> | ||
490 | <File | ||
491 | RelativePath=".\llscrollbar.h" | ||
492 | > | ||
493 | </File> | ||
494 | <File | ||
495 | RelativePath=".\llscrollcontainer.h" | ||
496 | > | ||
497 | </File> | ||
498 | <File | ||
499 | RelativePath=".\llscrollingpanellist.h" | ||
500 | > | ||
501 | </File> | ||
502 | <File | ||
503 | RelativePath=".\llscrolllistctrl.h" | ||
504 | > | ||
505 | </File> | ||
506 | <File | ||
507 | RelativePath=".\llslider.h" | ||
508 | > | ||
509 | </File> | ||
510 | <File | ||
511 | RelativePath=".\llsliderctrl.h" | ||
512 | > | ||
513 | </File> | ||
514 | <File | ||
515 | RelativePath=".\llspinctrl.h" | ||
516 | > | ||
517 | </File> | ||
518 | <File | ||
519 | RelativePath=".\llstyle.h" | ||
520 | > | ||
521 | </File> | ||
522 | <File | ||
523 | RelativePath=".\lltabcontainer.h" | ||
524 | > | ||
525 | </File> | ||
526 | <File | ||
527 | RelativePath=".\lltabcontainervertical.h" | ||
528 | > | ||
529 | </File> | ||
530 | <File | ||
531 | RelativePath=".\lltextbox.h" | ||
532 | > | ||
533 | </File> | ||
534 | <File | ||
535 | RelativePath=".\lltexteditor.h" | ||
536 | > | ||
537 | </File> | ||
538 | <File | ||
539 | RelativePath=".\llui.h" | ||
540 | > | ||
541 | </File> | ||
542 | <File | ||
543 | RelativePath=".\lluiconstants.h" | ||
544 | > | ||
545 | </File> | ||
546 | <File | ||
547 | RelativePath=".\lluictrl.h" | ||
548 | > | ||
549 | </File> | ||
550 | <File | ||
551 | RelativePath=".\lluictrlfactory.h" | ||
552 | > | ||
553 | </File> | ||
554 | <File | ||
555 | RelativePath=".\lluistring.h" | ||
556 | > | ||
557 | </File> | ||
558 | <File | ||
559 | RelativePath=".\lluixmltags.h" | ||
560 | > | ||
561 | </File> | ||
562 | <File | ||
563 | RelativePath=".\llundo.h" | ||
564 | > | ||
565 | </File> | ||
566 | <File | ||
567 | RelativePath=".\llview.h" | ||
568 | > | ||
569 | </File> | ||
570 | <File | ||
571 | RelativePath=".\llviewborder.h" | ||
572 | > | ||
573 | </File> | ||
574 | <File | ||
575 | RelativePath=".\llviewquery.h" | ||
576 | > | ||
577 | </File> | ||
578 | </Filter> | ||
579 | <Filter | ||
580 | Name="Resource Files" | ||
581 | Filter="rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx" | ||
582 | UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}" | ||
583 | > | ||
584 | </Filter> | ||
585 | </Files> | ||
586 | <Globals> | ||
587 | </Globals> | ||
588 | </VisualStudioProject> | ||
diff --git a/linden/indra/llui/lluictrl.h b/linden/indra/llui/lluictrl.h index 7f48378..47b5d66 100644 --- a/linden/indra/llui/lluictrl.h +++ b/linden/indra/llui/lluictrl.h | |||
@@ -36,7 +36,6 @@ | |||
36 | // | 36 | // |
37 | // Classes | 37 | // Classes |
38 | // | 38 | // |
39 | class LLViewerImage; | ||
40 | class LLFontGL; | 39 | class LLFontGL; |
41 | class LLButton; | 40 | class LLButton; |
42 | class LLTextBox; | 41 | class LLTextBox; |
diff --git a/linden/indra/llui/lluictrlfactory.cpp b/linden/indra/llui/lluictrlfactory.cpp index 5a35783..77ef749 100644 --- a/linden/indra/llui/lluictrlfactory.cpp +++ b/linden/indra/llui/lluictrlfactory.cpp | |||
@@ -210,12 +210,18 @@ LLUICtrlFactory::LLUICtrlFactory() | |||
210 | LLUICtrlCreator<LLMenuBarGL>::registerCreator(LL_MENU_BAR_GL_TAG, this); | 210 | LLUICtrlCreator<LLMenuBarGL>::registerCreator(LL_MENU_BAR_GL_TAG, this); |
211 | LLUICtrlCreator<LLScrollingPanelList>::registerCreator(LL_SCROLLING_PANEL_LIST_TAG, this); | 211 | LLUICtrlCreator<LLScrollingPanelList>::registerCreator(LL_SCROLLING_PANEL_LIST_TAG, this); |
212 | 212 | ||
213 | setupPaths(); | ||
213 | 214 | ||
215 | } | ||
216 | |||
217 | void LLUICtrlFactory::setupPaths() | ||
218 | { | ||
214 | LLString filename = gDirUtilp->getExpandedFilename(LL_PATH_SKINS, "paths.xml"); | 219 | LLString filename = gDirUtilp->getExpandedFilename(LL_PATH_SKINS, "paths.xml"); |
215 | 220 | ||
216 | LLXMLNodePtr root; | 221 | LLXMLNodePtr root; |
217 | BOOL success = LLXMLNode::parseFile(filename, root, NULL); | 222 | BOOL success = LLXMLNode::parseFile(filename, root, NULL); |
218 | 223 | mXUIPaths.clear(); | |
224 | |||
219 | if (!success) | 225 | if (!success) |
220 | { | 226 | { |
221 | LLString slash = gDirUtilp->getDirDelimiter(); | 227 | LLString slash = gDirUtilp->getDirDelimiter(); |
@@ -239,7 +245,7 @@ LLUICtrlFactory::LLUICtrlFactory() | |||
239 | path_val_ui.setArg("[Language]", language); | 245 | path_val_ui.setArg("[Language]", language); |
240 | LLString fullpath = app_dir + path_val_ui.getString(); | 246 | LLString fullpath = app_dir + path_val_ui.getString(); |
241 | 247 | ||
242 | if (mXUIPaths.empty() || (find(mXUIPaths.begin(), mXUIPaths.end(), fullpath) == mXUIPaths.end()) ) | 248 | if (std::find(mXUIPaths.begin(), mXUIPaths.end(), fullpath) == mXUIPaths.end()) |
243 | { | 249 | { |
244 | mXUIPaths.push_back(app_dir + path_val_ui.getString()); | 250 | mXUIPaths.push_back(app_dir + path_val_ui.getString()); |
245 | } | 251 | } |
@@ -297,7 +303,7 @@ bool LLUICtrlFactory::getLayeredXMLNode(const LLString &filename, LLXMLNodePtr& | |||
297 | // buildFloater() | 303 | // buildFloater() |
298 | //----------------------------------------------------------------------------- | 304 | //----------------------------------------------------------------------------- |
299 | void LLUICtrlFactory::buildFloater(LLFloater* floaterp, const LLString &filename, | 305 | void LLUICtrlFactory::buildFloater(LLFloater* floaterp, const LLString &filename, |
300 | const LLCallbackMap::map_t* factory_map, BOOL open) | 306 | const LLCallbackMap::map_t* factory_map, BOOL open) /* Flawfinder: ignore */ |
301 | { | 307 | { |
302 | LLXMLNodePtr root; | 308 | LLXMLNodePtr root; |
303 | 309 | ||
@@ -318,7 +324,7 @@ void LLUICtrlFactory::buildFloater(LLFloater* floaterp, const LLString &filename | |||
318 | mFactoryStack.push_front(factory_map); | 324 | mFactoryStack.push_front(factory_map); |
319 | } | 325 | } |
320 | 326 | ||
321 | floaterp->initFloaterXML(root, NULL, this, open); | 327 | floaterp->initFloaterXML(root, NULL, this, open); /* Flawfinder: ignore */ |
322 | 328 | ||
323 | if (LLUI::sShowXUINames) | 329 | if (LLUI::sShowXUINames) |
324 | { | 330 | { |
diff --git a/linden/indra/llui/lluictrlfactory.h b/linden/indra/llui/lluictrlfactory.h index ed2a396..b96dc5d 100644 --- a/linden/indra/llui/lluictrlfactory.h +++ b/linden/indra/llui/lluictrlfactory.h | |||
@@ -74,6 +74,8 @@ public: | |||
74 | // do not call! needs to be public so run-time can clean up the singleton | 74 | // do not call! needs to be public so run-time can clean up the singleton |
75 | virtual ~LLUICtrlFactory(); | 75 | virtual ~LLUICtrlFactory(); |
76 | 76 | ||
77 | void setupPaths(); | ||
78 | |||
77 | void buildFloater(LLFloater* floaterp, const LLString &filename, | 79 | void buildFloater(LLFloater* floaterp, const LLString &filename, |
78 | const LLCallbackMap::map_t* factory_map = NULL, BOOL open = TRUE); | 80 | const LLCallbackMap::map_t* factory_map = NULL, BOOL open = TRUE); |
79 | 81 | ||
diff --git a/linden/indra/llui/llview.cpp b/linden/indra/llui/llview.cpp index ab06c0f..13f1ddc 100644 --- a/linden/indra/llui/llview.cpp +++ b/linden/indra/llui/llview.cpp | |||
@@ -51,7 +51,6 @@ | |||
51 | BOOL LLView::sDebugRects = FALSE; | 51 | BOOL LLView::sDebugRects = FALSE; |
52 | BOOL LLView::sDebugKeys = FALSE; | 52 | BOOL LLView::sDebugKeys = FALSE; |
53 | S32 LLView::sDepth = 0; | 53 | S32 LLView::sDepth = 0; |
54 | LLView* LLView::sFastFrameView = NULL; | ||
55 | BOOL LLView::sDebugMouseHandling = FALSE; | 54 | BOOL LLView::sDebugMouseHandling = FALSE; |
56 | LLString LLView::sMouseHandlerMessage; | 55 | LLString LLView::sMouseHandlerMessage; |
57 | S32 LLView::sSelectID = GL_NAME_UI_RESERVED; | 56 | S32 LLView::sSelectID = GL_NAME_UI_RESERVED; |
@@ -112,7 +111,6 @@ LLView::LLView() : | |||
112 | mSaveToXML(TRUE), | 111 | mSaveToXML(TRUE), |
113 | mIsFocusRoot(FALSE), | 112 | mIsFocusRoot(FALSE), |
114 | mLastVisible(TRUE), | 113 | mLastVisible(TRUE), |
115 | mRenderInFastFrame(TRUE), | ||
116 | mSpanChildren(FALSE), | 114 | mSpanChildren(FALSE), |
117 | mVisible(TRUE), | 115 | mVisible(TRUE), |
118 | mHidden(FALSE), | 116 | mHidden(FALSE), |
@@ -133,7 +131,6 @@ LLView::LLView(const LLString& name, BOOL mouse_opaque) : | |||
133 | mSaveToXML(TRUE), | 131 | mSaveToXML(TRUE), |
134 | mIsFocusRoot(FALSE), | 132 | mIsFocusRoot(FALSE), |
135 | mLastVisible(TRUE), | 133 | mLastVisible(TRUE), |
136 | mRenderInFastFrame(TRUE), | ||
137 | mSpanChildren(FALSE), | 134 | mSpanChildren(FALSE), |
138 | mVisible(TRUE), | 135 | mVisible(TRUE), |
139 | mHidden(FALSE), | 136 | mHidden(FALSE), |
@@ -157,7 +154,6 @@ LLView::LLView( | |||
157 | mSaveToXML(TRUE), | 154 | mSaveToXML(TRUE), |
158 | mIsFocusRoot(FALSE), | 155 | mIsFocusRoot(FALSE), |
159 | mLastVisible(TRUE), | 156 | mLastVisible(TRUE), |
160 | mRenderInFastFrame(TRUE), | ||
161 | mSpanChildren(FALSE), | 157 | mSpanChildren(FALSE), |
162 | mVisible(TRUE), | 158 | mVisible(TRUE), |
163 | mHidden(FALSE), | 159 | mHidden(FALSE), |
@@ -199,11 +195,6 @@ LLView::~LLView() | |||
199 | mParentView->removeChild(this); | 195 | mParentView->removeChild(this); |
200 | } | 196 | } |
201 | 197 | ||
202 | if(LLView::sFastFrameView == this) | ||
203 | { | ||
204 | LLView::sFastFrameView = NULL; | ||
205 | } | ||
206 | |||
207 | dispatch_list_t::iterator itor; | 198 | dispatch_list_t::iterator itor; |
208 | for (itor = mDispatchList.begin(); itor != mDispatchList.end(); ++itor) | 199 | for (itor = mDispatchList.begin(); itor != mDispatchList.end(); ++itor) |
209 | { | 200 | { |
@@ -1789,26 +1780,6 @@ void LLView::localRectToScreen(const LLRect& local, LLRect* screen) const | |||
1789 | } | 1780 | } |
1790 | } | 1781 | } |
1791 | 1782 | ||
1792 | LLView* LLView::getRootMostFastFrameView() | ||
1793 | { | ||
1794 | if (gFocusMgr.getTopView() == this) | ||
1795 | { | ||
1796 | return this; | ||
1797 | } | ||
1798 | |||
1799 | if (getParent()) | ||
1800 | { | ||
1801 | LLView* rootmost_view = getParent()->getRootMostFastFrameView(); | ||
1802 | if (rootmost_view) | ||
1803 | { | ||
1804 | return rootmost_view; | ||
1805 | } | ||
1806 | } | ||
1807 | |||
1808 | return mRenderInFastFrame ? this : NULL; | ||
1809 | } | ||
1810 | |||
1811 | |||
1812 | LLView* LLView::getRootView() | 1783 | LLView* LLView::getRootView() |
1813 | { | 1784 | { |
1814 | LLView* view = this; | 1785 | LLView* view = this; |
diff --git a/linden/indra/llui/llview.h b/linden/indra/llui/llview.h index 268f157..3885789 100644 --- a/linden/indra/llui/llview.h +++ b/linden/indra/llui/llview.h | |||
@@ -164,7 +164,6 @@ protected: | |||
164 | public: | 164 | public: |
165 | LLViewHandle mViewHandle; | 165 | LLViewHandle mViewHandle; |
166 | BOOL mLastVisible; | 166 | BOOL mLastVisible; |
167 | BOOL mRenderInFastFrame; | ||
168 | BOOL mSpanChildren; | 167 | BOOL mSpanChildren; |
169 | 168 | ||
170 | private: | 169 | private: |
@@ -180,7 +179,6 @@ public: | |||
180 | static BOOL sDebugRects; // Draw debug rects behind everything. | 179 | static BOOL sDebugRects; // Draw debug rects behind everything. |
181 | static BOOL sDebugKeys; | 180 | static BOOL sDebugKeys; |
182 | static S32 sDepth; | 181 | static S32 sDepth; |
183 | static LLView* sFastFrameView; | ||
184 | static BOOL sDebugMouseHandling; | 182 | static BOOL sDebugMouseHandling; |
185 | static LLString sMouseHandlerMessage; | 183 | static LLString sMouseHandlerMessage; |
186 | static S32 sSelectID; | 184 | static S32 sSelectID; |
@@ -338,8 +336,8 @@ public: | |||
338 | virtual void reshape(S32 width, S32 height, BOOL called_from_parent = TRUE); | 336 | virtual void reshape(S32 width, S32 height, BOOL called_from_parent = TRUE); |
339 | 337 | ||
340 | virtual void translate( S32 x, S32 y ); | 338 | virtual void translate( S32 x, S32 y ); |
339 | virtual void setOrigin( S32 x, S32 y ) { mRect.translate( x - mRect.mLeft, y - mRect.mBottom ); } | ||
341 | BOOL translateIntoRect( const LLRect& constraint, BOOL allow_partial_outside ); | 340 | BOOL translateIntoRect( const LLRect& constraint, BOOL allow_partial_outside ); |
342 | void setOrigin( S32 x, S32 y ) { mRect.translate( x - mRect.mLeft, y - mRect.mBottom ); } | ||
343 | LLView* findSnapRect(LLRect& new_rect, const LLCoordGL& mouse_dir, LLView::ESnapType snap_type, S32 threshold, S32 padding = 0); | 341 | LLView* findSnapRect(LLRect& new_rect, const LLCoordGL& mouse_dir, LLView::ESnapType snap_type, S32 threshold, S32 padding = 0); |
344 | LLView* findSnapEdge(S32& new_edge_val, const LLCoordGL& mouse_dir, ESnapEdge snap_edge, ESnapType snap_type, S32 threshold, S32 padding = 0); | 342 | LLView* findSnapEdge(S32& new_edge_val, const LLCoordGL& mouse_dir, ESnapEdge snap_edge, ESnapType snap_type, S32 threshold, S32 padding = 0); |
345 | 343 | ||
@@ -437,8 +435,6 @@ public: | |||
437 | virtual void localRectToScreen( const LLRect& local, LLRect* screen ) const; | 435 | virtual void localRectToScreen( const LLRect& local, LLRect* screen ) const; |
438 | virtual BOOL localRectToOtherView( const LLRect& local, LLRect* other, LLView* other_view ) const; | 436 | virtual BOOL localRectToOtherView( const LLRect& local, LLRect* other, LLView* other_view ) const; |
439 | 437 | ||
440 | void setRenderInFastFrame(BOOL render) { mRenderInFastFrame = render; } | ||
441 | virtual LLView* getRootMostFastFrameView(); | ||
442 | 438 | ||
443 | static LLWindow* getWindow(void); | 439 | static LLWindow* getWindow(void); |
444 | 440 | ||
diff --git a/linden/indra/llui/llviewquery.cpp b/linden/indra/llui/llviewquery.cpp index 4867116..89b2192 100644 --- a/linden/indra/llui/llviewquery.cpp +++ b/linden/indra/llui/llviewquery.cpp | |||
@@ -1,8 +1,8 @@ | |||
1 | /** | 1 | /** |
2 | * @file llviewquery.cpp | 2 | * @file llviewquery.cpp |
3 | * @brief Implementation of view query class. | 3 | * @brief Implementation of view query class. |
4 | * | 4 | * |
5 | * Copyright (c) 2001-2007, Linden Research, Inc. | 5 | * Copyright (c) 2001-2007, Linden Research, Inc. |
6 | * | 6 | * |
7 | * The source code in this file ("Source Code") is provided by Linden Lab | 7 | * The source code in this file ("Source Code") is provided by Linden Lab |
8 | * to you under the terms of the GNU General Public License, version 2.0 | 8 | * to you under the terms of the GNU General Public License, version 2.0 |
@@ -22,124 +22,124 @@ | |||
22 | * | 22 | * |
23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | 23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO |
24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | 24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, |
25 | * COMPLETENESS OR PERFORMANCE. | 25 | * COMPLETENESS OR PERFORMANCE. |
26 | */ | 26 | */ |
27 | 27 | ||
28 | #include "llview.h" | 28 | #include "llview.h" |
29 | #include "lluictrl.h" | 29 | #include "lluictrl.h" |
30 | #include "llviewquery.h" | 30 | #include "llviewquery.h" |
31 | 31 | ||
32 | void LLQuerySorter::operator() (LLView * parent, viewList_t &children) const {} | 32 | void LLQuerySorter::operator() (LLView * parent, viewList_t &children) const {} |
33 | 33 | ||
34 | filterResult_t LLNoLeavesFilter::operator() (const LLView* const view, const viewList_t & children) const | 34 | filterResult_t LLNoLeavesFilter::operator() (const LLView* const view, const viewList_t & children) const |
35 | { | 35 | { |
36 | return filterResult_t(!(view->getChildList()->size() == 0), TRUE); | 36 | return filterResult_t(!(view->getChildList()->size() == 0), TRUE); |
37 | } | 37 | } |
38 | 38 | ||
39 | filterResult_t LLVisibleFilter::operator() (const LLView* const view, const viewList_t & children) const | 39 | filterResult_t LLVisibleFilter::operator() (const LLView* const view, const viewList_t & children) const |
40 | { | 40 | { |
41 | return filterResult_t(view->getVisible(), view->getVisible()); | 41 | return filterResult_t(view->getVisible(), view->getVisible()); |
42 | } | 42 | } |
43 | filterResult_t LLEnabledFilter::operator() (const LLView* const view, const viewList_t & children) const | 43 | filterResult_t LLEnabledFilter::operator() (const LLView* const view, const viewList_t & children) const |
44 | { | 44 | { |
45 | return filterResult_t(view->getEnabled(), view->getEnabled()); | 45 | return filterResult_t(view->getEnabled(), view->getEnabled()); |
46 | } | 46 | } |
47 | filterResult_t LLTabStopFilter::operator() (const LLView* const view, const viewList_t & children) const | 47 | filterResult_t LLTabStopFilter::operator() (const LLView* const view, const viewList_t & children) const |
48 | { | 48 | { |
49 | return filterResult_t(view->isCtrl() && static_cast<const LLUICtrl* const>(view)->hasTabStop(), | 49 | return filterResult_t(view->isCtrl() && static_cast<const LLUICtrl* const>(view)->hasTabStop(), |
50 | view->canFocusChildren()); | 50 | view->canFocusChildren()); |
51 | } | 51 | } |
52 | 52 | ||
53 | // LLViewQuery | 53 | // LLViewQuery |
54 | 54 | ||
55 | LLViewQuery::LLViewQuery(): mPreFilters(), mPostFilters(), mSorterp() | 55 | LLViewQuery::LLViewQuery(): mPreFilters(), mPostFilters(), mSorterp() |
56 | { | 56 | { |
57 | } | 57 | } |
58 | 58 | ||
59 | void LLViewQuery::addPreFilter(const LLQueryFilter* prefilter) { mPreFilters.push_back(prefilter); } | 59 | void LLViewQuery::addPreFilter(const LLQueryFilter* prefilter) { mPreFilters.push_back(prefilter); } |
60 | 60 | ||
61 | void LLViewQuery::addPostFilter(const LLQueryFilter* postfilter) { mPostFilters.push_back(postfilter); } | 61 | void LLViewQuery::addPostFilter(const LLQueryFilter* postfilter) { mPostFilters.push_back(postfilter); } |
62 | 62 | ||
63 | const LLViewQuery::filterList_t & LLViewQuery::getPreFilters() const { return mPreFilters; } | 63 | const LLViewQuery::filterList_t & LLViewQuery::getPreFilters() const { return mPreFilters; } |
64 | 64 | ||
65 | const LLViewQuery::filterList_t & LLViewQuery::getPostFilters() const { return mPostFilters; } | 65 | const LLViewQuery::filterList_t & LLViewQuery::getPostFilters() const { return mPostFilters; } |
66 | 66 | ||
67 | void LLViewQuery::setSorter(const LLQuerySorter* sorterp) { mSorterp = sorterp; } | 67 | void LLViewQuery::setSorter(const LLQuerySorter* sorterp) { mSorterp = sorterp; } |
68 | const LLQuerySorter* LLViewQuery::getSorter() const { return mSorterp; } | 68 | const LLQuerySorter* LLViewQuery::getSorter() const { return mSorterp; } |
69 | 69 | ||
70 | viewList_t LLViewQuery::run(LLView * view) const | 70 | viewList_t LLViewQuery::run(LLView * view) const |
71 | { | 71 | { |
72 | viewList_t result; | 72 | viewList_t result; |
73 | 73 | ||
74 | filterResult_t pre = runFilters(view, viewList_t(), mPreFilters); | 74 | filterResult_t pre = runFilters(view, viewList_t(), mPreFilters); |
75 | if(!pre.first && !pre.second) | 75 | if(!pre.first && !pre.second) |
76 | { | 76 | { |
77 | // skip post filters completely if we're not including ourselves or the children | 77 | // skip post filters completely if we're not including ourselves or the children |
78 | return result; | 78 | return result; |
79 | } | 79 | } |
80 | if(pre.second) | 80 | if(pre.second) |
81 | { | 81 | { |
82 | // run filters on children | 82 | // run filters on children |
83 | viewList_t filtered_children; | 83 | viewList_t filtered_children; |
84 | filterChildren(view, filtered_children); | 84 | filterChildren(view, filtered_children); |
85 | filterResult_t post = runFilters(view, filtered_children, mPostFilters); | 85 | filterResult_t post = runFilters(view, filtered_children, mPostFilters); |
86 | if(pre.first && post.first) | 86 | if(pre.first && post.first) |
87 | { | 87 | { |
88 | result.push_back(view); | 88 | result.push_back(view); |
89 | } | 89 | } |
90 | if(post.second) | 90 | if(post.second) |
91 | { | 91 | { |
92 | result.insert(result.end(), filtered_children.begin(), filtered_children.end()); | 92 | result.insert(result.end(), filtered_children.begin(), filtered_children.end()); |
93 | } | 93 | } |
94 | } | 94 | } |
95 | else | 95 | else |
96 | { | 96 | { |
97 | if(pre.first) | 97 | if(pre.first) |
98 | { | 98 | { |
99 | result.push_back(view); | 99 | result.push_back(view); |
100 | } | 100 | } |
101 | } | 101 | } |
102 | return result; | 102 | return result; |
103 | } | 103 | } |
104 | 104 | ||
105 | void LLViewQuery::filterChildren(LLView * view, viewList_t & filtered_children) const | 105 | void LLViewQuery::filterChildren(LLView * view, viewList_t & filtered_children) const |
106 | { | 106 | { |
107 | LLView::child_list_t views(*(view->getChildList())); | 107 | LLView::child_list_t views(*(view->getChildList())); |
108 | (*mSorterp)(view, views); // sort the children per the sorter | 108 | (*mSorterp)(view, views); // sort the children per the sorter |
109 | for(LLView::child_list_iter_t iter = views.begin(); | 109 | for(LLView::child_list_iter_t iter = views.begin(); |
110 | iter != views.end(); | 110 | iter != views.end(); |
111 | iter++) | 111 | iter++) |
112 | { | 112 | { |
113 | viewList_t indiv_children = this->run(*iter); | 113 | viewList_t indiv_children = this->run(*iter); |
114 | filtered_children.insert(filtered_children.end(), indiv_children.begin(), indiv_children.end()); | 114 | filtered_children.insert(filtered_children.end(), indiv_children.begin(), indiv_children.end()); |
115 | } | 115 | } |
116 | } | 116 | } |
117 | 117 | ||
118 | filterResult_t LLViewQuery::runFilters(LLView * view, const viewList_t children, const filterList_t filters) const | 118 | filterResult_t LLViewQuery::runFilters(LLView * view, const viewList_t children, const filterList_t filters) const |
119 | { | 119 | { |
120 | filterResult_t result = filterResult_t(TRUE, TRUE); | 120 | filterResult_t result = filterResult_t(TRUE, TRUE); |
121 | for(filterList_const_iter_t iter = filters.begin(); | 121 | for(filterList_const_iter_t iter = filters.begin(); |
122 | iter != filters.end(); | 122 | iter != filters.end(); |
123 | iter++) | 123 | iter++) |
124 | { | 124 | { |
125 | filterResult_t filtered = (**iter)(view, children); | 125 | filterResult_t filtered = (**iter)(view, children); |
126 | result.first = result.first && filtered.first; | 126 | result.first = result.first && filtered.first; |
127 | result.second = result.second && filtered.second; | 127 | result.second = result.second && filtered.second; |
128 | } | 128 | } |
129 | return result; | 129 | return result; |
130 | } | 130 | } |
131 | 131 | ||
132 | class SortByTabOrder : public LLQuerySorter, public LLSingleton<SortByTabOrder> | 132 | class SortByTabOrder : public LLQuerySorter, public LLSingleton<SortByTabOrder> |
133 | { | 133 | { |
134 | /*virtual*/ void operator() (LLView * parent, LLView::child_list_t &children) const | 134 | /*virtual*/ void operator() (LLView * parent, LLView::child_list_t &children) const |
135 | { | 135 | { |
136 | children.sort(LLCompareByTabOrder(parent->getCtrlOrder())); | 136 | children.sort(LLCompareByTabOrder(parent->getCtrlOrder())); |
137 | } | 137 | } |
138 | }; | 138 | }; |
139 | 139 | ||
140 | LLCtrlQuery::LLCtrlQuery() : | 140 | LLCtrlQuery::LLCtrlQuery() : |
141 | LLViewQuery() | 141 | LLViewQuery() |
142 | { | 142 | { |
143 | setSorter(SortByTabOrder::getInstance()); | 143 | setSorter(SortByTabOrder::getInstance()); |
144 | } | 144 | } |
145 | 145 | ||
diff --git a/linden/indra/llui/llviewquery.h b/linden/indra/llui/llviewquery.h index 3dc2861..7ab401a 100644 --- a/linden/indra/llui/llviewquery.h +++ b/linden/indra/llui/llviewquery.h | |||
@@ -1,8 +1,8 @@ | |||
1 | /** | 1 | /** |
2 | * @file llviewquery.h | 2 | * @file llviewquery.h |
3 | * @brief Query algorithm for flattening and filtering the view hierarchy. | 3 | * @brief Query algorithm for flattening and filtering the view hierarchy. |
4 | * | 4 | * |
5 | * Copyright (c) 2001-2007, Linden Research, Inc. | 5 | * Copyright (c) 2001-2007, Linden Research, Inc. |
6 | * | 6 | * |
7 | * The source code in this file ("Source Code") is provided by Linden Lab | 7 | * The source code in this file ("Source Code") is provided by Linden Lab |
8 | * to you under the terms of the GNU General Public License, version 2.0 | 8 | * to you under the terms of the GNU General Public License, version 2.0 |
@@ -22,87 +22,87 @@ | |||
22 | * | 22 | * |
23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | 23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO |
24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | 24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, |
25 | * COMPLETENESS OR PERFORMANCE. | 25 | * COMPLETENESS OR PERFORMANCE. |
26 | */ | 26 | */ |
27 | 27 | ||
28 | #ifndef LL_LLVIEWQUERY_H | 28 | #ifndef LL_LLVIEWQUERY_H |
29 | #define LL_LLVIEWQUERY_H | 29 | #define LL_LLVIEWQUERY_H |
30 | 30 | ||
31 | #include <list> | 31 | #include <list> |
32 | 32 | ||
33 | #include "llmemory.h" | 33 | #include "llmemory.h" |
34 | 34 | ||
35 | class LLView; | 35 | class LLView; |
36 | 36 | ||
37 | typedef std::list<LLView *> viewList_t; | 37 | typedef std::list<LLView *> viewList_t; |
38 | typedef std::pair<BOOL, BOOL> filterResult_t; | 38 | typedef std::pair<BOOL, BOOL> filterResult_t; |
39 | 39 | ||
40 | // Abstract base class for all filters. | 40 | // Abstract base class for all filters. |
41 | class LLQueryFilter : public LLRefCount | 41 | class LLQueryFilter : public LLRefCount |
42 | { | 42 | { |
43 | public: | 43 | public: |
44 | virtual filterResult_t operator() (const LLView* const view, const viewList_t & children) const =0; | 44 | virtual filterResult_t operator() (const LLView* const view, const viewList_t & children) const =0; |
45 | }; | 45 | }; |
46 | 46 | ||
47 | class LLQuerySorter : public LLRefCount | 47 | class LLQuerySorter : public LLRefCount |
48 | { | 48 | { |
49 | public: | 49 | public: |
50 | virtual void operator() (LLView * parent, viewList_t &children) const; | 50 | virtual void operator() (LLView * parent, viewList_t &children) const; |
51 | }; | 51 | }; |
52 | 52 | ||
53 | class LLNoLeavesFilter : public LLQueryFilter, public LLSingleton<LLNoLeavesFilter> | 53 | class LLNoLeavesFilter : public LLQueryFilter, public LLSingleton<LLNoLeavesFilter> |
54 | { | 54 | { |
55 | /*virtual*/ filterResult_t operator() (const LLView* const view, const viewList_t & children) const; | 55 | /*virtual*/ filterResult_t operator() (const LLView* const view, const viewList_t & children) const; |
56 | }; | 56 | }; |
57 | class LLVisibleFilter : public LLQueryFilter, public LLSingleton<LLVisibleFilter> | 57 | class LLVisibleFilter : public LLQueryFilter, public LLSingleton<LLVisibleFilter> |
58 | { | 58 | { |
59 | /*virtual*/ filterResult_t operator() (const LLView* const view, const viewList_t & children) const; | 59 | /*virtual*/ filterResult_t operator() (const LLView* const view, const viewList_t & children) const; |
60 | }; | 60 | }; |
61 | class LLEnabledFilter : public LLQueryFilter, public LLSingleton<LLEnabledFilter> | 61 | class LLEnabledFilter : public LLQueryFilter, public LLSingleton<LLEnabledFilter> |
62 | { | 62 | { |
63 | /*virtual*/ filterResult_t operator() (const LLView* const view, const viewList_t & children) const; | 63 | /*virtual*/ filterResult_t operator() (const LLView* const view, const viewList_t & children) const; |
64 | }; | 64 | }; |
65 | class LLTabStopFilter : public LLQueryFilter, public LLSingleton<LLTabStopFilter> | 65 | class LLTabStopFilter : public LLQueryFilter, public LLSingleton<LLTabStopFilter> |
66 | { | 66 | { |
67 | /*virtual*/ filterResult_t operator() (const LLView* const view, const viewList_t & children) const; | 67 | /*virtual*/ filterResult_t operator() (const LLView* const view, const viewList_t & children) const; |
68 | }; | 68 | }; |
69 | 69 | ||
70 | // Algorithm for flattening | 70 | // Algorithm for flattening |
71 | class LLViewQuery | 71 | class LLViewQuery |
72 | { | 72 | { |
73 | public: | 73 | public: |
74 | typedef std::list<const LLQueryFilter*> filterList_t; | 74 | typedef std::list<const LLQueryFilter*> filterList_t; |
75 | typedef filterList_t::iterator filterList_iter_t; | 75 | typedef filterList_t::iterator filterList_iter_t; |
76 | typedef filterList_t::const_iterator filterList_const_iter_t; | 76 | typedef filterList_t::const_iterator filterList_const_iter_t; |
77 | 77 | ||
78 | LLViewQuery(); | 78 | LLViewQuery(); |
79 | virtual ~LLViewQuery() {} | 79 | virtual ~LLViewQuery() {} |
80 | 80 | ||
81 | void addPreFilter(const LLQueryFilter* prefilter); | 81 | void addPreFilter(const LLQueryFilter* prefilter); |
82 | void addPostFilter(const LLQueryFilter* postfilter); | 82 | void addPostFilter(const LLQueryFilter* postfilter); |
83 | const filterList_t & getPreFilters() const; | 83 | const filterList_t & getPreFilters() const; |
84 | const filterList_t & getPostFilters() const; | 84 | const filterList_t & getPostFilters() const; |
85 | 85 | ||
86 | void setSorter(const LLQuerySorter* sorter); | 86 | void setSorter(const LLQuerySorter* sorter); |
87 | const LLQuerySorter* getSorter() const; | 87 | const LLQuerySorter* getSorter() const; |
88 | 88 | ||
89 | viewList_t run(LLView * view) const; | 89 | viewList_t run(LLView * view) const; |
90 | // syntactic sugar | 90 | // syntactic sugar |
91 | viewList_t operator () (LLView * view) const { return run(view); } | 91 | viewList_t operator () (LLView * view) const { return run(view); } |
92 | protected: | 92 | protected: |
93 | // override this method to provide iteration over other types of children | 93 | // override this method to provide iteration over other types of children |
94 | virtual void filterChildren(LLView * view, viewList_t & filtered_children) const; | 94 | virtual void filterChildren(LLView * view, viewList_t & filtered_children) const; |
95 | filterResult_t runFilters(LLView * view, const viewList_t children, const filterList_t filters) const; | 95 | filterResult_t runFilters(LLView * view, const viewList_t children, const filterList_t filters) const; |
96 | protected: | 96 | protected: |
97 | filterList_t mPreFilters; | 97 | filterList_t mPreFilters; |
98 | filterList_t mPostFilters; | 98 | filterList_t mPostFilters; |
99 | const LLQuerySorter* mSorterp; | 99 | const LLQuerySorter* mSorterp; |
100 | }; | 100 | }; |
101 | 101 | ||
102 | class LLCtrlQuery : public LLViewQuery | 102 | class LLCtrlQuery : public LLViewQuery |
103 | { | 103 | { |
104 | public: | 104 | public: |
105 | LLCtrlQuery(); | 105 | LLCtrlQuery(); |
106 | }; | 106 | }; |
107 | 107 | ||
108 | #endif | 108 | #endif |