source: trunk/src/gui/itemviews/qdirmodel.h@ 269

Last change on this file since 269 was 2, checked in by Dmitry A. Kuminov, 16 years ago

Initially imported qt-all-opensource-src-4.5.1 from Trolltech.

File size: 5.4 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
4** Contact: Qt Software Information (qt-info@nokia.com)
5**
6** This file is part of the QtGui module of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial Usage
10** Licensees holding valid Qt Commercial licenses may use this file in
11** accordance with the Qt Commercial License Agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and Nokia.
14**
15** GNU Lesser General Public License Usage
16** Alternatively, this file may be used under the terms of the GNU Lesser
17** General Public License version 2.1 as published by the Free Software
18** Foundation and appearing in the file LICENSE.LGPL included in the
19** packaging of this file. Please review the following information to
20** ensure the GNU Lesser General Public License version 2.1 requirements
21** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
22**
23** In addition, as a special exception, Nokia gives you certain
24** additional rights. These rights are described in the Nokia Qt LGPL
25** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
26** package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you are unsure which license is appropriate for your use, please
37** contact the sales department at qt-sales@nokia.com.
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42#ifndef QDIRMODEL_H
43#define QDIRMODEL_H
44
45#include <QtCore/qabstractitemmodel.h>
46#include <QtCore/qdir.h>
47#include <QtGui/qfileiconprovider.h>
48
49QT_BEGIN_HEADER
50
51QT_BEGIN_NAMESPACE
52
53QT_MODULE(Gui)
54
55#ifndef QT_NO_DIRMODEL
56
57class QDirModelPrivate;
58
59class Q_GUI_EXPORT QDirModel : public QAbstractItemModel
60{
61 Q_OBJECT
62 Q_PROPERTY(bool resolveSymlinks READ resolveSymlinks WRITE setResolveSymlinks)
63 Q_PROPERTY(bool readOnly READ isReadOnly WRITE setReadOnly)
64 Q_PROPERTY(bool lazyChildCount READ lazyChildCount WRITE setLazyChildCount)
65
66public:
67 enum Roles {
68 FileIconRole = Qt::DecorationRole,
69 FilePathRole = Qt::UserRole + 1,
70 FileNameRole
71 };
72
73 QDirModel(const QStringList &nameFilters, QDir::Filters filters,
74 QDir::SortFlags sort, QObject *parent = 0);
75 explicit QDirModel(QObject *parent = 0);
76 ~QDirModel();
77
78 QModelIndex index(int row, int column, const QModelIndex &parent = QModelIndex()) const;
79 QModelIndex parent(const QModelIndex &child) const;
80
81 int rowCount(const QModelIndex &parent = QModelIndex()) const;
82 int columnCount(const QModelIndex &parent = QModelIndex()) const;
83
84 QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const;
85 bool setData(const QModelIndex &index, const QVariant &value, int role = Qt::EditRole);
86
87 QVariant headerData(int section, Qt::Orientation orientation, int role = Qt::DisplayRole) const;
88
89 bool hasChildren(const QModelIndex &index = QModelIndex()) const;
90 Qt::ItemFlags flags(const QModelIndex &index) const;
91
92 void sort(int column, Qt::SortOrder order = Qt::AscendingOrder);
93
94 QStringList mimeTypes() const;
95 QMimeData *mimeData(const QModelIndexList &indexes) const;
96 bool dropMimeData(const QMimeData *data, Qt::DropAction action,
97 int row, int column, const QModelIndex &parent);
98 Qt::DropActions supportedDropActions() const;
99
100 // QDirModel specific API
101
102 void setIconProvider(QFileIconProvider *provider);
103 QFileIconProvider *iconProvider() const;
104
105 void setNameFilters(const QStringList &filters);
106 QStringList nameFilters() const;
107
108 void setFilter(QDir::Filters filters);
109 QDir::Filters filter() const;
110
111 void setSorting(QDir::SortFlags sort);
112 QDir::SortFlags sorting() const;
113
114 void setResolveSymlinks(bool enable);
115 bool resolveSymlinks() const;
116
117 void setReadOnly(bool enable);
118 bool isReadOnly() const;
119
120 void setLazyChildCount(bool enable);
121 bool lazyChildCount() const;
122
123 QModelIndex index(const QString &path, int column = 0) const;
124
125 bool isDir(const QModelIndex &index) const;
126 QModelIndex mkdir(const QModelIndex &parent, const QString &name);
127 bool rmdir(const QModelIndex &index);
128 bool remove(const QModelIndex &index);
129
130 QString filePath(const QModelIndex &index) const;
131 QString fileName(const QModelIndex &index) const;
132 QIcon fileIcon(const QModelIndex &index) const;
133 QFileInfo fileInfo(const QModelIndex &index) const;
134
135#ifdef Q_NO_USING_KEYWORD
136 inline QObject *parent() const { return QObject::parent(); }
137#else
138 using QObject::parent;
139#endif
140
141public Q_SLOTS:
142 void refresh(const QModelIndex &parent = QModelIndex());
143
144protected:
145 QDirModel(QDirModelPrivate &, QObject *parent = 0);
146 friend class QFileDialogPrivate;
147
148private:
149 Q_DECLARE_PRIVATE(QDirModel)
150 Q_DISABLE_COPY(QDirModel)
151 Q_PRIVATE_SLOT(d_func(), void _q_refresh())
152};
153
154#endif // QT_NO_DIRMODEL
155
156QT_END_NAMESPACE
157
158QT_END_HEADER
159
160#endif // QDIRMODEL_H
Note: See TracBrowser for help on using the repository browser.