X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/48850fa74dee8ace36f70059f1938488c4196a97..e7300ec6d9ebbd1cfa2fcf12c0ce6e5aee85a152:/src/gtk/region.cpp diff --git a/src/gtk/region.cpp b/src/gtk/region.cpp index 2159fea32e..f184e4d795 100644 --- a/src/gtk/region.cpp +++ b/src/gtk/region.cpp @@ -20,12 +20,11 @@ // headers // ---------------------------------------------------------------------------- -#include "wx/region.h" +#include "wx/log.h" -#include -#include +#include "wx/region.h" -#include "wx/log.h" +#include "wx/gtk/private.h" // ---------------------------------------------------------------------------- // wxRegionRefData: private class containing the information about the region @@ -87,7 +86,7 @@ void wxRegion::InitRect(wxCoord x, wxCoord y, wxCoord w, wxCoord h) m_refData = new wxRegionRefData(); #ifdef __WXGTK20__ - M_REGIONDATA->m_region = gdk_region_rectangle( rect ); + M_REGIONDATA->m_region = gdk_region_rectangle( &rect ); #else GdkRegion *reg = gdk_region_new(); M_REGIONDATA->m_region = gdk_region_union_with_rect( reg, &rect ); @@ -133,22 +132,22 @@ wxObjectRefData *wxRegion::CloneRefData(const wxObjectRefData *data) const { return new wxRegionRefData(*(wxRegionRefData *)data); } + // ---------------------------------------------------------------------------- // wxRegion comparison // ---------------------------------------------------------------------------- bool wxRegion::operator==( const wxRegion& region ) { + if (m_refData == region.m_refData) return TRUE; + + if (!m_refData || !region.m_refData) return FALSE; + // compare the regions themselves, not the pointers to ref data! return gdk_region_equal(M_REGIONDATA->m_region, M_REGIONDATA_OF(region)->m_region); } -bool wxRegion::operator != ( const wxRegion& region ) -{ - return !(*this == region); -} - // ---------------------------------------------------------------------------- // wxRegion operations // ---------------------------------------------------------------------------- @@ -170,7 +169,7 @@ bool wxRegion::Union( wxCoord x, wxCoord y, wxCoord width, wxCoord height ) { m_refData = new wxRegionRefData(); #ifdef __WXGTK20__ - M_REGIONDATA->m_region = gdk_region_rectangle( rect ); + M_REGIONDATA->m_region = gdk_region_rectangle( &rect ); #else GdkRegion *reg = gdk_region_new(); M_REGIONDATA->m_region = gdk_region_union_with_rect( reg, &rect ); @@ -498,9 +497,9 @@ void wxRIRefData::CreateRects( const wxRegion& region ) if (!gdkregion) return; #ifdef __WXGTK20__ - GdkRectangles *gdkrects = NULL; + GdkRectangle *gdkrects = NULL; gint numRects = 0; - gdk_region_get_rectangles( gdkregion, &gdkrect, &numRects ); + gdk_region_get_rectangles( gdkregion, &gdkrects, &numRects ); m_numRects = numRects; if (numRects) @@ -516,8 +515,8 @@ void wxRIRefData::CreateRects( const wxRegion& region ) wr.height = gr.height; } } - g_delete( gdkrects ); // delete [] -#else + g_free( gdkrects ); +#else // GTK+ 1.x Region r = ((GdkRegionPrivate *)gdkregion)->xregion; if (r) { @@ -536,7 +535,7 @@ void wxRIRefData::CreateRects( const wxRegion& region ) } } } -#endif +#endif // GTK+ 2.0/1.x } wxRegionIterator::wxRegionIterator()