X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/48850fa74dee8ace36f70059f1938488c4196a97..27f35b6674b796e61986681261ec7a96bef93502:/src/gtk1/region.cpp diff --git a/src/gtk1/region.cpp b/src/gtk1/region.cpp index 2159fea32e..e1394a48b4 100644 --- a/src/gtk1/region.cpp +++ b/src/gtk1/region.cpp @@ -20,12 +20,31 @@ // headers // ---------------------------------------------------------------------------- +#include "wx/log.h" + #include "wx/region.h" -#include -#include +#include "wx/gtk/private.h" -#include "wx/log.h" +#ifndef __WXGTK20__ + +// ---------------------------------------------------------------------------- +// wxGdkRegion: creates a new region in ctor and destroys in dtor +// ---------------------------------------------------------------------------- + +class wxGdkRegion +{ +public: + wxGdkRegion() { m_region = gdk_region_new(); } + ~wxGdkRegion() { gdk_region_destroy(m_region); } + + operator GdkRegion *() const { return m_region; } + +private: + GdkRegion *m_region; +}; + +#endif // __WXGTK20__ // ---------------------------------------------------------------------------- // wxRegionRefData: private class containing the information about the region @@ -38,19 +57,17 @@ public: { m_region = NULL; } - + wxRegionRefData(const wxRegionRefData& refData) + : wxObjectRefData() { #ifdef __WXGTK20__ m_region = gdk_region_copy(refData.m_region); #else - m_region = gdk_region_new(); - GdkRegion *regCopy = gdk_regions_union(m_region, refData.m_region); - gdk_region_destroy(m_region); - m_region = regCopy; + m_region = gdk_regions_union(wxGdkRegion(), refData.m_region); #endif } - + ~wxRegionRefData() { if (m_region) @@ -67,8 +84,8 @@ public: #define M_REGIONDATA ((wxRegionRefData *)m_refData) #define M_REGIONDATA_OF(rgn) ((wxRegionRefData *)(rgn.m_refData)) -IMPLEMENT_DYNAMIC_CLASS(wxRegion, wxGDIObject); -IMPLEMENT_DYNAMIC_CLASS(wxRegionIterator,wxObject); +IMPLEMENT_DYNAMIC_CLASS(wxRegion, wxGDIObject) +IMPLEMENT_DYNAMIC_CLASS(wxRegionIterator,wxObject) // ---------------------------------------------------------------------------- // wxRegion construction @@ -83,15 +100,23 @@ void wxRegion::InitRect(wxCoord x, wxCoord y, wxCoord w, wxCoord h) rect.y = y; rect.width = w; rect.height = 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 ); - gdk_region_destroy( reg ); + M_REGIONDATA->m_region = gdk_region_union_with_rect( wxGdkRegion(), &rect ); +#endif +} + +wxRegion::wxRegion( GdkRegion *region ) +{ + m_refData = new wxRegionRefData(); +#ifdef __WXGTK20__ + M_REGIONDATA->m_region = gdk_region_copy( region ); +#else + M_REGIONDATA->m_region = gdk_regions_union(wxGdkRegion(), region); #endif } @@ -133,22 +158,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 // ---------------------------------------------------------------------------- @@ -165,16 +190,14 @@ bool wxRegion::Union( wxCoord x, wxCoord y, wxCoord width, wxCoord height ) rect.y = y; rect.width = width; rect.height = height; - + if (!m_refData) { 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 ); - gdk_region_destroy( reg ); + M_REGIONDATA->m_region = gdk_region_union_with_rect(wxGdkRegion(), &rect); #endif } else @@ -234,7 +257,7 @@ bool wxRegion::Intersect( wxCoord x, wxCoord y, wxCoord width, wxCoord height ) bool wxRegion::Intersect( const wxRect& rect ) { wxRegion reg( rect ); - + return Intersect( reg ); } @@ -247,8 +270,8 @@ bool wxRegion::Intersect( const wxRegion& region ) { m_refData = new wxRegionRefData(); M_REGIONDATA->m_region = gdk_region_new(); - - // leave here + + // leave here return TRUE; } else @@ -471,37 +494,37 @@ struct _XRegion { class wxRIRefData: public wxObjectRefData { public: + wxRIRefData() { Init(); } + virtual ~wxRIRefData(); + + void CreateRects( const wxRegion& r ); - wxRIRefData() : m_rects(0), m_numRects(0){} - ~wxRIRefData(); + void Init() { m_rects = NULL; m_numRects = 0; } wxRect *m_rects; size_t m_numRects; - - void CreateRects( const wxRegion& r ); }; wxRIRefData::~wxRIRefData() { - delete m_rects; + delete [] m_rects; } void wxRIRefData::CreateRects( const wxRegion& region ) { - if (m_rects) - delete m_rects; + delete [] m_rects; + + Init(); - m_rects = 0; - m_numRects = 0; - GdkRegion *gdkregion = region.GetRegion(); - if (!gdkregion) return; - + 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 +539,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 +559,7 @@ void wxRIRefData::CreateRects( const wxRegion& region ) } } } -#endif +#endif // GTK+ 2.0/1.x } wxRegionIterator::wxRegionIterator()