images 8.3 KB

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