/* kstringvalidator.cpp Copyright (c) 2001 Marc Mutz <mutz@kde.org> This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License as published by the Free Software Foundation; version 2.0 of the License. This library 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 Library General Public License for more details. You should have received a copy of the GNU Library General Public License along with this library; if not, write to the Free Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ #include "kstringvalidator.h" #include "kdebug.h" // // KStringListValidator // TQValidator::State KStringListValidator::validate( TQString & input, int& ) const { if ( input.isEmpty() ) return Intermediate; if ( isRejecting() ) // anything not in mStringList is acceptable: if ( mStringList.find( input ) == mStringList.end() ) return Acceptable; else return Intermediate; else // only what is in mStringList is acceptable: if ( mStringList.find( input ) != mStringList.end() ) return Acceptable; else for ( TQStringList::ConstIterator it = mStringList.begin() ; it != mStringList.end() ; ++it ) if ( (*it).startsWith( input ) || input.startsWith( *it ) ) return Intermediate; return Invalid; } void KStringListValidator::fixup( TQString & /* input */ ) const { if ( !isFixupEnabled() ) return; // warn (but only once!) about non-implemented fixup(): static bool warn = true; if ( warn ) { kdDebug() << "KStringListValidator::fixup() isn't yet implemented!" << endl; warn = false; } } // // KMimeTypeValidator // #define ALLOWED_CHARS "!#-'*+.0-9^-~+-" TQValidator::State KMimeTypeValidator::validate( TQString & input, int& ) const { if ( input.isEmpty() ) return Intermediate; TQRegExp acceptable( "[" ALLOWED_CHARS "]+/[" ALLOWED_CHARS "]+", false /*case-insens.*/); if ( acceptable.exactMatch( input ) ) return Acceptable; TQRegExp intermediate( "[" ALLOWED_CHARS "]*/?[" ALLOWED_CHARS "]*", false /*case-insensitive*/); if ( intermediate.exactMatch( input ) ) return Intermediate; return Invalid; } void KMimeTypeValidator::fixup( TQString & input ) const { TQRegExp invalidChars("[^/" ALLOWED_CHARS "]+"); input.replace( invalidChars, TQString::null); } #include "kstringvalidator.moc"