/**************************************************************************** ** ** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies). ** Contact: http://www.qt-project.org/legal ** ** This file is part of the QtWidgets module of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL$ ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and Digia. For licensing terms and ** conditions see http://qt.digia.com/licensing. For further information ** use the contact form at http://qt.digia.com/contact-us. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 2.1 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPL included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 2.1 requirements ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. ** ** In addition, as a special exception, Digia gives you certain additional ** rights. These rights are described in the Digia Qt LGPL Exception ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3.0 as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL included in the ** packaging of this file. Please review the following information to ** ensure the GNU General Public License version 3.0 requirements will be ** met: http://www.gnu.org/copyleft/gpl.html. ** ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #ifndef QFILEINFOGATHERER_H #define QFILEINFOGATHERER_H // // W A R N I N G // ------------- // // This file is not part of the Qt API. It exists purely as an // implementation detail. This header file may change from version to // version without notice, or even be removed. // // We mean it. // #include #include #include #include #include #include #include #include #include #include #include QT_BEGIN_NAMESPACE class QExtendedInformation { public: enum Type { Dir, File, System }; QExtendedInformation() {} QExtendedInformation(const QFileInfo &info) : mFileInfo(info) {} inline bool isDir() { return type() == Dir; } inline bool isFile() { return type() == File; } inline bool isSystem() { return type() == System; } bool operator ==(const QExtendedInformation &fileInfo) const { return mFileInfo == fileInfo.mFileInfo && displayType == fileInfo.displayType && permissions() == fileInfo.permissions(); } #ifndef QT_NO_FSFILEENGINE bool isCaseSensitive() const { return QFileSystemEngine::isCaseSensitive(); } #endif QFile::Permissions permissions() const { return mFileInfo.permissions(); } Type type() const { if (mFileInfo.isDir()) { return QExtendedInformation::Dir; } if (mFileInfo.isFile()) { return QExtendedInformation::File; } if (!mFileInfo.exists() && mFileInfo.isSymLink()) { return QExtendedInformation::System; } return QExtendedInformation::System; } bool isSymLink(bool ignoreNtfsSymLinks = false) const { if (ignoreNtfsSymLinks) { #ifdef Q_OS_WIN return !mFileInfo.suffix().compare(QLatin1String("lnk"), Qt::CaseInsensitive); #endif } return mFileInfo.isSymLink(); } bool isHidden() const { return mFileInfo.isHidden(); } QFileInfo fileInfo() const { return mFileInfo; } QDateTime lastModified() const { return mFileInfo.lastModified(); } qint64 size() const { qint64 size = -1; if (type() == QExtendedInformation::Dir) size = 0; if (type() == QExtendedInformation::File) size = mFileInfo.size(); if (!mFileInfo.exists() && !mFileInfo.isSymLink()) size = -1; return size; } QString displayType; QIcon icon; private : QFileInfo mFileInfo; }; class QFileIconProvider; #ifndef QT_NO_FILESYSTEMMODEL class Q_AUTOTEST_EXPORT QFileInfoGatherer : public QThread { Q_OBJECT Q_SIGNALS: void updates(const QString &directory, const QList > &updates); void newListOfFiles(const QString &directory, const QStringList &listOfFiles) const; void nameResolved(const QString &fileName, const QString &resolvedName) const; void directoryLoaded(const QString &path); public: explicit QFileInfoGatherer(QObject *parent = 0); ~QFileInfoGatherer(); // only callable from this->thread(): void clear(); void removePath(const QString &path); QExtendedInformation getInfo(const QFileInfo &info) const; QFileIconProvider *iconProvider() const; bool resolveSymlinks() const; public Q_SLOTS: void list(const QString &directoryPath); void fetchExtendedInformation(const QString &path, const QStringList &files); void updateFile(const QString &path); void setResolveSymlinks(bool enable); void setIconProvider(QFileIconProvider *provider); private: void run() Q_DECL_OVERRIDE; // called by run(): void getFileInfos(const QString &path, const QStringList &files); void fetch(const QFileInfo &info, QElapsedTimer &base, bool &firstTime, QList > &updatedFiles, const QString &path); private: mutable QMutex mutex; // begin protected by mutex QWaitCondition condition; QStack path; QStack files; // end protected by mutex QAtomicInt abort; #ifndef QT_NO_FILESYSTEMWATCHER QFileSystemWatcher *watcher; #endif #ifdef Q_OS_WIN bool m_resolveSymlinks; // not accessed by run() #endif QFileIconProvider *m_iconProvider; // not accessed by run() QFileIconProvider defaultProvider; }; #endif // QT_NO_FILESYSTEMMODEL QT_END_NAMESPACE #endif // QFILEINFOGATHERER_H