mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-01-12 18:26:17 +03:00
Merge pull request #8578 from python-pillow/pre-commit-ci-update-config
[pre-commit.ci] pre-commit autoupdate
This commit is contained in:
commit
595bdf2057
|
@ -1,6 +1,6 @@
|
||||||
repos:
|
repos:
|
||||||
- repo: https://github.com/astral-sh/ruff-pre-commit
|
- repo: https://github.com/astral-sh/ruff-pre-commit
|
||||||
rev: v0.7.2
|
rev: v0.8.1
|
||||||
hooks:
|
hooks:
|
||||||
- id: ruff
|
- id: ruff
|
||||||
args: [--exit-non-zero-on-fix]
|
args: [--exit-non-zero-on-fix]
|
||||||
|
@ -11,7 +11,7 @@ repos:
|
||||||
- id: black
|
- id: black
|
||||||
|
|
||||||
- repo: https://github.com/PyCQA/bandit
|
- repo: https://github.com/PyCQA/bandit
|
||||||
rev: 1.7.10
|
rev: 1.8.0
|
||||||
hooks:
|
hooks:
|
||||||
- id: bandit
|
- id: bandit
|
||||||
args: [--severity-level=high]
|
args: [--severity-level=high]
|
||||||
|
@ -24,7 +24,7 @@ repos:
|
||||||
exclude: (Makefile$|\.bat$|\.cmake$|\.eps$|\.fits$|\.gd$|\.opt$)
|
exclude: (Makefile$|\.bat$|\.cmake$|\.eps$|\.fits$|\.gd$|\.opt$)
|
||||||
|
|
||||||
- repo: https://github.com/pre-commit/mirrors-clang-format
|
- repo: https://github.com/pre-commit/mirrors-clang-format
|
||||||
rev: v19.1.3
|
rev: v19.1.4
|
||||||
hooks:
|
hooks:
|
||||||
- id: clang-format
|
- id: clang-format
|
||||||
types: [c]
|
types: [c]
|
||||||
|
@ -50,7 +50,7 @@ repos:
|
||||||
exclude: ^.github/.*TEMPLATE|^Tests/(fonts|images)/
|
exclude: ^.github/.*TEMPLATE|^Tests/(fonts|images)/
|
||||||
|
|
||||||
- repo: https://github.com/python-jsonschema/check-jsonschema
|
- repo: https://github.com/python-jsonschema/check-jsonschema
|
||||||
rev: 0.29.4
|
rev: 0.30.0
|
||||||
hooks:
|
hooks:
|
||||||
- id: check-github-workflows
|
- id: check-github-workflows
|
||||||
- id: check-readthedocs
|
- id: check-readthedocs
|
||||||
|
@ -67,7 +67,7 @@ repos:
|
||||||
- id: pyproject-fmt
|
- id: pyproject-fmt
|
||||||
|
|
||||||
- repo: https://github.com/abravalheri/validate-pyproject
|
- repo: https://github.com/abravalheri/validate-pyproject
|
||||||
rev: v0.22
|
rev: v0.23
|
||||||
hooks:
|
hooks:
|
||||||
- id: validate-pyproject
|
- id: validate-pyproject
|
||||||
additional_dependencies: [trove-classifiers>=2024.10.12]
|
additional_dependencies: [trove-classifiers>=2024.10.12]
|
||||||
|
|
|
@ -357,7 +357,7 @@ def _save(im: Image.Image, fp: IO[bytes], filename: str | bytes) -> None:
|
||||||
name = "".join([name[: 92 - len(ext)], ext])
|
name = "".join([name[: 92 - len(ext)], ext])
|
||||||
|
|
||||||
fp.write(f"Name: {name}\r\n".encode("ascii"))
|
fp.write(f"Name: {name}\r\n".encode("ascii"))
|
||||||
fp.write(("Image size (x*y): %d*%d\r\n" % im.size).encode("ascii"))
|
fp.write(f"Image size (x*y): {im.size[0]}*{im.size[1]}\r\n".encode("ascii"))
|
||||||
fp.write(f"File size (no of images): {frames}\r\n".encode("ascii"))
|
fp.write(f"File size (no of images): {frames}\r\n".encode("ascii"))
|
||||||
if im.mode in ["P", "PA"]:
|
if im.mode in ["P", "PA"]:
|
||||||
fp.write(b"Lut: 1\r\n")
|
fp.write(b"Lut: 1\r\n")
|
||||||
|
|
|
@ -692,13 +692,10 @@ class Image:
|
||||||
)
|
)
|
||||||
|
|
||||||
def __repr__(self) -> str:
|
def __repr__(self) -> str:
|
||||||
return "<%s.%s image mode=%s size=%dx%d at 0x%X>" % (
|
return (
|
||||||
self.__class__.__module__,
|
f"<{self.__class__.__module__}.{self.__class__.__name__} "
|
||||||
self.__class__.__name__,
|
f"image mode={self.mode} size={self.size[0]}x{self.size[1]} "
|
||||||
self.mode,
|
f"at 0x{id(self):X}>"
|
||||||
self.size[0],
|
|
||||||
self.size[1],
|
|
||||||
id(self),
|
|
||||||
)
|
)
|
||||||
|
|
||||||
def _repr_pretty_(self, p: PrettyPrinter, cycle: bool) -> None:
|
def _repr_pretty_(self, p: PrettyPrinter, cycle: bool) -> None:
|
||||||
|
@ -707,14 +704,8 @@ class Image:
|
||||||
# Same as __repr__ but without unpredictable id(self),
|
# Same as __repr__ but without unpredictable id(self),
|
||||||
# to keep Jupyter notebook `text/plain` output stable.
|
# to keep Jupyter notebook `text/plain` output stable.
|
||||||
p.text(
|
p.text(
|
||||||
"<%s.%s image mode=%s size=%dx%d>"
|
f"<{self.__class__.__module__}.{self.__class__.__name__} "
|
||||||
% (
|
f"image mode={self.mode} size={self.size[0]}x{self.size[1]}>"
|
||||||
self.__class__.__module__,
|
|
||||||
self.__class__.__name__,
|
|
||||||
self.mode,
|
|
||||||
self.size[0],
|
|
||||||
self.size[1],
|
|
||||||
)
|
|
||||||
)
|
)
|
||||||
|
|
||||||
def _repr_image(self, image_format: str, **kwargs: Any) -> bytes | None:
|
def _repr_image(self, image_format: str, **kwargs: Any) -> bytes | None:
|
||||||
|
|
|
@ -72,7 +72,7 @@ def APP(self: JpegImageFile, marker: int) -> None:
|
||||||
n = i16(self.fp.read(2)) - 2
|
n = i16(self.fp.read(2)) - 2
|
||||||
s = ImageFile._safe_read(self.fp, n)
|
s = ImageFile._safe_read(self.fp, n)
|
||||||
|
|
||||||
app = "APP%d" % (marker & 15)
|
app = f"APP{marker & 15}"
|
||||||
|
|
||||||
self.app[app] = s # compatibility
|
self.app[app] = s # compatibility
|
||||||
self.applist.append((app, s))
|
self.applist.append((app, s))
|
||||||
|
|
|
@ -86,7 +86,7 @@ class PcxImageFile(ImageFile.ImageFile):
|
||||||
|
|
||||||
elif bits == 1 and planes in (2, 4):
|
elif bits == 1 and planes in (2, 4):
|
||||||
mode = "P"
|
mode = "P"
|
||||||
rawmode = "P;%dL" % planes
|
rawmode = f"P;{planes}L"
|
||||||
self.palette = ImagePalette.raw("RGB", s[16:64])
|
self.palette = ImagePalette.raw("RGB", s[16:64])
|
||||||
|
|
||||||
elif version == 5 and bits == 8 and planes == 1:
|
elif version == 5 and bits == 8 and planes == 1:
|
||||||
|
|
|
@ -523,7 +523,7 @@ class PngStream(ChunkStream):
|
||||||
|
|
||||||
assert self.fp is not None
|
assert self.fp is not None
|
||||||
s = ImageFile._safe_read(self.fp, length)
|
s = ImageFile._safe_read(self.fp, length)
|
||||||
raw_vals = struct.unpack(">%dI" % (len(s) // 4), s)
|
raw_vals = struct.unpack(f">{len(s) // 4}I", s)
|
||||||
self.im_info["chromaticity"] = tuple(elt / 100000.0 for elt in raw_vals)
|
self.im_info["chromaticity"] = tuple(elt / 100000.0 for elt in raw_vals)
|
||||||
return s
|
return s
|
||||||
|
|
||||||
|
|
|
@ -935,9 +935,9 @@ class ImageFileDirectory_v2(_IFDv2Base):
|
||||||
self._tagdata[tag] = data
|
self._tagdata[tag] = data
|
||||||
self.tagtype[tag] = typ
|
self.tagtype[tag] = typ
|
||||||
|
|
||||||
msg += " - value: " + (
|
bytes_value = size if size > 32 else repr(data)
|
||||||
"<table: %d bytes>" % size if size > 32 else repr(data)
|
msg += f" - value: <table: {bytes_value} bytes>"
|
||||||
)
|
|
||||||
logger.debug(msg)
|
logger.debug(msg)
|
||||||
|
|
||||||
(self.next,) = (
|
(self.next,) = (
|
||||||
|
@ -981,9 +981,10 @@ class ImageFileDirectory_v2(_IFDv2Base):
|
||||||
|
|
||||||
tagname = TiffTags.lookup(tag, self.group).name
|
tagname = TiffTags.lookup(tag, self.group).name
|
||||||
typname = "ifd" if is_ifd else TYPES.get(typ, "unknown")
|
typname = "ifd" if is_ifd else TYPES.get(typ, "unknown")
|
||||||
msg = f"save: {tagname} ({tag}) - type: {typname} ({typ})"
|
bytes_value = len(data) if len(data) >= 16 else str(values)
|
||||||
msg += " - value: " + (
|
msg = (
|
||||||
"<table: %d bytes>" % len(data) if len(data) >= 16 else str(values)
|
f"save: {tagname} ({tag}) - type: {typname} ({typ})"
|
||||||
|
f" - value: <table: {bytes_value} bytes>"
|
||||||
)
|
)
|
||||||
logger.debug(msg)
|
logger.debug(msg)
|
||||||
|
|
||||||
|
|
|
@ -44,7 +44,7 @@ _T_co = TypeVar("_T_co", covariant=True)
|
||||||
|
|
||||||
|
|
||||||
class SupportsRead(Protocol[_T_co]):
|
class SupportsRead(Protocol[_T_co]):
|
||||||
def read(self, __length: int = ...) -> _T_co: ...
|
def read(self, length: int = ..., /) -> _T_co: ...
|
||||||
|
|
||||||
|
|
||||||
StrOrBytesPath = Union[str, bytes, os.PathLike[str], os.PathLike[bytes]]
|
StrOrBytesPath = Union[str, bytes, os.PathLike[str], os.PathLike[bytes]]
|
||||||
|
|
Loading…
Reference in New Issue
Block a user