Mercurial > hg > octave-jordi
view libgui/src/symbol-information.h @ 15286:ae9079bbc627
Add '#include <config.h>' to C++ files in libgui/src
* documentation-dockwidget.cc, files-dockwidget.cc, file-editor-tab.cc,
file-editor.cc, find-dialog.cc, lexer-octave-gui.cc, main-window.cc,
octave-qt-event-listener.cc, qtinfo/parser.cc, settings-dialog.cc,
terminal-dockwidget.cc, welcome-wizard.cc, workspace-view.cc:
Add '#include <config.h>' as first header file.
author | Rik <rik@octave.org> |
---|---|
date | Tue, 04 Sep 2012 11:53:26 -0700 |
parents | 307912900544 |
children | 67fabb3d81f4 |
line wrap: on
line source
/* Copyright (C) 2011-2012 Jacob Dawid This file is part of Octave. Octave 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. Octave 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 Octave; see the file COPYING. If not, see <http://www.gnu.org/licenses/>. */ #ifndef SYMBOLINFORMATION_H #define SYMBOLINFORMATION_H // FIXME -- we should not be including config.h in header files. #ifdef HAVE_CONFIG_H #include <config.h> #endif #include <QString> #include <QHash> #include <sstream> #include "symtab.h" /** * \struct symbol_information * \brief Meta-information over a symbol-table entry. * \author Jacob Dawid * This struct is used to store meta information over a symbol entry. * It reduces memory consumption, since it only stores relevant data * about a symbol-table entry that will be used in the model for the * graphical user interface. */ struct symbol_information { enum Scope { local = 0, global = 1, persistent = 2, hidden = 3 }; QString _symbol; QString _type; QString _value; QString _dimension; Scope _scope; /** Hashes the symbol information for quickly comparing it. */ int hash () const { return qHash (_symbol) + qHash (_type) + qHash (_value) + qHash (_dimension) + (int)_scope; } /** Compares two symbol information objects. */ bool equals (const symbol_information& other) const { if (hash () == other.hash ()) { return _symbol == other._symbol && _type == other._type && _value == other._value && _scope == other._scope && _dimension == other._dimension; } } /** Extracts meta information from a given symbol record. */ bool from_symbol_record (const symbol_table::symbol_record& symbol_record); }; #endif // SYMBOLINFORMATION_H