#include "wx/log.h"
#include "wx/dialog.h"
-#include "wx/msgdlg.h"
#include "wx/control.h"
#include "wx/app.h"
#include "wx/dcclient.h"
/* Callback for wxTopLevelWindowGTK. This very strange beast has to be used because
* C++ has no virtual methods in a constructor. We have to emulate a
- * virtual function here as wxWindows requires different ways to insert
+ * virtual function here as wxWidgets requires different ways to insert
* a child in container classes. */
static void wxInsertChildInTopLevelWindow( wxTopLevelWindowGTK* parent, wxWindow* child )
m_insertCallback = (wxInsertChildFunction) wxInsertChildInTopLevelWindow;
- GtkWindowType win_type = GTK_WINDOW_TOPLEVEL;
+ // NB: m_widget may be !=NULL if it was created by derived class' Create,
+ // e.g. in wxTaskBarIconAreaGTK
+ if (m_widget == NULL)
+ {
+ GtkWindowType win_type = GTK_WINDOW_TOPLEVEL;
- if (style & wxFRAME_TOOL_WINDOW)
- win_type = GTK_WINDOW_POPUP;
+ if (style & wxFRAME_TOOL_WINDOW)
+ win_type = GTK_WINDOW_POPUP;
- if (GetExtraStyle() & wxTOPLEVEL_EX_DIALOG)
- {
- // there is no more GTK_WINDOW_DIALOG in 2.0
+ if (GetExtraStyle() & wxTOPLEVEL_EX_DIALOG)
+ {
+ // there is no more GTK_WINDOW_DIALOG in 2.0
#ifdef __WXGTK20__
- win_type = GTK_WINDOW_TOPLEVEL;
+ win_type = GTK_WINDOW_TOPLEVEL;
#else
- win_type = GTK_WINDOW_DIALOG;
+ win_type = GTK_WINDOW_DIALOG;
#endif
- }
+ }
- m_widget = gtk_window_new( win_type );
+ m_widget = gtk_window_new( win_type );
+ }
if (m_parent && (((GTK_IS_WINDOW(m_parent->m_widget)) &&
(GetExtraStyle() & wxTOPLEVEL_EX_DIALOG)) ||
bool wxTopLevelWindowGTK::Show( bool show )
{
- wxCHECK_VALID_WIDGET(FALSE);
+ wxASSERT_MSG( (m_widget != NULL), wxT("invalid frame") );
if (show && !m_sizeSet)
{
void wxTopLevelWindowGTK::DoSetSize( int x, int y, int width, int height, int sizeFlags )
{
- wxCHECK_VALID_WIDGET_RET();
-
+ wxASSERT_MSG( (m_widget != NULL), wxT("invalid frame") );
+
// this shouldn't happen: wxFrame, wxMDIParentFrame and wxMDIChildFrame have m_wxwindow
wxASSERT_MSG( (m_wxwindow != NULL), wxT("invalid frame") );
void wxTopLevelWindowGTK::DoGetClientSize( int *width, int *height ) const
{
- wxCHECK_VALID_WIDGET_RET();
-
+ wxASSERT_MSG( (m_widget != NULL), wxT("invalid frame") );
+
wxWindow::DoGetClientSize( width, height );
if (height)
{
void wxTopLevelWindowGTK::DoSetClientSize( int width, int height )
{
- wxCHECK_VALID_WIDGET_RET();
+ wxASSERT_MSG( (m_widget != NULL), wxT("invalid frame") );
DoSetSize(-1, -1,
width + m_miniEdge*2, height + m_miniEdge*2 + m_miniTitle, 0);
void wxTopLevelWindowGTK::SetTitle( const wxString &title )
{
- wxCHECK_VALID_WIDGET_RET();
-
+ wxASSERT_MSG( (m_widget != NULL), wxT("invalid frame") );
+
m_title = title;
gtk_window_set_title( GTK_WINDOW(m_widget), wxGTK_CONV( title ) );
}
void wxTopLevelWindowGTK::SetIcons( const wxIconBundle &icons )
{
- wxCHECK_VALID_WIDGET_RET();
+ wxASSERT_MSG( (m_widget != NULL), wxT("invalid frame") );
GdkWindow* window = m_widget->window;
wxTopLevelWindowBase::SetIcons( icons );