mirror of
https://github.com/octoleo/lsyncd.git
synced 2025-01-24 07:38:28 +00:00
some more files
This commit is contained in:
parent
742789e258
commit
be93533418
2
AUTHORS
2
AUTHORS
@ -1,2 +1,4 @@
|
|||||||
Axel Kittenberger <axel.kittenberger@univie.ac.at>
|
Axel Kittenberger <axel.kittenberger@univie.ac.at>
|
||||||
Jürgen "README" Mangler <juergen.mangler@univie.ac.at>
|
Jürgen "README" Mangler <juergen.mangler@univie.ac.at>
|
||||||
|
Eugene Sanivsky <eugenesan@gmail.com>
|
||||||
|
Junichi Uekawa <dancerj@gmail.com>
|
||||||
|
@ -1,6 +1,10 @@
|
|||||||
## Makefile.am -- Process this file with automake to produce Makefile.in
|
## Makefile.am -- Process this file with automake to produce Makefile.in
|
||||||
bin_PROGRAMS = lsyncd
|
bin_PROGRAMS = lsyncd
|
||||||
lsyncd_SOURCES = lsyncd.c
|
lsyncd_SOURCES = lsyncd.c
|
||||||
|
TESTS = tests/help.sh \
|
||||||
|
tests/version.sh \
|
||||||
|
tests/wrong-logfile.sh \
|
||||||
|
tests/wrong-rsync.sh
|
||||||
|
|
||||||
datarootdir = @datarootdir@
|
datarootdir = @datarootdir@
|
||||||
|
|
||||||
|
76
lsyncd.c
76
lsyncd.c
@ -7,6 +7,7 @@
|
|||||||
* Eugene Sanivsky <eugenesan@gmail.com>
|
* Eugene Sanivsky <eugenesan@gmail.com>
|
||||||
*/
|
*/
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
#define _GNU_SOURCE
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
@ -292,6 +293,49 @@ void *s_realloc(void *ptr, size_t size)
|
|||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* "secured" strdup.
|
||||||
|
*/
|
||||||
|
char *s_strdup(const char* src)
|
||||||
|
{
|
||||||
|
char *s = strdup(src);
|
||||||
|
|
||||||
|
if (s == NULL) {
|
||||||
|
printlogf(LOG_ERROR, "Out of memory!");
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the canonicalized path of a directory with a final '/',
|
||||||
|
* Makes sure it is a directory.
|
||||||
|
*/
|
||||||
|
char *realdir(const char * dir)
|
||||||
|
{
|
||||||
|
char* cs = canonicalize_file_name(dir);
|
||||||
|
|
||||||
|
if (cs == NULL) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (strlen(cs) + 2 >= MAX_PATH) {
|
||||||
|
// at systems maxpath already, we cannot add a '/' anyway.
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct stat st;
|
||||||
|
stat(cs, &st);
|
||||||
|
if (!S_ISDIR(st.st_mode)) {
|
||||||
|
free(cs);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
strcat(cs, '/');
|
||||||
|
return cs;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Calls rsync to sync from src to dest.
|
* Calls rsync to sync from src to dest.
|
||||||
* Returns after rsync has finished.
|
* Returns after rsync has finished.
|
||||||
@ -338,9 +382,10 @@ bool rsync(char const * src, const char * dest, bool recursive)
|
|||||||
waitpid(pid, &status, 0);
|
waitpid(pid, &status, 0);
|
||||||
assert(WIFEXITED(status));
|
assert(WIFEXITED(status));
|
||||||
if (WEXITSTATUS(status)){
|
if (WEXITSTATUS(status)){
|
||||||
printlogf(LOG_ERROR, "Forked rsync process returned non-zero return code");
|
printlogf(LOG_ERROR, "Forked rsync process returned non-zero return code: %i", WEXITSTATUS(status));
|
||||||
//TODO: dispute, to we really want to terminate in this case?
|
//TODO: really philosophize a little more what to do when rsync fails.
|
||||||
//exit(-1);
|
// this could also be just a temp. network error while running.
|
||||||
|
exit(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
printlogf(LOG_DEBUG, "Rsync of [%s] -> [%s] finished", src, dest);
|
printlogf(LOG_DEBUG, "Rsync of [%s] -> [%s] finished", src, dest);
|
||||||
@ -833,14 +878,17 @@ bool parse_options(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!strcmp("logfile", long_options[oi].name)) {
|
if (!strcmp("logfile", long_options[oi].name)) {
|
||||||
logfile = s_malloc(strlen(optarg) + 1);
|
logfile = s_strdup(optarg);
|
||||||
strcpy(logfile, optarg);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!strcmp("exclude-from", long_options[oi].name)) {
|
if (!strcmp("exclude-from", long_options[oi].name)) {
|
||||||
exclude_file = s_malloc(strlen(optarg) + 1);
|
exclude_file = s_strdup(optarg);
|
||||||
strcpy(exclude_file, optarg);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!strcmp("rsync-binary", long_options[oi].name)) {
|
||||||
|
rsync_binary = s_strdup(optarg);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -849,10 +897,16 @@ bool parse_options(int argc, char **argv)
|
|||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
option_source = argv[optind];
|
/* Resolves relative source path, lsyncd might chdir to / later. */
|
||||||
|
option_source = realdir(argv[optind]);
|
||||||
option_target = argv[optind + 1];
|
option_target = argv[optind + 1];
|
||||||
printf("syncing %s -> %s\n", option_source, option_target);
|
|
||||||
|
if (!option_source) {
|
||||||
|
printf("Error: Source [%s] not found or not a directory.\n", argv[optind]);
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
printlogf(LOG_NORMAL, "syncing %s -> %s\n", option_source, option_target);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -963,7 +1017,7 @@ int main(int argc, char **argv)
|
|||||||
rsync(option_source, option_target, true);
|
rsync(option_source, option_target, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
printlogf(LOG_NORMAL, "--- Entering normal operation with [%d] monitored directories ---", dir_watch_num);
|
printlogf(LOG_NORMAL, "--- Entering normal operation with [%d] monitored directories ---", dir_watch_num);
|
||||||
|
|
||||||
signal(SIGTERM, catch_alarm);
|
signal(SIGTERM, catch_alarm);
|
||||||
master_loop();
|
master_loop();
|
||||||
|
11
tests/help.sh
Normal file
11
tests/help.sh
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# copyright 2008 Junichi Uekawa <dancer@debian.org>
|
||||||
|
# licensed under GPLv2 or later, see the file ../COPYING for details.
|
||||||
|
|
||||||
|
# test that --help outputs help message and exit code of 0
|
||||||
|
set -e
|
||||||
|
set -o pipefail
|
||||||
|
|
||||||
|
# assume that USAGE being in output is good enough.
|
||||||
|
|
||||||
|
./lsyncd --help | grep '^USAGE:'
|
11
tests/version.sh
Normal file
11
tests/version.sh
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# copyright 2008 Junichi Uekawa <dancer@debian.org>
|
||||||
|
# licensed under GPLv2 or later, see the file ../COPYING for details.
|
||||||
|
|
||||||
|
# test that --version outputs some kind of version message and exit code of 0
|
||||||
|
set -e
|
||||||
|
set -o pipefail
|
||||||
|
|
||||||
|
./lsyncd --version | grep '^Version: '
|
||||||
|
|
||||||
|
|
14
tests/wrong-logfile.sh
Normal file
14
tests/wrong-logfile.sh
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# copyright 2008 Junichi Uekawa <dancer@debian.org>
|
||||||
|
# licensed under GPLv2 or later, see the file ../COPYING for details.
|
||||||
|
|
||||||
|
# make sure wrong logfile specification gives a reasonable error
|
||||||
|
# message
|
||||||
|
|
||||||
|
WORKTARGET=$(mktemp -d)
|
||||||
|
if [[ $( ./lsyncd --logfile /nonexisting/path/name . "${WORKTARGET}" ) =~ "cannot open logfile" ]]; then
|
||||||
|
rmdir "${WORKTARGET}"
|
||||||
|
exit 0;
|
||||||
|
else
|
||||||
|
exit 1;
|
||||||
|
fi
|
16
tests/wrong-rsync.sh
Normal file
16
tests/wrong-rsync.sh
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
# copyright 2008 Junichi Uekawa <dancer@debian.org>
|
||||||
|
# licensed under GPLv2 or later, see the file ../COPYING for details.
|
||||||
|
|
||||||
|
# make sure that program exits with exit code of -1 when rsync path is
|
||||||
|
# wrong.
|
||||||
|
|
||||||
|
WORKTARGET=$(mktemp -d)
|
||||||
|
./lsyncd --no-daemon --rsync-binary /wrong/path/to/rsync . "${WORKTARGET}"
|
||||||
|
if [[ $? = 255 ]]; then
|
||||||
|
rmdir "${WORKTARGET}"
|
||||||
|
exit 0;
|
||||||
|
else
|
||||||
|
exit 1;
|
||||||
|
fi
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user