Mercurial > octave
view libgui/src/find-files-model.cc @ 16620:818eef7b2618
allow terminal colors to be set from preferences dialog
* QTerminalInterface.h (QTerminalInterface::setBackgroundColor,
QTerminalInterface::setForeroundColor,
QTerminalInterface::setSelectionColor,
QTerminalInterface::setCursorColor): New functions.
* QUnixTerminalImpl.h, QUnixTerminalImpl.cpp
QUnixTerminalImpl::setBackgroundColor,
QUnixTerminalImpl::setForeroundColor,
QUnixTerminalImpl::setSelectionColor,
QUnixTerminalImpl::setCursorColor): New functions.
* QWinTerminalImpl.h, QWinTerminalImpl.cpp
(QConsolePrivate::setCursorColor): New argument, useForegroundColor.
(QConsolePrivate::m_selectionColor, QConsolePrivate::m_cursorColor):
New member variablebs.
(QConsolePrivate::selectionColor, QConsolePrivate::cursorColor,
QConsolePrivate::setSelectionColor, QConsolePrivate::setCursorColor):
Use member variables instead of Windows console color map.
(QConsolePrivate::cursorColor): Return foreground color if stored
color is invalid.
(QConsolePrivate::setCursorColor): Store invalid color if
useForegroundcolor.
(QConsolePrivate::QConsolePrivate): Set default selection and cursor
colors.
* QTerminal.cc (QTerminal::notice_settings): Handle terminal color
settings.
* resource-manager.h, resource-manager.cc
(resource_manager::terminal_color_names,
resource_manager::terminal_default_colors,
resource_manager::terminal_color_chars): New functions.
* settings-dialog.h, settings-dialog.cc
(settings_dialog::read_terminal_colors): New function.
(settings_dialog::settings_dialog): Call read_terminal_colors. Read
valud for using foreground color for cursor color.
(settings_dialog::write_terminal_colors): New function.
(settings_dialog::write_changed_settings): Call
write_terminal_colors. Handle setting for using foreground color for
cursor color.
* settings-dialog.ui: Add color selection to terminal settings
dialog.
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Mon, 06 May 2013 06:00:44 -0400 |
parents | 3e8fd0c479b4 |
children | 90d50e56a06a |
line wrap: on
line source
/* Copyright (C) 2013 John Donoghue 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/>. */ #include "find-files-model.h" #include <QFileIconProvider> find_files_model::find_files_model (QObject *p) : QAbstractListModel(p) { _columnNames.append (tr ("Filename")); _columnNames.append (tr ("Directory")); } find_files_model::~find_files_model () { } void find_files_model::clear () { beginResetModel(); _files.clear(); endResetModel (); } void find_files_model::addFile (const QFileInfo &info) { beginInsertRows(QModelIndex(), _files.size(), _files.size() ); _files.append(info); endInsertRows(); } int find_files_model::rowCount (const QModelIndex & p) const { return _files.size(); } int find_files_model::columnCount (const QModelIndex & p) const { return _columnNames.size (); } QVariant find_files_model::data (const QModelIndex& idx, int role) const { QVariant retval; if (idx.isValid ()) { if(role == Qt::DisplayRole) { switch (idx.column ()) { case 0: retval = QVariant (_files[idx.row()].fileName()); break; case 1: retval = QVariant (_files[idx.row()].absolutePath()); break; default: break; } } else if(role == Qt:: DecorationRole) { switch (idx.column()) { case 0: retval = fileIcon(idx); default: break; } } } return retval; } QVariant find_files_model::headerData (int section, Qt::Orientation orientation, int role) const { if (orientation == Qt::Horizontal && role == Qt::DisplayRole) return _columnNames[section]; else return QVariant (); } QFileInfo find_files_model::fileInfo (const QModelIndex & p) const { if(p.isValid ()) { return _files[p.row()]; } return QFileInfo (); } QIcon find_files_model::fileIcon (const QModelIndex &p) const { QFileIconProvider icon_provider; if(p.isValid ()) { return icon_provider.icon (_files[p.row()]); } return QIcon (); }