diff options
-rw-r--r-- | Utilities/cmtar/CMakeLists.txt | 6 | ||||
-rw-r--r-- | Utilities/cmtar/append.c | 10 | ||||
-rw-r--r-- | Utilities/cmtar/compat/basename.c | 4 | ||||
-rw-r--r-- | Utilities/cmtar/compat/compat.h | 9 | ||||
-rw-r--r-- | Utilities/cmtar/compat/dirname.c | 4 | ||||
-rw-r--r-- | Utilities/cmtar/decode.c | 8 | ||||
-rw-r--r-- | Utilities/cmtar/extract.c | 22 | ||||
-rw-r--r-- | Utilities/cmtar/filesystem.c | 4 | ||||
-rw-r--r-- | Utilities/cmtar/filesystem.h | 9 | ||||
-rw-r--r-- | Utilities/cmtar/handle.c | 15 | ||||
-rw-r--r-- | Utilities/cmtar/internal.h | 1 | ||||
-rw-r--r-- | Utilities/cmtar/libtar.c | 2 | ||||
-rw-r--r-- | Utilities/cmtar/util.c | 12 | ||||
-rw-r--r-- | Utilities/cmtar/wrapper.c | 22 |
14 files changed, 77 insertions, 51 deletions
diff --git a/Utilities/cmtar/CMakeLists.txt b/Utilities/cmtar/CMakeLists.txt index 48a3efa..7ffe0e1 100644 --- a/Utilities/cmtar/CMakeLists.txt +++ b/Utilities/cmtar/CMakeLists.txt @@ -290,7 +290,6 @@ SET(libtar_SRC output.c util.c wrapper.c - filesystem.c filesystem.h internal.h ${LIBTAR_BINARY_DIR}/libtar/config.h config.h.in @@ -304,6 +303,11 @@ SET(libtar_SRC # compat/strmode.c # compat/strsep.c ) +IF(NOT UNIX) + SET(libtar_SRC + ${libtar_SRC} + filesystem.c filesystem.h) +ENDIF(NOT UNIX) 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 5007c62..77bb34f 100644 --- a/Utilities/cmtar/append.c +++ b/Utilities/cmtar/append.c @@ -15,7 +15,7 @@ #include <stdio.h> #include <errno.h> #include <fcntl.h> -#ifdef _MSC_VER +#if defined(_WIN32) && !defined(__CYGWIN__) # include <libtar/compat.h> #else # include <sys/param.h> @@ -45,7 +45,7 @@ typedef struct tar_dev tar_dev_t; struct tar_ino { ino_t ti_ino; - char ti_name[MAXPATHLEN]; + char ti_name[TAR_MAXPATHLEN]; }; typedef struct tar_ino tar_ino_t; @@ -68,7 +68,7 @@ tar_append_file(TAR *t, char *realname, char *savename) libtar_hashptr_t hp; tar_dev_t *td = NULL; tar_ino_t *ti = NULL; - char path[MAXPATHLEN]; + char path[TAR_MAXPATHLEN]; #ifdef DEBUG printf("==> tar_append_file(TAR=0x%lx (\"%s\"), realname=\"%s\", " @@ -162,8 +162,8 @@ tar_append_file(TAR *t, char *realname, char *savename) #endif if (i == -1) return -1; - if (i >= MAXPATHLEN) - i = MAXPATHLEN - 1; + if (i >= TAR_MAXPATHLEN) + i = TAR_MAXPATHLEN - 1; path[i] = '\0'; #ifdef DEBUG printf(" tar_append_file(): encoding symlink \"%s\" -> " diff --git a/Utilities/cmtar/compat/basename.c b/Utilities/cmtar/compat/basename.c index 3b87b0e..ddaf89d 100644 --- a/Utilities/cmtar/compat/basename.c +++ b/Utilities/cmtar/compat/basename.c @@ -33,14 +33,14 @@ static char rcsid[] = "$OpenBSD: basename.c,v 1.4 1999/05/30 17:10:30 espie Exp #include <errno.h> #include <string.h> -//#include <sys/param.h> #include <libtar/compat.h> +#include <libtarint/internal.h> char * openbsd_basename(path) const char *path; { - static char bname[MAXPATHLEN]; + static char bname[TAR_MAXPATHLEN]; register const char *endp, *startp; /* Empty or NULL string gets treated as "." */ diff --git a/Utilities/cmtar/compat/compat.h b/Utilities/cmtar/compat/compat.h index 880f54b..f308b99 100644 --- a/Utilities/cmtar/compat/compat.h +++ b/Utilities/cmtar/compat/compat.h @@ -312,3 +312,12 @@ char *strsep(register char **, register const char *); #endif #define S_ISFIFO(m) (((m)&S_IFFIFO)==S_IFFIFO) #endif + +#if defined(PATH_MAX) +# define TAR_MAXPATHLEN PATH_MAX +#elif defined(MAXPATHLEN) +# define TAR_MAXPATHLEN MAXPATHLEN +#else +# define TAR_MAXPATHLEN 16384 +#endif + diff --git a/Utilities/cmtar/compat/dirname.c b/Utilities/cmtar/compat/dirname.c index f322bbd..f05a381 100644 --- a/Utilities/cmtar/compat/dirname.c +++ b/Utilities/cmtar/compat/dirname.c @@ -33,14 +33,14 @@ static char rcsid[] = "$OpenBSD: dirname.c,v 1.4 1999/05/30 17:10:30 espie Exp $ #include <errno.h> #include <string.h> -//#include <sys/param.h> #include <libtar/compat.h> +#include <libtarint/internal.h> char * openbsd_dirname(path) const char *path; { - static char bname[MAXPATHLEN]; + static char bname[TAR_MAXPATHLEN]; register const char *endp; /* Empty or NULL string gets treated as "." */ diff --git a/Utilities/cmtar/decode.c b/Utilities/cmtar/decode.c index 178ffc0..788fb3f 100644 --- a/Utilities/cmtar/decode.c +++ b/Utilities/cmtar/decode.c @@ -14,10 +14,10 @@ #include <stdio.h> -#ifndef _MSC_VER -#include <sys/param.h> +#if defined(_WIN32) && !defined(__CYGWIN__) +# include <libtar/compat.h> #else -#include <libtar/compat.h> +# include <sys/param.h> #endif #ifndef WIN32 @@ -34,7 +34,7 @@ char * th_get_pathname(TAR *t) { - char filename[MAXPATHLEN]; + char filename[TAR_MAXPATHLEN]; if (t->th_buf.gnu_longname) return t->th_buf.gnu_longname; diff --git a/Utilities/cmtar/extract.c b/Utilities/cmtar/extract.c index 506dff1..7ceece1 100644 --- a/Utilities/cmtar/extract.c +++ b/Utilities/cmtar/extract.c @@ -17,14 +17,20 @@ #include <sys/types.h> #include <fcntl.h> #include <errno.h> -#ifdef _MSC_VER -#include <sys/utime.h> -#include <io.h> -#include <direct.h> + +#if defined(_WIN32) && !defined(__CYGWIN__) +# ifdef _MSC_VER +# include <sys/utime.h> +# else +# include <utime.h> +# endif +# include <io.h> +# include <direct.h> #else -#include <utime.h> -#include <sys/param.h> +# include <utime.h> +# include <sys/param.h> #endif + #ifdef STDC_HEADERS # include <stdlib.h> # include <string.h> @@ -41,8 +47,8 @@ struct linkname { - char ln_save[MAXPATHLEN]; - char ln_real[MAXPATHLEN]; + char ln_save[TAR_MAXPATHLEN]; + char ln_real[TAR_MAXPATHLEN]; }; typedef struct linkname linkname_t; diff --git a/Utilities/cmtar/filesystem.c b/Utilities/cmtar/filesystem.c index 3418d1e..1ddd5a5 100644 --- a/Utilities/cmtar/filesystem.c +++ b/Utilities/cmtar/filesystem.c @@ -3,7 +3,6 @@ // First microsoft compilers -#ifdef _MSC_VER #include <windows.h> #include <io.h> #include <ctype.h> @@ -61,7 +60,7 @@ kwDirEntry * kwReadDir(kwDirectory * dir) return NULL; } entry = (kwDirEntry*)malloc(sizeof(kwDirEntry)); - strncpy(entry->d_name,dir->Entry.name,MAXPATHLEN-1); + strncpy(entry->d_name,dir->Entry.name,TAR_MAXPATHLEN-1); if(_findnext(dir->SrchHandle, &dir->Entry) == -1) { dir->EOD=1; @@ -79,4 +78,3 @@ int kwCloseDir(kwDirectory * dir) if(r==-1) return 0; return 1; } -#endif diff --git a/Utilities/cmtar/filesystem.h b/Utilities/cmtar/filesystem.h index f2ee202..cd61ed2 100644 --- a/Utilities/cmtar/filesystem.h +++ b/Utilities/cmtar/filesystem.h @@ -1,8 +1,8 @@ #ifndef _FILESYSTEM_H_ #define _FILESYSTEM_H_ -#ifdef _MSC_VER #include <io.h> +#include <libtarint/internal.h> struct _KWDIR { @@ -15,12 +15,9 @@ struct _KWDIR int EOD; //end of directory }; -#ifndef MAXPATHLEN -#define MAXPATHLEN _MAX_PATH -#endif typedef struct _KWDIRENTRY { - char d_name[MAXPATHLEN]; + char d_name[TAR_MAXPATHLEN]; }kwDirEntry; typedef struct _KWDIR kwDirectory; @@ -31,5 +28,3 @@ int kwCloseDir(kwDirectory * dir); #endif //MSC - -#endif diff --git a/Utilities/cmtar/handle.c b/Utilities/cmtar/handle.c index 1fe053e..5238e03 100644 --- a/Utilities/cmtar/handle.c +++ b/Utilities/cmtar/handle.c @@ -34,7 +34,22 @@ const char libtar_version[] = PACKAGE_VERSION; +#define libtar_symbol(name, ret, args, callargs) \ + static ret libtar_##name args \ + { \ + return name callargs; \ + } + +#if defined(__BORLANDC__) +libtar_symbol(open, int, (const char* pathname, int flags, mode_t mode), (pathname, flags, mode)); +libtar_symbol(close, int, (int fd), (fd)); +libtar_symbol(read, ssize_t, (int fd, void* buf, size_t count), (fd, buf, count)); +libtar_symbol(write, ssize_t, (int fd, void* buf, size_t count), (fd, buf, count)); + +static tartype_t default_type = { libtar_open, libtar_close, libtar_read, libtar_write }; +#else static tartype_t default_type = { open, close, read, write }; +#endif static int diff --git a/Utilities/cmtar/internal.h b/Utilities/cmtar/internal.h index 434fbb0..cc2cbd3 100644 --- a/Utilities/cmtar/internal.h +++ b/Utilities/cmtar/internal.h @@ -14,4 +14,3 @@ #include <libtar/compat.h> #include <libtar/libtar.h> - diff --git a/Utilities/cmtar/libtar.c b/Utilities/cmtar/libtar.c index cdbe7a1..ee01075 100644 --- a/Utilities/cmtar/libtar.c +++ b/Utilities/cmtar/libtar.c @@ -113,7 +113,7 @@ create(char *tarfile, char *rootdir, libtar_list_t *l) { TAR *t; char *pathname; - char buf[MAXPATHLEN]; + char buf[TAR_MAXPATHLEN]; libtar_listptr_t lp; if (tar_open(&t, tarfile, diff --git a/Utilities/cmtar/util.c b/Utilities/cmtar/util.c index 007ed93..1959e0a 100644 --- a/Utilities/cmtar/util.c +++ b/Utilities/cmtar/util.c @@ -20,7 +20,7 @@ # include <string.h> #endif -#ifdef _MSC_VER +#if defined(_WIN32) && !defined(__CYGWIN__) #include <direct.h> #else #include <sys/param.h> @@ -30,7 +30,7 @@ int path_hashfunc(char *key, int numbuckets) { - char buf[MAXPATHLEN]; + char buf[TAR_MAXPATHLEN]; char *p; strcpy(buf, key); @@ -82,7 +82,7 @@ ino_hash(ino_t *inode) int mkdirhier(char *path) { - char src[MAXPATHLEN], dst[MAXPATHLEN] = ""; + char src[TAR_MAXPATHLEN], dst[TAR_MAXPATHLEN] = ""; char *dirp, *nextp = src; int retval = 1; @@ -103,10 +103,10 @@ mkdirhier(char *path) if (dst[0] != '\0') strcat(dst, "/"); strcat(dst, dirp); -#ifndef _MSC_VER - if (mkdir(dst, 0777) == -1) -#else +#if defined(_WIN32) && !defined(__CYGWIN__) if (mkdir(dst) == -1) +#else + if (mkdir(dst, 0777) == -1) #endif { if (errno != EEXIST) diff --git a/Utilities/cmtar/wrapper.c b/Utilities/cmtar/wrapper.c index a545862..be090ee 100644 --- a/Utilities/cmtar/wrapper.c +++ b/Utilities/cmtar/wrapper.c @@ -14,7 +14,7 @@ #include <stdio.h> #include <libtar/compat.h> -#ifdef _MSC_VER +#if defined(_WIN32) && !defined(__CYGWIN__) #include <libtarint/filesystem.h> #else #include <sys/param.h> @@ -35,7 +35,7 @@ int tar_extract_glob(TAR *t, char *globname, char *prefix) { char *filename; - char buf[MAXPATHLEN]; + char buf[TAR_MAXPATHLEN]; int i; while ((i = th_read(t)) == 0) @@ -65,7 +65,7 @@ int tar_extract_all(TAR *t, char *prefix) { char *filename; - char buf[MAXPATHLEN]; + char buf[TAR_MAXPATHLEN]; int i; #ifdef DEBUG @@ -100,9 +100,9 @@ tar_extract_all(TAR *t, char *prefix) int tar_append_tree(TAR *t, char *realdir, char *savedir) { - char realpath[MAXPATHLEN]; - char savepath[MAXPATHLEN]; -#ifndef _MSC_VER + char realpath[TAR_MAXPATHLEN]; + char savepath[TAR_MAXPATHLEN]; +#if !defined(_WIN32) || defined(__CYGWIN__) struct dirent *dent; DIR *dp; #else @@ -123,7 +123,7 @@ tar_append_tree(TAR *t, char *realdir, char *savedir) puts(" tar_append_tree(): done with tar_append_file()..."); #endif -#ifdef _MSC_VER +#if defined(_WIN32) && !defined(__CYGWIN__) dp = kwOpenDir(realdir); #else dp = opendir(realdir); @@ -135,7 +135,7 @@ tar_append_tree(TAR *t, char *realdir, char *savedir) return 0; return -1; } -#ifdef _MSC_VER +#if defined(_WIN32) && !defined(__CYGWIN__) while ((dent = kwReadDir(dp)) != NULL) #else while ((dent = readdir(dp)) != NULL) @@ -145,10 +145,10 @@ tar_append_tree(TAR *t, char *realdir, char *savedir) strcmp(dent->d_name, "..") == 0) continue; - snprintf(realpath, MAXPATHLEN, "%s/%s", realdir, + snprintf(realpath, TAR_MAXPATHLEN, "%s/%s", realdir, dent->d_name); if (savedir) - snprintf(savepath, MAXPATHLEN, "%s/%s", savedir, + snprintf(savepath, TAR_MAXPATHLEN, "%s/%s", savedir, dent->d_name); #ifndef WIN32 @@ -171,7 +171,7 @@ tar_append_tree(TAR *t, char *realdir, char *savedir) return -1; } -#ifdef _MSC_VER +#if defined(_WIN32) && !defined(__CYGWIN__) kwCloseDir(dp); #else closedir(dp); |