compress 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. #------------------------------------------------------------------------------
  2. # compress: file(1) magic for pure-compression formats (no archives)
  3. #
  4. # compress, gzip, pack, compact, huf, squeeze, crunch, freeze, yabba, etc.
  5. #
  6. # Formats for various forms of compressed data
  7. # Formats for "compress" proper have been moved into "compress.c",
  8. # because it tries to uncompress it to figure out what's inside.
  9. # standard unix compress
  10. 0 string \037\235 compress'd data
  11. >2 byte&0x80 >0 block compressed
  12. >2 byte&0x1f x %d bits
  13. # gzip (GNU zip, not to be confused with Info-ZIP or PKWARE zip archiver)
  14. 0 string \037\213 gzip compressed data
  15. >2 byte <8 \b, reserved method,
  16. >2 byte 8 \b, deflated,
  17. >3 byte &0x01 ASCII,
  18. >3 byte &0x02 continuation,
  19. >3 byte &0x04 extra field,
  20. >3 byte &0x08 original filename,
  21. >3 byte &0x10 comment,
  22. >3 byte &0x20 encrypted,
  23. >4 ledate x last modified: %s,
  24. >8 byte 2 max compression,
  25. >8 byte 4 max speed,
  26. >9 byte =0x00 os: MS-DOS
  27. >9 byte =0x01 os: Amiga
  28. >9 byte =0x02 os: VMS
  29. >9 byte =0x03 os: Unix
  30. >9 byte =0x05 os: Atari
  31. >9 byte =0x06 os: OS/2
  32. >9 byte =0x07 os: MacOS
  33. >9 byte =0x0A os: Tops/20
  34. >9 byte =0x0B os: Win/32
  35. # packed data, Huffman (minimum redundancy) codes on a byte-by-byte basis
  36. 0 string \037\036 packed data
  37. >2 belong >1 \b, %d characters originally
  38. >2 belong =1 \b, %d character originally
  39. #
  40. # This magic number is byte-order-independent. XXX - Does that mean this
  41. # is big-endian, little-endian, either, or that you can't tell?
  42. # this short is valid for SunOS
  43. 0 short 017437 old packed data
  44. # XXX - why *two* entries for "compacted data", one of which is
  45. # byte-order independent, and one of which is byte-order dependent?
  46. #
  47. 0 short 0x1fff compacted data
  48. # This string is valid for SunOS (BE) and a matching "short" is listed
  49. # in the Ultrix (LE) magic file.
  50. 0 string \377\037 compacted data
  51. 0 short 0145405 huf output
  52. # Squeeze and Crunch...
  53. # These numbers were gleaned from the Unix versions of the programs to
  54. # handle these formats. Note that I can only uncrunch, not crunch, and
  55. # I didn't have a crunched file handy, so the crunch number is untested.
  56. # Keith Waclena <keith@cerberus.uchicago.edu>
  57. 0 leshort 0x76FF squeezed data (CP/M, DOS)
  58. 0 leshort 0x76FE crunched data (CP/M, DOS)
  59. # Freeze
  60. 0 string \037\237 frozen file 2.1
  61. 0 string \037\236 frozen file 1.0 (or gzip 0.5)
  62. # SCO compress -H (LZH)
  63. 0 string \037\240 SCO compress -H (LZH) data
  64. # European GSM 06.10 is a provisional standard for full-rate speech
  65. # transcoding, prI-ETS 300 036, which uses RPE/LTP (residual pulse
  66. # excitation/long term prediction) coding at 13 kbit/s.
  67. #
  68. # There's only a magic nibble (4 bits); that nibble repeats every 33
  69. # bytes. This isn't suited for use, but maybe we can use it someday.
  70. #
  71. # This will cause very short GSM files to be declared as data and
  72. # mismatches to be declared as data too!
  73. #0 byte&0xF0 0xd0 data
  74. #>33 byte&0xF0 0xd0
  75. #>66 byte&0xF0 0xd0
  76. #>99 byte&0xF0 0xd0
  77. #>132 byte&0xF0 0xd0 GSM 06.10 compressed audio