Newer
Older
#ifndef MANTID_KERNEL_FILEVALIDATOR_H_
#define MANTID_KERNEL_FILEVALIDATOR_H_
//----------------------------------------------------------------------
// Includes
//----------------------------------------------------------------------
#include "IValidator.h"
#include <vector>
namespace Mantid
{
namespace Kernel
{
/** FileValidator is a validator that checks that a filepath is valid.
@author Matt Clarke, ISIS.
@date 25/06/2008
Copyright © 2008-9 ISIS Rutherford Appleton Laboratory & NScD Oak Ridge National Laboratory
This file is part of Mantid.
Mantid is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
Mantid 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
File change history is stored at: <https://svn.mantidproject.org/mantid/trunk/Code/Mantid>.
Code Documentation is available at: <http://doxygen.mantidproject.org>
*/
class DLLExport FileValidator : public IValidator<std::string>
{
public:
FileValidator();
explicit FileValidator(const std::vector<std::string>& extensions, bool testFileExists = true);
virtual ~FileValidator();
std::set<std::string> allowedValues() const;
IValidator<std::string>* clone();
private:
/// The list of permitted extensions
Peterson, Peter
committed
const std::set<std::string> m_extensions;
/// Flag indicating whether to test for existence of filename
const bool m_fullTest;
std::string checkValidity(const std::string &value) const;
Peterson, Peter
committed
bool endswith(const std::string &value) const;