| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417 | .\" $File: libmagic.man,v 1.46 2022/09/15 16:54:14 christos Exp $.\".\" Copyright (c) Christos Zoulas 2003, 2018, 2022.\" All Rights Reserved..\".\" 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..\".Dd September 15, 2022.Dt LIBMAGIC 3.Os.Sh NAME.Nm magic_open ,.Nm magic_close ,.Nm magic_error ,.Nm magic_errno ,.Nm magic_descriptor ,.Nm magic_buffer ,.Nm magic_getflags ,.Nm magic_setflags ,.Nm magic_check ,.Nm magic_compile ,.Nm magic_list ,.Nm magic_load ,.Nm magic_load_buffers ,.Nm magic_setparam ,.Nm magic_getparam ,.Nm magic_version.Nd Magic number recognition library.Sh LIBRARY.Lb libmagic.Sh SYNOPSIS.In magic.h.Ft magic_t.Fn magic_open "int flags".Ft void.Fn magic_close "magic_t cookie".Ft const char *.Fn magic_error "magic_t cookie".Ft int.Fn magic_errno "magic_t cookie".Ft const char *.Fn magic_descriptor "magic_t cookie" "int fd".Ft const char *.Fn magic_file "magic_t cookie" "const char *filename".Ft const char *.Fn magic_buffer "magic_t cookie" "const void *buffer" "size_t length".Ft int.Fn magic_getflags "magic_t cookie".Ft int.Fn magic_setflags "magic_t cookie" "int flags".Ft int.Fn magic_check "magic_t cookie" "const char *filename".Ft int.Fn magic_compile "magic_t cookie" "const char *filename".Ft int.Fn magic_list "magic_t cookie" "const char *filename".Ft int.Fn magic_load "magic_t cookie" "const char *filename".Ft int.Fn magic_load_buffers "magic_t cookie" "void **buffers" "size_t *sizes" "size_t nbuffers".Ft int.Fn magic_getparam "magic_t cookie" "int param" "void *value".Ft int.Fn magic_setparam "magic_t cookie" "int param" "const void *value".Ft int.Fn magic_version "void".Sh DESCRIPTIONThese functionsoperate on the magic database filewhich is describedin.Xr magic __FSECTION__ ..PpThe function.Fn magic_opencreates a magic cookie pointer and returns it.It returns.Dv NULLif there was an error allocating the magic cookie.The.Ar flagsargument specifies how the other magic functions should behave:.Bl -tag -width MAGIC_COMPRESS.It Dv MAGIC_NONENo special handling..It Dv MAGIC_DEBUGPrint debugging messages to stderr..It Dv MAGIC_SYMLINKIf the file queried is a symlink, follow it..It Dv MAGIC_COMPRESSIf the file is compressed, unpack it and look at the contents..It Dv MAGIC_DEVICESIf the file is a block or character special device, then open the deviceand try to look in its contents..It Dv MAGIC_MIME_TYPEReturn a MIME type string, instead of a textual description..It Dv MAGIC_MIME_ENCODINGReturn a MIME encoding, instead of a textual description..It Dv MAGIC_MIMEA shorthand for MAGIC_MIME_TYPE | MAGIC_MIME_ENCODING..It Dv MAGIC_CONTINUEReturn all matches, not just the first..It Dv MAGIC_CHECKCheck the magic database for consistency and print warnings to stderr..It Dv MAGIC_PRESERVE_ATIMEOn systems that support.Xr utime 3or.Xr utimes 2 ,attempt to preserve the access time of files analysed..It Dv MAGIC_RAWDon't translate unprintable characters to a \eooo octal representation..It Dv MAGIC_ERRORTreat operating system errors while trying to open files and follow symlinksas real errors, instead of printing them in the magic buffer..It Dv MAGIC_APPLEReturn the Apple creator and type..It Dv MAGIC_EXTENSIONReturn a slash-separated list of extensions for this file type..It Dv MAGIC_COMPRESS_TRANSPDon't report on compression, only report about the uncompressed data..It Dv MAGIC_NO_CHECK_APPTYPEDon't check for.Dv EMXapplication type (only on EMX)..It Dv MAGIC_NO_COMPRESS_FORKDon't allow decompressors that use fork..It Dv MAGIC_NO_CHECK_CDFDon't get extra information on MS Composite Document Files..It Dv MAGIC_NO_CHECK_COMPRESSDon't look inside compressed files..It Dv MAGIC_NO_CHECK_ELFDon't print ELF details..It Dv MAGIC_NO_CHECK_ENCODINGDon't check text encodings..It Dv MAGIC_NO_CHECK_SOFTDon't consult magic files..It Dv MAGIC_NO_CHECK_TARDon't examine tar files..It Dv MAGIC_NO_CHECK_TEXTDon't check for various types of text files..It Dv MAGIC_NO_CHECK_TOKENSDon't look for known tokens inside ascii files..It Dv MAGIC_NO_CHECK_JSONDon't examine JSON files..It Dv MAGIC_NO_CHECK_CSVDon't examine CSV files..El.PpThe.Fn magic_closefunction closes the.Xr magic __FSECTION__database and deallocates any resources used..PpThe.Fn magic_errorfunction returns a textual explanation of the last error, or.Dv NULLif there was no error..PpThe.Fn magic_errnofunction returns the last operating system error number.Pq Xr errno 2that was encountered by a system call..PpThe.Fn magic_filefunction returns a textual description of the contents of the.Ar filenameargument, or.Dv NULLif an error occurred.If the.Ar filenameis.Dv NULL ,then stdin is used..PpThe.Fn magic_descriptorfunction returns a textual description of the contents of the.Ar fdargument, or.Dv NULLif an error occurred..PpThe.Fn magic_bufferfunction returns a textual description of the contents of the.Ar bufferargument with.Ar lengthbytes size..PpThe.Fn magic_getflagsfunctions returns a value representing current.Ar flagsset..PpThe.Fn magic_setflagsfunction sets the.Ar flagsdescribed above.Note that using both MIME flags together can alsoreturn extra information on the charset..PpThe.Fn magic_checkfunction can be used to check the validity of entries in the colonseparated database files passed in as.Ar filename ,or.Dv NULLfor the default database.It returns 0 on success and \-1 on failure..PpThe.Fn magic_compilefunction can be used to compile the colonseparated list of database files passed in as.Ar filename ,or.Dv NULLfor the default database.It returns 0 on success and \-1 on failure.The compiled files created are named from the.Xr basename 1of each file argument with.Dq .mgcappended to it..PpThe.Fn magic_listfunction dumps all magic entries in a human readable format,dumping first the entries that are matched against binary files and then theones that match text files.It takes and optional.Fa filenameargument which is a colon separated list of database files, or.Dv NULLfor the default database..PpThe.Fn magic_loadfunction must be used to load the colonseparated list of database files passed in as.Ar filename ,or.Dv NULLfor the default database file before any magic queries can performed..PpThe default database file is named by the MAGIC environment variable.If that variable is not set, the default database file name is __MAGIC__..Fn magic_loadadds.Dq .mgcto the database filename as appropriate..PpThe.Fn magic_load_buffersfunction takes an array of size.Fa nbuffersof.Fa bufferswith a respective size for each in the array of.Fa sizesloaded with the contents of the magic databases from the filesystem.This function can be used in environment where the magic library doesnot have direct access to the filesystem, but can access the magicdatabase via shared memory or other IPC means..PpThe.Fn magic_getparamand.Fn magic_setparamallow getting and setting various limits related to the magiclibrary..Bl -column "MAGIC_PARAM_ELF_PHNUM_MAX" "size_t" "Default" -offset indent.It Sy "Parameter" Ta Sy "Type" Ta Sy "Default".It Li MAGIC_PARAM_INDIR_MAX Ta size_t Ta 15.It Li MAGIC_PARAM_NAME_MAX Ta size_t Ta 30.It Li MAGIC_PARAM_ELF_NOTES_MAX Ta size_t Ta 256.It Li MAGIC_PARAM_ELF_PHNUM_MAX Ta size_t Ta 128.It Li MAGIC_PARAM_ELF_SHNUM_MAX Ta size_t Ta 32768.It Li MAGIC_PARAM_REGEX_MAX Ta size_t Ta 8192.It Li MAGIC_PARAM_BYTES_MAX Ta size_t Ta 1048576.El.PpThe.Dv MAGIC_PARAM_INDIR_RECURSIONparameter controls how many levels of recursion will be followed forindirect magic entries..PpThe.Dv MAGIC_PARAM_NAME_RECURSIONparameter controls how many levels of recursion will be followed forfor name/use calls..PpThe.Dv MAGIC_PARAM_NAME_MAXparameter controls the maximum number of calls for name/use..PpThe.Dv MAGIC_PARAM_NOTES_MAXparameter controls how many ELF notes will be processed..PpThe.Dv MAGIC_PARAM_PHNUM_MAXparameter controls how many ELF program sections will be processed..PpThe.Dv MAGIC_PARAM_SHNUM_MAXparameter controls how many ELF sections will be processed..PpThe.Fn magic_versioncommand returns the version number of this library which is compiled intothe shared library using the constant.Dv MAGIC_VERSIONfrom.In magic.h .This can be used by client programs to verify that the version they compileagainst is the same as the version that they run against..Sh RETURN VALUESThe function.Fn magic_openreturns a magic cookie on success and.Dv NULLon failure setting errno to an appropriate value.It will set errno to.Er EINVALif an unsupported value for flags was given.The.Fn magic_list ,.Fn magic_load ,.Fn magic_compile ,and.Fn magic_checkfunctions return 0 on success and \-1 on failure.The.Fn magic_buffer ,.Fn magic_getpath ,and.Fn magic_file ,functions return a string on success and.Dv NULLon failure.The.Fn magic_errorfunction returns a textual description of the errors of the abovefunctions, or.Dv NULLif there was no error.The.Fn magic_versionalways returns the version number of the library.Finally,.Fn magic_setflagsreturns \-1 on systems that don't support.Xr utime 3 ,or.Xr utimes 2when.Dv MAGIC_PRESERVE_ATIMEis set..Sh FILES.Bl -tag -width __MAGIC__.mgc -compact.It Pa __MAGIC__The non-compiled default magic database..It Pa __MAGIC__.mgcThe compiled default magic database..El.Sh SEE ALSO.Xr file __CSECTION__ ,.Xr magic __FSECTION__.Sh BUGSThe results from.Fn magic_bufferand.Fn magic_filewhere the buffer and the file contain the same datacan produce different results, because in the.Fn magic_filecase, the program can.Xr lseek 2and.Xr stat 2the file descriptor..Sh AUTHORS.An M\(oans Rullg\(oardInitial libmagic implementation, and configuration..An Christos ZoulasAPI cleanup, error code and allocation handling.
 |