From ffa5bc27268f89cb726c557d194378cd7a6a8832 Mon Sep 17 00:00:00 2001 From: Jon Dufresne Date: Mon, 14 Nov 2016 17:48:54 -0800 Subject: [PATCH] Use generator expressions instead of list comprehension Avoids unnecessary temporary lists in memory. --- PIL/GifImagePlugin.py | 2 +- PIL/ImageMorph.py | 4 ++-- PIL/JpegImagePlugin.py | 2 +- PIL/TiffImagePlugin.py | 2 +- Tests/helper.py | 2 +- Tests/test_file_gif.py | 2 +- Tests/test_font_pcf.py | 2 +- Tests/test_imagemorph.py | 4 ++-- setup.py | 8 +++----- 9 files changed, 13 insertions(+), 15 deletions(-) diff --git a/PIL/GifImagePlugin.py b/PIL/GifImagePlugin.py index 8b2dfac0a..2775a00f1 100644 --- a/PIL/GifImagePlugin.py +++ b/PIL/GifImagePlugin.py @@ -600,7 +600,7 @@ def _get_palette_bytes(im, palette, info): if palette and isinstance(palette, bytes): source_palette = palette[:768] else: - source_palette = bytearray([i//3 for i in range(768)]) + source_palette = bytearray(i//3 for i in range(768)) used_palette_colors = palette_bytes = None diff --git a/PIL/ImageMorph.py b/PIL/ImageMorph.py index 748ecdb61..0bbfbb42b 100644 --- a/PIL/ImageMorph.py +++ b/PIL/ImageMorph.py @@ -78,7 +78,7 @@ class LutBuilder(object): def build_default_lut(self): symbols = [0, 1] m = 1 << 4 # pos of current pixel - self.lut = bytearray([symbols[(i & m) > 0] for i in range(LUT_SIZE)]) + self.lut = bytearray(symbols[(i & m) > 0] for i in range(LUT_SIZE)) def get_lut(self): return self.lut @@ -88,7 +88,7 @@ class LutBuilder(object): string permuted according to the permutation list. """ assert(len(permutation) == 9) - return ''.join([pattern[p] for p in permutation]) + return ''.join(pattern[p] for p in permutation) def _pattern_permute(self, basic_pattern, options, basic_result): """pattern_permute takes a basic pattern and its result and clones diff --git a/PIL/JpegImagePlugin.py b/PIL/JpegImagePlugin.py index ef229e611..6d4e588c0 100644 --- a/PIL/JpegImagePlugin.py +++ b/PIL/JpegImagePlugin.py @@ -408,7 +408,7 @@ def _fixup_dict(src_dict): except: pass return value - return dict([(k, _fixup(v)) for k, v in src_dict.items()]) + return dict((k, _fixup(v)) for k, v in src_dict.items()) def _getexif(self): diff --git a/PIL/TiffImagePlugin.py b/PIL/TiffImagePlugin.py index 52e04654c..d442c3766 100644 --- a/PIL/TiffImagePlugin.py +++ b/PIL/TiffImagePlugin.py @@ -132,7 +132,7 @@ COMPRESSION_INFO = { 34677: "tiff_sgilog24", } -COMPRESSION_INFO_REV = dict([(v, k) for (k, v) in COMPRESSION_INFO.items()]) +COMPRESSION_INFO_REV = dict((v, k) for (k, v) in COMPRESSION_INFO.items()) OPEN_INFO = { # (ByteOrder, PhotoInterpretation, SampleFormat, FillOrder, BitsPerSample, diff --git a/Tests/helper.py b/Tests/helper.py index 9f1501249..5cfd7678f 100644 --- a/Tests/helper.py +++ b/Tests/helper.py @@ -49,7 +49,7 @@ class PillowTestCase(unittest.TestCase): len(a), len(b), msg or "got length %s, expected %s" % (len(a), len(b))) self.assertTrue( - all([x == y for x, y in zip(a, b)]), + all(x == y for x, y in zip(a, b)), msg or "got %s, expected %s" % (a, b)) except: self.assertEqual(a, b, msg) diff --git a/Tests/test_file_gif.py b/Tests/test_file_gif.py index 83318366b..1672a14f0 100644 --- a/Tests/test_file_gif.py +++ b/Tests/test_file_gif.py @@ -60,7 +60,7 @@ class TestFileGif(PillowTestCase): def check(colors, size, expected_palette_length): # make an image with empty colors in the start of the palette range im = Image.frombytes('P', (colors,colors), - bytes(bytearray(list(range(256-colors,256))*colors))) + bytes(bytearray(range(256-colors,256))*colors)) im = im.resize((size,size)) outfile = BytesIO() im.save(outfile, 'GIF') diff --git a/Tests/test_font_pcf.py b/Tests/test_font_pcf.py index 6afa9d476..25c5d7001 100644 --- a/Tests/test_font_pcf.py +++ b/Tests/test_font_pcf.py @@ -55,7 +55,7 @@ class TestFontPcf(PillowTestCase): self.assert_image_equal(image, compare) def test_high_characters(self): - message = "".join([chr(i+1) for i in range(140, 232)]) + message = "".join(chr(i+1) for i in range(140, 232)) self._test_high_characters(message) # accept bytes instances in Py3. if bytes is not str: diff --git a/Tests/test_imagemorph.py b/Tests/test_imagemorph.py index 22372b78d..ea54417a2 100644 --- a/Tests/test_imagemorph.py +++ b/Tests/test_imagemorph.py @@ -25,8 +25,8 @@ class MorphTests(PillowTestCase): chars = '.1' width, height = im.size return '\n'.join( - [''.join([chars[im.getpixel((c, r)) > 0] for c in range(width)]) - for r in range(height)]) + ''.join(chars[im.getpixel((c, r)) > 0] for c in range(width)) + for r in range(height)) def string_to_img(self, image_string): """Turn a string image representation into a binary image""" diff --git a/setup.py b/setup.py index 5d75884d4..4f82363c6 100644 --- a/setup.py +++ b/setup.py @@ -405,8 +405,7 @@ class pil_build_ext(build_ext): best_path = None for name in os.listdir(program_files): if name.startswith('OpenJPEG '): - version = tuple([int(x) for x in name[9:].strip().split( - '.')]) + version = tuple(int(x) for x in name[9:].strip().split('.')) if version > best_version: best_version = version best_path = os.path.join(program_files, name) @@ -466,7 +465,7 @@ class pil_build_ext(build_ext): os.path.isfile(os.path.join(directory, name, 'openjpeg.h')): _dbg('Found openjpeg.h in %s/%s', (directory, name)) - version = tuple([int(x) for x in name[9:].split('.')]) + version = tuple(int(x) for x in name[9:].split('.')) if best_version is None or version > best_version: best_version = version best_path = os.path.join(directory, name) @@ -479,8 +478,7 @@ class pil_build_ext(build_ext): # include path _add_directory(self.compiler.include_dirs, best_path, 0) feature.jpeg2000 = 'openjp2' - feature.openjpeg_version = '.'.join([str(x) for x in - best_version]) + feature.openjpeg_version = '.'.join(str(x) for x in best_version) if feature.want('imagequant'): _dbg('Looking for imagequant')