cfcbb28671
Have dfilter_compile() take an additional gchar ** argument, pointing to a gchar * item that, on error, gets set to point to a g_malloc()ed error string. That removes one bit of global state from the display filter parser, and doesn't impose a fixed limit on the error message strings. Have fvalue_from_string() and fvalue_from_unparsed() take a gchar ** argument, pointer to a gchar * item, rather than an error-reporting function, and set the gchar * item to point to a g_malloc()ed error string on an error. Allow either gchar ** argument to be null; if the argument is null, no error message is allocated or provided. Change-Id: Ibd36b8aaa9bf4234aa6efa1e7fb95f7037493b4c Reviewed-on: https://code.wireshark.org/review/6608 Reviewed-by: Guy Harris <guy@alum.mit.edu>
62 lines
1.8 KiB
C++
62 lines
1.8 KiB
C++
/* syntax_line_edit.h
|
|
*
|
|
* Wireshark - Network traffic analyzer
|
|
* By Gerald Combs <gerald@wireshark.org>
|
|
* Copyright 1998 Gerald Combs
|
|
*
|
|
* This program 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 2
|
|
* of the License, or (at your option) any later version.
|
|
*
|
|
* This program 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, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*/
|
|
|
|
#ifndef SYNTAX_LINE_EDIT_H
|
|
#define SYNTAX_LINE_EDIT_H
|
|
|
|
#include <QLineEdit>
|
|
|
|
class SyntaxLineEdit : public QLineEdit
|
|
{
|
|
Q_OBJECT
|
|
Q_PROPERTY(SyntaxState syntaxState READ syntaxState)
|
|
Q_ENUMS(SyntaxState)
|
|
public:
|
|
explicit SyntaxLineEdit(QWidget *parent = 0);
|
|
enum SyntaxState { Empty, Invalid, Deprecated, Valid };
|
|
|
|
SyntaxState syntaxState() const { return syntax_state_; }
|
|
void setSyntaxState(SyntaxState state = Empty);
|
|
QString syntaxErrorMessage();
|
|
QString styleSheet() const;
|
|
QString deprecatedToken();
|
|
|
|
public slots:
|
|
void setStyleSheet(const QString &style_sheet);
|
|
|
|
// Built-in syntax checks. Connect textChanged to these as needed.
|
|
void checkDisplayFilter(QString filter);
|
|
void checkFieldName(QString field);
|
|
void checkInteger(QString number);
|
|
|
|
private:
|
|
SyntaxState syntax_state_;
|
|
QString style_sheet_;
|
|
QString state_style_sheet_;
|
|
QString deprecated_token_;
|
|
QString syntax_error_message_;
|
|
|
|
signals:
|
|
|
|
};
|
|
|
|
#endif // SYNTAX_LINE_EDIT_H
|