]> git.saurik.com Git - wxWidgets.git/blobdiff - src/x11/icon.cpp
that was a memory leak
[wxWidgets.git] / src / x11 / icon.cpp
index e357f22925e7a1d2125fdb3b2ade93f6b6662f94..0086004ff43c60d315ecbf5c4067daeffb357d96 100644 (file)
@@ -9,79 +9,49 @@
 // Licence:    wxWindows licence
 /////////////////////////////////////////////////////////////////////////////
 
-#ifdef __GNUG__
+#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
 #pragma implementation "icon.h"
 #endif
 
 #include "wx/icon.h"
 #include "wx/window.h"
 
-#ifdef __VMS__
-#pragma message disable nosimpint
-#endif
-
-#ifdef __VMS__
-#pragma message enable nosimpint
-#endif
-
 #include "wx/x11/private.h"
 
-IMPLEMENT_DYNAMIC_CLASS(wxIcon, wxBitmap)
-
-/*
-* Icons
-*/
+//-----------------------------------------------------------------------------
+// wxIcon
+//-----------------------------------------------------------------------------
 
-wxIcon::wxIcon()
-{
-}
-
-// Create from XBM data
-wxIcon::wxIcon(const char bits[], int width, int height)
-{
-    (void) Create((void*) bits, wxBITMAP_TYPE_XBM_DATA, width, height, 1);
-}
+IMPLEMENT_DYNAMIC_CLASS(wxIcon,wxBitmap)
 
-// Create from XPM data
-wxIcon::wxIcon(char **data)
+wxIcon::wxIcon( const char **bits, int WXUNUSED(width), int WXUNUSED(height) ) :
+    wxBitmap( bits )
 {
-    (void) Create((void*) data, wxBITMAP_TYPE_XPM_DATA, 0, 0, 0);
 }
 
-wxIcon::wxIcon(const char **data)
+wxIcon::wxIcon( char **bits, int WXUNUSED(width), int WXUNUSED(height) ) :
+    wxBitmap( bits )
 {
-    (void) Create((void*) data, wxBITMAP_TYPE_XPM_DATA, 0, 0, 0);
 }
 
-wxIcon::wxIcon(const wxString& icon_file, long flags,
-               int desiredWidth, int desiredHeight)
-               
+wxIcon::wxIcon() :  wxBitmap()
 {
-    LoadFile(icon_file, flags, desiredWidth, desiredHeight);
 }
 
-wxIcon::~wxIcon()
+wxIcon::wxIcon( const wxIcon& icon ) : wxBitmap()
 {
+    Ref(icon);
 }
 
-bool wxIcon::LoadFile(const wxString& filename, long type,
-                      int desiredWidth, int desiredHeight)
+wxIcon& wxIcon::operator = ( const wxIcon& icon )
 {
-    UnRef();
-    
-    m_refData = new wxBitmapRefData;
-    
-    wxBitmapHandler *handler = FindHandler(type);
-    
-    if ( handler )
-        return handler->LoadFile(this, filename, type, desiredWidth, desiredHeight);
-    else
-        return FALSE;
+    if (*this == icon) return (*this);
+    Ref(icon);
+    return *this;
 }
 
-bool wxIcon::CopyFromBitmap(const wxBitmap& bitmap)
+void wxIcon::CopyFromBitmap(const wxBitmap& bmp)
 {
-    wxIcon* icon = (wxIcon*) (& bitmap);
+    wxIcon *icon = (wxIcon*)(&bmp);
     *this = *icon;
-    return TRUE;
 }