// Berkeley Open Infrastructure for Network Computing // http://boinc.berkeley.edu // Copyright (C) 2005 University of California // // This is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; // either version 2.1 of the License, or (at your option) any later version. // // This software is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. // See the GNU Lesser General Public License for more details. // // To view the GNU Lesser General Public License visit // http://www.gnu.org/copyleft/lesser.html // or write to the Free Software Foundation, Inc., // 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA #if defined(__GNUG__) && !defined(__APPLE__) #pragma implementation "ValidateEmailAddress.h" #endif #include "stdwx.h" #include "ValidateEmailAddress.h" IMPLEMENT_DYNAMIC_CLASS(CValidateEmailAddress, wxValidator) CValidateEmailAddress::CValidateEmailAddress(wxString *val) { m_stringValue = val ; } CValidateEmailAddress::CValidateEmailAddress(const CValidateEmailAddress& val) : wxValidator() { Copy(val); } CValidateEmailAddress::~CValidateEmailAddress() {} bool CValidateEmailAddress::Copy(const CValidateEmailAddress& val) { wxValidator::Copy(val); m_stringValue = val.m_stringValue ; return TRUE; } bool CValidateEmailAddress::Validate(wxWindow *parent) { if(!CheckValidator()) return FALSE; wxTextCtrl *control = (wxTextCtrl *) m_validatorWindow ; if (!control->IsEnabled()) return TRUE; bool ok = TRUE; wxString val(control->GetValue().Trim().Trim(false)); // trim spaces before and after // Okay, this is like the 5th iteration of trying to find a good regular expression // to validate an email address. This time around I went to a commercial package // that specializes in Regular Expressions. // // RegexBuddy // http://www.regexbuddy.com/ // // I took there 99% compatible email regex and added a '+' as a valid character and changed // the max length of the TLD to be 6 characters. Per there instructions I also made this regex // case insensitive. // // The formal RFC 822 regex is 6343 characters unescaped. ick. // wxRegEx reEmail(wxT("^[A-Z0-9.+_%-]+@(?:[A-Z0-9-]+\\.)+[A-Z]{2,6}$"), wxRE_EXTENDED|wxRE_ICASE); if (val.Length() == 0) { ok = FALSE; m_errormsg = _("Please specify an email address"); } else if (!reEmail.Matches(val)) { ok = FALSE; m_errormsg = _("Invalid email address; please enter a valid email address"); } if (!ok) { wxASSERT_MSG(!m_errormsg.empty(), _T("you forgot to set errormsg")); m_validatorWindow->SetFocus(); wxString buf; buf.Printf(m_errormsg, control->GetValue().c_str()); wxMessageBox(buf, _("Validation conflict"), wxOK | wxICON_EXCLAMATION, parent ); } return ok; } bool CValidateEmailAddress::TransferToWindow(void) { if(!CheckValidator()) return FALSE; if (!m_stringValue) return TRUE; wxTextCtrl *control = (wxTextCtrl *) m_validatorWindow ; control->SetValue(* m_stringValue) ; return TRUE; } bool CValidateEmailAddress::TransferFromWindow(void) { if(!CheckValidator()) return FALSE; if (!m_stringValue) return TRUE; wxTextCtrl *control = (wxTextCtrl *) m_validatorWindow ; * m_stringValue = control->GetValue() ; return TRUE; } bool CValidateEmailAddress::wxIsAlphaNumeric(const wxString& val) { int i; for (i = 0; i < (int)val.Length(); i++) { if (!wxIsalnum(val[i])) return FALSE; } return TRUE; } bool CValidateEmailAddress::CheckValidator() const { wxCHECK_MSG(m_validatorWindow, FALSE, _T("No window associated with validator")); wxCHECK_MSG(m_validatorWindow->IsKindOf(CLASSINFO(wxTextCtrl)), FALSE, _T("wxTextValidator is only for wxTextCtrl's")); wxCHECK_MSG(m_stringValue, FALSE, _T("No variable storage for validator")); return TRUE; }