diff options
-rw-r--r-- | Utilities/cmtar/CMakeLists.txt | 6 | ||||
-rw-r--r-- | Utilities/cmtar/append.c | 15 | ||||
-rw-r--r-- | Utilities/cmtar/config.h.in | 6 | ||||
-rw-r--r-- | Utilities/cmtar/encode.c | 9 | ||||
-rw-r--r-- | Utilities/cmtar/internal.h | 7 | ||||
-rw-r--r-- | Utilities/cmtar/output.c | 2 | ||||
-rw-r--r-- | Utilities/cmtar/util.c | 16 | ||||
-rw-r--r-- | Utilities/cmtar/wrapper.c | 45 |
8 files changed, 81 insertions, 25 deletions
diff --git a/Utilities/cmtar/CMakeLists.txt b/Utilities/cmtar/CMakeLists.txt index fc3a887..ee9d681 100644 --- a/Utilities/cmtar/CMakeLists.txt +++ b/Utilities/cmtar/CMakeLists.txt @@ -75,10 +75,12 @@ FOREACH(file "stdio.h" "string.h" "strings.h" + "sys/param.h" "sys/types.h" "sys/stat.h" "unistd.h" "glob.h" + "dirent.h" ) CHECK_INCLUDE_FILE_CONCAT("${file}") ENDFOREACH(file) @@ -293,11 +295,11 @@ SET(libtar_SRC # compat/strmode.c # compat/strsep.c ) -IF(NOT UNIX) +IF(NOT HAVE_DIRENT_H) SET(libtar_SRC ${libtar_SRC} filesystem.c filesystem.h) -ENDIF(NOT UNIX) +ENDIF(NOT HAVE_DIRENT_H) IF(NOT HAVE_STRLCPY) SET(libtar_SRC ${libtar_SRC} compat/strlcpy.c) diff --git a/Utilities/cmtar/append.c b/Utilities/cmtar/append.c index 6dbf1dd..6bcef98 100644 --- a/Utilities/cmtar/append.c +++ b/Utilities/cmtar/append.c @@ -69,8 +69,10 @@ tar_append_file(TAR *t, char *realname, char *savename) tar_ino_t *ti = NULL; #if !defined(_WIN32) || defined(__CYGWIN__) int i; - char path[TAR_MAXPATHLEN]; +#else + size_t plen; #endif + char path[TAR_MAXPATHLEN]; #ifdef DEBUG printf("==> tar_append_file(TAR=0x%lx (\"%s\"), realname=\"%s\", " @@ -79,7 +81,14 @@ tar_append_file(TAR *t, char *realname, char *savename) #endif #if defined(_WIN32) && !defined(__CYGWIN__) - if (stat(realname, &s) != 0) + strncpy(path, realname, sizeof(path)-1); + path[sizeof(path)-1] = 0; + plen = strlen(path); + if (path[plen-1] == '/' ) + { + path[plen-1] = 0; + } + if (stat(path, &s) != 0) #else if (lstat(realname, &s) != 0) #endif @@ -126,6 +135,7 @@ tar_append_file(TAR *t, char *realname, char *savename) return -1; } libtar_hashptr_reset(&hp); +#if !defined(_WIN32) || defined(__CYGWIN__) if (libtar_hash_getkey(td->td_h, &hp, &(s.st_ino), (libtar_matchfunc_t)ino_match) != 0) { @@ -138,6 +148,7 @@ tar_append_file(TAR *t, char *realname, char *savename) th_set_link(t, ti->ti_name); } else +#endif { #ifdef DEBUG printf("+++ adding entry: device (0x%lx,0x%lx), inode %ld " diff --git a/Utilities/cmtar/config.h.in b/Utilities/cmtar/config.h.in index 6702238..acbbead 100644 --- a/Utilities/cmtar/config.h.in +++ b/Utilities/cmtar/config.h.in @@ -36,6 +36,12 @@ /* Define to 1 if you have the <memory.h> header file. */ #cmakedefine HAVE_MEMORY_H @HAVE_MEMORY_H@ +/* Define to 1 if you have the <dirent.h> header file. */ +#cmakedefine HAVE_DIRENT_H @HAVE_DIRENT_H@ + +/* Define to 1 if you have the <sys/param.h> header file. */ +#cmakedefine HAVE_SYS_PARAM_H @HAVE_SYS_PARAM_H@ + /* Define to 1 if the system has the type `minor_t'. */ #cmakedefine HAVE_MINOR_T @HAVE_MINOR_T@ diff --git a/Utilities/cmtar/encode.c b/Utilities/cmtar/encode.c index cadac67..3c8cb6a 100644 --- a/Utilities/cmtar/encode.c +++ b/Utilities/cmtar/encode.c @@ -157,12 +157,6 @@ th_set_device(TAR *t, dev_t device) printf("th_set_device(): major = %d, minor = %d\n", major(device), minor(device)); #endif -#ifndef major -# define major(dev) ((int)(((dev) >> 8) & 0xff)) -#endif -#ifndef minor -# define minor(dev) ((int)((dev) & 0xff)) -#endif int_to_oct(major(device), t->th_buf.devmajor, 8); int_to_oct(minor(device), t->th_buf.devminor, 8); } @@ -209,7 +203,8 @@ th_set_mode(TAR *t, mode_t fmode) fmode |= S_IFIFO; } #endif - int_to_oct(fmode, (t)->th_buf.mode, 8); + /* Looks like on windows the st_mode is longer than 8 characters. */ + int_to_oct(fmode & 07777777, (t)->th_buf.mode, 8); } diff --git a/Utilities/cmtar/internal.h b/Utilities/cmtar/internal.h index cc2cbd3..60be2af 100644 --- a/Utilities/cmtar/internal.h +++ b/Utilities/cmtar/internal.h @@ -14,3 +14,10 @@ #include <libtar/compat.h> #include <libtar/libtar.h> + +#ifndef major +# define major(dev) ((int)(((dev) >> 8) & 0xff)) +#endif +#ifndef minor +# define minor(dev) ((int)((dev) & 0xff)) +#endif diff --git a/Utilities/cmtar/output.c b/Utilities/cmtar/output.c index 14757f4..38cf157 100644 --- a/Utilities/cmtar/output.c +++ b/Utilities/cmtar/output.c @@ -110,8 +110,8 @@ th_print_long_ls(TAR *t) if (TH_ISCHR(t) || TH_ISBLK(t)) printf(" %3d, %3d ", th_get_devmajor(t), th_get_devminor(t)); else - printf("%9ld ", (long)th_get_size(t)); #endif + printf("%9ld ", (long)th_get_size(t)); mtime = th_get_mtime(t); mtm = localtime(&mtime); diff --git a/Utilities/cmtar/util.c b/Utilities/cmtar/util.c index 1959e0a..494847b 100644 --- a/Utilities/cmtar/util.c +++ b/Utilities/cmtar/util.c @@ -103,12 +103,24 @@ mkdirhier(char *path) if (dst[0] != '\0') strcat(dst, "/"); strcat(dst, dirp); + if ( #if defined(_WIN32) && !defined(__CYGWIN__) - if (mkdir(dst) == -1) + mkdir(dst) == -1 #else - if (mkdir(dst, 0777) == -1) + mkdir(dst, 0777) == -1 #endif + ) { +#ifdef __BORLANDC__ + /* There is a bug in the Borland Run time library which makes MKDIR + return EACCES when it should return EEXIST + if it is some other error besides directory exists + then return false */ + if ( errno == EACCES) + { + errno = EEXIST; + } +#endif if (errno != EEXIST) return -1; } diff --git a/Utilities/cmtar/wrapper.c b/Utilities/cmtar/wrapper.c index be090ee..8f682c2 100644 --- a/Utilities/cmtar/wrapper.c +++ b/Utilities/cmtar/wrapper.c @@ -14,11 +14,13 @@ #include <stdio.h> #include <libtar/compat.h> -#if defined(_WIN32) && !defined(__CYGWIN__) -#include <libtarint/filesystem.h> -#else +#if defined(HAVE_SYS_PARAM_H) #include <sys/param.h> +#endif +#if defined(HAVE_DIRENT_H) #include <dirent.h> +#else +#include <libtarint/filesystem.h> #endif #include <errno.h> @@ -102,7 +104,8 @@ tar_append_tree(TAR *t, char *realdir, char *savedir) { char realpath[TAR_MAXPATHLEN]; char savepath[TAR_MAXPATHLEN]; -#if !defined(_WIN32) || defined(__CYGWIN__) + size_t plen; +#if defined(HAVE_DIRENT_H) struct dirent *dent; DIR *dp; #else @@ -110,6 +113,14 @@ tar_append_tree(TAR *t, char *realdir, char *savedir) kwDirectory *dp; #endif struct stat s; + strncpy(realpath, realdir, sizeof(realpath)); + realpath[sizeof(realpath)-1] = 0; + plen = strlen(realpath); + if ( realpath[plen-1] == '/' ) + { + realpath[plen-1] = 0; + } + #ifdef DEBUG printf("==> tar_append_tree(0x%lx, \"%s\", \"%s\")\n", @@ -123,10 +134,22 @@ tar_append_tree(TAR *t, char *realdir, char *savedir) puts(" tar_append_tree(): done with tar_append_file()..."); #endif + if ( stat(realpath, &s) != 0 ) + { + return -1; + } + if ( #if defined(_WIN32) && !defined(__CYGWIN__) - dp = kwOpenDir(realdir); + (s.st_mode & _S_IFDIR) == 0 #else + !S_ISDIR(s.st_mode) +#endif + ) + return 0; +#if defined(HAVE_DIRENT_H) dp = opendir(realdir); +#else + dp = kwOpenDir(realdir); #endif if (dp == NULL) @@ -135,10 +158,10 @@ tar_append_tree(TAR *t, char *realdir, char *savedir) return 0; return -1; } -#if defined(_WIN32) && !defined(__CYGWIN__) - while ((dent = kwReadDir(dp)) != NULL) -#else +#if defined(HAVE_DIRENT_H) while ((dent = readdir(dp)) != NULL) +#else + while ((dent = kwReadDir(dp)) != NULL) #endif { if (strcmp(dent->d_name, ".") == 0 || @@ -171,10 +194,10 @@ tar_append_tree(TAR *t, char *realdir, char *savedir) return -1; } -#if defined(_WIN32) && !defined(__CYGWIN__) - kwCloseDir(dp); -#else +#if defined(HAVE_DIRENT_H) closedir(dp); +#else + kwCloseDir(dp); #endif return 0; |