summaryrefslogtreecommitdiff
path: root/usr.bin/file/is_tar.c
diff options
context:
space:
mode:
authorTed Unangst <tedu@cvs.openbsd.org>2004-05-19 02:32:37 +0000
committerTed Unangst <tedu@cvs.openbsd.org>2004-05-19 02:32:37 +0000
commit05cabd309934408959a36a9feb018f1bf1e897ee (patch)
treea528b45949c0f3f8e8f232f70213ce635a357a5d /usr.bin/file/is_tar.c
parent2243525ab32c3771528c08a31aa8d25645ee7abc (diff)
big update to file 4.09. ok ian@
Diffstat (limited to 'usr.bin/file/is_tar.c')
-rw-r--r--usr.bin/file/is_tar.c87
1 files changed, 69 insertions, 18 deletions
diff --git a/usr.bin/file/is_tar.c b/usr.bin/file/is_tar.c
index 3a8027f5458..6422fd9e978 100644
--- a/usr.bin/file/is_tar.c
+++ b/usr.bin/file/is_tar.c
@@ -1,10 +1,36 @@
-/* $OpenBSD: is_tar.c,v 1.6 2003/08/02 18:42:11 deraadt Exp $ */
-
+/* $OpenBSD: is_tar.c,v 1.7 2004/05/19 02:32:35 tedu Exp $ */
+/*
+ * Copyright (c) Ian F. Darwin 1986-1995.
+ * Software written by Ian F. Darwin and others;
+ * maintained 1995-present by Christos Zoulas and others.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice immediately at the beginning of the file, without modification,
+ * this list of conditions, and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR
+ * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
/*
* is_tar() -- figure out whether file is a tar archive.
*
* Stolen (by the author!) from the public domain tar program:
- * Pubic Domain version written 26 Aug 1985 John Gilmore (ihnp4!hoptoad!gnu).
+ * Public Domain version written 26 Aug 1985 John Gilmore (ihnp4!hoptoad!gnu).
*
* @(#)list.c 1.18 9/23/86 Public Domain - gnu
*
@@ -12,15 +38,44 @@
* for file command by Ian Darwin.
*/
+#include "file.h"
+#include "magic.h"
#include <string.h>
#include <ctype.h>
#include <sys/types.h>
#include "tar.h"
-#include "file.h"
+
+#ifndef lint
+FILE_RCSID("@(#)$Id: is_tar.c,v 1.7 2004/05/19 02:32:35 tedu Exp $")
+#endif
#define isodigit(c) ( ((c) >= '0') && ((c) <= '7') )
-static int from_oct(int, char*); /* Decode octal number */
+private int is_tar(const unsigned char *, size_t);
+private int from_oct(int, const char *); /* Decode octal number */
+
+protected int
+file_is_tar(struct magic_set *ms, const unsigned char *buf, size_t nbytes)
+{
+ /*
+ * Do the tar test first, because if the first file in the tar
+ * archive starts with a dot, we can confuse it with an nroff file.
+ */
+ switch (is_tar(buf, nbytes)) {
+ case 1:
+ if (file_printf(ms, (ms->flags & MAGIC_MIME) ?
+ "application/x-tar" : "tar archive") == -1)
+ return -1;
+ return 1;
+ case 2:
+ if (file_printf(ms, (ms->flags & MAGIC_MIME) ?
+ "application/x-tar, POSIX" : "POSIX tar archive") == -1)
+ return -1;
+ return 1;
+ default:
+ return 0;
+ }
+}
/*
* Return
@@ -28,15 +83,13 @@ static int from_oct(int, char*); /* Decode octal number */
* 1 for old UNIX tar file,
* 2 for Unix Std (POSIX) tar file.
*/
-int
-is_tar(buf, nbytes)
-unsigned char *buf;
-int nbytes;
+private int
+is_tar(const unsigned char *buf, size_t nbytes)
{
- union record *header = (union record *)buf;
+ const union record *header = (const union record *)(const void *)buf;
int i;
int sum, recsum;
- char *p;
+ const char *p;
if (nbytes < sizeof(union record))
return 0;
@@ -47,7 +100,7 @@ int nbytes;
p = header->charptr;
for (i = sizeof(union record); --i >= 0;) {
/*
- * We can't use unsigned char here because of old compilers,
+ * We cannot use unsigned char here because of old compilers,
* e.g. V7.
*/
sum += 0xFF & *p++;
@@ -73,14 +126,12 @@ int nbytes;
*
* Result is -1 if the field is invalid (all blank, or nonoctal).
*/
-static int
-from_oct(digs, where)
- int digs;
- char *where;
+private int
+from_oct(int digs, const char *where)
{
int value;
- while (isspace(*where)) { /* Skip spaces */
+ while (isspace((unsigned char)*where)) { /* Skip spaces */
where++;
if (--digs <= 0)
return -1; /* All blank field */
@@ -91,7 +142,7 @@ from_oct(digs, where)
--digs;
}
- if (digs > 0 && *where && !isspace(*where))
+ if (digs > 0 && *where && !isspace((unsigned char)*where))
return -1; /* Ended on non-space/nul */
return value;