forked from mstone/vscan
-
Notifications
You must be signed in to change notification settings - Fork 0
/
stream_traversal.h
68 lines (51 loc) · 2.02 KB
/
stream_traversal.h
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
/* Copyright (c) 2011 Akamai Technologies, Inc. */
class StreamTraversal : public Traversal
{
public:
StreamTraversal();
virtual ~StreamTraversal();
int Init(Counter* counter,
struct path_dir_pair root,
const Decider* decider,
Scanner* scanner) WARN_RET;
int go(bool* done) WARN_RET;
int dbg_print_current_path(const char* msg, const char* frag) const;
int get_quoted_path(void* traversal_datum, string* qpath) const WARN_RET;
protected:
virtual int get_next_dirent(int* dfd, struct dirent** dip) WARN_RET;
virtual int go_dir(int dfd,
const struct dirent& di,
int fd,
const struct stat& st) WARN_RET;
virtual int go_reg(int dfd,
const struct dirent& di,
int fd,
const struct stat& st) WARN_RET;
virtual int go_lnk(int dfd, const struct dirent& di) WARN_RET;
/* The path we were given in Init(); used for printing summary stats. */
string root_path_;
/* A stack of DIR*s and path fragments which we're currently
traversing. The front of the list is the top of the stack.
Our traversal will be done when worklist_ is empty. */
list<struct path_dir_pair> worklist_;
/* sensors_ lets us figure out which sensor(s) caused a given hit.
Presently, we act based on the first sensor able to explain a given
hit. sensors_ also records per-sensor hit frequencies during our
traversal. */
list<struct sensor>* sensors_;
/* decider_ is used to figure out which paths we actually want to scan
based on a dirent's name and its inode's stat data. */
const Decider* decider_;
/* prev_dir_ is used by get_next_dirent() to figure out when we need to
fchdir() to a new directory.
TODO(mistone): remove prev_dir_ in favor of iopen() or openat(). */
DIR* prev_dir_;
/* counter_ records statistics about how many directories and files
we've visited and/or scanned. */
Counter* counter_;
/* We hand scanner_ over to the Scannables we construc in order to
perform whatever actual scanning or capture was requested. */
Scanner* scanner_;
private:
DISALLOW_COPY_AND_ASSIGN(StreamTraversal);
};