X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/2afba7c46ce2fbd13a6aed64e7600343fd01c224..5eed855656b3996f4c0aa0a585a4820a2af6d628:/src/common/sizer.cpp diff --git a/src/common/sizer.cpp b/src/common/sizer.cpp index 518ccce91f..959ba220a8 100644 --- a/src/common/sizer.cpp +++ b/src/common/sizer.cpp @@ -1319,6 +1319,7 @@ wxGridSizer::wxGridSizer( int cols, int vgap, int hgap ) m_vgap( vgap ), m_hgap( hgap ) { + wxASSERT(cols >= 0); } wxGridSizer::wxGridSizer( int cols, const wxSize& gap ) @@ -1327,6 +1328,7 @@ wxGridSizer::wxGridSizer( int cols, const wxSize& gap ) m_vgap( gap.GetHeight() ), m_hgap( gap.GetWidth() ) { + wxASSERT(cols >= 0); } wxGridSizer::wxGridSizer( int rows, int cols, int vgap, int hgap ) @@ -1335,6 +1337,7 @@ wxGridSizer::wxGridSizer( int rows, int cols, int vgap, int hgap ) m_vgap( vgap ), m_hgap( hgap ) { + wxASSERT(rows >= 0 && cols >= 0); } wxGridSizer::wxGridSizer( int rows, int cols, const wxSize& gap ) @@ -1343,6 +1346,7 @@ wxGridSizer::wxGridSizer( int rows, int cols, const wxSize& gap ) m_vgap( gap.GetHeight() ), m_hgap( gap.GetWidth() ) { + wxASSERT(rows >= 0 && cols >= 0); } wxSizerItem *wxGridSizer::DoInsert(size_t index, wxSizerItem *item) @@ -2567,46 +2571,38 @@ void wxStdDialogButtonSizer::Realize() // Extra space around and at the right Add(12, 40); #elif defined(__WXGTK20__) - Add(0, 0, 0, wxLEFT, 9); - if (m_buttonHelp) - Add((wxWindow*)m_buttonHelp, 0, wxALIGN_CENTRE | wxLEFT | wxRIGHT, 3); + // http://library.gnome.org/devel/hig-book/stable/windows-alert.html.en + // says that the correct button order is + // + // [Help] [Alternative] [Cancel] [Affirmative] - // extra whitespace between help and cancel/ok buttons - Add(0, 0, 1, wxEXPAND, 0); + // Flags ensuring that margins between the buttons are 6 pixels. + const wxSizerFlags + flagsBtn = wxSizerFlags().Centre().Border(wxLEFT | wxRIGHT, 3); - if (m_buttonNegative){ - Add((wxWindow*)m_buttonNegative, 0, wxALIGN_CENTRE | wxLEFT | wxRIGHT, 3); - } + // Margin around the entire sizer button should be 12. + AddSpacer(9); - if (m_buttonApply) - { - // according to HIG, in explicit apply windows the order is: - // [ Help Apply Cancel OK ] + if (m_buttonHelp) + Add(m_buttonHelp, flagsBtn); - Add((wxWindow*)m_buttonApply, - 0, wxALIGN_CENTRE | wxLEFT | wxRIGHT, 3); + // Align the rest of the buttons to the right. + AddStretchSpacer(); - if (m_buttonCancel) - Add((wxWindow*)m_buttonCancel, - 0, wxALIGN_CENTRE | wxLEFT | wxRIGHT, 3); + if (m_buttonNegative) + Add(m_buttonNegative, flagsBtn); - if (m_buttonAffirmative) - Add((wxWindow*)m_buttonAffirmative, - 0, wxALIGN_CENTRE | wxLEFT, 6); - } - else - { - // without an Apply button, have the buttons representing - // affirmative and negative close to each other. + if (m_buttonApply) + Add(m_buttonApply, flagsBtn); - if (m_buttonAffirmative) - Add((wxWindow*)m_buttonAffirmative, - 0, wxALIGN_CENTRE | wxLEFT | wxRIGHT, 3); + if (m_buttonCancel) + Add(m_buttonCancel, flagsBtn); - if (m_buttonCancel) - Add((wxWindow*)m_buttonCancel, 0, wxALIGN_CENTRE | wxLEFT, 6); - } + if (m_buttonAffirmative) + Add(m_buttonAffirmative, flagsBtn); + // Ensure that the right margin is 12 as well. + AddSpacer(9); #elif defined(__WXMSW__) // Windows