Mercurial > hg > octave-nkf
view libgui/src/workspace-model.cc @ 20830:b65888ec820e draft default tip gccjit
dmalcom gcc jit import
author | Stefan Mahr <dac922@gmx.de> |
---|---|
date | Fri, 27 Feb 2015 16:59:36 +0100 |
parents | 3a8e9e991d5e |
children |
line wrap: on
line source
/* Copyright (C) 2013-2015 John W. Eaton Copyright (C) 2011-2015 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/>. */ #ifdef HAVE_CONFIG_H #include <config.h> #endif #include <QTreeWidget> #include <QSettings> #include "utils.h" #include "resource-manager.h" #include "workspace-model.h" workspace_model::workspace_model (QObject *p) : QAbstractTableModel (p) { _columnNames.append (tr ("Name")); _columnNames.append (tr ("Class")); _columnNames.append (tr ("Dimension")); _columnNames.append (tr ("Value")); _columnNames.append (tr ("Attribute")); for (int i = 0; i < resource_manager::storage_class_chars ().length (); i++) _storage_class_colors.append (QColor (Qt::white)); } QList<QColor> workspace_model::storage_class_default_colors (void) { QList<QColor> colors; if (colors.isEmpty ()) { colors << QColor (190,255,255) << QColor (220,255,220) << QColor (220,220,255) << QColor (255,255,190) << QColor (255,220,220) << QColor (255,190,255); } return colors; } QStringList workspace_model::storage_class_names (void) { QStringList names; if (names.isEmpty ()) { names << QObject::tr ("automatic") << QObject::tr ("function") << QObject::tr ("global") << QObject::tr ("hidden") << QObject::tr ("inherited") << QObject::tr ("persistent"); } return names; } int workspace_model::rowCount (const QModelIndex&) const { return _symbols.size (); } int workspace_model::columnCount (const QModelIndex&) const { return _columnNames.size (); } Qt::ItemFlags workspace_model::flags (const QModelIndex& idx) const { Qt::ItemFlags retval = 0; if (idx.isValid ()) { retval |= Qt::ItemIsEnabled; if (_top_level && idx.column () == 0) retval |= Qt::ItemIsSelectable; } return retval; } QVariant workspace_model::headerData (int section, Qt::Orientation orientation, int role) const { if (orientation == Qt::Horizontal && role == Qt::DisplayRole) return _columnNames[section]; else return QVariant (); } QVariant workspace_model::data (const QModelIndex& idx, int role) const { QVariant retval; if (idx.isValid ()) { if (role == Qt::BackgroundColorRole) { QString class_chars = resource_manager::storage_class_chars (); int actual_class = class_chars.indexOf (_scopes[idx.row ()].toAscii ()); if (actual_class >= 0) return QVariant (_storage_class_colors.at (actual_class)); else return retval; } if (role == Qt::DisplayRole || (idx.column () == 0 && role == Qt::EditRole) || (idx.column () == 0 && role == Qt::ToolTipRole)) { switch (idx.column ()) { case 0: if (role == Qt::ToolTipRole) retval = QVariant (tr ("Right click to copy, rename, or display")); else retval = QVariant (_symbols[idx.row ()]); break; case 1: retval = QVariant (_class_names[idx.row ()]); break; case 2: retval = QVariant (_dimensions[idx.row ()]); break; case 3: retval = QVariant (_values[idx.row ()]); break; case 4: { QString sclass; QString class_chars = resource_manager::storage_class_chars (); int actual_class = class_chars.indexOf (_scopes[idx.row ()].toAscii ()); if (actual_class >= 0) { QStringList class_names = resource_manager::storage_class_names (); sclass = class_names.at (actual_class); } if (_complex_flags[idx.row ()]) { if (sclass.isEmpty ()) sclass = tr ("complex"); else sclass += ", " + tr ("complex"); } retval = QVariant (sclass); } break; } } } return retval; } bool workspace_model::setData (const QModelIndex& idx, const QVariant& value, int role) { bool retval = false; if (idx.column () == 0 && role == Qt::EditRole) { QString qold_name = _symbols[idx.row ()]; QString qnew_name = value.toString (); std::string new_name = qnew_name.toStdString (); if (valid_identifier (new_name)) { emit rename_variable (qold_name, qnew_name); retval = true; } } return retval; } void workspace_model::set_workspace (bool top_level, bool /* debug */, const QString& scopes, const QStringList& symbols, const QStringList& class_names, const QStringList& dimensions, const QStringList& values, const QIntList& complex_flags) { _top_level = top_level; _scopes = scopes; _symbols = symbols; _class_names = class_names; _dimensions = dimensions; _values = values; _complex_flags = complex_flags; update_table (); } void workspace_model::clear_workspace (void) { clear_data (); update_table (); } void workspace_model::clear_data (void) { _top_level = false; _scopes = QString (); _symbols = QStringList (); _class_names = QStringList (); _dimensions = QStringList (); _values = QStringList (); _complex_flags = QIntList (); } void workspace_model::update_table (void) { beginResetModel (); // Nothing to do except tell the world to recalc. endResetModel (); emit model_changed (); } void workspace_model::notice_settings (const QSettings *settings) { QList<QColor> default_colors = resource_manager::storage_class_default_colors (); QString class_chars = resource_manager::storage_class_chars (); for (int i = 0; i < class_chars.length (); i++) { QVariant default_var = default_colors.at (i); QColor setting_color = settings->value ("workspaceview/color_" + class_chars.mid (i,1), default_var).value<QColor> (); _storage_class_colors.replace (i,setting_color); } }