summaryrefslogtreecommitdiff
path: root/libopie2
Unidiff
Diffstat (limited to 'libopie2') (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiecore/ofilenotify.h1
1 files changed, 1 insertions, 0 deletions
diff --git a/libopie2/opiecore/ofilenotify.h b/libopie2/opiecore/ofilenotify.h
index bd2f9d0..d820f7c 100644
--- a/libopie2/opiecore/ofilenotify.h
+++ b/libopie2/opiecore/ofilenotify.h
@@ -1,189 +1,190 @@
1/* 1/*
2                This file is part of the Opie Project 2                This file is part of the Opie Project
3 =. Copyright (C) 2004 Michael 'Mickey' Lauer <mickey@Vanille.de> 3 =. Copyright (C) 2004 Michael 'Mickey' Lauer <mickey@Vanille.de>
4 .=l. Copyright (C) The Opie Team <opie-devel@handhelds.org> 4 .=l. Copyright (C) The Opie Team <opie-devel@handhelds.org>
5          .>+-= 5          .>+-=
6_;:,     .>    :=|. This program is free software; you can 6_;:,     .>    :=|. This program is free software; you can
7.> <`_,   >  .   <= redistribute it and/or modify it under 7.> <`_,   >  .   <= redistribute it and/or modify it under
8:`=1 )Y*s>-.--   : the terms of the GNU Library General Public 8:`=1 )Y*s>-.--   : the terms of the GNU Library General Public
9.="- .-=="i,     .._ License as published by the Free Software 9.="- .-=="i,     .._ License as published by the Free Software
10- .   .-<_>     .<> Foundation; either version 2 of the License, 10- .   .-<_>     .<> Foundation; either version 2 of the License,
11    ._= =}       : or (at your option) any later version. 11    ._= =}       : or (at your option) any later version.
12   .%`+i>       _;_. 12   .%`+i>       _;_.
13   .i_,=:_.      -<s. This program is distributed in the hope that 13   .i_,=:_.      -<s. This program is distributed in the hope that
14    +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY; 14    +  .  -:.       = it will be useful, but WITHOUT ANY WARRANTY;
15   : ..    .:,     . . . without even the implied warranty of 15   : ..    .:,     . . . without even the implied warranty of
16   =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A 16   =_        +     =;=|` MERCHANTABILITY or FITNESS FOR A
17 _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU 17 _.=:.       :    :=>`: PARTICULAR PURPOSE. See the GNU
18..}^=.=       =       ; Library General Public License for more 18..}^=.=       =       ; Library General Public License for more
19++=   -.     .`     .: details. 19++=   -.     .`     .: details.
20:     =  ...= . :.=- 20:     =  ...= . :.=-
21-.   .:....=;==+<; You should have received a copy of the GNU 21-.   .:....=;==+<; You should have received a copy of the GNU
22 -_. . .   )=.  = Library General Public License along with 22 -_. . .   )=.  = Library General Public License along with
23   --        :-=` this library; see the file COPYING.LIB. 23   --        :-=` this library; see the file COPYING.LIB.
24 If not, write to the Free Software Foundation, 24 If not, write to the Free Software Foundation,
25 Inc., 59 Temple Place - Suite 330, 25 Inc., 59 Temple Place - Suite 330,
26 Boston, MA 02111-1307, USA. 26 Boston, MA 02111-1307, USA.
27*/ 27*/
28 28
29#ifndef OFILENOTIFY_H 29#ifndef OFILENOTIFY_H
30#define OFILENOTIFY_H 30#define OFILENOTIFY_H
31#if defined (__GNUC__) && (__GNUC__ < 3) 31#if defined (__GNUC__) && (__GNUC__ < 3)
32#define _GNU_SOURCE 32#define _GNU_SOURCE
33#endif 33#endif
34 34
35/* QT */ 35/* QT */
36#include <qobject.h> 36#include <qobject.h>
37#include <qsignal.h> 37#include <qsignal.h>
38#include <qstring.h> 38#include <qstring.h>
39 39
40/* STD */ 40/* STD */
41#include <signal.h> 41#include <signal.h>
42#include <fcntl.h> 42#include <fcntl.h>
43 43
44namespace Opie { 44namespace Opie {
45namespace Core { 45namespace Core {
46 46
47/*====================================================================================== 47/*======================================================================================
48 * OFileNotificationType 48 * OFileNotificationType
49 *======================================================================================*/ 49 *======================================================================================*/
50 50
51/** 51/**
52 * @brief An enumerate for the different types of file notifications 52 * @brief An enumerate for the different types of file notifications
53 * 53 *
54 * This enumerate provides a means to specify the type of events that you are interest in. 54 * This enumerate provides a means to specify the type of events that you are interest in.
55 * Valid values are: 55 * Valid values are:
56 * <ul> 56 * <ul>
57 * <li>Access: The file was accessed (read) 57 * <li>Access: The file was accessed (read)
58 * <li>Modify The file was modified (write,truncate) 58 * <li>Modify The file was modified (write,truncate)
59 * <li>Create = The file was created in the directory 59 * <li>Create = The file was created in the directory
60 * <li>Delete = The file was unlinked from directory 60 * <li>Delete = The file was unlinked from directory
61 * <li>Rename = The file was renamed 61 * <li>Rename = The file was renamed
62 * <li>Attrib = The file had its attributes changed (chmod,chown,chgrp) 62 * <li>Attrib = The file had its attributes changed (chmod,chown,chgrp)
63 * </ul> 63 * </ul>
64 * 64 *
65 **/ 65 **/
66 66
67enum OFileNotificationType { Single = 0x0000000, 67enum OFileNotificationType { Single = 0x0000000,
68 Multi = DN_MULTISHOT, 68 Multi = DN_MULTISHOT,
69 Access = DN_ACCESS, 69 Access = DN_ACCESS,
70 Modify = DN_MODIFY, 70 Modify = DN_MODIFY,
71 Create = DN_CREATE, 71 Create = DN_CREATE,
72 Delete = DN_DELETE, 72 Delete = DN_DELETE,
73 Rename = DN_RENAME, 73 Rename = DN_RENAME,
74 Attrib = DN_ATTRIB }; 74 Attrib = DN_ATTRIB };
75 75
76/*====================================================================================== 76/*======================================================================================
77 * OFileNotification 77 * OFileNotification
78 *======================================================================================*/ 78 *======================================================================================*/
79 79
80/** 80/**
81 * @brief Represents a file notification 81 * @brief Represents a file notification
82 * 82 *
83 * This class allows to watch for events happening to files. 83 * This class allows to watch for events happening to files.
84 * It uses the dnotify kernel interface which is a very efficient signalling interface. 84 * It uses the dnotify kernel interface which is a very efficient signalling interface.
85 * 85 *
86 * @see <file:///usr/src/linux/Documentation/dnotify.txt> 86 * @see <file:///usr/src/linux/Documentation/dnotify.txt>
87 * 87 *
88 * @author Michael 'Mickey' Lauer <mickey@vanille.de> 88 * @author Michael 'Mickey' Lauer <mickey@vanille.de>
89 * 89 *
90 **/ 90 **/
91 91
92class OFileNotification : public QObject 92class OFileNotification : public QObject
93{ 93{
94 Q_OBJECT 94 Q_OBJECT
95 95
96 public: 96 public:
97 OFileNotification( QObject* parent = 0, const char* name = 0 ); 97 OFileNotification( QObject* parent = 0, const char* name = 0 );
98 ~OFileNotification(); 98 ~OFileNotification();
99 /** 99 /**
100 * This static function calls a slot when an event with @a type happens to file @a path. 100 * This static function calls a slot when an event with @a type happens to file @a path.
101 * 101 *
102 * It is very convenient to use this function because you do not need to 102 * It is very convenient to use this function because you do not need to
103 * bother with a timerEvent or to create a local QTimer object. 103 * bother with a timerEvent or to create a local QTimer object.
104 * 104 *
105 * Example: 105 * Example:
106 * <pre> 106 * <pre>
107 * 107 *
108 * #include <opie2/oapplication.h> 108 * #include <opie2/oapplication.h>
109 * #include <opie2/onitify.h> 109 * #include <opie2/onitify.h>
110 * using namespace Opie::Core; 110 * using namespace Opie::Core;
111 * 111 *
112 * int main( int argc, char **argv ) 112 * int main( int argc, char **argv )
113 * { 113 * {
114 * OApplication a( argc, argv, "File Notification Example" ); 114 * OApplication a( argc, argv, "File Notification Example" );
115 * OFileNotification::singleShot( "/tmp/quit", &a, SLOT(quit()), Create ); 115 * OFileNotification::singleShot( "/tmp/quit", &a, SLOT(quit()), Create );
116 * ... // create and show your widgets 116 * ... // create and show your widgets
117 * return a.exec(); 117 * return a.exec();
118 * } 118 * }
119 * </pre>
119 * 120 *
120 * This sample program automatically terminates when the file "/tmp/quite" has been created. 121 * This sample program automatically terminates when the file "/tmp/quite" has been created.
121 * 122 *
122 * 123 *
123 * The @a receiver is the receiving object and the @a member is the slot. 124 * The @a receiver is the receiving object and the @a member is the slot.
124 **/ 125 **/
125 static void singleShot( const QString& path, QObject* receiver, const char* member, OFileNotificationType type = Modify ); 126 static void singleShot( const QString& path, QObject* receiver, const char* member, OFileNotificationType type = Modify );
126 /** 127 /**
127 * Starts to watch for @a type changes to @a path. Set @a sshot to True if you want to be notified only once. 128 * Starts to watch for @a type changes to @a path. Set @a sshot to True if you want to be notified only once.
128 * Note that in that case it may be more convenient to use @ref OFileNotification::singleShot() then. 129 * Note that in that case it may be more convenient to use @ref OFileNotification::singleShot() then.
129 **/ 130 **/
130 int start( const QString& path, bool sshot = false, OFileNotificationType type = Modify ); 131 int start( const QString& path, bool sshot = false, OFileNotificationType type = Modify );
131 /** 132 /**
132 * Stop watching for file events. 133 * Stop watching for file events.
133 **/ 134 **/
134 void stop(); 135 void stop();
135 /** 136 /**
136 * @returns the notification type as set by @ref start(). 137 * @returns the notification type as set by @ref start().
137 **/ 138 **/
138 OFileNotificationType type() const; 139 OFileNotificationType type() const;
139 /** 140 /**
140 * @returns the path to the file being watched by this instance. 141 * @returns the path to the file being watched by this instance.
141 **/ 142 **/
142 QString path() const; 143 QString path() const;
143 /** 144 /**
144 * @returns the UNIX file descriptor for the file being watched. 145 * @returns the UNIX file descriptor for the file being watched.
145 **/ 146 **/
146 int fileno() const; 147 int fileno() const;
147 /** 148 /**
148 * @returns if a file is currently being watched. 149 * @returns if a file is currently being watched.
149 **/ 150 **/
150 bool isActive() const; 151 bool isActive() const;
151 152
152 signals: 153 signals:
153 /** 154 /**
154 * This signal is emitted if an event happens of the specified type happens to the file being watched. 155 * This signal is emitted if an event happens of the specified type happens to the file being watched.
155 **/ 156 **/
156 void triggered(); 157 void triggered();
157 158
158 protected: 159 protected:
159 bool activate(); 160 bool activate();
160 virtual bool hasChanged(); 161 virtual bool hasChanged();
161 static bool registerSignalHandler(); 162 static bool registerSignalHandler();
162 static void unregisterSignalHandler(); 163 static void unregisterSignalHandler();
163 static void __signalHandler( int sig, siginfo_t *si, void *data ); 164 static void __signalHandler( int sig, siginfo_t *si, void *data );
164 165
165 private: 166 private:
166 QString _path; 167 QString _path;
167 OFileNotificationType _type; 168 OFileNotificationType _type;
168 QSignal _signal; 169 QSignal _signal;
169 int _fd; 170 int _fd;
170 bool _active; 171 bool _active;
171 struct stat _stat; 172 struct stat _stat;
172}; 173};
173 174
174#if 0 175#if 0
175 176
176class ODirectoryNotification : public OFileNotification 177class ODirectoryNotification : public OFileNotification
177{ 178{
178 179
179 public: 180 public:
180 virtual bool hasChanged() { return true; }; 181 virtual bool hasChanged() { return true; };
181}; 182};
182 183
183#endif 184#endif
184 185
185} 186}
186} 187}
187 188
188#endif 189#endif
189 190