diff options
| author | coyot@coyot-sager-PC <coyot@coyot-sager-PC> | 2017-03-16 22:21:49 +0100 | 
|---|---|---|
| committer | coyot@coyot-sager-PC <coyot@coyot-sager-PC> | 2017-03-16 22:21:49 +0100 | 
| commit | fc56311ebf05d6d6c155e097bffbff9feb0c411f (patch) | |
| tree | 56445b8c652b930dfc4cec7efe51d934d151eafb /indra/llui | |
| parent | 3a3da6e4a76859f32dc36491fde2992e92ae57b5 (diff) | |
| parent | d7f5122ee9e12b5aec14b15517c3a4c0021544ce (diff) | |
pull from viewer64 gate
Diffstat (limited to 'indra/llui')
| -rw-r--r-- | indra/llui/llmenugl.cpp | 28 | ||||
| -rw-r--r-- | indra/llui/llmenugl.h | 5 | ||||
| -rw-r--r-- | indra/llui/llradiogroup.cpp | 53 | ||||
| -rw-r--r-- | indra/llui/llradiogroup.h | 4 | ||||
| -rw-r--r-- | indra/llui/llspellcheck.cpp | 1 | ||||
| -rw-r--r-- | indra/llui/lltabcontainer.cpp | 16 | ||||
| -rw-r--r-- | indra/llui/lltabcontainer.h | 2 | ||||
| -rw-r--r-- | indra/llui/lltextbase.cpp | 46 | ||||
| -rw-r--r-- | indra/llui/lltextbase.h | 22 | ||||
| -rw-r--r-- | indra/llui/llurlentry.cpp | 20 | ||||
| -rw-r--r-- | indra/llui/llurlentry.h | 8 | ||||
| -rw-r--r-- | indra/llui/llurlregistry.cpp | 1 | 
12 files changed, 152 insertions, 54 deletions
diff --git a/indra/llui/llmenugl.cpp b/indra/llui/llmenugl.cpp index 848367f8a8..8425774d46 100644 --- a/indra/llui/llmenugl.cpp +++ b/indra/llui/llmenugl.cpp @@ -1736,6 +1736,7 @@ LLMenuGL::LLMenuGL(const LLMenuGL::Params& p)  	mJumpKey(p.jump_key),  	mCreateJumpKeys(p.create_jump_keys),  	mNeedsArrange(FALSE), +	mAlwaysShowMenu(FALSE),  	mResetScrollPositionOnShow(true),  	mShortcutPad(p.shortcut_pad)  { @@ -3223,20 +3224,23 @@ void LLMenuGL::showPopup(LLView* spawning_view, LLMenuGL* menu, S32 x, S32 y)  	menu->setVisible( TRUE ); -	//Do not show menu if all menu items are disabled -	BOOL item_enabled = false; -	for (LLView::child_list_t::const_iterator itor = menu->getChildList()->begin(); -			 itor != menu->getChildList()->end(); -			 ++itor) +	if(!menu->getAlwaysShowMenu())  	{ -		LLView *menu_item = (*itor); -		item_enabled = item_enabled || menu_item->getEnabled(); -	} +		//Do not show menu if all menu items are disabled +		BOOL item_enabled = false; +		for (LLView::child_list_t::const_iterator itor = menu->getChildList()->begin(); +				itor != menu->getChildList()->end(); +				++itor) +		{ +			LLView *menu_item = (*itor); +			item_enabled = item_enabled || menu_item->getEnabled(); +		} -	if(!item_enabled) -	{ -		menu->setVisible( FALSE ); -		return; +		if(!item_enabled) +		{ +			menu->setVisible( FALSE ); +			return; +		}  	}  	// Save click point for detecting cursor moves before mouse-up. diff --git a/indra/llui/llmenugl.h b/indra/llui/llmenugl.h index c7f7f6848c..69f7d21513 100644 --- a/indra/llui/llmenugl.h +++ b/indra/llui/llmenugl.h @@ -531,6 +531,9 @@ public:  	void resetScrollPositionOnShow(bool reset_scroll_pos) { mResetScrollPositionOnShow = reset_scroll_pos; }  	bool isScrollPositionOnShowReset() { return mResetScrollPositionOnShow; } +	void setAlwaysShowMenu(BOOL show) { mAlwaysShowMenu = show; } +	BOOL getAlwaysShowMenu() { return mAlwaysShowMenu; } +  	// add a context menu branch  	BOOL appendContextSubMenu(LLMenuGL *menu); @@ -572,6 +575,8 @@ private:  	static LLColor4 sDefaultBackgroundColor;  	static BOOL		sKeyboardMode; +	BOOL			mAlwaysShowMenu; +  	LLUIColor		mBackgroundColor;  	BOOL			mBgVisible;  	LLHandle<LLView> mParentMenuItem; diff --git a/indra/llui/llradiogroup.cpp b/indra/llui/llradiogroup.cpp index 8cf72928ff..2c7e7ab13d 100644 --- a/indra/llui/llradiogroup.cpp +++ b/indra/llui/llradiogroup.cpp @@ -54,6 +54,7 @@ public:  	/*virtual*/ void setValue(const LLSD& value);  	/*virtual*/ BOOL postBuild(); +	/*virtual*/ BOOL handleMouseDown(S32 x, S32 y, MASK mask);  	LLSD getPayload() { return mPayload; } @@ -224,6 +225,22 @@ BOOL LLRadioGroup::setSelectedIndex(S32 index, BOOL from_event)  	return TRUE;  } +void LLRadioGroup::focusSelectedRadioBtn() +{ +    if (mSelectedIndex >= 0) +    { +        LLRadioCtrl* radio_item = mRadioButtons[mSelectedIndex]; +        if (radio_item->hasTabStop() && radio_item->getEnabled()) +        { +            radio_item->focusFirstItem(FALSE, FALSE); +        } +    } +    else if (mRadioButtons[0]->hasTabStop() || hasTabStop()) +    { +        focusFirstItem(FALSE, FALSE); +    } +} +  BOOL LLRadioGroup::handleKeyHere(KEY key, MASK mask)  {  	BOOL handled = FALSE; @@ -283,19 +300,6 @@ BOOL LLRadioGroup::handleKeyHere(KEY key, MASK mask)  	return handled;  } -BOOL LLRadioGroup::handleMouseDown(S32 x, S32 y, MASK mask) -{ -	// grab focus preemptively, before child button takes mousecapture -	//  -	if (hasTabStop()) -	{ -		focusFirstItem(FALSE, FALSE); -	} - -	return LLUICtrl::handleMouseDown(x, y, mask); -} - -  // Handle one button being clicked.  All child buttons must have this  // function as their callback function. @@ -466,6 +470,29 @@ BOOL LLRadioCtrl::postBuild()  	return TRUE;  } +BOOL LLRadioCtrl::handleMouseDown(S32 x, S32 y, MASK mask) +{ +    // Grab focus preemptively, before button takes mousecapture +    if (hasTabStop() && getEnabled()) +    { +        focusFirstItem(FALSE, FALSE); +    } +    else +    { +        // Only currently selected item in group has tab stop as result it is +        // unclear how focus should behave on click, just let the group handle +        // focus and LLRadioGroup::onClickButton() will set correct state later +        // if needed +        LLRadioGroup* parent = (LLRadioGroup*)getParent(); +        if (parent) +        { +            parent->focusSelectedRadioBtn(); +        } +    } + +    return LLCheckBoxCtrl::handleMouseDown(x, y, mask); +} +  LLRadioCtrl::~LLRadioCtrl()  {  } diff --git a/indra/llui/llradiogroup.h b/indra/llui/llradiogroup.h index 8bd5698538..dcb2f43bfe 100644 --- a/indra/llui/llradiogroup.h +++ b/indra/llui/llradiogroup.h @@ -66,8 +66,6 @@ public:  	virtual BOOL postBuild(); -	virtual BOOL handleMouseDown(S32 x, S32 y, MASK mask); -	  	virtual BOOL handleKeyHere(KEY key, MASK mask);  	void setIndexEnabled(S32 index, BOOL enabled); @@ -75,6 +73,8 @@ public:  	S32 getSelectedIndex() const { return mSelectedIndex; }  	// set the index value programatically  	BOOL setSelectedIndex(S32 index, BOOL from_event = FALSE); +	// foxus child by index if it can get focus +	void focusSelectedRadioBtn();  	// Accept and retrieve strings of the radio group control names  	virtual void	setValue(const LLSD& value ); diff --git a/indra/llui/llspellcheck.cpp b/indra/llui/llspellcheck.cpp index 0db4281059..5a52600337 100644 --- a/indra/llui/llspellcheck.cpp +++ b/indra/llui/llspellcheck.cpp @@ -161,6 +161,7 @@ void LLSpellChecker::refreshDictionaryMap()  	}  	// Load user installed dictionary information +	user_filename = user_path + DICT_FILE_USER;  	llifstream custom_file(user_filename.c_str(), std::ios::binary);  	if (custom_file.is_open())  	{ diff --git a/indra/llui/lltabcontainer.cpp b/indra/llui/lltabcontainer.cpp index 701a06a085..1b2f09cff5 100644 --- a/indra/llui/lltabcontainer.cpp +++ b/indra/llui/lltabcontainer.cpp @@ -210,6 +210,7 @@ LLTabContainer::Params::Params()  	label_pad_left("label_pad_left"),  	tab_position("tab_position"),  	hide_tabs("hide_tabs", false), +	hide_scroll_arrows("hide_scroll_arrows", false),  	tab_padding_right("tab_padding_right"),  	first_tab("first_tab"),  	middle_tab("middle_tab"), @@ -240,6 +241,7 @@ LLTabContainer::LLTabContainer(const LLTabContainer::Params& p)  	mPrevArrowBtn(NULL),  	mNextArrowBtn(NULL),  	mIsVertical( p.tab_position == LEFT ), +	mHideScrollArrows(p.hide_scroll_arrows),  	// Horizontal Specific  	mJumpPrevArrowBtn(NULL),  	mJumpNextArrowBtn(NULL), @@ -409,7 +411,7 @@ void LLTabContainer::draw()  	setScrollPosPixels((S32)lerp((F32)getScrollPosPixels(), (F32)target_pixel_scroll, LLSmoothInterpolation::getInterpolant(0.08f))); -	BOOL has_scroll_arrows = !getTabsHidden() && ((mMaxScrollPos > 0) || (mScrollPosPixels > 0)); +	BOOL has_scroll_arrows = !mHideScrollArrows && !getTabsHidden() && ((mMaxScrollPos > 0) || (mScrollPosPixels > 0));  	if (!mIsVertical)  	{  		mJumpPrevArrowBtn->setVisible( has_scroll_arrows ); @@ -517,7 +519,7 @@ BOOL LLTabContainer::handleMouseDown( S32 x, S32 y, MASK mask )  {  	static LLUICachedControl<S32> tabcntrv_pad ("UITabCntrvPad", 0);  	BOOL handled = FALSE; -	BOOL has_scroll_arrows = (getMaxScrollPos() > 0) && !getTabsHidden(); +	BOOL has_scroll_arrows = !mHideScrollArrows && (getMaxScrollPos() > 0) && !getTabsHidden();  	if (has_scroll_arrows)  	{ @@ -591,7 +593,7 @@ BOOL LLTabContainer::handleMouseDown( S32 x, S32 y, MASK mask )  BOOL LLTabContainer::handleHover( S32 x, S32 y, MASK mask )  {  	BOOL handled = FALSE; -	BOOL has_scroll_arrows = (getMaxScrollPos() > 0) && !getTabsHidden(); +	BOOL has_scroll_arrows = !mHideScrollArrows && (getMaxScrollPos() > 0) && !getTabsHidden();  	if (has_scroll_arrows)  	{ @@ -633,7 +635,7 @@ BOOL LLTabContainer::handleHover( S32 x, S32 y, MASK mask )  BOOL LLTabContainer::handleMouseUp( S32 x, S32 y, MASK mask )  {  	BOOL handled = FALSE; -	BOOL has_scroll_arrows = (getMaxScrollPos() > 0)  && !getTabsHidden(); +	BOOL has_scroll_arrows = !mHideScrollArrows && (getMaxScrollPos() > 0)  && !getTabsHidden();  	S32 local_x = x - getRect().mLeft;  	S32 local_y = y - getRect().mBottom; @@ -701,7 +703,7 @@ BOOL LLTabContainer::handleToolTip( S32 x, S32 y, MASK mask)  	{  		LLTabTuple* firsttuple = getTab(0); -		BOOL has_scroll_arrows = (getMaxScrollPos() > 0); +		BOOL has_scroll_arrows = !mHideScrollArrows && (getMaxScrollPos() > 0);  		LLRect clip;  		if (mIsVertical)  		{ @@ -826,7 +828,7 @@ BOOL LLTabContainer::handleKeyHere(KEY key, MASK mask)  // virtual  BOOL LLTabContainer::handleDragAndDrop(S32 x, S32 y, MASK mask,	BOOL drop,	EDragAndDropType type, void* cargo_data, EAcceptance *accept, std::string	&tooltip)  { -	BOOL has_scroll_arrows = (getMaxScrollPos() > 0); +	BOOL has_scroll_arrows = !mHideScrollArrows && (getMaxScrollPos() > 0);  	if(mOpenTabsOnDragAndDrop && !getTabsHidden())  	{ @@ -1543,7 +1545,7 @@ BOOL LLTabContainer::setTab(S32 which)  						is_visible = FALSE;  					}  				} -				else if (getMaxScrollPos() > 0) +				else if (!mHideScrollArrows && getMaxScrollPos() > 0)  				{  					if( i < getScrollPos() )  					{ diff --git a/indra/llui/lltabcontainer.h b/indra/llui/lltabcontainer.h index 057809dc42..4a5f08f5d3 100644 --- a/indra/llui/lltabcontainer.h +++ b/indra/llui/lltabcontainer.h @@ -83,6 +83,7 @@ public:  											label_pad_left;  		Optional<bool>						hide_tabs; +		Optional<bool>						hide_scroll_arrows;  		Optional<S32>						tab_padding_right;  		Optional<TabParams>					first_tab, @@ -262,6 +263,7 @@ private:  	S32								mCurrentTabIdx;  	BOOL							mTabsHidden; +	BOOL							mHideScrollArrows;  	BOOL							mScrolled;  	LLFrameTimer					mScrollTimer; diff --git a/indra/llui/lltextbase.cpp b/indra/llui/lltextbase.cpp index 20be739286..88a5c3a587 100644 --- a/indra/llui/lltextbase.cpp +++ b/indra/llui/lltextbase.cpp @@ -1522,6 +1522,7 @@ void LLTextBase::reflow()  		}  		S32 line_height = 0; +		S32 seg_line_offset = line_count;  		while(seg_iter != mSegments.end())  		{ @@ -1534,7 +1535,8 @@ void LLTextBase::reflow()  			S32 character_count = segment->getNumChars(getWordWrap() ? llmax(0, remaining_pixels) : S32_MAX,  														seg_offset,   														cur_index - line_start_index,  -														S32_MAX); +														S32_MAX, +														line_count - seg_line_offset);  			S32 segment_width, segment_height;  			bool force_newline = segment->getDimensions(seg_offset, character_count, segment_width, segment_height); @@ -1597,6 +1599,7 @@ void LLTextBase::reflow()  				}  				++seg_iter;  				seg_offset = 0; +				seg_line_offset = force_newline ? line_count + 1 : line_count;  			}  			if (force_newline)   			{ @@ -3065,7 +3068,7 @@ LLTextSegment::~LLTextSegment()  bool LLTextSegment::getDimensions(S32 first_char, S32 num_chars, S32& width, S32& height) const { width = 0; height = 0; return false;}  S32	LLTextSegment::getOffset(S32 segment_local_x_coord, S32 start_offset, S32 num_chars, bool round) const { return 0; } -S32	LLTextSegment::getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars) const { return 0; } +S32	LLTextSegment::getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars, S32 line_ind) const { return 0; }  void LLTextSegment::updateLayout(const LLTextBase& editor) {}  F32	LLTextSegment::draw(S32 start, S32 end, S32 selection_start, S32 selection_end, const LLRectf& draw_rect) { return draw_rect.mLeft; }  bool LLTextSegment::canEdit() const { return false; } @@ -3335,7 +3338,7 @@ S32	LLNormalTextSegment::getOffset(S32 segment_local_x_coord, S32 start_offset,  											   round);  } -S32	LLNormalTextSegment::getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars) const +S32	LLNormalTextSegment::getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars, S32 line_ind) const  {  	const LLWString &text = getWText(); @@ -3352,7 +3355,7 @@ S32	LLNormalTextSegment::getNumChars(S32 num_pixels, S32 segment_offset, S32 lin  	// if no character yet displayed on this line, don't require word wrapping since  	// we can just move to the next line, otherwise insist on it so we make forward progress -	LLFontGL::EWordWrapStyle word_wrap_style = (line_offset == 0)  +	LLFontGL::EWordWrapStyle word_wrap_style = (line_offset == 0)  		? LLFontGL::WORD_BOUNDARY_IF_POSSIBLE   		: LLFontGL::ONLY_WORD_BOUNDARIES; @@ -3490,12 +3493,26 @@ LLInlineViewSegment::~LLInlineViewSegment()  bool LLInlineViewSegment::getDimensions(S32 first_char, S32 num_chars, S32& width, S32& height) const  { -	if (first_char == 0 && num_chars == 0)  +	if (first_char == 0 && num_chars == 0)  	{ -		// we didn't fit on a line, the widget will fall on the next line -		// so dimensions here are 0 +		// We didn't fit on a line or were forced to new string +		// the widget will fall on the next line, so width here is 0  		width = 0; -		height = 0; + +		if (mForceNewLine) +		{ +			// Chat, string can't be smaller then font height even if it is empty +			LLStyleSP s(new LLStyle(LLStyle::Params().visible(true))); +			height = s->getFont()->getLineHeight(); + +			return true; // new line +		} +		else +		{ +			// height from previous segment in same string will be used, word-wrap +			height = 0; +		} +  	}  	else  	{ @@ -3506,13 +3523,16 @@ bool LLInlineViewSegment::getDimensions(S32 first_char, S32 num_chars, S32& widt  	return false;  } -S32	LLInlineViewSegment::getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars) const +S32	LLInlineViewSegment::getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars, S32 line_ind) const  {  	// if putting a widget anywhere but at the beginning of a line  	// and the widget doesn't fit or mForceNewLine is true  	// then return 0 chars for that line, and all characters for the next -	if (line_offset != 0  -		&& (mForceNewLine || num_pixels < mView->getRect().getWidth()))  +	if (mForceNewLine && line_ind == 0) +	{ +		return 0; +	} +	else if (line_offset != 0 && num_pixels < mView->getRect().getWidth())  	{  		return 0;  	} @@ -3565,7 +3585,7 @@ bool LLLineBreakTextSegment::getDimensions(S32 first_char, S32 num_chars, S32& w  	return true;  } -S32	LLLineBreakTextSegment::getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars) const +S32	LLLineBreakTextSegment::getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars, S32 line_ind) const  {  	return 1;  } @@ -3601,7 +3621,7 @@ bool LLImageTextSegment::getDimensions(S32 first_char, S32 num_chars, S32& width  	return false;  } -S32	 LLImageTextSegment::getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars) const +S32	 LLImageTextSegment::getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars, S32 line_ind) const  {  	LLUIImagePtr image = mStyle->getImage(); diff --git a/indra/llui/lltextbase.h b/indra/llui/lltextbase.h index 3d3a6ca869..c7b6203445 100644 --- a/indra/llui/lltextbase.h +++ b/indra/llui/lltextbase.h @@ -64,7 +64,19 @@ public:  	virtual bool				getDimensions(S32 first_char, S32 num_chars, S32& width, S32& height) const;  	virtual S32					getOffset(S32 segment_local_x_coord, S32 start_offset, S32 num_chars, bool round) const; -	virtual S32					getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars) const; + +	/** +	* Get number of chars that fit into free part of current line. +	* +	* @param num_pixels - maximum width of rect +	* @param segment_offset - symbol in segment we start processing line from +	* @param line_offset - symbol in line after which segment starts +	* @param max_chars - limit of symbols that will fit in current line +	* @param line_ind - index of not word-wrapped string inside segment for multi-line segments. +	* Two string separated by word-wrap will have same index. +	* @return number of chars that will fit into current line +	*/ +	virtual S32					getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars, S32 line_ind) const;  	virtual void				updateLayout(const class LLTextBase& editor);  	virtual F32					draw(S32 start, S32 end, S32 selection_start, S32 selection_end, const LLRectf& draw_rect);  	virtual bool				canEdit() const; @@ -116,7 +128,7 @@ public:  	/*virtual*/ bool				getDimensions(S32 first_char, S32 num_chars, S32& width, S32& height) const;  	/*virtual*/ S32					getOffset(S32 segment_local_x_coord, S32 start_offset, S32 num_chars, bool round) const; -	/*virtual*/ S32					getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars) const; +	/*virtual*/ S32					getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars, S32 line_ind) const;  	/*virtual*/ F32					draw(S32 start, S32 end, S32 selection_start, S32 selection_end, const LLRectf& draw_rect);  	/*virtual*/ bool				canEdit() const { return true; }  	/*virtual*/ const LLColor4&		getColor() const					{ return mStyle->getColor(); } @@ -201,7 +213,7 @@ public:  	LLInlineViewSegment(const Params& p, S32 start, S32 end);  	~LLInlineViewSegment();  	/*virtual*/ bool		getDimensions(S32 first_char, S32 num_chars, S32& width, S32& height) const; -	/*virtual*/ S32			getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars) const; +	/*virtual*/ S32			getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars, S32 line_ind) const;  	/*virtual*/ void		updateLayout(const class LLTextBase& editor);  	/*virtual*/ F32			draw(S32 start, S32 end, S32 selection_start, S32 selection_end, const LLRectf& draw_rect);  	/*virtual*/ bool		canEdit() const { return false; } @@ -225,7 +237,7 @@ public:  	LLLineBreakTextSegment(S32 pos);  	~LLLineBreakTextSegment();  	bool		getDimensions(S32 first_char, S32 num_chars, S32& width, S32& height) const; -	S32			getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars) const; +	S32			getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars, S32 line_ind) const;  	F32			draw(S32 start, S32 end, S32 selection_start, S32 selection_end, const LLRectf& draw_rect);  private: @@ -238,7 +250,7 @@ public:  	LLImageTextSegment(LLStyleConstSP style,S32 pos,class LLTextBase& editor);  	~LLImageTextSegment();  	bool		getDimensions(S32 first_char, S32 num_chars, S32& width, S32& height) const; -	S32			getNumChars(S32 num_pixels, S32 segment_offset, S32 line_offset, S32 max_chars) const; +	S32			getNumChars(S32 num_pixels, S32 segment_offset, S32 char_offset, S32 max_chars, S32 line_ind) const;  	F32			draw(S32 start, S32 end, S32 selection_start, S32 selection_end, const LLRectf& draw_rect);  	/*virtual*/ BOOL	handleToolTip(S32 x, S32 y, MASK mask); diff --git a/indra/llui/llurlentry.cpp b/indra/llui/llurlentry.cpp index b5a31f5118..b211829496 100644 --- a/indra/llui/llurlentry.cpp +++ b/indra/llui/llurlentry.cpp @@ -764,7 +764,23 @@ LLUrlEntryAgentCompleteName::LLUrlEntryAgentCompleteName()  std::string LLUrlEntryAgentCompleteName::getName(const LLAvatarName& avatar_name)  { -	return avatar_name.getCompleteName(); +	return avatar_name.getCompleteName(true, true); +} + +// +// LLUrlEntryAgentLegacyName describes a Second Life agent legacy name Url, e.g., +// secondlife:///app/agent/0e346d8b-4433-4d66-a6b0-fd37083abc4c/legacyname +// x-grid-location-info://lincoln.lindenlab.com/app/agent/0e346d8b-4433-4d66-a6b0-fd37083abc4c/legacyname +// +LLUrlEntryAgentLegacyName::LLUrlEntryAgentLegacyName() +{ +	mPattern = boost::regex(APP_HEADER_REGEX "/agent/[\\da-f-]+/legacyname", +							boost::regex::perl|boost::regex::icase); +} + +std::string LLUrlEntryAgentLegacyName::getName(const LLAvatarName& avatar_name) +{ +	return avatar_name.getLegacyName();  }  // @@ -780,7 +796,7 @@ LLUrlEntryAgentDisplayName::LLUrlEntryAgentDisplayName()  std::string LLUrlEntryAgentDisplayName::getName(const LLAvatarName& avatar_name)  { -	return avatar_name.getDisplayName(); +	return avatar_name.getDisplayName(true);  }  // diff --git a/indra/llui/llurlentry.h b/indra/llui/llurlentry.h index 413c20a657..28e9931718 100644 --- a/indra/llui/llurlentry.h +++ b/indra/llui/llurlentry.h @@ -269,6 +269,14 @@ private:  	/*virtual*/ std::string getName(const LLAvatarName& avatar_name);  }; +class LLUrlEntryAgentLegacyName : public LLUrlEntryAgentName +{ +public: +	LLUrlEntryAgentLegacyName(); +private: +	/*virtual*/ std::string getName(const LLAvatarName& avatar_name); +}; +  ///  /// LLUrlEntryAgentDisplayName Describes a Second Life agent display name Url, e.g.,  /// secondlife:///app/agent/0e346d8b-4433-4d66-a6b0-fd37083abc4c/displayname diff --git a/indra/llui/llurlregistry.cpp b/indra/llui/llurlregistry.cpp index 23c6d5a954..fa6593267a 100644 --- a/indra/llui/llurlregistry.cpp +++ b/indra/llui/llurlregistry.cpp @@ -57,6 +57,7 @@ LLUrlRegistry::LLUrlRegistry()  	mUrlEntryHTTPLabel = new LLUrlEntryHTTPLabel();  	registerUrl(mUrlEntryHTTPLabel);  	registerUrl(new LLUrlEntryAgentCompleteName()); +	registerUrl(new LLUrlEntryAgentLegacyName());  	registerUrl(new LLUrlEntryAgentDisplayName());  	registerUrl(new LLUrlEntryAgentUserName());  	// LLUrlEntryAgent*Name must appear before LLUrlEntryAgent since   | 
