2013-07-28 12:40:11 +00:00
|
|
|
#ifndef CSV_WORLD_IDVALIDATOR_H
|
|
|
|
#define CSV_WORLD_IDVALIDATOR_H
|
|
|
|
|
2014-08-14 12:21:34 +00:00
|
|
|
#include <string>
|
|
|
|
|
2013-07-28 12:40:11 +00:00
|
|
|
#include <QValidator>
|
|
|
|
|
|
|
|
namespace CSVWorld
|
|
|
|
{
|
|
|
|
class IdValidator : public QValidator
|
|
|
|
{
|
2013-10-22 09:08:37 +00:00
|
|
|
bool mRelaxed;
|
2014-08-14 12:21:34 +00:00
|
|
|
std::string mNamespace;
|
2014-08-15 11:11:55 +00:00
|
|
|
mutable std::string mError;
|
2013-10-22 09:08:37 +00:00
|
|
|
|
2013-07-28 12:40:11 +00:00
|
|
|
private:
|
|
|
|
bool isValid(const QChar& c, bool first) const;
|
|
|
|
|
2022-09-22 18:26:05 +00:00
|
|
|
public:
|
2013-07-28 12:40:11 +00:00
|
|
|
IdValidator(bool relaxed = false, QObject* parent = nullptr);
|
|
|
|
///< \param relaxed Relaxed rules for IDs that also functino as user visible text
|
|
|
|
|
|
|
|
State validate(QString& input, int& pos) const override;
|
|
|
|
|
2014-08-14 12:21:34 +00:00
|
|
|
void setNamespace(const std::string& namespace_);
|
2014-08-15 11:11:55 +00:00
|
|
|
|
|
|
|
/// Return a description of the error that resulted in the last call of validate
|
|
|
|
/// returning QValidator::Intermediate. If the last call to validate returned
|
|
|
|
/// a different value (or if there was no such call yet), an empty string is
|
|
|
|
/// returned.
|
|
|
|
std::string getError() const;
|
2013-07-28 12:40:11 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|