update: don't check for symlinks on WIN32

WIN32 does have some kind of symbolic links (e.g. in NTFS), but the
readlink() function is not available.  Disable symlink checking for
now.
This commit is contained in:
Max Kellermann 2009-01-03 13:19:58 +01:00
parent 48aace1859
commit a8dbd8f44f

View File

@ -68,6 +68,8 @@ static struct song *delete;
static struct condition delete_cond; static struct condition delete_cond;
#ifndef WIN32
enum { enum {
DEFAULT_FOLLOW_INSIDE_SYMLINKS = true, DEFAULT_FOLLOW_INSIDE_SYMLINKS = true,
DEFAULT_FOLLOW_OUTSIDE_SYMLINKS = true, DEFAULT_FOLLOW_OUTSIDE_SYMLINKS = true,
@ -76,6 +78,8 @@ enum {
static bool follow_inside_symlinks; static bool follow_inside_symlinks;
static bool follow_outside_symlinks; static bool follow_outside_symlinks;
#endif
unsigned unsigned
isUpdatingDB(void) isUpdatingDB(void)
{ {
@ -427,6 +431,7 @@ static bool skip_path(const char *path)
static bool static bool
skip_symlink(const struct directory *directory, const char *utf8_name) skip_symlink(const struct directory *directory, const char *utf8_name)
{ {
#ifndef WIN32
char buffer[MPD_PATH_MAX]; char buffer[MPD_PATH_MAX];
char *path_fs; char *path_fs;
const char *p; const char *p;
@ -476,6 +481,14 @@ skip_symlink(const struct directory *directory, const char *utf8_name)
to a song which is already in the database - skip according to a song which is already in the database - skip according
to the follow_inside_symlinks param*/ to the follow_inside_symlinks param*/
return !follow_inside_symlinks; return !follow_inside_symlinks;
#else
/* no symlink checking on WIN32 */
(void)directory;
(void)utf8_name;
return false;
#endif
} }
static bool static bool
@ -697,6 +710,7 @@ static void reap_update_task(void)
void update_global_init(void) void update_global_init(void)
{ {
#ifndef WIN32
follow_inside_symlinks = follow_inside_symlinks =
config_get_bool(CONF_FOLLOW_INSIDE_SYMLINKS, config_get_bool(CONF_FOLLOW_INSIDE_SYMLINKS,
DEFAULT_FOLLOW_INSIDE_SYMLINKS); DEFAULT_FOLLOW_INSIDE_SYMLINKS);
@ -704,6 +718,7 @@ void update_global_init(void)
follow_outside_symlinks = follow_outside_symlinks =
config_get_bool(CONF_FOLLOW_OUTSIDE_SYMLINKS, config_get_bool(CONF_FOLLOW_OUTSIDE_SYMLINKS,
DEFAULT_FOLLOW_OUTSIDE_SYMLINKS); DEFAULT_FOLLOW_OUTSIDE_SYMLINKS);
#endif
cond_init(&delete_cond); cond_init(&delete_cond);