projects
/
wxWidgets.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Declarations missing from VC++ 5
[wxWidgets.git]
/
src
/
motif
/
checkbox.cpp
diff --git
a/src/motif/checkbox.cpp
b/src/motif/checkbox.cpp
index bac46094725f1599df778ed65f92e97b6401939e..f4b8b886441b849342427fcd8c889a6534f401ff 100644
(file)
--- a/
src/motif/checkbox.cpp
+++ b/
src/motif/checkbox.cpp
@@
-1,36
+1,28
@@
/////////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////////
-// Name: checkbox.cpp
+// Name:
src/motif/
checkbox.cpp
// Purpose: wxCheckBox
// Author: Julian Smart
// Modified by:
// Created: 04/01/98
// RCS-ID: $Id$
// Copyright: (c) Julian Smart
// Purpose: wxCheckBox
// Author: Julian Smart
// Modified by:
// Created: 04/01/98
// RCS-ID: $Id$
// Copyright: (c) Julian Smart
-// Licence: wxWindows licence
+// Licence:
wxWindows licence
/////////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////////
-#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
-#pragma implementation "checkbox.h"
-#endif
-
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
#ifdef __VMS
#define XtDisplay XTDISPLAY
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
#ifdef __VMS
#define XtDisplay XTDISPLAY
-#define XmNtoggleMode 0
-#define XmTOGGLE_INDETERMINATE 1
-#define XmTOGGLE_BOOLEAN 2
-#define XmUNSET 3
-#define XmSET 4
-#define XmINDETERMINATE 5
#endif
#endif
-#include "wx/defs.h"
-
#include "wx/checkbox.h"
#include "wx/checkbox.h"
+
+#ifndef WX_PRECOMP
+ #include "wx/utils.h"
+#endif
+
#include "wx/tglbtn.h"
#include "wx/tglbtn.h"
-#include "wx/utils.h"
#ifdef __VMS__
#pragma message disable nosimpint
#ifdef __VMS__
#pragma message disable nosimpint
@@
-43,6
+35,16
@@
#pragma message enable nosimpint
#endif
#pragma message enable nosimpint
#endif
+#include "wx/motif/private.h"
+
+// define symbols that are missing in old versions of Motif.
+#if wxCHECK_MOTIF_VERSION( 2, 0 )
+ #define wxHAS_3STATE 1
+#else
+ #define wxHAS_3STATE 0
+#endif
+
+
#include "wx/motif/private.h"
void wxCheckBoxCallback (Widget w, XtPointer clientData,
#include "wx/motif/private.h"
void wxCheckBoxCallback (Widget w, XtPointer clientData,
@@
-59,34
+61,35
@@
bool wxCheckBox::Create(wxWindow *parent, wxWindowID id, const wxString& label,
{
if( !wxControl::CreateControl( parent, id, pos, size, style, validator,
name ) )
{
if( !wxControl::CreateControl( parent, id, pos, size, style, validator,
name ) )
- return FALSE;
+ return false;
+
+ wxXmString text( GetLabelText(label) );
- wxString label1(wxStripMenuCodes(label));
- wxXmString text( label1 );
-
Widget parentWidget = (Widget) parent->GetClientWidget();
m_mainWidget = (WXWidget) XtVaCreateManagedWidget ("toggle",
xmToggleButtonWidgetClass, parentWidget,
Widget parentWidget = (Widget) parent->GetClientWidget();
m_mainWidget = (WXWidget) XtVaCreateManagedWidget ("toggle",
xmToggleButtonWidgetClass, parentWidget,
- wxFont::GetFontTag(), m_font.GetFontType(XtDisplay(parentWidget)),
+ wxFont::GetFontTag(), m_font.GetFontType
C
(XtDisplay(parentWidget)),
XmNlabelString, text(),
XmNrecomputeSize, False,
// XmNindicatorOn, XmINDICATOR_CHECK_BOX,
// XmNfillOnSelect, False,
XmNlabelString, text(),
XmNrecomputeSize, False,
// XmNindicatorOn, XmINDICATOR_CHECK_BOX,
// XmNfillOnSelect, False,
+#if wxHAS_3STATE
XmNtoggleMode, Is3State() ? XmTOGGLE_INDETERMINATE : XmTOGGLE_BOOLEAN,
XmNtoggleMode, Is3State() ? XmTOGGLE_INDETERMINATE : XmTOGGLE_BOOLEAN,
+#endif
NULL);
NULL);
-
+
XtAddCallback( (Widget)m_mainWidget,
XmNvalueChangedCallback, (XtCallbackProc)wxCheckBoxCallback,
(XtPointer)this );
XtAddCallback( (Widget)m_mainWidget,
XmNvalueChangedCallback, (XtCallbackProc)wxCheckBoxCallback,
(XtPointer)this );
- XmToggleButtonSetState ((Widget) m_mainWidget, F
ALSE, TRUE
);
+ XmToggleButtonSetState ((Widget) m_mainWidget, F
alse, True
);
AttachWidget( parent, m_mainWidget, (WXWidget)NULL,
pos.x, pos.y, size.x, size.y );
ChangeBackgroundColour();
AttachWidget( parent, m_mainWidget, (WXWidget)NULL,
pos.x, pos.y, size.x, size.y );
ChangeBackgroundColour();
- return
TRUE
;
+ return
true
;
}
void wxCheckBox::SetValue(bool val)
}
void wxCheckBox::SetValue(bool val)
@@
-151,7
+154,8
@@
void wxCheckBox::ChangeBackgroundColour()
XmNforeground, g_itemColors[wxFORE_INDEX].pixel,
NULL);
XmNforeground, g_itemColors[wxFORE_INDEX].pixel,
NULL);
- int selectPixel = wxBLACK->AllocColour(XtDisplay((Widget)m_mainWidget));
+ wxColour colour = *wxBLACK;
+ int selectPixel = colour.AllocColour(XtDisplay((Widget)m_mainWidget));
// Better to have the checkbox selection in black, or it's
// hard to determine what state it is in.
// Better to have the checkbox selection in black, or it's
// hard to determine what state it is in.
@@
-164,6
+168,7
@@
void wxCheckBox::DoSet3StateValue(wxCheckBoxState state)
{
m_inSetValue = true;
{
m_inSetValue = true;
+#if wxHAS_3STATE
unsigned char value;
switch (state)
unsigned char value;
switch (state)
@@
-171,17
+176,23
@@
void wxCheckBox::DoSet3StateValue(wxCheckBoxState state)
case wxCHK_UNCHECKED: value = XmUNSET; break;
case wxCHK_CHECKED: value = XmSET; break;
case wxCHK_UNDETERMINED: value = XmINDETERMINATE; break;
case wxCHK_UNCHECKED: value = XmUNSET; break;
case wxCHK_CHECKED: value = XmSET; break;
case wxCHK_UNDETERMINED: value = XmINDETERMINATE; break;
+ default: wxASSERT(0); return;
}
XtVaSetValues( (Widget) m_mainWidget,
XmNset, value,
NULL );
}
XtVaSetValues( (Widget) m_mainWidget,
XmNset, value,
NULL );
+#else
+ XmToggleButtonSetState ((Widget) m_mainWidget,
+ state == wxCHK_CHECKED, True);
+#endif
m_inSetValue = false;
}
wxCheckBoxState wxCheckBox::DoGet3StateValue() const
{
m_inSetValue = false;
}
wxCheckBoxState wxCheckBox::DoGet3StateValue() const
{
+#if wxHAS_3STATE
unsigned char value = 0;
XtVaGetValues( (Widget) m_mainWidget,
unsigned char value = 0;
XtVaGetValues( (Widget) m_mainWidget,
@@
-197,6
+208,9
@@
wxCheckBoxState wxCheckBox::DoGet3StateValue() const
// impossible...
return wxCHK_UNDETERMINED;
// impossible...
return wxCHK_UNDETERMINED;
+#else
+ return wxCheckBoxState(XmToggleButtonGetState ((Widget) m_mainWidget));
+#endif
}
///////////////////////////////////////////////////////////////////////////////
}
///////////////////////////////////////////////////////////////////////////////