svn commit: r239646 - stable/9/usr.bin/unzip
Dag-Erling Smørgrav
des at FreeBSD.org
Fri Aug 24 10:09:35 UTC 2012
Author: des
Date: Fri Aug 24 10:09:34 2012
New Revision: 239646
URL: http://svn.freebsd.org/changeset/base/239646
Log:
MFH (r236226): pass filename to libarchive rather than descriptor
Modified:
stable/9/usr.bin/unzip/unzip.c
Directory Properties:
stable/9/usr.bin/unzip/ (props changed)
Modified: stable/9/usr.bin/unzip/unzip.c
==============================================================================
--- stable/9/usr.bin/unzip/unzip.c Fri Aug 24 09:58:14 2012 (r239645)
+++ stable/9/usr.bin/unzip/unzip.c Fri Aug 24 10:09:34 2012 (r239646)
@@ -865,19 +865,14 @@ unzip(const char *fn)
{
struct archive *a;
struct archive_entry *e;
- int fd, ret;
+ int ret;
uintmax_t total_size, file_count, error_count;
- if (strcmp(fn, "-") == 0)
- fd = STDIN_FILENO;
- else if ((fd = open(fn, O_RDONLY)) < 0)
- error("%s", fn);
-
if ((a = archive_read_new()) == NULL)
error("archive_read_new failed");
ac(archive_read_support_format_zip(a));
- ac(archive_read_open_fd(a, fd, 8192));
+ ac(archive_read_open_filename(a, fn, 8192));
if (!zipinfo_mode) {
if (!p_opt && !q_opt)
@@ -933,9 +928,6 @@ unzip(const char *fn)
ac(archive_read_close(a));
(void)archive_read_finish(a);
- if (fd != STDIN_FILENO && close(fd) != 0)
- error("%s", fn);
-
if (t_opt) {
if (error_count > 0) {
errorx("%d checksum error(s) found.", error_count);
@@ -1061,6 +1053,9 @@ main(int argc, char *argv[])
usage();
zipfile = argv[nopts++];
+ if (strcmp(zipfile, "-") == 0)
+ zipfile = NULL; /* STDIN */
+
while (nopts < argc && *argv[nopts] != '-')
add_pattern(&include, argv[nopts++]);
More information about the svn-src-stable
mailing list