1
/****************************************************************************
3
** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
4
** All rights reserved.
5
** Contact: Nokia Corporation (qt-info@nokia.com)
7
** This file is part of the QtCore module of the Qt Toolkit.
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
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.
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.
28
** If you have questions regarding the use of this file, please contact
29
** Nokia at qt-info@nokia.com.
40
****************************************************************************/
43
#ifndef FILEWATCHER_FSEVENTS_P_H
44
#define FILEWATCHER_FSEVENTS_P_H
50
// This file is not part of the Qt API. It exists for the convenience
51
// of the QLibrary class. This header file may change from
52
// version to version without notice, or even be removed.
57
#include "qfilesystemwatcher_p.h"
59
#include <QtCore/qmutex.h>
60
#include <QtCore/qwaitcondition.h>
61
#include <QtCore/qthread.h>
62
#include <QtCore/qhash.h>
63
#include <QtCore/qlinkedlist.h>
64
#include <private/qcore_mac_p.h>
67
typedef struct __FSEventStream *FSEventStreamRef;
68
typedef const struct __FSEventStream *ConstFSEventStreamRef;
69
typedef const struct __CFArray *CFArrayRef;
70
typedef UInt32 FSEventStreamEventFlags;
71
typedef uint64_t FSEventStreamEventId;
75
#if MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_5
76
// Yes, I use a stat64 element here. QFileInfo requires too much knowledge about implementation
77
// details to be used as a long-standing record. Since I'm going to have to store this information, I can
78
// do the stat myself too.
80
PathInfo(const QString &path, const QByteArray &absPath)
81
: originalPath(path), absolutePath(absPath) {}
82
QString originalPath; // The path we need to emit
83
QByteArray absolutePath; // The path we need to stat.
84
struct ::stat64 savedInfo; // All the info for the path so we can compare it.
86
typedef QLinkedList<PathInfo> PathInfoList;
87
typedef QHash<QString, PathInfoList> PathHash;
90
class QFSEventsFileSystemWatcherEngine : public QFileSystemWatcherEngine
94
~QFSEventsFileSystemWatcherEngine();
96
static QFSEventsFileSystemWatcherEngine *create();
98
QStringList addPaths(const QStringList &paths, QStringList *files, QStringList *directories);
99
QStringList removePaths(const QStringList &paths, QStringList *files, QStringList *directories);
104
QFSEventsFileSystemWatcherEngine();
105
void warmUpFSEvents();
108
static void fseventsCallback(ConstFSEventStreamRef streamRef, void *clientCallBackInfo, size_t numEvents,
109
void *eventPaths, const FSEventStreamEventFlags eventFlags[],
110
const FSEventStreamEventId eventIds[]);
112
FSEventStreamRef fsStream;
113
CFArrayRef pathsToWatch;
114
CFRunLoopRef threadsRunLoop;
116
QWaitCondition waitCondition;
117
QWaitCondition waitForStop;
118
#if MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_5
119
PathHash filePathInfoHash;
120
PathHash dirPathInfoHash;
121
void updateHash(PathHash &pathHash);
122
void updateList(PathInfoList &list, bool directory, bool emitSignals);