images 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. #------------------------------------------------------------------------------
  2. # images: file(1) magic for image formats (see also "iff")
  3. #
  4. # originally from jef@helios.ee.lbl.gov (Jef Poskanzer),
  5. # additions by janl@ifi.uio.no as well as others. Jan also suggested
  6. # merging several one- and two-line files into here.
  7. #
  8. # little magic: PCX (first byte is 0x0a)
  9. # Targa - matches `povray', `ppmtotga' and `xv' outputs
  10. # by Philippe De Muyter <phdm@macqel.be>
  11. # at 2, byte ImgType must be 1, 2, 3, 9, 10 or 11
  12. # at 1, byte CoMapType must be 1 if ImgType is 1 or 9, 0 otherwise
  13. # at 3, leshort Index is 0 for povray, ppmtotga and xv outputs
  14. # `xv' recognizes only a subset of the following (RGB with pixelsize = 24)
  15. # `tgatoppm' recognizes a superset (Index may be anything)
  16. 1 belong&0xfff7ffff 0x01010000 Targa image data - Map
  17. >2 byte&8 8 - RLE
  18. 1 belong&0xfff7ffff 0x00020000 Targa image data - RGB
  19. >2 byte&8 8 - RLE
  20. 1 belong&0xfff7ffff 0x00030000 Targa image data - Mono
  21. >2 byte&8 8 - RLE
  22. # PBMPLUS images
  23. # The next byte following the magic is always whitespace.
  24. 0 string P1 PBM image text
  25. 0 string P2 PGM image text
  26. 0 string P3 PPM image text
  27. 0 string P4 PBM "rawbits" image data
  28. 0 string P5 PGM "rawbits" image data
  29. 0 string P6 PPM "rawbits" image data
  30. # NIFF (Navy Interchange File Format, a modification of TIFF) images
  31. 0 string IIN1 NIFF image data
  32. # Tag Image File Format, from Daniel Quinlan (quinlan@yggdrasil.com)
  33. # The second word of TIFF files is the TIFF version number, 42, which has
  34. # never changed. The TIFF specification recommends testing for it.
  35. 0 string MM\x00\x2a TIFF image data, big-endian
  36. 0 string II\x2a\x00 TIFF image data, little-endian
  37. # PNG [Portable Network Graphics, or "PNG's Not GIF"] images
  38. # (Greg Roelofs, newt@uchicago.edu)
  39. # (Albert Cahalan, acahalan@cs.uml.edu)
  40. #
  41. # 137 P N G \r \n ^Z \n [4-byte length] H E A D [HEAD data] [HEAD crc] ...
  42. #
  43. 0 string \x89PNG PNG image data,
  44. >4 belong !0x0d0a1a0a CORRUPTED,
  45. >4 belong 0x0d0a1a0a
  46. >>16 belong x %ld x
  47. >>20 belong x %ld,
  48. >>24 byte x %d-bit
  49. >>25 byte 0 grayscale,
  50. >>25 byte 2 \b/color RGB,
  51. >>25 byte 3 colormap,
  52. >>25 byte 4 gray+alpha,
  53. >>25 byte 6 \b/color RGBA,
  54. #>>26 byte 0 deflate/32K,
  55. >>28 byte 0 non-interlaced
  56. >>28 byte 1 interlaced
  57. 1 string PNG PNG image data, CORRUPTED
  58. # GIF
  59. 0 string GIF8 GIF image data
  60. >4 string 7a \b, version 8%s,
  61. >4 string 9a \b, version 8%s,
  62. >6 leshort >0 %hd x
  63. >8 leshort >0 %hd,
  64. #>10 byte &0x80 color mapped,
  65. #>10 byte&0x07 =0x00 2 colors
  66. #>10 byte&0x07 =0x01 4 colors
  67. #>10 byte&0x07 =0x02 8 colors
  68. #>10 byte&0x07 =0x03 16 colors
  69. #>10 byte&0x07 =0x04 32 colors
  70. #>10 byte&0x07 =0x05 64 colors
  71. #>10 byte&0x07 =0x06 128 colors
  72. #>10 byte&0x07 =0x07 256 colors
  73. # ITC (CMU WM) raster files. It is essentially a byte-reversed Sun raster,
  74. # 1 plane, no encoding.
  75. 0 string \361\0\100\273 CMU window manager raster image data
  76. >4 lelong >0 %d x
  77. >8 lelong >0 %d,
  78. >12 lelong >0 %d-bit
  79. # Magick Image File Format
  80. 0 string id=ImageMagick MIFF image data
  81. # Artisan
  82. 0 long 1123028772 Artisan image data
  83. >4 long 1 \b, rectangular 24-bit
  84. >4 long 2 \b, rectangular 8-bit with colormap
  85. >4 long 3 \b, rectangular 32-bit (24-bit with matte)
  86. # FIG (Facility for Interactive Generation of figures), an object-based format
  87. 0 string #FIG FIG image text
  88. >5 string x \b, version %.3s
  89. # PHIGS
  90. 0 string ARF_BEGARF PHIGS clear text archive
  91. 0 string @(#)SunPHIGS SunPHIGS
  92. # version number follows, in the form m.n
  93. >40 string SunBin binary
  94. >32 string archive archive
  95. # GKS (Graphics Kernel System)
  96. 0 string GKSM GKS Metafile
  97. >24 string SunGKS \b, SunGKS
  98. # CGM image files
  99. 0 string BEGMF clear text Computer Graphics Metafile
  100. # XXX - questionable magic
  101. 0 beshort&0xffe0 0x0020 binary Computer Graphics Metafile
  102. 0 beshort 0x3020 character Computer Graphics Metafile
  103. # MGR bitmaps (Michael Haardt, u31b3hs@pool.informatik.rwth-aachen.de)
  104. 0 string yz MGR bitmap, modern format, 8-bit aligned
  105. 0 string zz MGR bitmap, old format, 1-bit deep, 16-bit aligned
  106. 0 string xz MGR bitmap, old format, 1-bit deep, 32-bit aligned
  107. 0 string yx MGR bitmap, modern format, squeezed
  108. # Fuzzy Bitmap (FBM) images
  109. 0 string %bitmap\0 FBM image data
  110. >30 long 0x31 \b, mono
  111. >30 long 0x33 \b, color
  112. # facsimile data
  113. 1 string PC\ Research,\ Inc group 3 fax data
  114. >29 byte 0 \b, normal resolution (204x98 DPI)
  115. >29 byte 1 \b, fine resolution (204x196 DPI)
  116. # PC bitmaps (OS/2, Windoze BMP files) (Greg Roelofs, newt@uchicago.edu)
  117. 0 string BM PC bitmap data
  118. >14 leshort 12 \b, OS/2 1.x format
  119. >>18 leshort x \b, %d x
  120. >>20 leshort x %d
  121. >14 leshort 64 \b, OS/2 2.x format
  122. >>18 leshort x \b, %d x
  123. >>20 leshort x %d
  124. >14 leshort 40 \b, Windows 3.x format
  125. >>18 lelong x \b, %d x
  126. >>22 lelong x %d x
  127. >>28 leshort x %d
  128. 0 string IC PC icon data
  129. 0 string PI PC pointer image data
  130. 0 string CI PC color icon data
  131. 0 string CP PC color pointer image data
  132. # Conflicts with other entries [BABYL]
  133. #0 string BA PC bitmap array data
  134. # XPM icons (Greg Roelofs, newt@uchicago.edu)
  135. # note possible collision with C/REXX entry in c-lang; currently commented out
  136. 0 string /*\ XPM\ */ X pixmap image text
  137. # Utah Raster Toolkit RLE images (janl@ifi.uio.no)
  138. 0 leshort 0xcc52 RLE image data,
  139. >6 leshort x %d x
  140. >8 leshort x %d
  141. >2 leshort >0 \b, lower left corner: %d
  142. >4 leshort >0 \b, lower right corner: %d
  143. >10 byte&0x1 =0x1 \b, clear first
  144. >10 byte&0x2 =0x2 \b, no background
  145. >10 byte&0x4 =0x4 \b, alpha channel
  146. >10 byte&0x8 =0x8 \b, comment
  147. >11 byte >0 \b, %d color channels
  148. >12 byte >0 \b, %d bits per pixel
  149. >13 byte >0 \b, %d color map channels
  150. # image file format (Robert Potter, potter@cs.rochester.edu)
  151. 0 string Imagefile\ version- iff image data
  152. # this adds the whole header (inc. version number), informative but longish
  153. >10 string >\0 %s
  154. # Sun raster images, from Daniel Quinlan (quinlan@yggdrasil.com)
  155. 0 belong 0x59a66a95 Sun raster image data
  156. >4 belong >0 \b, %d x
  157. >8 belong >0 %d,
  158. >12 belong >0 %d-bit,
  159. #>16 belong >0 %d bytes long,
  160. >20 belong 0 old format,
  161. #>20 belong 1 standard,
  162. >20 belong 2 compressed,
  163. >20 belong 3 RGB,
  164. >20 belong 4 TIFF,
  165. >20 belong 5 IFF,
  166. >20 belong 0xffff reserved for testing,
  167. >24 belong 0 no colormap
  168. >24 belong 1 RGB colormap
  169. >24 belong 2 raw colormap
  170. #>28 belong >0 colormap is %d bytes long
  171. # SGI image file format, from Daniel Quinlan (quinlan@yggdrasil.com)
  172. #
  173. # See
  174. # http://reality.sgi.com/grafica/sgiimage.html
  175. #
  176. 0 beshort 474 SGI image data
  177. #>2 byte 0 \b, verbatim
  178. >2 byte 1 \b, RLE
  179. #>3 byte 1 \b, normal precision
  180. >3 byte 2 \b, high precision
  181. >4 beshort x \b, %d-D
  182. >6 beshort x \b, %d x
  183. >8 beshort x %d
  184. >10 beshort x \b, %d channel
  185. >10 beshort !1 \bs
  186. >80 string >0 \b, "%s"
  187. 0 string IT01 FIT image data
  188. >4 belong x \b, %d x
  189. >8 belong x %d x
  190. >12 belong x %d
  191. #
  192. 0 string IT02 FIT image data
  193. >4 belong x \b, %d x
  194. >8 belong x %d x
  195. >12 belong x %d
  196. #
  197. 2048 string PCD_IPI Kodak Photo CD image pack file
  198. 0 string PCD_OPA Kodak Photo CD overview pack file
  199. # FITS format. Jeff Uphoff <juphoff@tarsier.cv.nrao.edu>
  200. # FITS is the Flexible Image Transport System, the de facto standard for
  201. # data and image transfer, storage, etc., for the astronomical community.
  202. # (FITS floating point formats are big-endian.)
  203. 0 string SIMPLE\ \ = FITS image data
  204. >109 string 8 \b, 8-bit, character or unsigned binary integer
  205. >108 string 16 \b, 16-bit, two's complement binary integer
  206. >107 string \ 32 \b, 32-bit, two's complement binary integer
  207. >107 string -32 \b, 32-bit, floating point, single precision
  208. >107 string -64 \b, 64-bit, floating point, double precision
  209. # other images
  210. 0 string This\ is\ a\ BitMap\ file Lisp Machine bit-array-file
  211. 0 string !! Bennet Yee's "face" format
  212. # From SunOS 5.5.1 "/etc/magic" - appeared right before Sun raster image
  213. # stuff.
  214. #
  215. 0 beshort 0x1010 PEX Binary Archive
  216. # Visio drawings
  217. 03000 string Visio\ (TM)\ Drawing %s