#include "wx/control.h"
#include "wx/checkbox.h"
#include "wx/radiobut.h"
+ #include "wx/statbox.h"
#include "wx/textctrl.h"
#include "wx/settings.h"
#include "wx/dialog.h"
// when a new ctor is added which doesn't call InitWindow)
wxASSERT_MSG( m_isWindow, wxT("Init() must have been called before!") );
+#if wxUSE_STATBOX
+ // wxGTK doesn't allow to create controls with static box as the parent so
+ // this will result in a crash when the program is ported to wxGTK so warn
+ // the user about it
+
+ // if you get this assert, the correct solution is to create the controls
+ // as siblings of the static box
+ wxASSERT_MSG( !parent || !wxDynamicCast(parent, wxStaticBox),
+ _T("wxStaticBox can't be used as a window parent!") );
+#endif // wxUSE_STATBOX
+
// generate a new id if the user doesn't care about it
m_windowId = id == -1 ? NewControlId() : id;
#endif // wxUSE_CONSTRAINTS
if ( m_containingSizer )
- m_containingSizer->Remove((wxWindow*)this);
+ m_containingSizer->Detach( (wxWindow*)this );
if ( m_windowSizer )
delete m_windowSizer;
{
wxSize s( GetClientSize() );
- if( m_virtualSize.GetWidth() != -1 )
- s.SetWidth( m_virtualSize.GetWidth() );
- if( m_virtualSize.GetHeight() != -1 )
- s.SetHeight( m_virtualSize.GetHeight() );
-
- return s;
+ return wxSize( wxMax( m_virtualSize.GetWidth(), s.GetWidth() ),
+ wxMax( m_virtualSize.GetHeight(), s.GetHeight() ) );
}
// ----------------------------------------------------------------------------
if ( validator && !validator->TransferToWindow() )
{
wxLogWarning(_("Could not transfer data to window"));
+#if wxUSE_LOG
wxLog::FlushActive();
+#endif // wxUSE_LOG
return FALSE;
}
switch ( wxGetOsVersion() )
{
- case wxMOTIF_X: port = _T("Motif"); break;
+ case wxMOTIF_X: port += _T("Motif"); break;
case wxMAC:
- case wxMAC_DARWIN: port = _T("Mac"); break;
- case wxBEOS: port = _T("BeOS"); break;
+ case wxMAC_DARWIN: port += _T("Mac"); break;
+ case wxBEOS: port += _T("BeOS"); break;
case wxGTK:
case wxGTK_WIN32:
case wxGTK_OS2:
- case wxGTK_BEOS: port = _T("GTK"); break;
+ case wxGTK_BEOS: port += _T("GTK"); break;
case wxWINDOWS:
case wxPENWINDOWS:
case wxWINDOWS_NT:
case wxWIN32S:
case wxWIN95:
- case wxWIN386: port = _T("MS Windows"); break;
+ case wxWIN386: port += _T("MS Windows"); break;
case wxMGL_UNIX:
case wxMGL_X:
case wxMGL_WIN32:
- case wxMGL_OS2: port = _T("MGL"); break;
+ case wxMGL_OS2: port += _T("MGL"); break;
case wxWINDOWS_OS2:
- case wxOS2_PM: port = _T("OS/2"); break;
- default: port = _T("unknown"); break;
+ case wxOS2_PM: port += _T("OS/2"); break;
+ default: port += _T("unknown"); break;
}
wxMessageBox(wxString::Format(