/* Copyright © 2005-2007 Fredrik Höglund * (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 #include 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: QListmList; QStringList mBaseDirs; QString mDefaultName; }; int XCursorThemeModel::rowCount (const QModelIndex &) const { return mList.count(); } int XCursorThemeModel::columnCount (const QModelIndex &) const { return 2; } #endif