3 * This file is part of LyX, the document processor.
4 * Licence details can be found in the file COPYING.
6 * \author Angus Leeming
9 * Full author contact details are available in file CREDITS.
15 #include "Validator.h"
16 #include "qt_helpers.h"
18 #include "support/gettext.h"
21 #include "frontends/alert.h"
23 #include "support/docstring.h"
24 #include "support/lstrings.h"
34 LengthValidator::LengthValidator(QWidget * parent)
36 no_bottom_(true), glue_length_(false)
40 QValidator::State LengthValidator::validate(QString & qtext, int &) const
42 string const text = fromqstr(qtext);
43 if (text.empty() || support::isStrDbl(text))
44 return QValidator::Acceptable;
48 return (isValidGlueLength(text, &gl)) ?
49 QValidator::Acceptable : QValidator::Intermediate;
53 bool const valid_length = isValidLength(text, &l);
55 return QValidator::Intermediate;
58 return QValidator::Acceptable;
60 return b_.inPixels(100) <= l.inPixels(100) ?
61 QValidator::Acceptable : QValidator::Intermediate;
65 void LengthValidator::setBottom(Length const & b)
72 void LengthValidator::setBottom(GlueLength const & g)
80 LengthValidator * unsignedLengthValidator(QLineEdit * ed)
82 LengthValidator * v = new LengthValidator(ed);
83 v->setBottom(Length());
88 LengthAutoValidator::LengthAutoValidator(QWidget * parent)
89 : LengthValidator(parent)
93 QValidator::State LengthAutoValidator::validate(QString & qtext, int & dummy) const
96 return QValidator::Acceptable;
97 return LengthValidator::validate(qtext, dummy);
101 LengthAutoValidator * unsignedLengthAutoValidator(QLineEdit * ed)
103 LengthAutoValidator * v = new LengthAutoValidator(ed);
104 v->setBottom(Length());
109 DoubleAutoValidator::DoubleAutoValidator(QWidget * parent)
110 : QDoubleValidator(parent)
114 DoubleAutoValidator::DoubleAutoValidator(double bottom,
115 double top, int decimals, QObject * parent)
116 : QDoubleValidator(bottom, top, decimals, parent)
120 QValidator::State DoubleAutoValidator::validate(QString & input, int & pos) const {
122 return QValidator::Acceptable;
123 return QDoubleValidator::validate(input, pos);
127 PathValidator::PathValidator(bool acceptable_if_empty,
129 : QValidator(parent),
130 acceptable_if_empty_(acceptable_if_empty),
132 tex_allows_spaces_(false)
136 static docstring const printable_list(docstring const & invalid_chars)
139 docstring::const_iterator const begin = invalid_chars.begin();
140 docstring::const_iterator const end = invalid_chars.end();
141 docstring::const_iterator it = begin;
143 for (; it != end; ++it) {
156 QValidator::State PathValidator::validate(QString & qtext, int &) const
159 return QValidator::Acceptable;
161 docstring const text = support::trim(qstring_to_ucs4(qtext));
163 return acceptable_if_empty_ ?
164 QValidator::Acceptable : QValidator::Intermediate;
166 docstring invalid_chars = from_ascii("#$%{}()[]\"^");
167 if (!tex_allows_spaces_)
168 invalid_chars += ' ';
170 if (text.find_first_of(invalid_chars) != docstring::npos) {
172 static int counter = 0;
174 Alert::error(_("Invalid filename"),
175 _("LyX does not provide LaTeX support for file names containing any of these characters:\n") +
176 printable_list(invalid_chars));
179 return QValidator::Intermediate;
182 return QValidator::Acceptable;
186 void PathValidator::setChecker(KernelDocType const & type, LyXRC const & lyxrc)
188 latex_doc_ = type == LATEX;
189 tex_allows_spaces_ = lyxrc.tex_allows_spaces;
193 PathValidator * getPathValidator(QLineEdit * ed)
197 QValidator * validator = const_cast<QValidator *>(ed->validator());
200 return dynamic_cast<PathValidator *>(validator);
203 } // namespace frontend
206 #include "Validator_moc.cpp"