Sync usage with man page.
[netbsd-mini2440.git] / external / bsd / file / dist / src / magic.h
blobacf4a6f65cb1e5c7b8356560d796bd8752daa99d
1 /* $NetBSD$ */
3 /*
4 * Copyright (c) Christos Zoulas 2003.
5 * All Rights Reserved.
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 * 1. Redistributions of source code must retain the above copyright
11 * notice immediately at the beginning of the file, without modification,
12 * this list of conditions, and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
18 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR
21 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27 * SUCH DAMAGE.
29 #ifndef _MAGIC_H
30 #define _MAGIC_H
32 #include <sys/types.h>
34 #define MAGIC_NONE 0x000000 /* No flags */
35 #define MAGIC_DEBUG 0x000001 /* Turn on debugging */
36 #define MAGIC_SYMLINK 0x000002 /* Follow symlinks */
37 #define MAGIC_COMPRESS 0x000004 /* Check inside compressed files */
38 #define MAGIC_DEVICES 0x000008 /* Look at the contents of devices */
39 #define MAGIC_MIME_TYPE 0x000010 /* Return the MIME type */
40 #define MAGIC_CONTINUE 0x000020 /* Return all matches */
41 #define MAGIC_CHECK 0x000040 /* Print warnings to stderr */
42 #define MAGIC_PRESERVE_ATIME 0x000080 /* Restore access time on exit */
43 #define MAGIC_RAW 0x000100 /* Don't translate unprintable chars */
44 #define MAGIC_ERROR 0x000200 /* Handle ENOENT etc as real errors */
45 #define MAGIC_MIME_ENCODING 0x000400 /* Return the MIME encoding */
46 #define MAGIC_MIME (MAGIC_MIME_TYPE|MAGIC_MIME_ENCODING)
47 #define MAGIC_APPLE 0x000800 /* Return the Apple creator and type */
48 #define MAGIC_NO_CHECK_COMPRESS 0x001000 /* Don't check for compressed files */
49 #define MAGIC_NO_CHECK_TAR 0x002000 /* Don't check for tar files */
50 #define MAGIC_NO_CHECK_SOFT 0x004000 /* Don't check magic entries */
51 #define MAGIC_NO_CHECK_APPTYPE 0x008000 /* Don't check application type */
52 #define MAGIC_NO_CHECK_ELF 0x010000 /* Don't check for elf details */
53 #define MAGIC_NO_CHECK_TEXT 0x020000 /* Don't check for text files */
54 #define MAGIC_NO_CHECK_CDF 0x040000 /* Don't check for cdf files */
55 #define MAGIC_NO_CHECK_TOKENS 0x100000 /* Don't check tokens */
56 #define MAGIC_NO_CHECK_ENCODING 0x200000 /* Don't check text encodings */
58 /* Defined for backwards compatibility (renamed) */
59 #define MAGIC_NO_CHECK_ASCII MAGIC_NO_CHECK_TEXT
61 /* Defined for backwards compatibility; do nothing */
62 #define MAGIC_NO_CHECK_FORTRAN 0x000000 /* Don't check ascii/fortran */
63 #define MAGIC_NO_CHECK_TROFF 0x000000 /* Don't check ascii/troff */
66 #ifdef __cplusplus
67 extern "C" {
68 #endif
70 typedef struct magic_set *magic_t;
71 magic_t magic_open(int);
72 void magic_close(magic_t);
74 const char *magic_file(magic_t, const char *);
75 const char *magic_descriptor(magic_t, int);
76 const char *magic_buffer(magic_t, const void *, size_t);
78 const char *magic_error(magic_t);
79 int magic_setflags(magic_t, int);
81 int magic_load(magic_t, const char *);
82 int magic_compile(magic_t, const char *);
83 int magic_check(magic_t, const char *);
84 int magic_errno(magic_t);
86 #ifdef __cplusplus
88 #endif
90 #endif /* _MAGIC_H */