#endif
#include "wx/spinctrl.h"
-#include "wx/datectrl.h"
+// #include "wx/datectrl.h" -- can't use it in this (core) file for now
#if wxUSE_SPINBTN
#include "wx/spinbutt.h"
#if wxUSE_TOGGLEBTN
#include "wx/tglbtn.h"
#endif
+#include "wx/filename.h"
#include "wx/valgen.h"
m_pDateTime = val;
}
+wxGenericValidator::wxGenericValidator(wxFileName *val)
+{
+ Initialize();
+ m_pFileName = val;
+}
+
+wxGenericValidator::wxGenericValidator(float *val)
+{
+ Initialize();
+ m_pFloat = val;
+}
+
+wxGenericValidator::wxGenericValidator(double *val)
+{
+ Initialize();
+ m_pDouble = val;
+}
+
#endif // wxUSE_DATETIME
wxGenericValidator::wxGenericValidator(const wxGenericValidator& val)
#if wxUSE_DATETIME
m_pDateTime = val.m_pDateTime;
#endif // wxUSE_DATETIME
+ m_pFileName = val.m_pFileName;
+ m_pFloat = val.m_pFloat;
+ m_pDouble = val.m_pDouble;
return true;
}
return true;
}
} else
-#if defined(__WXMAC__) || defined(__WXGTK20__)
+#if (defined(__WXMAC__) || defined(__WXMSW__) || defined(__WXGTK20__)) && !defined(__WXUNIVERSAL__)
if (m_validatorWindow->IsKindOf(CLASSINFO(wxBitmapToggleButton)) )
{
wxBitmapToggleButton * pControl = (wxBitmapToggleButton *) m_validatorWindow;
pControl->SetValue(str);
return true;
}
+ else if (m_pFileName)
+ {
+ pControl->SetValue(m_pFileName->GetFullPath());
+ return true;
+ }
+ else if (m_pFloat)
+ {
+ pControl->SetValue(wxString::Format(wxT("%g"), *m_pFloat));
+ return true;
+ }
+ else if (m_pDouble)
+ {
+ pControl->SetValue(wxString::Format(wxT("%g"), *m_pDouble));
+ return true;
+ }
} else
#endif
}
} else
#endif
- ; // to match the last 'else' above
+ { // to match the last 'else' above
+ }
// unrecognized control, or bad pointer
return false;
return true;
}
} else
+#if (defined(__WXMAC__) || defined(__WXMSW__) || defined(__WXGTK20__)) && !defined(__WXUNIVERSAL__)
+ if (m_validatorWindow->IsKindOf(CLASSINFO(wxBitmapToggleButton)) )
+ {
+ wxBitmapToggleButton *pControl = (wxBitmapToggleButton *) m_validatorWindow;
+ if (m_pBool)
+ {
+ *m_pBool = pControl->GetValue() ;
+ return true;
+ }
+ } else
+#endif
#endif
// INT CONTROLS ***************************************
*m_pInt = wxAtoi(pControl->GetValue());
return true;
}
+ else if (m_pFileName)
+ {
+ m_pFileName->Assign(pControl->GetValue());
+ return true;
+ }
+ else if (m_pFloat)
+ {
+ *m_pFloat = (float)wxAtof(pControl->GetValue());
+ return true;
+ }
+ else if (m_pDouble)
+ {
+ *m_pDouble = wxAtof(pControl->GetValue());
+ return true;
+ }
} else
#endif
*/
void wxGenericValidator::Initialize()
{
- m_pBool = 0;
- m_pInt = 0;
- m_pString = 0;
- m_pArrayInt = 0;
+ m_pBool = NULL;
+ m_pInt = NULL;
+ m_pString = NULL;
+ m_pArrayInt = NULL;
#if wxUSE_DATETIME
- m_pDateTime = 0;
+ m_pDateTime = NULL;
#endif // wxUSE_DATETIME
+ m_pFileName = NULL;
+ m_pFloat = NULL;
+ m_pDouble = NULL;
}
#endif // wxUSE_VALIDATORS