X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/3b439e60e0119e890ec0040545875ff11352f24a..64ea838d8f4d1853b7d850db93ee565e901d099a:/src/gtk1/msgdlg.cpp diff --git a/src/gtk1/msgdlg.cpp b/src/gtk1/msgdlg.cpp index 4e3eb6d2ff..6bdc9f5c90 100644 --- a/src/gtk1/msgdlg.cpp +++ b/src/gtk1/msgdlg.cpp @@ -1,134 +1,17 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: msgdlg.cpp +// Name: src/gtk1/msgdlg.cpp // Purpose: wxMessageDialog for GTK+2 // Author: Vaclav Slavik // Modified by: // Created: 2003/02/28 // RCS-ID: $Id$ // Copyright: (c) Vaclav Slavik, 2003 -// Licence: wxWindows licence +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) -#pragma implementation "msgdlg.h" -#endif - // For compilers that support precompilation, includes "wx.h". #include "wx/wxprec.h" #ifdef __BORLANDC__ #pragma hdrstop #endif - -#if wxUSE_MSGDLG && defined(__WXGTK20__) && !defined(__WXGPE__) - -#include "wx/msgdlg.h" -#include "wx/gtk/private.h" -#include - -#include "wx/intl.h" - -IMPLEMENT_CLASS(wxMessageDialog, wxDialog) - -wxMessageDialog::wxMessageDialog(wxWindow *parent, - const wxString& message, - const wxString& caption, - long style, - const wxPoint& WXUNUSED(pos)) -{ - m_caption = caption; - m_message = message; - m_dialogStyle = style; - m_parent = wxGetTopLevelParent(parent); - - GtkMessageType type = GTK_MESSAGE_ERROR; - GtkButtonsType buttons = GTK_BUTTONS_OK; - - if (m_dialogStyle & wxYES_NO) - { - buttons = GTK_BUTTONS_YES_NO; - } - - if (m_dialogStyle & wxOK) - { - if (m_dialogStyle & wxCANCEL) - buttons = GTK_BUTTONS_OK_CANCEL; - else - buttons = GTK_BUTTONS_OK; - } - - if (m_dialogStyle & wxICON_EXCLAMATION) - type = GTK_MESSAGE_WARNING; - else if (m_dialogStyle & wxICON_ERROR) - type = GTK_MESSAGE_ERROR; - else if (m_dialogStyle & wxICON_INFORMATION) - type = GTK_MESSAGE_INFO; - else if (m_dialogStyle & wxICON_QUESTION) - type = GTK_MESSAGE_QUESTION; - else - { - // GTK+ doesn't have a "typeless" msg box, so try to auto detect... - type = m_dialogStyle & wxYES ? GTK_MESSAGE_QUESTION : GTK_MESSAGE_INFO; - } - - m_widget = gtk_message_dialog_new(m_parent ? - GTK_WINDOW(m_parent->m_widget) : NULL, - GTK_DIALOG_MODAL, - type, buttons, - "%s", (const char*)wxGTK_CONV(m_message)); - if (m_caption != wxMessageBoxCaptionStr) - gtk_window_set_title(GTK_WINDOW(m_widget), wxGTK_CONV(m_caption)); - - if (m_dialogStyle & wxYES_NO) - { - if (m_dialogStyle & wxCANCEL) - gtk_dialog_add_button(GTK_DIALOG(m_widget), GTK_STOCK_CANCEL, - GTK_RESPONSE_CANCEL); - if (m_dialogStyle & wxNO_DEFAULT) - gtk_dialog_set_default_response(GTK_DIALOG(m_widget), GTK_RESPONSE_NO); - else - gtk_dialog_set_default_response(GTK_DIALOG(m_widget), GTK_RESPONSE_YES); - } - - if (m_parent) - gtk_window_set_transient_for(GTK_WINDOW(m_widget), - GTK_WINDOW(m_parent->m_widget)); -} - -wxMessageDialog::~wxMessageDialog() -{ -} - -int wxMessageDialog::ShowModal() -{ - // This should be necessary, but otherwise the - // parent TLW will disappear.. - if (m_parent) - gtk_window_present( GTK_WINDOW(m_parent->m_widget) ); - - gint result = gtk_dialog_run(GTK_DIALOG(m_widget)); - gtk_widget_destroy(m_widget); - m_widget = NULL; - - switch (result) - { - default: - wxFAIL_MSG(_T("unexpected GtkMessageDialog return code")); - // fall through - - case GTK_RESPONSE_CANCEL: - case GTK_RESPONSE_DELETE_EVENT: - case GTK_RESPONSE_CLOSE: - return wxID_CANCEL; - case GTK_RESPONSE_OK: - return wxID_OK; - case GTK_RESPONSE_YES: - return wxID_YES; - case GTK_RESPONSE_NO: - return wxID_NO; - } -} - - -#endif // wxUSE_MSGDLG && defined(__WXGTK20__) -