在libuv中可用uv_fs_event_t來發(fā)現(xiàn)并處理文件的變化。
用到的API函數(shù)也非常簡單:
1.API函數(shù)介紹
1.1初始化uv_fs_event_t對象
int uv_fs_event_init(uv_loop_t* loop, uv_fs_event_t* handle);
1.2.啟動監(jiān)控
int uv_fs_event_start(uv_fs_event_t* handle,uv_fs_event_cb cb,const char* path,unsigned int flags);
參數(shù)1:uv_fs_event_t對象
參數(shù)2:當(dāng)文件發(fā)生變化時的回調(diào)函數(shù)
參數(shù)3:文件路徑名
參數(shù)4:flag,可選數(shù)值如下:
UV_FS_EVENT_WATCH_ENTRY:設(shè)置此標(biāo)志可以監(jiān)控子目錄朦拖。官方注釋中解釋說是:使fs_event僅報告對目錄條目本身的更改捅僵,但測試起來并不是(也可能是自己理解的有問題)。
UV_FS_EVENT_STAT:使用內(nèi)核接口來監(jiān)測文件的變化床三。此標(biāo)志使fs_event定期調(diào)用stat();
UV_FS_EVENT_RECURSIVE:使用此標(biāo)志惕澎,在監(jiān)控目錄時,將忽略子目錄中的更改嫌拣。
2.回調(diào)函數(shù)
void (uv_fs_event_cb)(uv_fs_event_t handle,const char* filename,int events,int status);
handle:上下文對象柔袁;
filename:果目錄被監(jiān)視,它代表發(fā)生改變的文件名异逐。只在Linux和Windows上不為null瘦馍,在其他平臺上可能為null.
event:可能是UV_RENAME、UV_CHANGE或者兩者都包含应役。
status:在這里為0.
3.示例代碼:
#include <stdio.h>
#include <stdlib.h>
#include <uv.h>
uv_loop_t *loop;
const char *command;
void run_command(uv_fs_event_t *handle, const char *filename, int events, int status) {
char path[1024];
size_t size = 1023;
// Does not handle error if path is longer than 1023.
uv_fs_event_getpath(handle, path, &size);
path[size] = '\0';
fprintf(stderr, "Change detected in %s: ", path);
if (events & UV_RENAME)
fprintf(stderr, "renamed");
if (events & UV_CHANGE)
fprintf(stderr, "changed");
fprintf(stderr, " %s\n", filename ? filename : "");
system(command);
}
int main(int argc, char **argv) {
if (argc <= 2) {
fprintf(stderr, "Usage: %s <command> <file1> [file2 ...]\n", argv[0]);
return 1;
}
loop = uv_default_loop();
command = argv[1];
while (argc-- > 2) {
fprintf(stderr, "Adding watch on %s\n", argv[argc]);
uv_fs_event_t *fs_event_req = malloc(sizeof(uv_fs_event_t));
uv_fs_event_init(loop, fs_event_req);
// The recursive flag watches subdirectories too.
uv_fs_event_start(fs_event_req, run_command, argv[argc], UV_FS_EVENT_RECURSIVE);
}
return uv_run(loop, UV_RUN_DEFAULT);
}