Mercurial > hg > octave-nkf
view libgui/src/symbol-information.h @ 15196:017f0b2e6933
rename gui directory to libgu
* libgui: Rename from gui.
* .hgsub (libgui/qterminal): Rename from gui/qterminal.
* Makefile.am (GUIDIR): Set to libgui instead of gui if
AMCOND_BUILD_GUI is true.
* configure.ac (AC_CONFIG_FILES): Update list for directory renaming.
* Makefile.am (.NOTPARALLEL): Delete.
List octave.html/index.html as the primary HTML target, not
octave.html.
(octave.html): New target for making the octave.html directory.
(octave.pdf): Depend on octave.dvi.
* images.awk: In generated rules for png files, depend on octave.html,
not octave.html/index.html.
* src/Makefile.am (OCTAVE_GUI_CPPFLAGS, OCTAVE_GUI_LIBS): Update for
directory renaming.
(CLEANFILES): Fix typo.
* fntests.m (src_tree): Use libinterp, not src.
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Sat, 18 Aug 2012 18:10:09 -0400 |
parents | gui/src/symbol-information.h@9e62d5a3a45e |
children | 359098ad343e |
line wrap: on
line source
/* OctaveGUI - A graphical user interface for Octave * Copyright (C) 2011 Jacob Dawid (jacob.dawid@googlemail.com) * * 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 3 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, 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