aboutsummaryrefslogtreecommitdiff
path: root/Foundation/GTMFileSystemKQueue.h
blob: a8291540c7755d9ba2200fb03ec1789d11e7e736 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
//
//  GTMFileSystemKQueue.h
//
//  Copyright 2008 Google Inc.
//
//  Licensed under the Apache License, Version 2.0 (the "License"); you may not
//  use this file except in compliance with the License.  You may obtain a copy
//  of the License at
//
//  http://www.apache.org/licenses/LICENSE-2.0
//
//  Unless required by applicable law or agreed to in writing, software
//  distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
//  WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the
//  License for the specific language governing permissions and limitations under
//  the License.
//

#import <Foundation/Foundation.h>
#import "GTMDefines.h"

#import <sys/event.h>  // for kqueue() and kevent and the NOTE_* constants

//  Event constants
enum {
  kGTMFileSystemKQueueDeleteEvent = NOTE_DELETE,
  kGTMFileSystemKQueueWriteEvent = NOTE_WRITE,
  kGTMFileSystemKQueueExtendEvent = NOTE_EXTEND,
  kGTMFileSystemKQueueAttributeChangeEvent = NOTE_ATTRIB,
  kGTMFileSystemKQueueLinkChangeEvent = NOTE_LINK,
  kGTMFileSystemKQueueRenameEvent = NOTE_RENAME,
  kGTMFileSystemKQueueRevokeEvent = NOTE_REVOKE,
  kGTMFileSystemKQueueAllEvents = NOTE_DELETE | NOTE_WRITE | NOTE_EXTEND |
                                  NOTE_ATTRIB | NOTE_LINK | NOTE_RENAME |
                                  NOTE_REVOKE,
};
typedef unsigned int GTMFileSystemKQueueEvents;

// GTMFileSystemKQueue.
//
// This is a very simple, easy-to-use class for registering handlers that get
// called when a events happen to a given file system path.
//
// The default runloop for the first path kqueued is used for notification
// delivery, so keep that in mind when you're using this class.  This class
// explicitly does not handle arbitrary runloops and threading.
//
@interface GTMFileSystemKQueue : NSObject {
 @private
  NSString *path_;
  int fd_;
  GTMFileSystemKQueueEvents events_;
  BOOL acrossReplace_;
  GTM_WEAK id target_;
  SEL action_;
}

// |path| is the full path to monitor.  |events| is a combination of events
// listed above that you want notification of.  |acrossReplace| will cause this
// object to reattach when a the file is deleted & recreated or moved out of the
// way and a new one put in place.  |selector| should be of the signature:
//    - (void)fileSystemKQueue:(GTMFileSystemKQueue *)fskq
//                      events:(GTMFileSystemKQueueEvents)events;
// where the events can be one or more of the events listed above ORed together.
//
// NOTE: |acrossReplace| is not fool proof.  If the file is renamed/deleted,
// then the object will make one attempt at the time it gets the rename/delete
// to reopen the file.  If the new file has not been created, no more action is
// taken.  To handle the file coming into existance later, you need to monitor
// the directory in some other way.
- (id)initWithPath:(NSString *)path
         forEvents:(GTMFileSystemKQueueEvents)events
     acrossReplace:(BOOL)acrossReplace
            target:(id)target
            action:(SEL)action;

- (NSString *)path;

@end