X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/b4819fcaeabd1a53c3ce7d62a13f30bf9333a5e2..aed08d7967af9365edd61723ca9fff977ca744c2:/src/gtk/colour.cpp diff --git a/src/gtk/colour.cpp b/src/gtk/colour.cpp index 9ac38bff4b..84c790a329 100644 --- a/src/gtk/colour.cpp +++ b/src/gtk/colour.cpp @@ -25,13 +25,42 @@ class wxColourRefData: public wxObjectRefData { public: - wxColourRefData(); - ~wxColourRefData(); + wxColourRefData() + { + m_color.red = 0; + m_color.green = 0; + m_color.blue = 0; + m_color.pixel = 0; + m_colormap = (GdkColormap *) NULL; + m_hasPixel = FALSE; + } + + wxColourRefData(const wxColourRefData& data) + : wxObjectRefData() + { + m_color = data.m_color; + m_colormap = data.m_colormap; + m_hasPixel = data.m_hasPixel; + } + ~wxColourRefData() + { + FreeColour(); + } + + bool operator == (const wxColourRefData& data) const + { + return (m_colormap == data.m_colormap && + m_hasPixel == data.m_hasPixel && + m_color.red == data.m_color.red && + m_color.green == data.m_color.green && + m_color.blue == data.m_color.blue && + m_color.pixel == data.m_color.pixel); + } + void FreeColour(); void AllocColour( GdkColormap* cmap ); -public: GdkColor m_color; GdkColormap *m_colormap; bool m_hasPixel; @@ -59,21 +88,6 @@ gushort wxColourRefData::colMapAllocCounter[ 256 ] = 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; -wxColourRefData::wxColourRefData() -{ - m_color.red = 0; - m_color.green = 0; - m_color.blue = 0; - m_color.pixel = 0; - m_colormap = (GdkColormap *) NULL; - m_hasPixel = FALSE; -} - -wxColourRefData::~wxColourRefData() -{ - FreeColour(); -} - void wxColourRefData::FreeColour() { if (m_colormap) @@ -104,8 +118,8 @@ void wxColourRefData::AllocColour( GdkColormap *cmap ) FreeColour(); #ifdef __WXGTK20__ - if ((m_colormap->visual->type == GDK_VISUAL_GRAYSCALE) || - (m_colormap->visual->type == GDK_VISUAL_PSEUDO_COLOR)) + if ( (cmap->visual->type == GDK_VISUAL_GRAYSCALE) || + (cmap->visual->type == GDK_VISUAL_PSEUDO_COLOR) ) #else GdkColormapPrivate *private_colormap = (GdkColormapPrivate*) cmap; if ((private_colormap->visual->type == GDK_VISUAL_GRAYSCALE) || @@ -131,10 +145,6 @@ void wxColourRefData::AllocColour( GdkColormap *cmap ) IMPLEMENT_DYNAMIC_CLASS(wxColour,wxGDIObject) -wxColour::wxColour() -{ -} - wxColour::wxColour( unsigned char red, unsigned char green, unsigned char blue ) { m_refData = new wxColourRefData(); @@ -156,6 +166,7 @@ void wxColour::InitFromName( const wxString &colourName ) else { m_refData = new wxColourRefData(); + if (!gdk_color_parse( colourName.mb_str(), &M_COLDATA->m_color )) { // VZ: asserts are good in general but this one is triggered by @@ -173,28 +184,15 @@ void wxColour::InitFromName( const wxString &colourName ) } } -wxColour::wxColour( const wxColour& col ) -{ - Ref( col ); -} - wxColour::~wxColour() { } -wxColour& wxColour::operator = ( const wxColour& col ) -{ - if (*this == col) return (*this); - Ref( col ); - return *this; -} - bool wxColour::operator == ( const wxColour& col ) const { if (m_refData == col.m_refData) return TRUE; - if (!m_refData) return FALSE; - if (!col.m_refData) return FALSE; + if (!m_refData || !col.m_refData) return FALSE; GdkColor *own = &(((wxColourRefData*)m_refData)->m_color); GdkColor *other = &(((wxColourRefData*)col.m_refData)->m_color); @@ -205,14 +203,20 @@ bool wxColour::operator == ( const wxColour& col ) const return TRUE; } -bool wxColour::operator != ( const wxColour& col) const +wxObjectRefData *wxColour::CreateRefData() const +{ + return new wxColourRefData; +} + +wxObjectRefData *wxColour::CloneRefData(const wxObjectRefData *data) const { - return !(*this == col); + return new wxColourRefData(*(wxColourRefData *)data); } void wxColour::Set( unsigned char red, unsigned char green, unsigned char blue ) { - UnRef(); + AllocExclusive(); + m_refData = new wxColourRefData(); M_COLDATA->m_color.red = ((unsigned short)red) << SHIFT; M_COLDATA->m_color.green = ((unsigned short)green) << SHIFT; @@ -241,11 +245,6 @@ unsigned char wxColour::Blue() const return (unsigned char)(M_COLDATA->m_color.blue >> SHIFT); } -bool wxColour::Ok() const -{ - return (m_refData != NULL); -} - void wxColour::CalcPixel( GdkColormap *cmap ) { if (!Ok()) return;