automated merge
commit
419bfb16fd
|
|
@ -74,6 +74,10 @@ if (WINDOWS)
|
|||
if (NOT VS_DISABLE_FATAL_WARNINGS)
|
||||
add_definitions(/WX)
|
||||
endif (NOT VS_DISABLE_FATAL_WARNINGS)
|
||||
|
||||
# configure win32 API for windows XP+ compatibility
|
||||
set(WINVER "0x0501" CACHE STRING "Win32 API Target version (see http://msdn.microsoft.com/en-us/library/aa383745%28v=VS.85%29.aspx)")
|
||||
add_definitions("/DWINVER=${WINVER}" "/D_WIN32_WINNT=${WINVER}")
|
||||
endif (WINDOWS)
|
||||
|
||||
|
||||
|
|
|
|||
|
|
@ -863,7 +863,13 @@ bool unix_post_minidump_callback(const char *dump_dir,
|
|||
|
||||
llinfos << "generated minidump: " << LLApp::instance()->getMiniDumpFilename() << llendl;
|
||||
LLApp::runErrorHandler();
|
||||
|
||||
#ifndef LL_RELEASE_FOR_DOWNLOAD
|
||||
clear_signals();
|
||||
return false;
|
||||
#else
|
||||
return true;
|
||||
#endif
|
||||
}
|
||||
#endif // !WINDOWS
|
||||
|
||||
|
|
@ -920,6 +926,10 @@ bool windows_post_minidump_callback(const wchar_t* dump_path,
|
|||
ms_sleep(10);
|
||||
}
|
||||
|
||||
#ifndef LL_RELEASE_FOR_DOWNLOAD
|
||||
return false;
|
||||
#else
|
||||
return true;
|
||||
#endif
|
||||
}
|
||||
#endif
|
||||
|
|
|
|||
|
|
@ -40,6 +40,7 @@
|
|||
#include "llscrollcontainer.h"
|
||||
#include "llstl.h"
|
||||
#include "lltextparser.h"
|
||||
#include "lltextutil.h"
|
||||
#include "lltooltip.h"
|
||||
#include "lluictrl.h"
|
||||
#include "llurlaction.h"
|
||||
|
|
@ -1595,6 +1596,9 @@ void LLTextBase::appendTextImpl(const std::string &new_text, const LLStyle::Para
|
|||
while ( LLUrlRegistry::instance().findUrl(text, match,
|
||||
boost::bind(&LLTextBase::replaceUrlLabel, this, _1, _2)) )
|
||||
{
|
||||
|
||||
LLTextUtil::processUrlMatch(&match,this);
|
||||
|
||||
start = match.getStart();
|
||||
end = match.getEnd()+1;
|
||||
|
||||
|
|
@ -1619,22 +1623,6 @@ void LLTextBase::appendTextImpl(const std::string &new_text, const LLStyle::Para
|
|||
std::string subtext=text.substr(0,start);
|
||||
appendAndHighlightText(subtext, part, style_params);
|
||||
}
|
||||
|
||||
// output an optional icon before the Url
|
||||
if (! match.getIcon().empty())
|
||||
{
|
||||
LLUIImagePtr image = LLUI::getUIImage(match.getIcon());
|
||||
if (image)
|
||||
{
|
||||
LLStyle::Params icon;
|
||||
icon.image = image;
|
||||
// Text will be replaced during rendering with the icon,
|
||||
// but string cannot be empty or the segment won't be
|
||||
// added (or drawn).
|
||||
appendImageSegment(icon);
|
||||
}
|
||||
}
|
||||
|
||||
// output the styled Url (unless we've been asked to suppress hyperlinking)
|
||||
if (match.isLinkDisabled())
|
||||
{
|
||||
|
|
@ -1716,7 +1704,14 @@ void LLTextBase::appendImageSegment(const LLStyle::Params& style_params)
|
|||
insertStringNoUndo(getLength(), utf8str_to_wstring(" "), &segments);
|
||||
}
|
||||
|
||||
void LLTextBase::appendWidget(const LLInlineViewSegment::Params& params, const std::string& text, bool allow_undo)
|
||||
{
|
||||
segment_vec_t segments;
|
||||
LLWString widget_wide_text = utf8str_to_wstring(text);
|
||||
segments.push_back(new LLInlineViewSegment(params, getLength(), getLength() + widget_wide_text.size()));
|
||||
|
||||
insertStringNoUndo(getLength(), widget_wide_text, &segments);
|
||||
}
|
||||
|
||||
void LLTextBase::appendAndHighlightTextImpl(const std::string &new_text, S32 highlight_part, const LLStyle::Params& style_params)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -47,8 +47,170 @@
|
|||
#include <boost/signals2.hpp>
|
||||
|
||||
class LLContextMenu;
|
||||
class LLTextSegment;
|
||||
class LLNormalTextSegment;
|
||||
class LLUrlMatch;
|
||||
|
||||
///
|
||||
/// A text segment is used to specify a subsection of a text string
|
||||
/// that should be formatted differently, such as a hyperlink. It
|
||||
/// includes a start/end offset from the start of the string, a
|
||||
/// style to render with, an optional tooltip, etc.
|
||||
///
|
||||
class LLTextSegment : public LLRefCount, public LLMouseHandler
|
||||
{
|
||||
public:
|
||||
LLTextSegment(S32 start, S32 end) : mStart(start), mEnd(end){};
|
||||
virtual ~LLTextSegment();
|
||||
|
||||
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 void updateLayout(const class LLTextBase& editor);
|
||||
virtual F32 draw(S32 start, S32 end, S32 selection_start, S32 selection_end, const LLRect& draw_rect);
|
||||
virtual bool canEdit() const;
|
||||
virtual void unlinkFromDocument(class LLTextBase* editor);
|
||||
virtual void linkToDocument(class LLTextBase* editor);
|
||||
|
||||
virtual const LLColor4& getColor() const;
|
||||
//virtual void setColor(const LLColor4 &color);
|
||||
virtual LLStyleConstSP getStyle() const;
|
||||
virtual void setStyle(LLStyleConstSP style);
|
||||
virtual void setToken( LLKeywordToken* token );
|
||||
virtual LLKeywordToken* getToken() const;
|
||||
virtual void setToolTip(const std::string& tooltip);
|
||||
virtual void dump() const;
|
||||
|
||||
// LLMouseHandler interface
|
||||
/*virtual*/ BOOL handleMouseDown(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleMouseUp(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleMiddleMouseDown(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleMiddleMouseUp(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleRightMouseDown(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleRightMouseUp(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleDoubleClick(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleHover(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleScrollWheel(S32 x, S32 y, S32 clicks);
|
||||
/*virtual*/ BOOL handleToolTip(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ std::string getName() const;
|
||||
/*virtual*/ void onMouseCaptureLost();
|
||||
/*virtual*/ void screenPointToLocal(S32 screen_x, S32 screen_y, S32* local_x, S32* local_y) const;
|
||||
/*virtual*/ void localPointToScreen(S32 local_x, S32 local_y, S32* screen_x, S32* screen_y) const;
|
||||
/*virtual*/ BOOL hasMouseCapture();
|
||||
|
||||
S32 getStart() const { return mStart; }
|
||||
void setStart(S32 start) { mStart = start; }
|
||||
S32 getEnd() const { return mEnd; }
|
||||
void setEnd( S32 end ) { mEnd = end; }
|
||||
|
||||
protected:
|
||||
S32 mStart;
|
||||
S32 mEnd;
|
||||
};
|
||||
|
||||
class LLNormalTextSegment : public LLTextSegment
|
||||
{
|
||||
public:
|
||||
LLNormalTextSegment( LLStyleConstSP style, S32 start, S32 end, LLTextBase& editor );
|
||||
LLNormalTextSegment( const LLColor4& color, S32 start, S32 end, LLTextBase& editor, BOOL is_visible = TRUE);
|
||||
~LLNormalTextSegment();
|
||||
|
||||
/*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*/ F32 draw(S32 start, S32 end, S32 selection_start, S32 selection_end, const LLRect& draw_rect);
|
||||
/*virtual*/ bool canEdit() const { return true; }
|
||||
/*virtual*/ const LLColor4& getColor() const { return mStyle->getColor(); }
|
||||
/*virtual*/ LLStyleConstSP getStyle() const { return mStyle; }
|
||||
/*virtual*/ void setStyle(LLStyleConstSP style) { mStyle = style; }
|
||||
/*virtual*/ void setToken( LLKeywordToken* token ) { mToken = token; }
|
||||
/*virtual*/ LLKeywordToken* getToken() const { return mToken; }
|
||||
/*virtual*/ BOOL getToolTip( std::string& msg ) const;
|
||||
/*virtual*/ void setToolTip(const std::string& tooltip);
|
||||
/*virtual*/ void dump() const;
|
||||
|
||||
/*virtual*/ BOOL handleHover(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleRightMouseDown(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleMouseDown(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleMouseUp(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleToolTip(S32 x, S32 y, MASK mask);
|
||||
|
||||
protected:
|
||||
F32 drawClippedSegment(S32 seg_start, S32 seg_end, S32 selection_start, S32 selection_end, LLRect rect);
|
||||
|
||||
protected:
|
||||
class LLTextBase& mEditor;
|
||||
LLStyleConstSP mStyle;
|
||||
S32 mFontHeight;
|
||||
LLKeywordToken* mToken;
|
||||
std::string mTooltip;
|
||||
boost::signals2::connection mImageLoadedConnection;
|
||||
};
|
||||
|
||||
class LLIndexSegment : public LLTextSegment
|
||||
{
|
||||
public:
|
||||
LLIndexSegment(S32 pos) : LLTextSegment(pos, pos) {}
|
||||
};
|
||||
|
||||
class LLInlineViewSegment : public LLTextSegment
|
||||
{
|
||||
public:
|
||||
struct Params : public LLInitParam::Block<Params>
|
||||
{
|
||||
Mandatory<LLView*> view;
|
||||
Optional<bool> force_newline;
|
||||
Optional<S32> left_pad,
|
||||
right_pad,
|
||||
bottom_pad,
|
||||
top_pad;
|
||||
};
|
||||
|
||||
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*/ void updateLayout(const class LLTextBase& editor);
|
||||
/*virtual*/ F32 draw(S32 start, S32 end, S32 selection_start, S32 selection_end, const LLRect& draw_rect);
|
||||
/*virtual*/ bool canEdit() const { return false; }
|
||||
/*virtual*/ void unlinkFromDocument(class LLTextBase* editor);
|
||||
/*virtual*/ void linkToDocument(class LLTextBase* editor);
|
||||
|
||||
private:
|
||||
S32 mLeftPad;
|
||||
S32 mRightPad;
|
||||
S32 mTopPad;
|
||||
S32 mBottomPad;
|
||||
LLView* mView;
|
||||
bool mForceNewLine;
|
||||
};
|
||||
|
||||
class LLLineBreakTextSegment : public LLTextSegment
|
||||
{
|
||||
public:
|
||||
|
||||
LLLineBreakTextSegment(LLStyleConstSP style,S32 pos);
|
||||
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;
|
||||
F32 draw(S32 start, S32 end, S32 selection_start, S32 selection_end, const LLRect& draw_rect);
|
||||
|
||||
private:
|
||||
S32 mFontHeight;
|
||||
};
|
||||
|
||||
class LLImageTextSegment : public LLTextSegment
|
||||
{
|
||||
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;
|
||||
F32 draw(S32 start, S32 end, S32 selection_start, S32 selection_end, const LLRect& draw_rect);
|
||||
|
||||
private:
|
||||
class LLTextBase& mEditor;
|
||||
LLStyleConstSP mStyle;
|
||||
};
|
||||
|
||||
typedef LLPointer<LLTextSegment> LLTextSegmentPtr;
|
||||
|
||||
|
|
@ -196,8 +358,9 @@ public:
|
|||
|
||||
const LLFontGL* getDefaultFont() const { return mDefaultFont; }
|
||||
|
||||
void appendLineBreakSegment(const LLStyle::Params& style_params);
|
||||
void appendImageSegment(const LLStyle::Params& style_params);
|
||||
virtual void appendLineBreakSegment(const LLStyle::Params& style_params);
|
||||
virtual void appendImageSegment(const LLStyle::Params& style_params);
|
||||
virtual void appendWidget(const LLInlineViewSegment::Params& params, const std::string& text, bool allow_undo);
|
||||
|
||||
public:
|
||||
// Fired when a URL link is clicked
|
||||
|
|
@ -386,167 +549,4 @@ protected:
|
|||
|
||||
};
|
||||
|
||||
///
|
||||
/// A text segment is used to specify a subsection of a text string
|
||||
/// that should be formatted differently, such as a hyperlink. It
|
||||
/// includes a start/end offset from the start of the string, a
|
||||
/// style to render with, an optional tooltip, etc.
|
||||
///
|
||||
class LLTextSegment : public LLRefCount, public LLMouseHandler
|
||||
{
|
||||
public:
|
||||
LLTextSegment(S32 start, S32 end) : mStart(start), mEnd(end){};
|
||||
virtual ~LLTextSegment();
|
||||
|
||||
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 void updateLayout(const class LLTextBase& editor);
|
||||
virtual F32 draw(S32 start, S32 end, S32 selection_start, S32 selection_end, const LLRect& draw_rect);
|
||||
virtual bool canEdit() const;
|
||||
virtual void unlinkFromDocument(class LLTextBase* editor);
|
||||
virtual void linkToDocument(class LLTextBase* editor);
|
||||
|
||||
virtual const LLColor4& getColor() const;
|
||||
//virtual void setColor(const LLColor4 &color);
|
||||
virtual LLStyleConstSP getStyle() const;
|
||||
virtual void setStyle(LLStyleConstSP style);
|
||||
virtual void setToken( LLKeywordToken* token );
|
||||
virtual LLKeywordToken* getToken() const;
|
||||
virtual void setToolTip(const std::string& tooltip);
|
||||
virtual void dump() const;
|
||||
|
||||
// LLMouseHandler interface
|
||||
/*virtual*/ BOOL handleMouseDown(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleMouseUp(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleMiddleMouseDown(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleMiddleMouseUp(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleRightMouseDown(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleRightMouseUp(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleDoubleClick(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleHover(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleScrollWheel(S32 x, S32 y, S32 clicks);
|
||||
/*virtual*/ BOOL handleToolTip(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ std::string getName() const;
|
||||
/*virtual*/ void onMouseCaptureLost();
|
||||
/*virtual*/ void screenPointToLocal(S32 screen_x, S32 screen_y, S32* local_x, S32* local_y) const;
|
||||
/*virtual*/ void localPointToScreen(S32 local_x, S32 local_y, S32* screen_x, S32* screen_y) const;
|
||||
/*virtual*/ BOOL hasMouseCapture();
|
||||
|
||||
S32 getStart() const { return mStart; }
|
||||
void setStart(S32 start) { mStart = start; }
|
||||
S32 getEnd() const { return mEnd; }
|
||||
void setEnd( S32 end ) { mEnd = end; }
|
||||
|
||||
protected:
|
||||
S32 mStart;
|
||||
S32 mEnd;
|
||||
};
|
||||
|
||||
class LLNormalTextSegment : public LLTextSegment
|
||||
{
|
||||
public:
|
||||
LLNormalTextSegment( LLStyleConstSP style, S32 start, S32 end, LLTextBase& editor );
|
||||
LLNormalTextSegment( const LLColor4& color, S32 start, S32 end, LLTextBase& editor, BOOL is_visible = TRUE);
|
||||
~LLNormalTextSegment();
|
||||
|
||||
/*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*/ F32 draw(S32 start, S32 end, S32 selection_start, S32 selection_end, const LLRect& draw_rect);
|
||||
/*virtual*/ bool canEdit() const { return true; }
|
||||
/*virtual*/ const LLColor4& getColor() const { return mStyle->getColor(); }
|
||||
/*virtual*/ LLStyleConstSP getStyle() const { return mStyle; }
|
||||
/*virtual*/ void setStyle(LLStyleConstSP style) { mStyle = style; }
|
||||
/*virtual*/ void setToken( LLKeywordToken* token ) { mToken = token; }
|
||||
/*virtual*/ LLKeywordToken* getToken() const { return mToken; }
|
||||
/*virtual*/ BOOL getToolTip( std::string& msg ) const;
|
||||
/*virtual*/ void setToolTip(const std::string& tooltip);
|
||||
/*virtual*/ void dump() const;
|
||||
|
||||
/*virtual*/ BOOL handleHover(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleRightMouseDown(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleMouseDown(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleMouseUp(S32 x, S32 y, MASK mask);
|
||||
/*virtual*/ BOOL handleToolTip(S32 x, S32 y, MASK mask);
|
||||
|
||||
protected:
|
||||
F32 drawClippedSegment(S32 seg_start, S32 seg_end, S32 selection_start, S32 selection_end, LLRect rect);
|
||||
|
||||
protected:
|
||||
class LLTextBase& mEditor;
|
||||
LLStyleConstSP mStyle;
|
||||
S32 mFontHeight;
|
||||
LLKeywordToken* mToken;
|
||||
std::string mTooltip;
|
||||
boost::signals2::connection mImageLoadedConnection;
|
||||
};
|
||||
|
||||
class LLIndexSegment : public LLTextSegment
|
||||
{
|
||||
public:
|
||||
LLIndexSegment(S32 pos) : LLTextSegment(pos, pos) {}
|
||||
};
|
||||
|
||||
class LLInlineViewSegment : public LLTextSegment
|
||||
{
|
||||
public:
|
||||
struct Params : public LLInitParam::Block<Params>
|
||||
{
|
||||
Mandatory<LLView*> view;
|
||||
Optional<bool> force_newline;
|
||||
Optional<S32> left_pad,
|
||||
right_pad,
|
||||
bottom_pad,
|
||||
top_pad;
|
||||
};
|
||||
|
||||
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*/ void updateLayout(const class LLTextBase& editor);
|
||||
/*virtual*/ F32 draw(S32 start, S32 end, S32 selection_start, S32 selection_end, const LLRect& draw_rect);
|
||||
/*virtual*/ bool canEdit() const { return false; }
|
||||
/*virtual*/ void unlinkFromDocument(class LLTextBase* editor);
|
||||
/*virtual*/ void linkToDocument(class LLTextBase* editor);
|
||||
|
||||
private:
|
||||
S32 mLeftPad;
|
||||
S32 mRightPad;
|
||||
S32 mTopPad;
|
||||
S32 mBottomPad;
|
||||
LLView* mView;
|
||||
bool mForceNewLine;
|
||||
};
|
||||
|
||||
class LLLineBreakTextSegment : public LLTextSegment
|
||||
{
|
||||
public:
|
||||
|
||||
LLLineBreakTextSegment(LLStyleConstSP style,S32 pos);
|
||||
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;
|
||||
F32 draw(S32 start, S32 end, S32 selection_start, S32 selection_end, const LLRect& draw_rect);
|
||||
|
||||
private:
|
||||
S32 mFontHeight;
|
||||
};
|
||||
|
||||
class LLImageTextSegment : public LLTextSegment
|
||||
{
|
||||
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;
|
||||
F32 draw(S32 start, S32 end, S32 selection_start, S32 selection_end, const LLRect& draw_rect);
|
||||
|
||||
private:
|
||||
class LLTextBase& mEditor;
|
||||
LLStyleConstSP mStyle;
|
||||
};
|
||||
|
||||
#endif
|
||||
|
|
|
|||
|
|
@ -34,7 +34,9 @@
|
|||
|
||||
#include "lluicolor.h"
|
||||
#include "lltextbox.h"
|
||||
#include "llurlmatch.h"
|
||||
|
||||
boost::function<bool(LLUrlMatch*,LLTextBase*)> LLTextUtil::TextHelpers::iconCallbackCreationFunction = 0;
|
||||
|
||||
void LLTextUtil::textboxSetHighlightedVal(LLTextBox *txtbox, const LLStyle::Params& normal_style, const std::string& text, const std::string& hl)
|
||||
{
|
||||
|
|
@ -76,4 +78,36 @@ const std::string& LLTextUtil::formatPhoneNumber(const std::string& phone_str)
|
|||
return formatted_phone_str;
|
||||
}
|
||||
|
||||
bool LLTextUtil::processUrlMatch(LLUrlMatch* match,LLTextBase* text_base)
|
||||
{
|
||||
if (match == 0 || text_base == 0)
|
||||
return false;
|
||||
|
||||
if(match->getID() != LLUUID::null && TextHelpers::iconCallbackCreationFunction)
|
||||
{
|
||||
bool segment_created = TextHelpers::iconCallbackCreationFunction(match,text_base);
|
||||
if(segment_created)
|
||||
return true;
|
||||
}
|
||||
|
||||
// output an optional icon before the Url
|
||||
if (!match->getIcon().empty() )
|
||||
{
|
||||
LLUIImagePtr image = LLUI::getUIImage(match->getIcon());
|
||||
if (image)
|
||||
{
|
||||
LLStyle::Params icon;
|
||||
icon.image = image;
|
||||
// Text will be replaced during rendering with the icon,
|
||||
// but string cannot be empty or the segment won't be
|
||||
// added (or drawn).
|
||||
text_base->appendImageSegment(icon);
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
// EOF
|
||||
|
|
|
|||
|
|
@ -36,6 +36,8 @@
|
|||
#include "llstyle.h"
|
||||
|
||||
class LLTextBox;
|
||||
class LLUrlMatch;
|
||||
class LLTextBase;
|
||||
|
||||
namespace LLTextUtil
|
||||
{
|
||||
|
|
@ -67,6 +69,19 @@ namespace LLTextUtil
|
|||
* @return reference to string with formatted phone number
|
||||
*/
|
||||
const std::string& formatPhoneNumber(const std::string& phone_str);
|
||||
|
||||
bool processUrlMatch(LLUrlMatch* match,LLTextBase* text_base);
|
||||
|
||||
class TextHelpers
|
||||
{
|
||||
|
||||
//we need this special callback since we need to create LLAvataIconCtrls while parsing
|
||||
//avatar/group url but can't create LLAvataIconCtrl from LLUI
|
||||
public:
|
||||
static boost::function<bool(LLUrlMatch*,LLTextBase*)> iconCallbackCreationFunction;
|
||||
};
|
||||
|
||||
|
||||
}
|
||||
|
||||
#endif // LL_LLTEXTUTIL_H
|
||||
|
|
|
|||
|
|
@ -326,6 +326,11 @@ void LLUrlEntryAgent::onAgentNameReceived(const LLUUID& id,
|
|||
callObservers(id.asString(), first + " " + last);
|
||||
}
|
||||
|
||||
LLUUID LLUrlEntryAgent::getID(const std::string &string) const
|
||||
{
|
||||
return LLUUID(getIDStringFromUrl(string));
|
||||
}
|
||||
|
||||
std::string LLUrlEntryAgent::getTooltip(const std::string &string) const
|
||||
{
|
||||
// return a tooltip corresponding to the URL type instead of the generic one
|
||||
|
|
@ -434,6 +439,8 @@ LLUrlEntryGroup::LLUrlEntryGroup()
|
|||
mColor = LLUIColorTable::instance().getColor("GroupLinkColor");
|
||||
}
|
||||
|
||||
|
||||
|
||||
void LLUrlEntryGroup::onGroupNameReceived(const LLUUID& id,
|
||||
const std::string& first,
|
||||
const std::string& last,
|
||||
|
|
@ -443,6 +450,12 @@ void LLUrlEntryGroup::onGroupNameReceived(const LLUUID& id,
|
|||
callObservers(id.asString(), first);
|
||||
}
|
||||
|
||||
LLUUID LLUrlEntryGroup::getID(const std::string &string) const
|
||||
{
|
||||
return LLUUID(getIDStringFromUrl(string));
|
||||
}
|
||||
|
||||
|
||||
std::string LLUrlEntryGroup::getLabel(const std::string &url, const LLUrlLabelCallback &cb)
|
||||
{
|
||||
if (!gCacheName)
|
||||
|
|
|
|||
|
|
@ -172,6 +172,7 @@ public:
|
|||
LLUrlEntryAgent();
|
||||
/*virtual*/ std::string getLabel(const std::string &url, const LLUrlLabelCallback &cb);
|
||||
/*virtual*/ std::string getTooltip(const std::string &string) const;
|
||||
/*virtual*/ LLUUID getID(const std::string &string) const;
|
||||
private:
|
||||
void onAgentNameReceived(const LLUUID& id, const std::string& first,
|
||||
const std::string& last, BOOL is_group);
|
||||
|
|
@ -186,6 +187,7 @@ class LLUrlEntryGroup : public LLUrlEntryBase
|
|||
public:
|
||||
LLUrlEntryGroup();
|
||||
/*virtual*/ std::string getLabel(const std::string &url, const LLUrlLabelCallback &cb);
|
||||
/*virtual*/ LLUUID getID(const std::string &string) const;
|
||||
private:
|
||||
void onGroupNameReceived(const LLUUID& id, const std::string& first,
|
||||
const std::string& last, BOOL is_group);
|
||||
|
|
|
|||
|
|
@ -1150,10 +1150,12 @@ endif (LINUX)
|
|||
if (WINDOWS)
|
||||
list(APPEND viewer_SOURCE_FILES
|
||||
llappviewerwin32.cpp
|
||||
llwindebug.cpp
|
||||
)
|
||||
|
||||
list(APPEND viewer_HEADER_FILES
|
||||
llappviewerwin32.h
|
||||
llwindebug.h
|
||||
)
|
||||
|
||||
# precompiled header configuration
|
||||
|
|
@ -1319,8 +1321,6 @@ set(viewer_APPSETTINGS_FILES
|
|||
${CMAKE_SOURCE_DIR}/../scripts/messages/message_template.msg
|
||||
)
|
||||
|
||||
use_prebuilt_binary(artwork-common)
|
||||
|
||||
source_group("App Settings" FILES ${viewer_APPSETTINGS_FILES})
|
||||
|
||||
set_source_files_properties(${viewer_APPSETTINGS_FILES}
|
||||
|
|
|
|||
|
|
@ -11404,9 +11404,9 @@
|
|||
<key>Persist</key>
|
||||
<integer>0</integer>
|
||||
<key>Type</key>
|
||||
<string>Boolean</string>
|
||||
<string>S32</string>
|
||||
<key>Value</key>
|
||||
<integer>0</integer>
|
||||
<integer>-1</integer>
|
||||
</map>
|
||||
<key>WaterEditPresets</key>
|
||||
<map>
|
||||
|
|
|
|||
Binary file not shown.
Binary file not shown.
|
|
@ -58,6 +58,8 @@ Disregard96DefaultDrawDistance 1 1
|
|||
RenderTextureMemoryMultiple 1 1.0
|
||||
RenderShaderLightingMaxLevel 1 3
|
||||
SkyUseClassicClouds 1 1
|
||||
WatchdogDisabled 1 1
|
||||
|
||||
|
||||
//
|
||||
// Low Graphics Settings
|
||||
|
|
|
|||
|
|
@ -57,6 +57,7 @@ Disregard128DefaultDrawDistance 1 1
|
|||
Disregard96DefaultDrawDistance 1 1
|
||||
RenderTextureMemoryMultiple 1 1.0
|
||||
SkyUseClassicClouds 1 1
|
||||
WatchdogDisabled 1 1
|
||||
|
||||
//
|
||||
// Low Graphics Settings
|
||||
|
|
|
|||
|
|
@ -59,6 +59,7 @@ RenderTextureMemoryMultiple 1 0.5
|
|||
Disregard128DefaultDrawDistance 1 1
|
||||
Disregard96DefaultDrawDistance 1 1
|
||||
SkyUseClassicClouds 1 1
|
||||
WatchdogDisabled 1 1
|
||||
|
||||
//
|
||||
// Low Graphics Settings
|
||||
|
|
|
|||
|
|
@ -37,6 +37,8 @@ VertexShaderEnable 1 1
|
|||
RenderTextureMemoryMultiple 1 1.0
|
||||
UseOcclusion 1 1
|
||||
RenderCubeMap 1 1
|
||||
WatchdogDisabled 1 1
|
||||
|
||||
|
||||
//
|
||||
// Class 0 Hardware (Unknown or just old)
|
||||
|
|
|
|||
|
|
@ -511,7 +511,11 @@ void LLAgentWearables::saveWearableAs(const LLWearableType::EType type,
|
|||
void LLAgentWearables::revertWearable(const LLWearableType::EType type, const U32 index)
|
||||
{
|
||||
LLWearable* wearable = getWearable(type, index);
|
||||
wearable->revertValues();
|
||||
llassert(wearable);
|
||||
if (wearable)
|
||||
{
|
||||
wearable->revertValues();
|
||||
}
|
||||
|
||||
gAgent.sendAgentSetAppearance();
|
||||
}
|
||||
|
|
@ -543,6 +547,7 @@ void LLAgentWearables::setWearableName(const LLUUID& item_id, const std::string&
|
|||
{
|
||||
LLWearable* old_wearable = getWearable((LLWearableType::EType)i,j);
|
||||
llassert(old_wearable);
|
||||
if (!old_wearable) continue;
|
||||
|
||||
std::string old_name = old_wearable->getName();
|
||||
old_wearable->setName(new_name);
|
||||
|
|
@ -1940,7 +1945,11 @@ void LLAgentWearables::animateAllWearableParams(F32 delta, BOOL upload_bake)
|
|||
for (S32 count = 0; count < (S32)getWearableCount((LLWearableType::EType)type); ++count)
|
||||
{
|
||||
LLWearable *wearable = getWearable((LLWearableType::EType)type,count);
|
||||
wearable->animateParams(delta, upload_bake);
|
||||
llassert(wearable);
|
||||
if (wearable)
|
||||
{
|
||||
wearable->animateParams(delta, upload_bake);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -989,22 +989,15 @@ bool LLAppearanceMgr::wearItemOnAvatar(const LLUUID& item_id_to_wear, bool do_up
|
|||
{
|
||||
removeCOFItemLinks(gAgentWearables.getWearableItemID(item_to_wear->getWearableType(), wearable_count-1), false);
|
||||
}
|
||||
addCOFItemLink(item_to_wear, do_update);
|
||||
}
|
||||
break;
|
||||
case LLAssetType::AT_BODYPART:
|
||||
// Don't wear anything until initial wearables are loaded, can
|
||||
// destroy clothing items.
|
||||
if (!gAgentWearables.areWearablesLoaded())
|
||||
{
|
||||
LLNotificationsUtil::add("CanNotChangeAppearanceUntilLoaded");
|
||||
return false;
|
||||
}
|
||||
|
||||
// TODO: investigate wearables may not be loaded at this point EXT-8231
|
||||
|
||||
// Remove the existing wearables of the same type.
|
||||
// Remove existing body parts anyway because we must not be able to wear e.g. two skins.
|
||||
if (item_to_wear->getType() == LLAssetType::AT_BODYPART)
|
||||
{
|
||||
removeCOFLinksOfType(item_to_wear->getWearableType(), false);
|
||||
}
|
||||
removeCOFLinksOfType(item_to_wear->getWearableType(), false);
|
||||
|
||||
addCOFItemLink(item_to_wear, do_update);
|
||||
break;
|
||||
|
|
@ -2596,7 +2589,7 @@ void LLAppearanceMgr::dumpItemArray(const LLInventoryModel::item_array_t& items,
|
|||
{
|
||||
asset_id = linked_item->getAssetUUID();
|
||||
}
|
||||
llinfos << msg << " " << i <<" " << item->getName() << " " << asset_id.asString() << llendl;
|
||||
llinfos << msg << " " << i <<" " << (item ? item->getName() : "(nullitem)") << " " << asset_id.asString() << llendl;
|
||||
}
|
||||
llinfos << llendl;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -81,7 +81,9 @@
|
|||
#include "llvoicechannel.h"
|
||||
#include "llvoavatarself.h"
|
||||
#include "llsidetray.h"
|
||||
|
||||
#include "llfeaturemanager.h"
|
||||
#include "llurlmatch.h"
|
||||
#include "lltextutil.h"
|
||||
|
||||
#include "llweb.h"
|
||||
#include "llsecondlifeurls.h"
|
||||
|
|
@ -192,6 +194,7 @@
|
|||
#include "llviewerthrottle.h"
|
||||
#include "llparcel.h"
|
||||
#include "llavatariconctrl.h"
|
||||
#include "llgroupiconctrl.h"
|
||||
|
||||
// Include for security api initialization
|
||||
#include "llsecapi.h"
|
||||
|
|
@ -351,6 +354,45 @@ static void ui_audio_callback(const LLUUID& uuid)
|
|||
}
|
||||
}
|
||||
|
||||
bool create_text_segment_icon_from_url_match(LLUrlMatch* match,LLTextBase* base)
|
||||
{
|
||||
if(!match || !base)
|
||||
return false;
|
||||
|
||||
LLUUID match_id = match->getID();
|
||||
|
||||
LLIconCtrl* icon;
|
||||
|
||||
if(gAgent.isInGroup(match_id, TRUE))
|
||||
{
|
||||
LLGroupIconCtrl::Params icon_params = LLUICtrlFactory::instance().getDefaultParams<LLGroupIconCtrl>();
|
||||
icon_params.group_id = match_id;
|
||||
icon_params.rect = LLRect(0, 16, 16, 0);
|
||||
icon_params.visible = true;
|
||||
icon = LLUICtrlFactory::instance().createWidget<LLGroupIconCtrl>(icon_params);
|
||||
}
|
||||
else
|
||||
{
|
||||
LLAvatarIconCtrl::Params icon_params = LLUICtrlFactory::instance().getDefaultParams<LLAvatarIconCtrl>();
|
||||
icon_params.avatar_id = match_id;
|
||||
icon_params.rect = LLRect(0, 16, 16, 0);
|
||||
icon_params.visible = true;
|
||||
icon = LLUICtrlFactory::instance().createWidget<LLAvatarIconCtrl>(icon_params);
|
||||
}
|
||||
|
||||
LLInlineViewSegment::Params params;
|
||||
params.force_newline = false;
|
||||
params.view = icon;
|
||||
params.left_pad = 4;
|
||||
params.right_pad = 4;
|
||||
params.top_pad = 2;
|
||||
params.bottom_pad = 2;
|
||||
|
||||
base->appendWidget(params," ",false);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
void request_initial_instant_messages()
|
||||
{
|
||||
static BOOL requested = FALSE;
|
||||
|
|
@ -379,14 +421,8 @@ bool handleCrashSubmitBehaviorChanged(const LLSD& newvalue)
|
|||
const S32 NEVER_SUBMIT_REPORT = 2;
|
||||
if(cb == NEVER_SUBMIT_REPORT)
|
||||
{
|
||||
// LLWatchdog::getInstance()->cleanup(); // SJB: cleaning up a running watchdog thread is unsafe
|
||||
LLAppViewer::instance()->destroyMainloopTimeout();
|
||||
}
|
||||
else if(gSavedSettings.getBOOL("WatchdogEnabled") == TRUE)
|
||||
{
|
||||
// Don't re-enable the watchdog when we change the setting; this may get called before it's started
|
||||
// LLWatchdog::getInstance()->init();
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
@ -893,6 +929,7 @@ bool LLAppViewer::init()
|
|||
}
|
||||
|
||||
LLViewerMedia::initClass();
|
||||
LLTextUtil::TextHelpers::iconCallbackCreationFunction = create_text_segment_icon_from_url_match;
|
||||
|
||||
//EXT-7013 - On windows for some locale (Japanese) standard
|
||||
//datetime formatting functions didn't support some parameters such as "weekday".
|
||||
|
|
@ -1689,14 +1726,6 @@ bool LLAppViewer::initThreads()
|
|||
static const bool enable_threads = true;
|
||||
#endif
|
||||
|
||||
const S32 NEVER_SUBMIT_REPORT = 2;
|
||||
bool use_watchdog = gSavedSettings.getBOOL("WatchdogEnabled");
|
||||
bool send_reports = gCrashSettings.getS32(CRASH_BEHAVIOR_SETTING) != NEVER_SUBMIT_REPORT;
|
||||
if(use_watchdog && send_reports)
|
||||
{
|
||||
LLWatchdog::getInstance()->init(watchdog_killer_callback);
|
||||
}
|
||||
|
||||
LLVFSThread::initClass(enable_threads && false);
|
||||
LLLFSThread::initClass(enable_threads && false);
|
||||
|
||||
|
|
@ -1925,18 +1954,11 @@ bool LLAppViewer::initConfiguration()
|
|||
}
|
||||
#endif
|
||||
|
||||
//*FIX:Mani - Set default to disabling watchdog mainloop
|
||||
// timeout for mac and linux. There is no call stack info
|
||||
// on these platform to help debug.
|
||||
#ifndef LL_RELEASE_FOR_DOWNLOAD
|
||||
gSavedSettings.setBOOL("WatchdogEnabled", FALSE);
|
||||
gSavedSettings.setBOOL("QAMode", TRUE );
|
||||
gSavedSettings.setS32("WatchdogEnabled", 0);
|
||||
#endif
|
||||
|
||||
#ifndef LL_WINDOWS
|
||||
gSavedSettings.setBOOL("WatchdogEnabled", FALSE);
|
||||
#endif
|
||||
|
||||
|
||||
gCrashSettings.getControl(CRASH_BEHAVIOR_SETTING)->getSignal()->connect(boost::bind(&handleCrashSubmitBehaviorChanged, _2));
|
||||
|
||||
// These are warnings that appear on the first experience of that condition.
|
||||
|
|
@ -2364,6 +2386,25 @@ bool LLAppViewer::initWindow()
|
|||
gSavedSettings.getS32("WindowWidth"), gSavedSettings.getS32("WindowHeight"),
|
||||
FALSE, ignorePixelDepth);
|
||||
|
||||
// Need to load feature table before cheking to start watchdog.
|
||||
const S32 NEVER_SUBMIT_REPORT = 2;
|
||||
bool use_watchdog = false;
|
||||
int watchdog_enabled_setting = gSavedSettings.getS32("WatchdogEnabled");
|
||||
if(watchdog_enabled_setting == -1){
|
||||
use_watchdog = !LLFeatureManager::getInstance()->isFeatureAvailable("WatchdogDisabled");
|
||||
}
|
||||
else
|
||||
{
|
||||
// The user has explicitly set this setting; always use that value.
|
||||
use_watchdog = bool(watchdog_enabled_setting);
|
||||
}
|
||||
|
||||
bool send_reports = gCrashSettings.getS32(CRASH_BEHAVIOR_SETTING) != NEVER_SUBMIT_REPORT;
|
||||
if(use_watchdog && send_reports)
|
||||
{
|
||||
LLWatchdog::getInstance()->init(watchdog_killer_callback);
|
||||
}
|
||||
|
||||
LLNotificationsUI::LLNotificationManager::getInstance();
|
||||
|
||||
if (gSavedSettings.getBOOL("WindowMaximized"))
|
||||
|
|
@ -4133,7 +4174,7 @@ void LLAppViewer::forceErrorBreakpoint()
|
|||
void LLAppViewer::forceErrorBadMemoryAccess()
|
||||
{
|
||||
S32* crash = NULL;
|
||||
*crash = 0xDEADBEEF;
|
||||
*crash = 0xDEADBEEF;
|
||||
return;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -64,6 +64,10 @@
|
|||
#include "llcommandlineparser.h"
|
||||
#include "lltrans.h"
|
||||
|
||||
#ifndef LL_RELEASE_FOR_DOWNLOAD
|
||||
#include "llwindebug.h"
|
||||
#endif
|
||||
|
||||
// *FIX:Mani - This hack is to fix a linker issue with libndofdev.lib
|
||||
// The lib was compiled under VS2005 - in VS2003 we need to remap assert
|
||||
#ifdef LL_DEBUG
|
||||
|
|
@ -342,6 +346,10 @@ bool LLAppViewerWin32::init()
|
|||
llinfos << "Turning off Windows error reporting." << llendl;
|
||||
disableWinErrorReporting();
|
||||
|
||||
#ifndef LL_RELEASE_FOR_DOWNLOAD
|
||||
LLWinDebug::instance().init();
|
||||
#endif
|
||||
|
||||
return LLAppViewer::init();
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -449,7 +449,7 @@ void LLCallFloater::updateAgentModeratorState()
|
|||
if(gAgent.isInGroup(mSpeakerManager->getSessionID()))
|
||||
{
|
||||
// This method can be called when LLVoiceChannel.mState == STATE_NO_CHANNEL_INFO
|
||||
// in this case there are no any speakers yet.
|
||||
// in this case there are not any speakers yet.
|
||||
if (mSpeakerManager->findSpeaker(gAgentID))
|
||||
{
|
||||
// Agent is Moderator
|
||||
|
|
|
|||
|
|
@ -557,11 +557,14 @@ void LLChatHistory::appendMessage(const LLChat& chat, const LLSD &args, const LL
|
|||
{
|
||||
bool use_plain_text_chat_history = args["use_plain_text_chat_history"].asBoolean();
|
||||
|
||||
if(mEditor)
|
||||
llassert(mEditor);
|
||||
if (!mEditor)
|
||||
{
|
||||
mEditor->setPlainText(use_plain_text_chat_history);
|
||||
return;
|
||||
}
|
||||
|
||||
mEditor->setPlainText(use_plain_text_chat_history);
|
||||
|
||||
if (!mEditor->scrolledToEnd() && chat.mFromID != gAgent.getID() && !chat.mFromName.empty())
|
||||
{
|
||||
mUnreadChatSources.insert(chat.mFromName);
|
||||
|
|
@ -740,7 +743,7 @@ void LLChatHistory::appendMessage(const LLChat& chat, const LLSD &args, const LL
|
|||
mIsLastMessageFromLog = message_from_log;
|
||||
}
|
||||
|
||||
if (chat.mNotifId.notNull())
|
||||
if (chat.mNotifId.notNull())
|
||||
{
|
||||
LLNotificationPtr notification = LLNotificationsUtil::find(chat.mNotifId);
|
||||
if (notification != NULL)
|
||||
|
|
@ -832,6 +835,7 @@ void LLChatHistory::appendMessage(const LLChat& chat, const LLSD &args, const LL
|
|||
|
||||
mEditor->appendText(message, FALSE, style_params);
|
||||
}
|
||||
|
||||
mEditor->blockUndo();
|
||||
|
||||
// automatically scroll to end when receiving chat from myself
|
||||
|
|
|
|||
|
|
@ -372,6 +372,11 @@ void LLCOFWearables::refresh()
|
|||
iter != iter_end; ++iter)
|
||||
{
|
||||
LLFlatListView* list = iter->first;
|
||||
if (!list) continue;
|
||||
|
||||
//restoring selection should not fire commit callbacks
|
||||
list->setCommitOnSelectionChange(false);
|
||||
|
||||
const values_vector_t& values = iter->second;
|
||||
for (values_vector_t::const_iterator
|
||||
value_it = values.begin(),
|
||||
|
|
@ -385,6 +390,8 @@ void LLCOFWearables::refresh()
|
|||
list->selectItemByValue(*value_it);
|
||||
}
|
||||
}
|
||||
|
||||
list->setCommitOnSelectionChange(true);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -557,8 +557,6 @@ BOOL LLPanelScriptLimitsRegionMemory::getLandScriptResources()
|
|||
|
||||
void LLPanelScriptLimitsRegionMemory::processParcelInfo(const LLParcelData& parcel_data)
|
||||
{
|
||||
mParcelId = parcel_data.parcel_id;
|
||||
|
||||
if(!getLandScriptResources())
|
||||
{
|
||||
std::string msg_error = LLTrans::getString("ScriptLimitsRequestError");
|
||||
|
|
@ -580,6 +578,7 @@ void LLPanelScriptLimitsRegionMemory::setParcelID(const LLUUID& parcel_id)
|
|||
LLRemoteParcelInfoProcessor::getInstance()->removeObserver(mParcelId, this);
|
||||
mParcelId.setNull();
|
||||
}
|
||||
mParcelId = parcel_id;
|
||||
LLRemoteParcelInfoProcessor::getInstance()->addObserver(parcel_id, this);
|
||||
LLRemoteParcelInfoProcessor::getInstance()->sendParcelInfoRequest(parcel_id);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -199,7 +199,12 @@ void LLFloaterVoiceEffect::refreshEffectList()
|
|||
if(sl_item)
|
||||
{
|
||||
LLFontGL::StyleFlags style = is_template_only ? LLFontGL::NORMAL : LLFontGL::BOLD;
|
||||
dynamic_cast<LLScrollListText*>(sl_item->getColumn(0))->setFontStyle(style);
|
||||
LLScrollListText* slt = dynamic_cast<LLScrollListText*>(sl_item->getColumn(0));
|
||||
llassert(slt);
|
||||
if (slt)
|
||||
{
|
||||
slt->setFontStyle(style);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -4528,13 +4528,7 @@ void LLWearableBridge::onWearOnAvatar(void* user_data)
|
|||
|
||||
void LLWearableBridge::wearOnAvatar()
|
||||
{
|
||||
// Don't wear anything until initial wearables are loaded, can
|
||||
// destroy clothing items.
|
||||
if (!gAgentWearables.areWearablesLoaded())
|
||||
{
|
||||
LLNotificationsUtil::add("CanNotChangeAppearanceUntilLoaded");
|
||||
return;
|
||||
}
|
||||
// TODO: investigate wearables may not be loaded at this point EXT-8231
|
||||
|
||||
LLViewerInventoryItem* item = getItem();
|
||||
if(item)
|
||||
|
|
@ -4545,13 +4539,7 @@ void LLWearableBridge::wearOnAvatar()
|
|||
|
||||
void LLWearableBridge::wearAddOnAvatar()
|
||||
{
|
||||
// Don't wear anything until initial wearables are loaded, can
|
||||
// destroy clothing items.
|
||||
if (!gAgentWearables.areWearablesLoaded())
|
||||
{
|
||||
LLNotificationsUtil::add("CanNotChangeAppearanceUntilLoaded");
|
||||
return;
|
||||
}
|
||||
// TODO: investigate wearables may not be loaded at this point EXT-8231
|
||||
|
||||
LLViewerInventoryItem* item = getItem();
|
||||
if(item)
|
||||
|
|
@ -5109,13 +5097,7 @@ BOOL LLWearableBridgeAction::isAgentInventory() const
|
|||
|
||||
void LLWearableBridgeAction::wearOnAvatar()
|
||||
{
|
||||
// Don't wear anything until initial wearables are loaded, can
|
||||
// destroy clothing items.
|
||||
if (!gAgentWearables.areWearablesLoaded())
|
||||
{
|
||||
LLNotificationsUtil::add("CanNotChangeAppearanceUntilLoaded");
|
||||
return;
|
||||
}
|
||||
// TODO: investigate wearables may not be loaded at this point EXT-8231
|
||||
|
||||
LLViewerInventoryItem* item = getItem();
|
||||
if(item)
|
||||
|
|
|
|||
|
|
@ -433,13 +433,12 @@ void show_item_original(const LLUUID& item_uuid)
|
|||
LLPanelMainInventory* main_inventory = floater_inventory->getMainInventoryPanel();
|
||||
|
||||
main_inventory->onFilterEdit("");
|
||||
}
|
||||
|
||||
if(floater_inventory->getVisible())
|
||||
{
|
||||
floater_inventory_visible = true;
|
||||
if(floater_inventory->getVisible())
|
||||
{
|
||||
floater_inventory_visible = true;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
if(sidepanel_inventory && !floater_inventory_visible)
|
||||
{
|
||||
|
|
|
|||
|
|
@ -231,7 +231,7 @@ LLLocationInputCtrl::LLLocationInputCtrl(const LLLocationInputCtrl::Params& p)
|
|||
params.rect(text_entry_rect);
|
||||
params.default_text(LLStringUtil::null);
|
||||
params.max_length_bytes(p.max_chars);
|
||||
params.keystroke_callback(boost::bind(&LLComboBox::onTextEntry, this, _1));
|
||||
params.keystroke_callback(boost::bind(&LLLocationInputCtrl::onTextEntry, this, _1));
|
||||
params.commit_on_focus_lost(false);
|
||||
params.follows.flags(FOLLOWS_ALL);
|
||||
mTextEntry = LLUICtrlFactory::create<LLURLLineEditor>(params);
|
||||
|
|
@ -484,13 +484,16 @@ void LLLocationInputCtrl::onTextEntry(LLLineEditor* line_editor)
|
|||
KEY key = gKeyboard->currentKey();
|
||||
MASK mask = gKeyboard->currentMask(TRUE);
|
||||
|
||||
// Typing? (moving cursor should not affect showing the list)
|
||||
bool typing = mask != MASK_CONTROL && key != KEY_LEFT && key != KEY_RIGHT && key != KEY_HOME && key != KEY_END;
|
||||
bool pasting = mask == MASK_CONTROL && key == 'V';
|
||||
|
||||
if (line_editor->getText().empty())
|
||||
{
|
||||
prearrangeList(); // resets filter
|
||||
hideList();
|
||||
}
|
||||
// Typing? (moving cursor should not affect showing the list)
|
||||
else if (mask != MASK_CONTROL && key != KEY_LEFT && key != KEY_RIGHT && key != KEY_HOME && key != KEY_END)
|
||||
else if (typing || pasting)
|
||||
{
|
||||
prearrangeList(line_editor->getText());
|
||||
if (mList->getItemCount() != 0)
|
||||
|
|
@ -966,7 +969,12 @@ void LLLocationInputCtrl::focusTextEntry()
|
|||
// if the "select_on_focus" parameter is true it places the cursor
|
||||
// at the beginning (after selecting text), thus screwing up updateSelection().
|
||||
if (mTextEntry)
|
||||
{
|
||||
gFocusMgr.setKeyboardFocus(mTextEntry);
|
||||
|
||||
// Enable the text entry to handle accelerator keys (EXT-8104).
|
||||
LLEditMenuHandler::gEditMenuHandler = mTextEntry;
|
||||
}
|
||||
}
|
||||
|
||||
void LLLocationInputCtrl::enableAddLandmarkButton(bool val)
|
||||
|
|
|
|||
|
|
@ -37,6 +37,7 @@
|
|||
#include "llpanelimcontrolpanel.h"
|
||||
|
||||
#include "llagent.h"
|
||||
#include "llappviewer.h" // for gDisconnected
|
||||
#include "llavataractions.h"
|
||||
#include "llavatariconctrl.h"
|
||||
#include "llbutton.h"
|
||||
|
|
@ -163,7 +164,7 @@ BOOL LLPanelIMControlPanel::postBuild()
|
|||
childSetAction("pay_btn", boost::bind(&LLPanelIMControlPanel::onPayButtonClicked, this));
|
||||
childSetEnabled("add_friend_btn", !LLAvatarActions::isFriend(getChild<LLAvatarIconCtrl>("avatar_icon")->getAvatarId()));
|
||||
|
||||
|
||||
setFocusReceivedCallback(boost::bind(&LLPanelIMControlPanel::onFocusReceived, this));
|
||||
|
||||
return LLPanelChatControlPanel::postBuild();
|
||||
}
|
||||
|
|
@ -194,6 +195,15 @@ void LLPanelIMControlPanel::onShareButtonClicked()
|
|||
LLAvatarActions::share(mAvatarID);
|
||||
}
|
||||
|
||||
void LLPanelIMControlPanel::onFocusReceived()
|
||||
{
|
||||
// Disable all the buttons (Call, Teleport, etc) if disconnected.
|
||||
if (gDisconnected)
|
||||
{
|
||||
setAllChildrenEnabled(FALSE);
|
||||
}
|
||||
}
|
||||
|
||||
void LLPanelIMControlPanel::setSessionId(const LLUUID& session_id)
|
||||
{
|
||||
LLPanelChatControlPanel::setSessionId(session_id);
|
||||
|
|
|
|||
|
|
@ -95,6 +95,7 @@ private:
|
|||
void onShareButtonClicked();
|
||||
void onTeleportButtonClicked();
|
||||
void onPayButtonClicked();
|
||||
void onFocusReceived();
|
||||
|
||||
LLUUID mAvatarID;
|
||||
};
|
||||
|
|
|
|||
|
|
@ -53,6 +53,8 @@
|
|||
#include "lltooldraganddrop.h"
|
||||
#include "llviewermenu.h"
|
||||
#include "llviewertexturelist.h"
|
||||
#include "llsidepanelinventory.h"
|
||||
#include "llsidetray.h"
|
||||
|
||||
const std::string FILTERS_FILENAME("filters.xml");
|
||||
|
||||
|
|
@ -1163,6 +1165,12 @@ BOOL LLPanelMainInventory::isActionEnabled(const LLSD& userdata)
|
|||
return FALSE;
|
||||
}
|
||||
|
||||
if (command_name == "share")
|
||||
{
|
||||
LLSidepanelInventory* parent = dynamic_cast<LLSidepanelInventory*>(LLSideTray::getInstance()->getPanel("sidepanel_inventory"));
|
||||
return parent ? parent->canShare() : FALSE;
|
||||
}
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -726,21 +726,33 @@ void LLPanelOutfitEdit::filterWearablesBySelectedItem(void)
|
|||
bool more_than_one_selected = ids.size() > 1;
|
||||
bool is_dummy_item = (ids.size() && dynamic_cast<LLPanelDummyClothingListItem*>(mCOFWearables->getSelectedItem()));
|
||||
|
||||
//resetting selection if no item is selected or than one item is selected
|
||||
if (nothing_selected || more_than_one_selected)
|
||||
//expanded accordion tab determines filtering when no item is selected
|
||||
if (nothing_selected)
|
||||
{
|
||||
if (nothing_selected)
|
||||
showWearablesListView();
|
||||
|
||||
switch (mCOFWearables->getExpandedAccordionAssetType())
|
||||
{
|
||||
showWearablesFolderView();
|
||||
applyFolderViewFilter(FVIT_ALL);
|
||||
case LLAssetType::AT_OBJECT:
|
||||
applyListViewFilter(LVIT_ATTACHMENT);
|
||||
break;
|
||||
case LLAssetType::AT_BODYPART:
|
||||
applyListViewFilter(LVIT_BODYPART);
|
||||
break;
|
||||
case LLAssetType::AT_CLOTHING:
|
||||
default:
|
||||
applyListViewFilter(LVIT_CLOTHING);
|
||||
break;
|
||||
}
|
||||
|
||||
if (more_than_one_selected)
|
||||
{
|
||||
showWearablesListView();
|
||||
applyListViewFilter(LVIT_ALL);
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
//resetting selection if more than one item is selected
|
||||
if (more_than_one_selected)
|
||||
{
|
||||
showWearablesListView();
|
||||
applyListViewFilter(LVIT_ALL);
|
||||
return;
|
||||
}
|
||||
|
||||
|
|
@ -761,7 +773,7 @@ void LLPanelOutfitEdit::filterWearablesBySelectedItem(void)
|
|||
return;
|
||||
}
|
||||
|
||||
if (one_selected && !is_dummy_item)
|
||||
if (item && one_selected && !is_dummy_item)
|
||||
{
|
||||
if (item->isWearableType())
|
||||
{
|
||||
|
|
|
|||
|
|
@ -282,10 +282,17 @@ void LLPanelOutfitsInventory::showGearMenu()
|
|||
|
||||
void LLPanelOutfitsInventory::onTrashButtonClick()
|
||||
{
|
||||
mMyOutfitsPanel->removeSelected();
|
||||
LLNotificationsUtil::add("DeleteOutfits", LLSD(), LLSD(), boost::bind(&LLPanelOutfitsInventory::onOutfitsRemovalConfirmation, this, _1, _2));
|
||||
}
|
||||
|
||||
updateListCommands();
|
||||
updateVerbs();
|
||||
void LLPanelOutfitsInventory::onOutfitsRemovalConfirmation(const LLSD& notification, const LLSD& response)
|
||||
{
|
||||
S32 option = LLNotificationsUtil::getSelectedOption(notification, response);
|
||||
if (option != 0) return; // canceled
|
||||
|
||||
mMyOutfitsPanel->removeSelected();
|
||||
updateListCommands();
|
||||
updateVerbs();
|
||||
}
|
||||
|
||||
bool LLPanelOutfitsInventory::isActionEnabled(const LLSD& userdata)
|
||||
|
|
|
|||
|
|
@ -94,6 +94,7 @@ protected:
|
|||
void onWearButtonClick();
|
||||
void showGearMenu();
|
||||
void onTrashButtonClick();
|
||||
void onOutfitsRemovalConfirmation(const LLSD& notification, const LLSD& response);
|
||||
bool isActionEnabled(const LLSD& userdata);
|
||||
void setWearablesLoading(bool val);
|
||||
void onWearablesLoaded();
|
||||
|
|
|
|||
|
|
@ -129,6 +129,8 @@ void LLPanelVoiceEffect::update(bool list_updated)
|
|||
if (mVoiceEffectCombo)
|
||||
{
|
||||
LLVoiceEffectInterface* effect_interface = LLVoiceClient::instance().getVoiceEffectInterface();
|
||||
llassert(effect_interface);
|
||||
if (!effect_interface) return;
|
||||
if (list_updated)
|
||||
{
|
||||
// Add the default "No Voice Morph" entry.
|
||||
|
|
|
|||
|
|
@ -58,6 +58,9 @@ public:
|
|||
void showTaskInfoPanel();
|
||||
void showInventoryPanel();
|
||||
|
||||
// checks can share selected item(s)
|
||||
bool canShare();
|
||||
|
||||
protected:
|
||||
// Tracks highlighted (selected) item in inventory panel.
|
||||
LLInventoryItem *getSelectedItem();
|
||||
|
|
@ -65,8 +68,6 @@ protected:
|
|||
void onSelectionChange(const std::deque<LLFolderViewItem*> &items, BOOL user_action);
|
||||
// "wear", "teleport", etc.
|
||||
void performActionOnSelection(const std::string &action);
|
||||
bool canShare();
|
||||
|
||||
void updateVerbs();
|
||||
|
||||
//
|
||||
|
|
|
|||
|
|
@ -582,8 +582,6 @@ LLIMWellWindow::LLIMWellWindow(const LLSD& key)
|
|||
: LLSysWellWindow(key)
|
||||
{
|
||||
LLIMMgr::getInstance()->addSessionObserver(this);
|
||||
LLIMChiclet::sFindChicletsSignal.connect(boost::bind(&LLIMWellWindow::findIMChiclet, this, _1));
|
||||
LLIMChiclet::sFindChicletsSignal.connect(boost::bind(&LLIMWellWindow::findObjectChiclet, this, _1));
|
||||
}
|
||||
|
||||
LLIMWellWindow::~LLIMWellWindow()
|
||||
|
|
@ -601,6 +599,10 @@ BOOL LLIMWellWindow::postBuild()
|
|||
{
|
||||
BOOL rv = LLSysWellWindow::postBuild();
|
||||
setTitle(getString("title_im_well_window"));
|
||||
|
||||
LLIMChiclet::sFindChicletsSignal.connect(boost::bind(&LLIMWellWindow::findIMChiclet, this, _1));
|
||||
LLIMChiclet::sFindChicletsSignal.connect(boost::bind(&LLIMWellWindow::findObjectChiclet, this, _1));
|
||||
|
||||
return rv;
|
||||
}
|
||||
|
||||
|
|
@ -641,6 +643,8 @@ void LLIMWellWindow::sessionIDUpdated(const LLUUID& old_session_id, const LLUUID
|
|||
|
||||
LLChiclet* LLIMWellWindow::findObjectChiclet(const LLUUID& notification_id)
|
||||
{
|
||||
if (!mMessageList) return NULL;
|
||||
|
||||
LLChiclet* res = NULL;
|
||||
ObjectRowPanel* panel = mMessageList->getTypedItemByValue<ObjectRowPanel>(notification_id);
|
||||
if (panel != NULL)
|
||||
|
|
@ -655,6 +659,8 @@ LLChiclet* LLIMWellWindow::findObjectChiclet(const LLUUID& notification_id)
|
|||
// PRIVATE METHODS
|
||||
LLChiclet* LLIMWellWindow::findIMChiclet(const LLUUID& sessionId)
|
||||
{
|
||||
if (!mMessageList) return NULL;
|
||||
|
||||
LLChiclet* res = NULL;
|
||||
RowPanel* panel = mMessageList->getTypedItemByValue<RowPanel>(sessionId);
|
||||
if (panel != NULL)
|
||||
|
|
|
|||
|
|
@ -1871,13 +1871,8 @@ EAcceptance LLToolDragAndDrop::dad3dWearItem(
|
|||
|
||||
if (drop)
|
||||
{
|
||||
// Don't wear anything until initial wearables are loaded, can
|
||||
// destroy clothing items.
|
||||
if (!gAgentWearables.areWearablesLoaded())
|
||||
{
|
||||
LLNotificationsUtil::add("CanNotChangeAppearanceUntilLoaded");
|
||||
return ACCEPT_NO;
|
||||
}
|
||||
// TODO: investigate wearables may not be loaded at this point EXT-8231
|
||||
|
||||
LLAppearanceMgr::instance().wearItemOnAvatar(item->getUUID(),true, !(mask & MASK_CONTROL));
|
||||
}
|
||||
return ACCEPT_YES_MULTI;
|
||||
|
|
@ -1949,13 +1944,7 @@ EAcceptance LLToolDragAndDrop::dad3dWearCategory(
|
|||
|
||||
if (drop)
|
||||
{
|
||||
// Don't wear anything until initial wearables are loaded, can
|
||||
// destroy clothing items.
|
||||
if (!gAgentWearables.areWearablesLoaded())
|
||||
{
|
||||
LLNotificationsUtil::add("CanNotChangeAppearanceUntilLoaded");
|
||||
return ACCEPT_NO;
|
||||
}
|
||||
// TODO: investigate wearables may not be loaded at this point EXT-8231
|
||||
}
|
||||
|
||||
if (mSource == SOURCE_AGENT)
|
||||
|
|
|
|||
|
|
@ -269,13 +269,13 @@ LLPanelAttachmentListItem* LLPanelAttachmentListItem::create(LLViewerInventoryIt
|
|||
void LLPanelAttachmentListItem::updateItem(const std::string& name,
|
||||
EItemState item_state)
|
||||
{
|
||||
std::string title_joint;
|
||||
std::string title_joint = name;
|
||||
|
||||
LLViewerInventoryItem* inv_item = getItem();
|
||||
if (inv_item && isAgentAvatarValid() && gAgentAvatarp->isWearingAttachment(inv_item->getLinkedUUID()))
|
||||
{
|
||||
std::string joint = LLTrans::getString(gAgentAvatarp->getAttachedPointName(inv_item->getLinkedUUID()));
|
||||
title_joint = name + " (" + joint + ")";
|
||||
title_joint = title_joint + " (" + joint + ")";
|
||||
}
|
||||
|
||||
LLPanelInventoryListItemBase::updateItem(title_joint, item_state);
|
||||
|
|
@ -783,10 +783,7 @@ void LLWearableItemsList::ContextMenu::createNewWearable(const LLUUID& item_id)
|
|||
// static
|
||||
bool LLWearableItemsList::ContextMenu::canAddWearable(const LLUUID& item_id)
|
||||
{
|
||||
if (!gAgentWearables.areWearablesLoaded())
|
||||
{
|
||||
return false;
|
||||
}
|
||||
// TODO: investigate wearables may not be loaded at this point EXT-8231
|
||||
|
||||
LLViewerInventoryItem* item = gInventory.getItem(item_id);
|
||||
if (!item || item->getType() != LLAssetType::AT_CLOTHING)
|
||||
|
|
|
|||
|
|
@ -0,0 +1,188 @@
|
|||
/**
|
||||
* @file llwindebug.cpp
|
||||
* @brief Windows debugging functions
|
||||
*
|
||||
* $LicenseInfo:firstyear=2004&license=viewergpl$
|
||||
*
|
||||
* Copyright (c) 2004-2009, Linden Research, Inc.
|
||||
*
|
||||
* Second Life Viewer Source Code
|
||||
* The source code in this file ("Source Code") is provided by Linden Lab
|
||||
* to you under the terms of the GNU General Public License, version 2.0
|
||||
* ("GPL"), unless you have obtained a separate licensing agreement
|
||||
* ("Other License"), formally executed by you and Linden Lab. Terms of
|
||||
* the GPL can be found in doc/GPL-license.txt in this distribution, or
|
||||
* online at http://secondlifegrid.net/programs/open_source/licensing/gplv2
|
||||
*
|
||||
* There are special exceptions to the terms and conditions of the GPL as
|
||||
* it is applied to this Source Code. View the full text of the exception
|
||||
* in the file doc/FLOSS-exception.txt in this software distribution, or
|
||||
* online at
|
||||
* http://secondlifegrid.net/programs/open_source/licensing/flossexception
|
||||
*
|
||||
* By copying, modifying or distributing this software, you acknowledge
|
||||
* that you have read and understood your obligations described above,
|
||||
* and agree to abide by those obligations.
|
||||
*
|
||||
* ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
|
||||
* WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
|
||||
* COMPLETENESS OR PERFORMANCE.
|
||||
* $/LicenseInfo$
|
||||
*/
|
||||
#include "llviewerprecompiledheaders.h"
|
||||
|
||||
#include "llwindebug.h"
|
||||
#include "lldir.h"
|
||||
|
||||
|
||||
// based on dbghelp.h
|
||||
typedef BOOL (WINAPI *MINIDUMPWRITEDUMP)(HANDLE hProcess, DWORD dwPid, HANDLE hFile, MINIDUMP_TYPE DumpType,
|
||||
CONST PMINIDUMP_EXCEPTION_INFORMATION ExceptionParam,
|
||||
CONST PMINIDUMP_USER_STREAM_INFORMATION UserStreamParam,
|
||||
CONST PMINIDUMP_CALLBACK_INFORMATION CallbackParam
|
||||
);
|
||||
|
||||
MINIDUMPWRITEDUMP f_mdwp = NULL;
|
||||
|
||||
|
||||
class LLMemoryReserve {
|
||||
public:
|
||||
LLMemoryReserve();
|
||||
~LLMemoryReserve();
|
||||
void reserve();
|
||||
void release();
|
||||
protected:
|
||||
unsigned char *mReserve;
|
||||
static const size_t MEMORY_RESERVATION_SIZE;
|
||||
};
|
||||
|
||||
LLMemoryReserve::LLMemoryReserve() :
|
||||
mReserve(NULL)
|
||||
{
|
||||
};
|
||||
|
||||
LLMemoryReserve::~LLMemoryReserve()
|
||||
{
|
||||
release();
|
||||
}
|
||||
|
||||
// I dunno - this just seemed like a pretty good value.
|
||||
const size_t LLMemoryReserve::MEMORY_RESERVATION_SIZE = 5 * 1024 * 1024;
|
||||
|
||||
void LLMemoryReserve::reserve()
|
||||
{
|
||||
if(NULL == mReserve)
|
||||
mReserve = new unsigned char[MEMORY_RESERVATION_SIZE];
|
||||
};
|
||||
|
||||
void LLMemoryReserve::release()
|
||||
{
|
||||
delete [] mReserve;
|
||||
mReserve = NULL;
|
||||
};
|
||||
|
||||
static LLMemoryReserve gEmergencyMemoryReserve;
|
||||
|
||||
|
||||
LONG NTAPI vectoredHandler(PEXCEPTION_POINTERS exception_infop)
|
||||
{
|
||||
LLWinDebug::instance().generateMinidump(exception_infop);
|
||||
return EXCEPTION_CONTINUE_SEARCH;
|
||||
}
|
||||
|
||||
// static
|
||||
void LLWinDebug::init()
|
||||
{
|
||||
static bool s_first_run = true;
|
||||
// Load the dbghelp dll now, instead of waiting for the crash.
|
||||
// Less potential for stack mangling
|
||||
|
||||
if (s_first_run)
|
||||
{
|
||||
// First, try loading from the directory that the app resides in.
|
||||
std::string local_dll_name = gDirUtilp->findFile("dbghelp.dll", gDirUtilp->getWorkingDir(), gDirUtilp->getExecutableDir());
|
||||
|
||||
HMODULE hDll = NULL;
|
||||
hDll = LoadLibraryA(local_dll_name.c_str());
|
||||
if (!hDll)
|
||||
{
|
||||
hDll = LoadLibrary(L"dbghelp.dll");
|
||||
}
|
||||
|
||||
if (!hDll)
|
||||
{
|
||||
LL_WARNS("AppInit") << "Couldn't find dbghelp.dll!" << LL_ENDL;
|
||||
}
|
||||
else
|
||||
{
|
||||
f_mdwp = (MINIDUMPWRITEDUMP) GetProcAddress(hDll, "MiniDumpWriteDump");
|
||||
|
||||
if (!f_mdwp)
|
||||
{
|
||||
FreeLibrary(hDll);
|
||||
hDll = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
gEmergencyMemoryReserve.reserve();
|
||||
|
||||
s_first_run = false;
|
||||
|
||||
// Add this exeption hanlder to save windows style minidump.
|
||||
AddVectoredExceptionHandler(0, &vectoredHandler);
|
||||
}
|
||||
}
|
||||
|
||||
void LLWinDebug::writeDumpToFile(MINIDUMP_TYPE type, MINIDUMP_EXCEPTION_INFORMATION *ExInfop, const std::string& filename)
|
||||
{
|
||||
if(f_mdwp == NULL || gDirUtilp == NULL)
|
||||
{
|
||||
return;
|
||||
}
|
||||
else
|
||||
{
|
||||
std::string dump_path = gDirUtilp->getExpandedFilename(LL_PATH_LOGS, filename);
|
||||
|
||||
HANDLE hFile = CreateFileA(dump_path.c_str(),
|
||||
GENERIC_WRITE,
|
||||
FILE_SHARE_WRITE,
|
||||
NULL,
|
||||
CREATE_ALWAYS,
|
||||
FILE_ATTRIBUTE_NORMAL,
|
||||
NULL);
|
||||
|
||||
if (hFile != INVALID_HANDLE_VALUE)
|
||||
{
|
||||
// Write the dump, ignoring the return value
|
||||
f_mdwp(GetCurrentProcess(),
|
||||
GetCurrentProcessId(),
|
||||
hFile,
|
||||
type,
|
||||
ExInfop,
|
||||
NULL,
|
||||
NULL);
|
||||
|
||||
CloseHandle(hFile);
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
// static
|
||||
void LLWinDebug::generateMinidump(struct _EXCEPTION_POINTERS *exception_infop)
|
||||
{
|
||||
std::string dump_path = gDirUtilp->getExpandedFilename(LL_PATH_LOGS,
|
||||
"SecondLifeException");
|
||||
if (exception_infop)
|
||||
{
|
||||
// Since there is exception info... Release the hounds.
|
||||
gEmergencyMemoryReserve.release();
|
||||
|
||||
_MINIDUMP_EXCEPTION_INFORMATION ExInfo;
|
||||
|
||||
ExInfo.ThreadId = ::GetCurrentThreadId();
|
||||
ExInfo.ExceptionPointers = exception_infop;
|
||||
ExInfo.ClientPointers = NULL;
|
||||
writeDumpToFile((MINIDUMP_TYPE)(MiniDumpWithDataSegs | MiniDumpWithIndirectlyReferencedMemory), &ExInfo, "SecondLife.dmp");
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,49 @@
|
|||
/**
|
||||
* @file llwindebug.h
|
||||
* @brief LLWinDebug class header file
|
||||
*
|
||||
* $LicenseInfo:firstyear=2004&license=viewergpl$
|
||||
*
|
||||
* Copyright (c) 2004-2009, Linden Research, Inc.
|
||||
*
|
||||
* Second Life Viewer Source Code
|
||||
* The source code in this file ("Source Code") is provided by Linden Lab
|
||||
* to you under the terms of the GNU General Public License, version 2.0
|
||||
* ("GPL"), unless you have obtained a separate licensing agreement
|
||||
* ("Other License"), formally executed by you and Linden Lab. Terms of
|
||||
* the GPL can be found in doc/GPL-license.txt in this distribution, or
|
||||
* online at http://secondlifegrid.net/programs/open_source/licensing/gplv2
|
||||
*
|
||||
* There are special exceptions to the terms and conditions of the GPL as
|
||||
* it is applied to this Source Code. View the full text of the exception
|
||||
* in the file doc/FLOSS-exception.txt in this software distribution, or
|
||||
* online at
|
||||
* http://secondlifegrid.net/programs/open_source/licensing/flossexception
|
||||
*
|
||||
* By copying, modifying or distributing this software, you acknowledge
|
||||
* that you have read and understood your obligations described above,
|
||||
* and agree to abide by those obligations.
|
||||
*
|
||||
* ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
|
||||
* WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
|
||||
* COMPLETENESS OR PERFORMANCE.
|
||||
* $/LicenseInfo$
|
||||
*/
|
||||
|
||||
#ifndef LL_LLWINDEBUG_H
|
||||
#define LL_LLWINDEBUG_H
|
||||
|
||||
#include "stdtypes.h"
|
||||
#include <dbghelp.h>
|
||||
|
||||
class LLWinDebug:
|
||||
public LLSingleton<LLWinDebug>
|
||||
{
|
||||
public:
|
||||
static void init();
|
||||
static void generateMinidump(struct _EXCEPTION_POINTERS *pExceptionInfo = NULL);
|
||||
private:
|
||||
static void writeDumpToFile(MINIDUMP_TYPE type, MINIDUMP_EXCEPTION_INFORMATION *ExInfop, const std::string& filename);
|
||||
};
|
||||
|
||||
#endif // LL_LLWINDEBUG_H
|
||||
|
|
@ -199,7 +199,15 @@
|
|||
mouse_opaque="false"
|
||||
name="popup_holder"
|
||||
class="popup_holder"
|
||||
width="1024"/>
|
||||
width="1024">
|
||||
<icon follows="right|bottom"
|
||||
image_name="Resize_Corner"
|
||||
right="-1"
|
||||
name="resize_corner"
|
||||
width="11"
|
||||
bottom="-1"
|
||||
height="11" />
|
||||
</panel>
|
||||
<menu_holder top="0"
|
||||
follows="all"
|
||||
height="768"
|
||||
|
|
|
|||
|
|
@ -81,6 +81,17 @@
|
|||
function="Inventory.GearDefault.Enable"
|
||||
parameter="save_texture" />
|
||||
</menu_item_call>
|
||||
<menu_item_call
|
||||
label="Share"
|
||||
layout="topleft"
|
||||
name="Share"
|
||||
visible="true">
|
||||
<on_click
|
||||
function="Inventory.Share" />
|
||||
<on_enable
|
||||
function="Inventory.GearDefault.Enable"
|
||||
parameter="share" />
|
||||
</menu_item_call>
|
||||
<menu_item_call
|
||||
label="Find Original"
|
||||
layout="topleft"
|
||||
|
|
|
|||
|
|
@ -815,6 +815,17 @@ Delete pick <nolink>[PICK]</nolink>?
|
|||
yestext="OK"/>
|
||||
</notification>
|
||||
|
||||
<notification
|
||||
icon="alertmodal.tga"
|
||||
name="DeleteOutfits"
|
||||
type="alertmodal">
|
||||
Delete the selected outfit/s?
|
||||
<usetemplate
|
||||
name="okcancelbuttons"
|
||||
notext="Cancel"
|
||||
yestext="OK"/>
|
||||
</notification>
|
||||
|
||||
<notification
|
||||
icon="alertmodal.tga"
|
||||
name="PromptGoToEventsPage"
|
||||
|
|
|
|||
|
|
@ -503,5 +503,17 @@ image_pressed_selected "Lit" + "Selected" - there are new messages and the Well
|
|||
</button>
|
||||
</chiclet_notification>
|
||||
</layout_panel>
|
||||
<icon
|
||||
auto_resize="false"
|
||||
color="0 0 0 0"
|
||||
follows="left|right"
|
||||
height="10"
|
||||
image_name="spacer24.tga"
|
||||
layout="topleft"
|
||||
left="0"
|
||||
min_width="4"
|
||||
name="DUMMY2"
|
||||
top="0"
|
||||
width="8" />
|
||||
</layout_stack>
|
||||
</panel>
|
||||
|
|
|
|||
|
|
@ -20,6 +20,23 @@
|
|||
background_visible="true"
|
||||
bg_alpha_color="DkGray2"
|
||||
width="311">
|
||||
<accordion_tab
|
||||
layout="topleft"
|
||||
name="tab_clothing"
|
||||
title="Clothing">
|
||||
<flat_list_view
|
||||
allow_select="true"
|
||||
follows="all"
|
||||
height="10"
|
||||
item_pad="3"
|
||||
keep_selection_visible_on_reshape="true"
|
||||
layout="topleft"
|
||||
left="0"
|
||||
multi_select="true"
|
||||
name="list_clothing"
|
||||
top="0"
|
||||
width="311" />
|
||||
</accordion_tab>
|
||||
<accordion_tab
|
||||
layout="topleft"
|
||||
name="tab_attachments"
|
||||
|
|
@ -40,23 +57,6 @@
|
|||
value="No attachments worn" />
|
||||
</flat_list_view>
|
||||
</accordion_tab>
|
||||
<accordion_tab
|
||||
layout="topleft"
|
||||
name="tab_clothing"
|
||||
title="Clothing">
|
||||
<flat_list_view
|
||||
allow_select="true"
|
||||
follows="all"
|
||||
height="10"
|
||||
item_pad="3"
|
||||
keep_selection_visible_on_reshape="true"
|
||||
layout="topleft"
|
||||
left="0"
|
||||
multi_select="true"
|
||||
name="list_clothing"
|
||||
top="0"
|
||||
width="311" />
|
||||
</accordion_tab>
|
||||
<accordion_tab
|
||||
layout="topleft"
|
||||
name="tab_body_parts"
|
||||
|
|
|
|||
|
|
@ -214,9 +214,9 @@
|
|||
<key>windows</key>
|
||||
<map>
|
||||
<key>md5sum</key>
|
||||
<string>94fd43f534e2055858d524086384907d</string>
|
||||
<string>72e6e2eff5d146a107f3059b6c31fb95</string>
|
||||
<key>url</key>
|
||||
<uri>http://s3.amazonaws.com/viewer-source-downloads/install_pkgs/boost-1.39.0-windows-20100219.tar.bz2</uri>
|
||||
<uri>http://s3.amazonaws.com/viewer-source-downloads/install_pkgs/boost-1.39.0-windows-20100630.tar.bz2</uri>
|
||||
</map>
|
||||
</map>
|
||||
</map>
|
||||
|
|
|
|||
Loading…
Reference in New Issue