Stuff
This commit is contained in:
parent
c296b54827
commit
0dfac6b9ce
@ -7,9 +7,9 @@
|
|||||||
#include "internal.h"
|
#include "internal.h"
|
||||||
#ifdef BB_GZIP
|
#ifdef BB_GZIP
|
||||||
|
|
||||||
#ifndef BB_ZCAT
|
//#ifndef BB_ZCAT
|
||||||
#error you need zcat to have gzip support!
|
//#error you need zcat to have gzip support!
|
||||||
#endif
|
//#endif
|
||||||
|
|
||||||
static const char gzip_usage[] =
|
static const char gzip_usage[] =
|
||||||
"gzip [OPTION]... [FILE]...\n\n"
|
"gzip [OPTION]... [FILE]...\n\n"
|
||||||
@ -276,7 +276,7 @@ extern int save_orig_name; /* set if original name must be saved */
|
|||||||
#define WARN(msg) {if (!quiet) fprintf msg ; \
|
#define WARN(msg) {if (!quiet) fprintf msg ; \
|
||||||
if (exit_code == OK) exit_code = WARNING;}
|
if (exit_code == OK) exit_code = WARNING;}
|
||||||
|
|
||||||
local void do_exit(int exitcode);
|
local void do_exit(int exitcode) __attribute__ ((noreturn));
|
||||||
|
|
||||||
/* in zip.c: */
|
/* in zip.c: */
|
||||||
extern int zip OF((int in, int out));
|
extern int zip OF((int in, int out));
|
||||||
@ -1762,9 +1762,6 @@ unsigned outcnt; /* bytes in output buffer */
|
|||||||
|
|
||||||
/* local functions */
|
/* local functions */
|
||||||
|
|
||||||
local void treat_stdin OF((void));
|
|
||||||
static int (*work) OF((int infile, int outfile)) = zip; /* function to call */
|
|
||||||
|
|
||||||
#define strequ(s1, s2) (strcmp((s1),(s2)) == 0)
|
#define strequ(s1, s2) (strcmp((s1),(s2)) == 0)
|
||||||
|
|
||||||
/* ======================================================================== */
|
/* ======================================================================== */
|
||||||
@ -1774,6 +1771,9 @@ static int (*work) OF((int infile, int outfile)) = zip; /* function to call */
|
|||||||
int gzip_main(int argc, char ** argv)
|
int gzip_main(int argc, char ** argv)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
int inFileNum;
|
||||||
|
int outFileNum;
|
||||||
|
|
||||||
/* Parse any options */
|
/* Parse any options */
|
||||||
while (--argc > 0 && **(++argv) == '-') {
|
while (--argc > 0 && **(++argv) == '-') {
|
||||||
while (*(++(*argv))) {
|
while (*(++(*argv))) {
|
||||||
@ -1817,20 +1817,13 @@ int gzip_main(int argc, char ** argv)
|
|||||||
ALLOC(ush, tab_prefix1, 1L<<(BITS-1));
|
ALLOC(ush, tab_prefix1, 1L<<(BITS-1));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
if (tostdout==1) {
|
||||||
/* And get to work */
|
/* And get to work */
|
||||||
treat_stdin();
|
|
||||||
do_exit(exit_code);
|
|
||||||
return exit_code; /* just to avoid lint warning */
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ========================================================================
|
|
||||||
* Compress or decompress stdin
|
|
||||||
*/
|
|
||||||
local void treat_stdin()
|
|
||||||
{
|
|
||||||
SET_BINARY_MODE(fileno(stdout));
|
SET_BINARY_MODE(fileno(stdout));
|
||||||
strcpy(ifname, "stdin");
|
strcpy(ifname, "stdin");
|
||||||
strcpy(ofname, "stdout");
|
strcpy(ofname, "stdout");
|
||||||
|
inFileNum=fileno(stdin);
|
||||||
|
outFileNum=fileno(stdout);
|
||||||
|
|
||||||
/* Get the time stamp on the input file. */
|
/* Get the time stamp on the input file. */
|
||||||
time_stamp = 0; /* time unknown by default */
|
time_stamp = 0; /* time unknown by default */
|
||||||
@ -1840,9 +1833,51 @@ local void treat_stdin()
|
|||||||
clear_bufs(); /* clear input and output buffers */
|
clear_bufs(); /* clear input and output buffers */
|
||||||
part_nb = 0;
|
part_nb = 0;
|
||||||
|
|
||||||
/* Actually do the compression/decompression. Loop over zipped members.
|
/* Actually do the compression/decompression. */
|
||||||
*/
|
zip(inFileNum, outFileNum);
|
||||||
if ((*work)(fileno(stdin), fileno(stdout)) != OK) return;
|
|
||||||
|
} else {
|
||||||
|
int result;
|
||||||
|
struct stat statBuf;
|
||||||
|
|
||||||
|
/* And get to work */
|
||||||
|
if (*argv=='\0')
|
||||||
|
usage(gzip_usage);
|
||||||
|
strncpy(ifname, *argv, MAX_PATH_LEN);
|
||||||
|
strncpy(ofname, *argv, MAX_PATH_LEN-4);
|
||||||
|
strcat(ofname, ".gz");
|
||||||
|
|
||||||
|
inFileNum=open( ifname, O_RDONLY);
|
||||||
|
if (inFileNum < 0) {
|
||||||
|
perror(ifname);
|
||||||
|
do_exit(WARNING);
|
||||||
|
}
|
||||||
|
result = stat(ifname, &statBuf);
|
||||||
|
if (result < 0) {
|
||||||
|
perror(ifname);
|
||||||
|
do_exit(WARNING);
|
||||||
|
}
|
||||||
|
|
||||||
|
outFileNum=open( ofname, O_RDONLY);
|
||||||
|
if (outFileNum < 0) {
|
||||||
|
perror(ofname);
|
||||||
|
do_exit(WARNING);
|
||||||
|
}
|
||||||
|
SET_BINARY_MODE(outFileNum);
|
||||||
|
|
||||||
|
/* Get the time stamp on the input file. */
|
||||||
|
time_stamp = statBuf.st_ctime; /* time unknown by default */
|
||||||
|
|
||||||
|
ifile_size = statBuf.st_size; /* convention for unknown size */
|
||||||
|
|
||||||
|
clear_bufs(); /* clear input and output buffers */
|
||||||
|
part_nb = 0;
|
||||||
|
|
||||||
|
/* Actually do the compression/decompression. */
|
||||||
|
zip(inFileNum, outFileNum);
|
||||||
|
}
|
||||||
|
|
||||||
|
do_exit(exit_code);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ========================================================================
|
/* ========================================================================
|
||||||
|
75
gzip.c
75
gzip.c
@ -7,9 +7,9 @@
|
|||||||
#include "internal.h"
|
#include "internal.h"
|
||||||
#ifdef BB_GZIP
|
#ifdef BB_GZIP
|
||||||
|
|
||||||
#ifndef BB_ZCAT
|
//#ifndef BB_ZCAT
|
||||||
#error you need zcat to have gzip support!
|
//#error you need zcat to have gzip support!
|
||||||
#endif
|
//#endif
|
||||||
|
|
||||||
static const char gzip_usage[] =
|
static const char gzip_usage[] =
|
||||||
"gzip [OPTION]... [FILE]...\n\n"
|
"gzip [OPTION]... [FILE]...\n\n"
|
||||||
@ -276,7 +276,7 @@ extern int save_orig_name; /* set if original name must be saved */
|
|||||||
#define WARN(msg) {if (!quiet) fprintf msg ; \
|
#define WARN(msg) {if (!quiet) fprintf msg ; \
|
||||||
if (exit_code == OK) exit_code = WARNING;}
|
if (exit_code == OK) exit_code = WARNING;}
|
||||||
|
|
||||||
local void do_exit(int exitcode);
|
local void do_exit(int exitcode) __attribute__ ((noreturn));
|
||||||
|
|
||||||
/* in zip.c: */
|
/* in zip.c: */
|
||||||
extern int zip OF((int in, int out));
|
extern int zip OF((int in, int out));
|
||||||
@ -1762,9 +1762,6 @@ unsigned outcnt; /* bytes in output buffer */
|
|||||||
|
|
||||||
/* local functions */
|
/* local functions */
|
||||||
|
|
||||||
local void treat_stdin OF((void));
|
|
||||||
static int (*work) OF((int infile, int outfile)) = zip; /* function to call */
|
|
||||||
|
|
||||||
#define strequ(s1, s2) (strcmp((s1),(s2)) == 0)
|
#define strequ(s1, s2) (strcmp((s1),(s2)) == 0)
|
||||||
|
|
||||||
/* ======================================================================== */
|
/* ======================================================================== */
|
||||||
@ -1774,6 +1771,9 @@ static int (*work) OF((int infile, int outfile)) = zip; /* function to call */
|
|||||||
int gzip_main(int argc, char ** argv)
|
int gzip_main(int argc, char ** argv)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
int inFileNum;
|
||||||
|
int outFileNum;
|
||||||
|
|
||||||
/* Parse any options */
|
/* Parse any options */
|
||||||
while (--argc > 0 && **(++argv) == '-') {
|
while (--argc > 0 && **(++argv) == '-') {
|
||||||
while (*(++(*argv))) {
|
while (*(++(*argv))) {
|
||||||
@ -1817,20 +1817,13 @@ int gzip_main(int argc, char ** argv)
|
|||||||
ALLOC(ush, tab_prefix1, 1L<<(BITS-1));
|
ALLOC(ush, tab_prefix1, 1L<<(BITS-1));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
if (tostdout==1) {
|
||||||
/* And get to work */
|
/* And get to work */
|
||||||
treat_stdin();
|
|
||||||
do_exit(exit_code);
|
|
||||||
return exit_code; /* just to avoid lint warning */
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ========================================================================
|
|
||||||
* Compress or decompress stdin
|
|
||||||
*/
|
|
||||||
local void treat_stdin()
|
|
||||||
{
|
|
||||||
SET_BINARY_MODE(fileno(stdout));
|
SET_BINARY_MODE(fileno(stdout));
|
||||||
strcpy(ifname, "stdin");
|
strcpy(ifname, "stdin");
|
||||||
strcpy(ofname, "stdout");
|
strcpy(ofname, "stdout");
|
||||||
|
inFileNum=fileno(stdin);
|
||||||
|
outFileNum=fileno(stdout);
|
||||||
|
|
||||||
/* Get the time stamp on the input file. */
|
/* Get the time stamp on the input file. */
|
||||||
time_stamp = 0; /* time unknown by default */
|
time_stamp = 0; /* time unknown by default */
|
||||||
@ -1840,9 +1833,51 @@ local void treat_stdin()
|
|||||||
clear_bufs(); /* clear input and output buffers */
|
clear_bufs(); /* clear input and output buffers */
|
||||||
part_nb = 0;
|
part_nb = 0;
|
||||||
|
|
||||||
/* Actually do the compression/decompression. Loop over zipped members.
|
/* Actually do the compression/decompression. */
|
||||||
*/
|
zip(inFileNum, outFileNum);
|
||||||
if ((*work)(fileno(stdin), fileno(stdout)) != OK) return;
|
|
||||||
|
} else {
|
||||||
|
int result;
|
||||||
|
struct stat statBuf;
|
||||||
|
|
||||||
|
/* And get to work */
|
||||||
|
if (*argv=='\0')
|
||||||
|
usage(gzip_usage);
|
||||||
|
strncpy(ifname, *argv, MAX_PATH_LEN);
|
||||||
|
strncpy(ofname, *argv, MAX_PATH_LEN-4);
|
||||||
|
strcat(ofname, ".gz");
|
||||||
|
|
||||||
|
inFileNum=open( ifname, O_RDONLY);
|
||||||
|
if (inFileNum < 0) {
|
||||||
|
perror(ifname);
|
||||||
|
do_exit(WARNING);
|
||||||
|
}
|
||||||
|
result = stat(ifname, &statBuf);
|
||||||
|
if (result < 0) {
|
||||||
|
perror(ifname);
|
||||||
|
do_exit(WARNING);
|
||||||
|
}
|
||||||
|
|
||||||
|
outFileNum=open( ofname, O_RDONLY);
|
||||||
|
if (outFileNum < 0) {
|
||||||
|
perror(ofname);
|
||||||
|
do_exit(WARNING);
|
||||||
|
}
|
||||||
|
SET_BINARY_MODE(outFileNum);
|
||||||
|
|
||||||
|
/* Get the time stamp on the input file. */
|
||||||
|
time_stamp = statBuf.st_ctime; /* time unknown by default */
|
||||||
|
|
||||||
|
ifile_size = statBuf.st_size; /* convention for unknown size */
|
||||||
|
|
||||||
|
clear_bufs(); /* clear input and output buffers */
|
||||||
|
part_nb = 0;
|
||||||
|
|
||||||
|
/* Actually do the compression/decompression. */
|
||||||
|
zip(inFileNum, outFileNum);
|
||||||
|
}
|
||||||
|
|
||||||
|
do_exit(exit_code);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ========================================================================
|
/* ========================================================================
|
||||||
|
Loading…
x
Reference in New Issue
Block a user