ImtImagePlugin.py 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. #
  2. # The Python Imaging Library.
  3. # $Id$
  4. #
  5. # IM Tools support for PIL
  6. #
  7. # history:
  8. # 1996-05-27 fl Created (read 8-bit images only)
  9. # 2001-02-17 fl Use 're' instead of 'regex' (Python 2.1) (0.2)
  10. #
  11. # Copyright (c) Secret Labs AB 1997-2001.
  12. # Copyright (c) Fredrik Lundh 1996-2001.
  13. #
  14. # See the README file for information on usage and redistribution.
  15. #
  16. from __future__ import annotations
  17. import re
  18. from . import Image, ImageFile
  19. #
  20. # --------------------------------------------------------------------
  21. field = re.compile(rb"([a-z]*) ([^ \r\n]*)")
  22. ##
  23. # Image plugin for IM Tools images.
  24. class ImtImageFile(ImageFile.ImageFile):
  25. format = "IMT"
  26. format_description = "IM Tools"
  27. def _open(self):
  28. # Quick rejection: if there's not a LF among the first
  29. # 100 bytes, this is (probably) not a text header.
  30. buffer = self.fp.read(100)
  31. if b"\n" not in buffer:
  32. msg = "not an IM file"
  33. raise SyntaxError(msg)
  34. xsize = ysize = 0
  35. while True:
  36. if buffer:
  37. s = buffer[:1]
  38. buffer = buffer[1:]
  39. else:
  40. s = self.fp.read(1)
  41. if not s:
  42. break
  43. if s == b"\x0C":
  44. # image data begins
  45. self.tile = [
  46. (
  47. "raw",
  48. (0, 0) + self.size,
  49. self.fp.tell() - len(buffer),
  50. (self.mode, 0, 1),
  51. )
  52. ]
  53. break
  54. else:
  55. # read key/value pair
  56. if b"\n" not in buffer:
  57. buffer += self.fp.read(100)
  58. lines = buffer.split(b"\n")
  59. s += lines.pop(0)
  60. buffer = b"\n".join(lines)
  61. if len(s) == 1 or len(s) > 100:
  62. break
  63. if s[0] == ord(b"*"):
  64. continue # comment
  65. m = field.match(s)
  66. if not m:
  67. break
  68. k, v = m.group(1, 2)
  69. if k == b"width":
  70. xsize = int(v)
  71. self._size = xsize, ysize
  72. elif k == b"height":
  73. ysize = int(v)
  74. self._size = xsize, ysize
  75. elif k == b"pixel" and v == b"n8":
  76. self._mode = "L"
  77. #
  78. # --------------------------------------------------------------------
  79. Image.register_open(ImtImageFile.format, ImtImageFile)
  80. #
  81. # no extension registered (".im" is simply too common)