fswatch 1.17.1
poll_monitor.hpp
Go to the documentation of this file.
1/*
2 * Copyright (c) 2014-2021 Enrico M. Crisostomo
3 *
4 * This program is free software; you can redistribute it and/or modify it under
5 * the terms of the GNU General Public License as published by the Free Software
6 * Foundation; either version 3, or (at your option) any later version.
7 *
8 * This program is distributed in the hope that it will be useful, but WITHOUT
9 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
10 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
11 * details.
12 *
13 * You should have received a copy of the GNU General Public License along with
14 * this program. If not, see <http://www.gnu.org/licenses/>.
15 */
26#ifndef FSW_POLL_MONITOR_H
27# define FSW_POLL_MONITOR_H
28
29# include "monitor.hpp"
30# include <sys/stat.h>
31# include <ctime>
32# include <memory>
33
34namespace fsw
35{
42 class poll_monitor : public monitor
43 {
44 public:
48 poll_monitor(std::vector<std::string> paths,
50 void *context = nullptr);
51
55 virtual ~poll_monitor();
56
57 protected:
58 void run();
59
60 private:
61 static const unsigned int MIN_POLL_LATENCY = 1;
62
63 poll_monitor(const poll_monitor& orig) = delete;
64 poll_monitor& operator=(const poll_monitor& that) = delete;
65
66 typedef bool (poll_monitor::*poll_monitor_scan_callback)(
67 const std::string& path,
68 const struct stat& stat);
69
70 typedef struct watched_file_info
71 {
72 time_t mtime;
73 time_t ctime;
74 } watched_file_info;
75
76 struct poll_monitor_data;
77
78 void scan(const std::string& path, poll_monitor_scan_callback fn);
79 void collect_initial_data();
80 void collect_data();
81 bool add_path(const std::string& path,
82 const struct stat& fd_stat,
83 poll_monitor_scan_callback poll_callback);
84 bool initial_scan_callback(const std::string& path, const struct stat& stat);
85 bool intermediate_scan_callback(const std::string& path,
86 const struct stat& stat);
87 void find_removed_files();
88 void swap_data_containers();
89
90 std::unique_ptr<poll_monitor_data> previous_data;
91 std::unique_ptr<poll_monitor_data> new_data;
92
93 std::vector<event> events;
94 time_t curr_time;
95 };
96}
97
98#endif /* FSW_POLL_MONITOR_H */
Base class of all monitors.
Definition: monitor.hpp:148
std::vector< std::string > paths
List of paths to watch.
Definition: monitor.hpp:534
void * context
Pointer to context data that will be passed to the monitor::callback.
Definition: monitor.hpp:554
FSW_EVENT_CALLBACK * callback
Callback to which change events should be notified.
Definition: monitor.hpp:549
stat()-based monitor.
Definition: poll_monitor.hpp:43
poll_monitor(std::vector< std::string > paths, FSW_EVENT_CALLBACK *callback, void *context=nullptr)
Constructs an instance of this class.
virtual ~poll_monitor()
Destroys an instance of this class.
void run()
Execute monitor loop.
Definition: poll_monitor.cpp:188
Header of the fsw::monitor class.
Main namespace of libfswatch.
Definition: event.cpp:24
void FSW_EVENT_CALLBACK(const std::vector< event > &, void *)
Function definition of an event callback.
Definition: monitor.hpp:61