Files
qt-creator/src/plugins/coreplugin/filemanager.h

176 lines
5.7 KiB
C
Raw Normal View History

/**************************************************************************
2008-12-02 12:01:29 +01:00
**
** This file is part of Qt Creator
**
2010-03-05 11:25:49 +01:00
** Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
2008-12-02 12:01:29 +01:00
**
** Contact: Nokia Corporation (qt-info@nokia.com)
2008-12-02 12:01:29 +01:00
**
** Commercial Usage
**
** Licensees holding valid Qt Commercial licenses may use this file in
** accordance with the Qt Commercial License Agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and Nokia.
**
** 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.
**
** If you are unsure which license is appropriate for your use, please
2009-08-14 09:30:56 +02:00
** contact the sales department at http://qt.nokia.com/contact.
2008-12-02 12:01:29 +01:00
**
**************************************************************************/
2008-12-02 14:09:21 +01:00
2008-12-02 12:01:29 +01:00
#ifndef FILEMANAGER_H
#define FILEMANAGER_H
#include <coreplugin/core_global.h>
#include <QtCore/QObject>
#include <QtCore/QStringList>
QT_BEGIN_NAMESPACE
class QMainWindow;
2008-12-02 12:01:29 +01:00
QT_END_NAMESPACE
namespace Core {
class ICore;
class IContext;
class IFile;
namespace Internal {
struct FileManagerPrivate;
2008-12-02 12:01:29 +01:00
}
class CORE_EXPORT FileManager : public QObject
{
Q_OBJECT
public:
enum FixMode {
ResolveLinks,
KeepLinks
};
explicit FileManager(QMainWindow *ew);
virtual ~FileManager();
2008-12-02 12:01:29 +01:00
// file pool to monitor
2010-11-18 18:11:15 +01:00
void addFiles(const QList<IFile *> &files, bool addWatcher = true);
void addFile(IFile *file, bool addWatcher = true);
void removeFile(IFile *file);
2008-12-02 12:01:29 +01:00
QList<IFile *> modifiedFiles() const;
void renamedFile(const QString &from, QString &to);
2008-12-02 12:01:29 +01:00
void blockFileChange(IFile *file);
void unblockFileChange(IFile *file);
void expectFileChange(const QString &fileName);
void unexpectFileChange(const QString &fileName);
2008-12-02 12:01:29 +01:00
// recent files
void addToRecentFiles(const QString &fileName);
QStringList recentFiles() const;
void saveSettings();
2008-12-02 12:01:29 +01:00
// current file
void setCurrentFile(const QString &filePath);
QString currentFile() const;
// helper methods
static QString fixFileName(const QString &fileName, FixMode fixmode);
2008-12-02 12:01:29 +01:00
QStringList getOpenFileNames(const QString &filters,
const QString path = QString(),
QString *selectedFilter = 0);
QString getSaveFileName(const QString &title, const QString &pathIn,
const QString &filter = QString(), QString *selectedFilter = 0);
QString getSaveFileNameWithExtension(const QString &title, const QString &pathIn,
const QString &filter);
QString getSaveAsFileName(IFile *file, const QString &filter = QString(),
QString *selectedFilter = 0);
2008-12-02 12:01:29 +01:00
QList<IFile *> saveModifiedFilesSilently(const QList<IFile *> &files);
2009-01-20 17:14:00 +01:00
QList<IFile *> saveModifiedFiles(const QList<IFile *> &files,
bool *cancelled = 0,
const QString &message = QString(),
const QString &alwaysSaveMessage = QString::null,
bool *alwaysSave = 0);
2008-12-02 12:01:29 +01:00
QString fileDialogLastVisitedDirectory() const;
void setFileDialogLastVisitedDirectory(const QString &);
QString fileDialogInitialDirectory() const;
bool useProjectsDirectory() const;
void setUseProjectsDirectory(bool);
QString projectsDirectory() const;
void setProjectsDirectory(const QString &);
public slots:
/* Used to notify e.g. the code model to update the given files. Does *not*
lead to any editors to reload or any other editor manager actions. */
void notifyFilesChangedInternally(const QStringList &files);
2008-12-02 12:01:29 +01:00
signals:
void currentFileChanged(const QString &filePath);
/* Used to notify e.g. the code model to update the given files. Does *not*
lead to any editors to reload or any other editor manager actions. */
void filesChangedInternally(const QStringList &files);
2008-12-02 12:01:29 +01:00
private slots:
void fileDestroyed(QObject *obj);
void checkForNewFileName();
void checkForReload();
void changedFile(const QString &file);
void mainWindowActivated();
void syncWithEditor(Core::IContext *context);
private:
void readSettings();
void dump();
void addFileInfo(IFile *file);
void addFileInfo(const QString &fileName, IFile *file, bool isLink);
void removeFileInfo(IFile *file);
2008-12-02 12:01:29 +01:00
void updateFileInfo(IFile *file);
void updateExpectedState(const QString &fileName);
2008-12-02 12:01:29 +01:00
QList<IFile *> saveModifiedFiles(const QList<IFile *> &files,
bool *cancelled, bool silently,
const QString &message,
const QString &alwaysSaveMessage = QString::null,
bool *alwaysSave = 0);
2008-12-02 12:01:29 +01:00
Internal::FileManagerPrivate *d;
2008-12-02 12:01:29 +01:00
};
/*! The FileChangeBlocker blocks all change notifications to all IFile * that
match the given filename. And unblocks in the destructor.
To also reload the IFile in the destructor class set modifiedReload to true
*/
class CORE_EXPORT FileChangeBlocker
{
public:
explicit FileChangeBlocker(const QString &fileName);
~FileChangeBlocker();
private:
const QString m_fileName;
Q_DISABLE_COPY(FileChangeBlocker)
};
2008-12-02 12:01:29 +01:00
} // namespace Core
#endif // FILEMANAGER_H