mirror of
https://github.com/octoleo/lsyncd.git
synced 2025-01-07 17:14:03 +00:00
delays as pointers
This commit is contained in:
parent
49e7f3aa0d
commit
641da03053
108
lsyncd.c
108
lsyncd.c
@ -320,32 +320,6 @@ struct call_option standard_callopts[] = {
|
|||||||
{ CO_EOL, NULL },
|
{ CO_EOL, NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
|
||||||
* General purpose growable vector of integers.
|
|
||||||
*/
|
|
||||||
struct ivector {
|
|
||||||
/**
|
|
||||||
* data
|
|
||||||
*/
|
|
||||||
int *data;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* allocated mem
|
|
||||||
*/
|
|
||||||
size_t size;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* length used
|
|
||||||
*/
|
|
||||||
size_t len;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* List of directories on a delay.
|
|
||||||
*/
|
|
||||||
struct ivector delays_obj = {0, };
|
|
||||||
struct ivector *delays = &delays_obj;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Structure to store strings for the diversve inotfy masked events.
|
* Structure to store strings for the diversve inotfy masked events.
|
||||||
* Used for comfortable log messages only.
|
* Used for comfortable log messages only.
|
||||||
@ -388,6 +362,24 @@ struct watch_vector {
|
|||||||
size_t len;
|
size_t len;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Holds all entries on delay.
|
||||||
|
*/
|
||||||
|
struct delay_vector {
|
||||||
|
/**
|
||||||
|
* TODO
|
||||||
|
*/
|
||||||
|
struct watch **data;
|
||||||
|
size_t size;
|
||||||
|
size_t len;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List of directories on a delay.
|
||||||
|
*/
|
||||||
|
struct delay_vector delays_obj = {0, };
|
||||||
|
struct delay_vector *delays = &delays_obj;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Array of strings of directory names to include.
|
* Array of strings of directory names to include.
|
||||||
* This is limited to MAX_EXCLUDES.
|
* This is limited to MAX_EXCLUDES.
|
||||||
@ -665,25 +657,6 @@ realdir(const struct log *log, const char *dir)
|
|||||||
return cs;
|
return cs;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Appends one value on an integer vector.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
ivector_push(const struct log *log, struct ivector *ivect, int val){
|
|
||||||
if (ivect->size > ivect->len + 1) {
|
|
||||||
ivect->data[ivect->len++] = val;
|
|
||||||
} else if (!ivect->data) {
|
|
||||||
ivect->data = s_calloc(log, VECT_INIT_SIZE, sizeof(int));
|
|
||||||
ivect->size = VECT_INIT_SIZE;
|
|
||||||
ivect->len = 1;
|
|
||||||
ivect->data[0] = val;
|
|
||||||
} else {
|
|
||||||
ivect->size *= 2;
|
|
||||||
ivect->data = s_realloc(log, ivect->data, ivect->size * sizeof(int));
|
|
||||||
ivect->data[ivect->len++] = val;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*--------------------------------------------------------------------------*
|
/*--------------------------------------------------------------------------*
|
||||||
* Per directory configuration handling.
|
* Per directory configuration handling.
|
||||||
*--------------------------------------------------------------------------*/
|
*--------------------------------------------------------------------------*/
|
||||||
@ -768,16 +741,13 @@ append_delay(const struct log *log,
|
|||||||
watch->delayed = true;
|
watch->delayed = true;
|
||||||
watch->alarm = alarm;
|
watch->alarm = alarm;
|
||||||
|
|
||||||
{
|
// extend the delays vector if needed
|
||||||
// TODO remove this
|
if (delays->len + 1 >= delays->size) {
|
||||||
int i;
|
delays->size *= 2;
|
||||||
for(i = 0; i < watches->len; i++) {
|
delays->data = s_realloc(log, delays->data, delays->size * sizeof(struct watch *));
|
||||||
if(watches->data[i] == watch) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
ivector_push(log, delays, i);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
delays->data[delays->len++] = watch;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -788,9 +758,9 @@ append_delay(const struct log *log,
|
|||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
remove_first_delay(struct watch_vector *watches) {
|
remove_first_delay(struct watch_vector *watches) {
|
||||||
int tw = delays->data[0];
|
delays->data[0]->delayed = false;
|
||||||
memmove(delays->data, delays->data + 1, (--delays->len) * sizeof(int));
|
delays->data[0]->alarm = 0;
|
||||||
watches->data[tw]->delayed = false;
|
memmove(delays->data, delays->data + 1, (--delays->len) * sizeof(struct watch *));
|
||||||
}
|
}
|
||||||
|
|
||||||
/*--------------------------------------------------------------------------*
|
/*--------------------------------------------------------------------------*
|
||||||
@ -1386,7 +1356,7 @@ remove_dirwatch(const struct global_options *opts,
|
|||||||
if (delays->len > 0 && dw->delayed) {
|
if (delays->len > 0 && dw->delayed) {
|
||||||
int i;
|
int i;
|
||||||
for(i = 0; i < delays->len; i++) {
|
for(i = 0; i < delays->len; i++) {
|
||||||
if (watches->data[delays->data[i]] == dw) { // TODO delay pointers
|
if (delays->data[i] == dw) {
|
||||||
// move the list up.
|
// move the list up.
|
||||||
memmove(delays->data + i, delays->data + i + 1, (delays->len - i - 1) * sizeof(int));
|
memmove(delays->data + i, delays->data + i + 1, (delays->len - i - 1) * sizeof(int));
|
||||||
delays->len--;
|
delays->len--;
|
||||||
@ -1535,7 +1505,7 @@ master_loop(const struct global_options *opts,
|
|||||||
|
|
||||||
while (keep_going) {
|
while (keep_going) {
|
||||||
int do_read;
|
int do_read;
|
||||||
if (delays->len > 0 && time_after_eq(times(NULL), watches->data[delays->data[0]]->alarm)) {
|
if (delays->len > 0 && time_after_eq(times(NULL), delays->data[0]->alarm)) {
|
||||||
// there is a delay that wants to be handled already
|
// there is a delay that wants to be handled already
|
||||||
// do not read from inotify_fd and jump directly to delay handling
|
// do not read from inotify_fd and jump directly to delay handling
|
||||||
printlogf(log, DEBUG, "immediately handling delayed entries");
|
printlogf(log, DEBUG, "immediately handling delayed entries");
|
||||||
@ -1545,7 +1515,7 @@ master_loop(const struct global_options *opts,
|
|||||||
// a new event or "alarm" of an event to actually
|
// a new event or "alarm" of an event to actually
|
||||||
// call its binary. The delay with the index 0
|
// call its binary. The delay with the index 0
|
||||||
// should have the nearest alarm time.
|
// should have the nearest alarm time.
|
||||||
alarm = watches->data[delays->data[0]]->alarm;
|
alarm = delays->data[0]->alarm;
|
||||||
now = times(NULL);
|
now = times(NULL);
|
||||||
tv.tv_sec = (alarm - now) / clocks_per_sec;
|
tv.tv_sec = (alarm - now) / clocks_per_sec;
|
||||||
tv.tv_usec = (alarm - now) * 1000000 / clocks_per_sec % 1000000;
|
tv.tv_usec = (alarm - now) * 1000000 / clocks_per_sec % 1000000;
|
||||||
@ -1601,9 +1571,9 @@ master_loop(const struct global_options *opts,
|
|||||||
// until one item is found whose expiry time has not yet come
|
// until one item is found whose expiry time has not yet come
|
||||||
// or the stack is empty. Using now time - times(NULL) - everytime
|
// or the stack is empty. Using now time - times(NULL) - everytime
|
||||||
// again as time may progresses while handling delayed entries.
|
// again as time may progresses while handling delayed entries.
|
||||||
while (delays->len > 0 && time_after_eq(times(NULL), watches->data[delays->data[0]]->alarm)) {
|
while (delays->len > 0 && time_after_eq(times(NULL), delays->data[0])) {
|
||||||
printlogf(log, DEBUG, "time for %d arrived.", delays->data[0]);
|
printlogf(log, DEBUG, "time for '%s' arrived.", delays->data[0]->dirname);
|
||||||
rsync_dir(opts, watches, watches->data[delays->data[0]]); // TODO
|
rsync_dir(opts, watches, delays->data[0]);
|
||||||
remove_first_delay(watches);
|
remove_first_delay(watches);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2300,7 +2270,11 @@ main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
watches.size = 2;
|
watches.size = 2;
|
||||||
watches.data = s_calloc(log, watches.size, sizeof(struct watch));
|
watches.data = s_calloc(log, watches.size, sizeof(struct watch *));
|
||||||
|
|
||||||
|
delays->size = 2;
|
||||||
|
delays->data = s_calloc(log, delays->size, sizeof(struct watch *));
|
||||||
|
|
||||||
|
|
||||||
{
|
{
|
||||||
// add all watches
|
// add all watches
|
||||||
@ -2313,12 +2287,12 @@ main(int argc, char **argv)
|
|||||||
|
|
||||||
// clears delay FIFO again, because the startup recursive rsync will
|
// clears delay FIFO again, because the startup recursive rsync will
|
||||||
// handle it eitherway or if started no-startup it has to be ignored.
|
// handle it eitherway or if started no-startup it has to be ignored.
|
||||||
printlogf(log, DEBUG, "dumped delay list.");
|
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
printlogf(log, DEBUG, "dumping delay list.");
|
||||||
for(i = 0; i < delays->len; i++) {
|
for(i = 0; i < delays->len; i++) {
|
||||||
watches.data[delays->data[i]]->delayed = false;
|
delays->data[i]->delayed = false;
|
||||||
watches.data[delays->data[i]]->alarm = 0;
|
delays->data[i]->alarm = 0;
|
||||||
}
|
}
|
||||||
delays->len = 0;
|
delays->len = 0;
|
||||||
}
|
}
|
||||||
|
@ -18,7 +18,7 @@ mkdir -p "${WORKSOURCE}"/a/a
|
|||||||
echo 'test' > "${WORKSOURCE}"/a/a/file
|
echo 'test' > "${WORKSOURCE}"/a/a/file
|
||||||
|
|
||||||
echo -e "$CON* starting lsyncd$COFF"
|
echo -e "$CON* starting lsyncd$COFF"
|
||||||
./lsyncd --logfile "${LOGFILE}" --pidfile "${PIDFILE}" --no-daemon --debug "${WORKSOURCE}" "${WORKTARGET}"&
|
./lsyncd --logfile "${LOGFILE}" --pidfile "${PIDFILE}" --no-daemon "${WORKSOURCE}" "${WORKTARGET}"&
|
||||||
|
|
||||||
echo -e "$CON* waiting for lsyncd to start$COFF"
|
echo -e "$CON* waiting for lsyncd to start$COFF"
|
||||||
sleep 4s
|
sleep 4s
|
||||||
|
Loading…
Reference in New Issue
Block a user