#endif
#include "wx/pen.h"
-#include "wx/bitmap.h"
-#include "wx/colour.h"
+
+#ifndef WX_PRECOMP
+ #include "wx/bitmap.h"
+ #include "wx/colour.h"
+#endif
+
#include "wx/mgl/private.h"
//-----------------------------------------------------------------------------
wxPenRefData();
wxPenRefData(const wxPenRefData& data);
+ bool operator==(const wxPenRefData& data) const
+ {
+ // we intentionally don't compare m_hPen fields here
+ return m_style == data.m_style &&
+ m_width == data.m_width &&
+ m_pixPattern == data.m_pixPattern &&
+ m_capStyle == data.m_capStyle &&
+ m_joinStyle == data.m_joinStyle &&
+ m_colour == data.m_colour &&
+ (m_style != wxSTIPPLE || m_stipple.IsSameAs(data.m_stipple)) &&
+ (m_style != wxUSER_DASH ||
+ (m_dash == data.m_dash &&
+ memcmp(m_dash, data.m_dash, m_countDashes*sizeof(wxDash)) == 0));
+ }
+
int m_width;
int m_style;
wxColour m_colour;
wxBitmapToPixPattern(stipple, &(M_PENDATA->m_pixPattern), NULL);
}
-wxPen::wxPen(const wxPen& pen)
+bool wxPen::operator == (const wxPen& pen) const
{
- Ref(pen);
-}
+ if (m_refData == pen.m_refData) return true;
-wxPen& wxPen::operator = (const wxPen& pen)
-{
- if (*this == pen) return (*this);
- Ref(pen);
- return *this;
-}
+ if (!m_refData || !pen.m_refData) return false;
-bool wxPen::operator == (const wxPen& pen) const
-{
- return m_refData == pen.m_refData;
+ return ( *(wxPenRefData*)m_refData == *(wxPenRefData*)pen.m_refData );
}
bool wxPen::operator != (const wxPen& pen) const
M_PENDATA->m_dash = (wxDash *)dash; /* TODO */
}
-void wxPen::SetColour(const unsigned char red, const unsigned char green, const unsigned char blue)
+void wxPen::SetColour(unsigned char red, unsigned char green, unsigned char blue)
{
AllocExclusive();
M_PENDATA->m_colour.Set(red, green, blue);
}
-bool wxPen::Ok() const
+bool wxPen::IsOk() const
{
return (m_refData != NULL);
}