1
/****************************************************************************
2
**
3
** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
4
** All rights reserved.
5
** Contact: Nokia Corporation (qt-info@nokia.com)
6
**
7
** This file is part of the QtCore module of the Qt Toolkit.
8
**
9
** $QT_BEGIN_LICENSE:LGPL$
10
** No Commercial Usage
11
** This file contains pre-release code and may not be distributed.
12
** You may use this file in accordance with the terms and conditions
13
** contained in the Technology Preview License Agreement accompanying
14
** this package.
15
**
16
** GNU Lesser General Public License Usage
17
** Alternatively, this file may be used under the terms of the GNU Lesser
18
** General Public License version 2.1 as published by the Free Software
19
** Foundation and appearing in the file LICENSE.LGPL included in the
20
** packaging of this file.  Please review the following information to
21
** ensure the GNU Lesser General Public License version 2.1 requirements
22
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
23
**
24
** In addition, as a special exception, Nokia gives you certain additional
25
** rights.  These rights are described in the Nokia Qt LGPL Exception
26
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
27
**
28
** If you have questions regarding the use of this file, please contact
29
** Nokia at qt-info@nokia.com.
30
**
31
**
32
**
33
**
34
**
35
**
36
**
37
**
38
** $QT_END_LICENSE$
39
**
40
****************************************************************************/
41
42
#ifndef QFILESYSTEMWATCHER_P_H
43
#define QFILESYSTEMWATCHER_P_H
44
45
//
46
//  W A R N I N G
47
//  -------------
48
//
49
// This file is not part of the Qt API.  It exists for the convenience
50
// of the QLibrary class.  This header file may change from
51
// version to version without notice, or even be removed.
52
//
53
// We mean it.
54
//
55
56
#include "qfilesystemwatcher.h"
57
58
#ifndef QT_NO_FILESYSTEMWATCHER
59
60
#include <private/qobject_p.h>
61
62
#include <QtCore/qstringlist.h>
63
#include <QtCore/qthread.h>
64
65
QT_BEGIN_NAMESPACE
66
67
class QFileSystemWatcherEngine : public QThread
68
{
69
    Q_OBJECT
70
71
protected:
72
    inline QFileSystemWatcherEngine()
73
    {
74
        moveToThread(this);
75
    }
76
77
public:
78
    // fills \a files and \a directires with the \a paths it could
79
    // watch, and returns a list of paths this engine could not watch
80
    virtual QStringList addPaths(const QStringList &paths,
81
                                 QStringList *files,
82
                                 QStringList *directories) = 0;
83
    // removes \a paths from \a files and \a directories, and returns
84
    // a list of paths this engine does not know about (either addPath
85
    // failed or wasn't called)
86
    virtual QStringList removePaths(const QStringList &paths,
87
                                    QStringList *files,
88
                                    QStringList *directories) = 0;
89
90
    virtual void stop() = 0;
91
92
Q_SIGNALS:
93
    void fileChanged(const QString &path, bool removed);
94
    void directoryChanged(const QString &path, bool removed);
95
};
96
97
class QFileSystemWatcherPrivate : public QObjectPrivate
98
{
99
    Q_DECLARE_PUBLIC(QFileSystemWatcher)
100
101
    static QFileSystemWatcherEngine *createNativeEngine();
102
103
public:
104
    QFileSystemWatcherPrivate();
105
    void init();
106
    void initPollerEngine();
107
    void initForcedEngine(const QString &);
108
109
    QFileSystemWatcherEngine *native, *poller, *forced;
110
    QStringList files, directories;
111
112
    // private slots
113
    void _q_fileChanged(const QString &path, bool removed);
114
    void _q_directoryChanged(const QString &path, bool removed);
115
};
116
117
118
QT_END_NAMESPACE
119
#endif // QT_NO_FILESYSTEMWATCHER
120
#endif // QFILESYSTEMWATCHER_P_H