#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"
//-----------------------------------------------------------------------------
class wxPenRefData: public wxObjectRefData
{
- public:
- wxPenRefData();
- wxPenRefData(const wxPenRefData& data);
-
- int m_width;
- int m_style;
- wxColour m_colour;
- wxBitmap m_stipple;
- pixpattern24_t m_pixPattern;
-
- // not used by wxMGL, but we want to preserve values
- int m_joinStyle;
- int m_capStyle;
- int m_countDashes;
- wxDash *m_dash;
+public:
+ 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 &&
+ memcmp(&m_pixPattern,
+ &data.m_pixPattern, sizeof(m_pixPattern)) == 0 &&
+ 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;
+ wxBitmap m_stipple;
+ pixpattern24_t m_pixPattern;
+
+ // not used by wxMGL, but we want to preserve values
+ int m_joinStyle;
+ int m_capStyle;
+ int m_countDashes;
+ wxDash *m_dash;
};
wxPenRefData::wxPenRefData()
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);
}