mirror of
https://github.com/octoleo/lsyncd.git
synced 2025-01-07 09:04:05 +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>
|
||||
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
|
||||
bin_PROGRAMS = lsyncd
|
||||
lsyncd_SOURCES = lsyncd.c
|
||||
TESTS = tests/help.sh \
|
||||
tests/version.sh \
|
||||
tests/wrong-logfile.sh \
|
||||
tests/wrong-rsync.sh
|
||||
|
||||
datarootdir = @datarootdir@
|
||||
|
||||
|
74
lsyncd.c
74
lsyncd.c
@ -7,6 +7,7 @@
|
||||
* Eugene Sanivsky <eugenesan@gmail.com>
|
||||
*/
|
||||
#include "config.h"
|
||||
#define _GNU_SOURCE
|
||||
|
||||
#include <sys/types.h>
|
||||
#include <sys/stat.h>
|
||||
@ -292,6 +293,49 @@ void *s_realloc(void *ptr, size_t size)
|
||||
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.
|
||||
* Returns after rsync has finished.
|
||||
@ -338,9 +382,10 @@ bool rsync(char const * src, const char * dest, bool recursive)
|
||||
waitpid(pid, &status, 0);
|
||||
assert(WIFEXITED(status));
|
||||
if (WEXITSTATUS(status)){
|
||||
printlogf(LOG_ERROR, "Forked rsync process returned non-zero return code");
|
||||
//TODO: dispute, to we really want to terminate in this case?
|
||||
//exit(-1);
|
||||
printlogf(LOG_ERROR, "Forked rsync process returned non-zero return code: %i", WEXITSTATUS(status));
|
||||
//TODO: really philosophize a little more what to do when rsync fails.
|
||||
// this could also be just a temp. network error while running.
|
||||
exit(-1);
|
||||
}
|
||||
|
||||
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)) {
|
||||
logfile = s_malloc(strlen(optarg) + 1);
|
||||
strcpy(logfile, optarg);
|
||||
logfile = s_strdup(optarg);
|
||||
}
|
||||
|
||||
if (!strcmp("exclude-from", long_options[oi].name)) {
|
||||
exclude_file = s_malloc(strlen(optarg) + 1);
|
||||
strcpy(exclude_file, optarg);
|
||||
exclude_file = s_strdup(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);
|
||||
}
|
||||
|
||||
option_source = argv[optind];
|
||||
|
||||
/* Resolves relative source path, lsyncd might chdir to / later. */
|
||||
option_source = realdir(argv[optind]);
|
||||
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;
|
||||
}
|
||||
|
||||
|
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…
Reference in New Issue
Block a user