You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
117 lines
3.9 KiB
117 lines
3.9 KiB
10 years ago
|
/* Copyright © 2005-2007 Fredrik Höglund <fredrik@kde.org>
|
||
|
* (c)GPL2 (c)GPL3
|
||
|
*
|
||
|
* This program is free software; you can redistribute it and/or
|
||
|
* modify it under the terms of the GNU General Public
|
||
|
* License version 2 or at your option version 3 as published
|
||
|
* by the Free Software Foundation.
|
||
|
*
|
||
|
* 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; see the file COPYING. If not, write to
|
||
|
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
||
|
* Boston, MA 02110-1301, USA.
|
||
|
*/
|
||
|
/*
|
||
|
* additional code: Ketmar // Vampire Avalon (psyc://ketmar.no-ip.org/~Ketmar)
|
||
|
*/
|
||
|
#ifndef THEMEMODEL_H
|
||
|
#define THEMEMODEL_H
|
||
|
|
||
|
#include <QAbstractTableModel>
|
||
|
#include <QStringList>
|
||
|
|
||
|
class QDir;
|
||
|
class XCursorThemeData;
|
||
|
|
||
|
|
||
|
// The two TableView/TreeView columns provided by the model
|
||
|
enum Columns { NameColumn = 0, DescColumn };
|
||
|
|
||
|
|
||
|
/**
|
||
|
* The XCursorThemeModel class provides a model for all locally installed
|
||
|
* Xcursor themes, and the KDE/Qt legacy bitmap theme.
|
||
|
*
|
||
|
* This class automatically scans the locations in the file system from
|
||
|
* which Xcursor loads cursors, and creates an internal list of all
|
||
|
* available cursor themes.
|
||
|
*
|
||
|
* The model provides this theme list to item views in the form of a list
|
||
|
* of rows with two columns; the first column has the theme's descriptive
|
||
|
* name and its sample cursor as its icon, and the second column contains
|
||
|
* the theme's description.
|
||
|
*
|
||
|
* Additional Xcursor themes can be added to a model after it's been
|
||
|
* created, by calling addTheme(), which takes QDir as a parameter,
|
||
|
* with the themes location. The intention is for this function to be
|
||
|
* called when a new Xcursor theme has been installed, after the model
|
||
|
* was instantiated.
|
||
|
*
|
||
|
* The KDE legacy theme is a read-only entry, with the descriptive name
|
||
|
* "KDE Classic", and the internal name "#kde_legacy#".
|
||
|
*
|
||
|
* Calling defaultIndex() will return the index of the theme Xcursor
|
||
|
* will use if the user hasn't explicitly configured a cursor theme.
|
||
|
*/
|
||
|
class XCursorThemeModel : public QAbstractTableModel
|
||
|
{
|
||
|
Q_OBJECT
|
||
|
|
||
|
public:
|
||
|
XCursorThemeModel (QObject *parent = 0);
|
||
|
~XCursorThemeModel ();
|
||
|
|
||
|
inline int columnCount (const QModelIndex &parent = QModelIndex()) const;
|
||
|
inline int rowCount (const QModelIndex &parent = QModelIndex()) const;
|
||
|
QVariant headerData (int section, Qt::Orientation orientation, int role) const;
|
||
|
QVariant data (const QModelIndex &index, int role) const;
|
||
|
void sort (int column, Qt::SortOrder order = Qt::AscendingOrder);
|
||
|
|
||
|
/// Returns the CursorTheme at @p index.
|
||
|
const XCursorThemeData *theme (const QModelIndex &index);
|
||
|
|
||
|
/// Returns the index for the CursorTheme with the internal name @p name,
|
||
|
/// or an invalid index if no matching theme can be found.
|
||
|
QModelIndex findIndex (const QString &name);
|
||
|
|
||
|
/// Returns the index for the default theme.
|
||
|
QModelIndex defaultIndex ();
|
||
|
|
||
|
/// Adds the theme in @p dir, and returns @a true if successful or @a false otherwise.
|
||
|
bool addTheme (const QDir &dir);
|
||
|
void removeTheme (const QModelIndex &index);
|
||
|
|
||
|
/// Returns the list of base dirs Xcursor looks for themes in.
|
||
|
const QStringList searchPaths ();
|
||
|
|
||
|
private:
|
||
|
bool handleDefault (const QDir &dir);
|
||
|
void processThemeDir (const QDir &dir);
|
||
|
void insertThemes ();
|
||
|
bool hasTheme (const QString &theme) const;
|
||
|
bool isCursorTheme (const QString &theme, const int depth = 0);
|
||
|
|
||
|
private:
|
||
|
QList<XCursorThemeData *>mList;
|
||
|
QStringList mBaseDirs;
|
||
|
QString mDefaultName;
|
||
|
};
|
||
|
|
||
|
int XCursorThemeModel::rowCount (const QModelIndex &) const
|
||
|
{
|
||
|
return mList.count();
|
||
|
}
|
||
|
|
||
|
|
||
|
int XCursorThemeModel::columnCount (const QModelIndex &) const
|
||
|
{
|
||
|
return 2;
|
||
|
}
|
||
|
|
||
|
#endif
|