diff options
author | Wayne Davison <wayned@samba.org> | 2006-12-28 07:54:19 +0000 |
---|---|---|
committer | Wayne Davison <wayned@samba.org> | 2006-12-28 07:54:19 +0000 |
commit | fe04532ad287836dbba6305b734e6fd1978e02c6 (patch) | |
tree | c92e985ee3f86c83635c420ef4e335ffb3a2e89b | |
parent | e4b619b46d6ad596a8e5ceaa6b5d34b0fd2cc527 (diff) | |
download | android_external_rsync-fe04532ad287836dbba6305b734e6fd1978e02c6.tar.gz android_external_rsync-fe04532ad287836dbba6305b734e6fd1978e02c6.tar.bz2 android_external_rsync-fe04532ad287836dbba6305b734e6fd1978e02c6.zip |
New support function: change_local_filter_dir().
-rw-r--r-- | exclude.c | 24 |
1 files changed, 24 insertions, 0 deletions
@@ -493,6 +493,30 @@ void pop_local_filters(void *mem) free(pop); } +void change_local_filter_dir(const char *dname, int dlen, int dir_depth) +{ + static int min_depth = MAXPATHLEN, cur_depth = -1; + static void *filt_array[MAXPATHLEN/2+1]; + + if (!dname) { + while (cur_depth >= min_depth) + pop_local_filters(filt_array[cur_depth--]); + min_depth = MAXPATHLEN; + cur_depth = -1; + return; + } + + assert(dir_depth < MAXPATHLEN/2+1); + + while (cur_depth >= dir_depth && cur_depth >= min_depth) + pop_local_filters(filt_array[cur_depth--]); + cur_depth = dir_depth; + if (cur_depth < min_depth) + min_depth = cur_depth; + + filt_array[cur_depth] = push_local_filters(dname, dlen); +} + static int rule_matches(char *name, struct filter_struct *ex, int name_is_dir) { int slash_handling, str_cnt = 0, anchored_match = 0; |