summaryrefslogtreecommitdiffstats
path: root/Utilities/cmtar
diff options
context:
space:
mode:
Diffstat (limited to 'Utilities/cmtar')
-rw-r--r--Utilities/cmtar/handle.c53
-rw-r--r--Utilities/cmtar/libtar.c9
-rw-r--r--Utilities/cmtar/libtar.h24
3 files changed, 38 insertions, 48 deletions
diff --git a/Utilities/cmtar/handle.c b/Utilities/cmtar/handle.c
index 6770b2b..4b9a169 100644
--- a/Utilities/cmtar/handle.c
+++ b/Utilities/cmtar/handle.c
@@ -34,29 +34,37 @@
const char libtar_version[] = PACKAGE_VERSION;
+struct libtar_fd_file
+{
+ int fd;
+};
+
+static struct libtar_fd_file libtar_fd_file_pointer;
+
static int libtar_open(void* call_data, const char* pathname, int flags, mode_t mode)
{
- (void)call_data;
- return open(pathname, flags, mode);
+ struct libtar_fd_file* lf = (struct libtar_fd_file*)call_data;
+ lf->fd = open(pathname, flags, mode);
+ return lf->fd;
}
-static int libtar_close(void* call_data, int fd)
+static int libtar_close(void* call_data)
{
- (void)call_data;
- return close(fd);
+ struct libtar_fd_file* lf = (struct libtar_fd_file*)call_data;
+ return close(lf->fd);
}
-static ssize_t libtar_read(void* call_data, int fd, void* buf, size_t count)
+static ssize_t libtar_read(void* call_data, void* buf, size_t count)
{
- (void)call_data;
- return read(fd, buf, count);
+ struct libtar_fd_file* lf = (struct libtar_fd_file*)call_data;
+ return read(lf->fd, buf, count);
}
-static ssize_t libtar_write(void* call_data, int fd, const void* buf, size_t count)
+static ssize_t libtar_write(void* call_data, const void* buf, size_t count)
{
- (void)call_data;
- return write(fd, buf, count);
+ struct libtar_fd_file* lf = (struct libtar_fd_file*)call_data;
+ return write(lf->fd, buf, count);
}
-static tartype_t default_type = { libtar_open, libtar_close, libtar_read, libtar_write, 0 };
+static tartype_t default_type = { libtar_open, libtar_close, libtar_read, libtar_write, &libtar_fd_file_pointer };
static int
tar_init(TAR **t, char *pathname, tartype_t *type,
@@ -98,6 +106,7 @@ int
tar_open(TAR **t, char *pathname, tartype_t *type,
int oflags, int mode, int options)
{
+ int res;
if (tar_init(t, pathname, type, oflags, mode, options) == -1)
return -1;
@@ -108,8 +117,8 @@ tar_open(TAR **t, char *pathname, tartype_t *type,
oflags |= O_BINARY;
#endif
- (*t)->fd = (*((*t)->type->openfunc))((*t)->type->call_data, pathname, oflags, mode);
- if ((*t)->fd == -1)
+ res = (*((*t)->type->openfunc))((*t)->type->call_data, pathname, oflags, mode);
+ if (res == -1)
{
free(*t);
return -1;
@@ -126,25 +135,21 @@ tar_fdopen(TAR **t, int fd, char *pathname, tartype_t *type,
if (tar_init(t, pathname, type, oflags, mode, options) == -1)
return -1;
- (*t)->fd = fd;
+ if ( !type )
+ {
+ struct libtar_fd_file* lf = (struct libtar_fd_file*)((*t)->type->call_data);
+ lf->fd = fd;
+ }
return 0;
}
-
-int
-tar_fd(TAR *t)
-{
- return t->fd;
-}
-
-
/* close tarfile handle */
int
tar_close(TAR *t)
{
int i;
- i = (*(t->type->closefunc))(t->type->call_data, t->fd);
+ i = (*(t->type->closefunc))(t->type->call_data);
if (t->h != NULL)
libtar_hash_free(t->h, ((t->oflags & O_ACCMODE) == O_RDONLY
diff --git a/Utilities/cmtar/libtar.c b/Utilities/cmtar/libtar.c
index 58326b0..a4c9741 100644
--- a/Utilities/cmtar/libtar.c
+++ b/Utilities/cmtar/libtar.c
@@ -110,24 +110,21 @@ int libtar_gzopen(void* call_data, const char *pathname, int oflags, mode_t mode
return fd;
}
-int libtar_gzclose(void* call_data, int fd)
+int libtar_gzclose(void* call_data)
{
struct gzStruct* gzf = (struct gzStruct*)call_data;
- (void)fd;
return cm_zlib_gzclose(gzf->GZFile);
}
-ssize_t libtar_gzread(void* call_data, int fd, void* buf, size_t count)
+ssize_t libtar_gzread(void* call_data, void* buf, size_t count)
{
struct gzStruct* gzf = (struct gzStruct*)call_data;
- (void)fd;
return cm_zlib_gzread(gzf->GZFile, buf, count);
}
-ssize_t libtar_gzwrite(void* call_data, int fd, const void* buf, size_t count)
+ssize_t libtar_gzwrite(void* call_data, const void* buf, size_t count)
{
struct gzStruct* gzf = (struct gzStruct*)call_data;
- (void)fd;
return cm_zlib_gzwrite(gzf->GZFile, (void*)buf, count);
}
diff --git a/Utilities/cmtar/libtar.h b/Utilities/cmtar/libtar.h
index 9990a97..fb87e5b 100644
--- a/Utilities/cmtar/libtar.h
+++ b/Utilities/cmtar/libtar.h
@@ -20,8 +20,7 @@
#include <libtar/libtar_listhash.h>
#include <libtar/compat.h>
#ifdef __cplusplus
-extern "C"
-{
+extern "C" {
#endif
@@ -63,9 +62,9 @@ struct tar_header
/***** handle.c ************************************************************/
typedef int (*openfunc_t)(void* call_data, const char *, int, mode_t);
-typedef int (*closefunc_t)(void* call_data, int);
-typedef ssize_t (*readfunc_t)(void* call_data, int, void *, size_t);
-typedef ssize_t (*writefunc_t)(void* call_data, int, const void *, size_t);
+typedef int (*closefunc_t)(void* call_data);
+typedef ssize_t (*readfunc_t)(void* call_data, void *, size_t);
+typedef ssize_t (*writefunc_t)(void* call_data, const void *, size_t);
typedef struct
{
@@ -81,7 +80,6 @@ typedef struct
{
tartype_t *type;
char *pathname;
- long fd;
int oflags;
int options;
struct tar_header th_buf;
@@ -103,7 +101,6 @@ TAR;
extern const char libtar_version[];
-
/* open a new tarfile handle */
int tar_open(TAR **t, char *pathname, tartype_t *type,
int oflags, int mode, int options);
@@ -112,15 +109,6 @@ int tar_open(TAR **t, char *pathname, tartype_t *type,
int tar_fdopen(TAR **t, int fd, char *pathname, tartype_t *type,
int oflags, int mode, int options);
-/* returns the descriptor associated with t */
-int tar_fd(TAR *t);
-
-/* returns the descriptor associated with t */
-void* tar_call_data(TAR *t);
-
-/* returns the descriptor associated with t */
-void tar_set_call_data(TAR *t, void* cd);
-
/* close tarfile handle */
int tar_close(TAR *t);
@@ -152,9 +140,9 @@ int tar_append_regfile(TAR *t, char *realname);
/* macros for reading/writing tarchive blocks */
#define tar_block_read(t, buf) \
- (*((t)->type->readfunc))((t)->type->call_data, (t)->fd, (char *)(buf), T_BLOCKSIZE)
+ (*((t)->type->readfunc))((t)->type->call_data, (char *)(buf), T_BLOCKSIZE)
#define tar_block_write(t, buf) \
- (*((t)->type->writefunc))((t)->type->call_data, (t)->fd, (char *)(buf), T_BLOCKSIZE)
+ (*((t)->type->writefunc))((t)->type->call_data, (char *)(buf), T_BLOCKSIZE)
/* read/write a header block */
int th_read(TAR *t);