mirror of
				https://github.com/python-pillow/Pillow.git
				synced 2025-10-25 05:01:26 +03:00 
			
		
		
		
	Deprecate non-image and unsupported modes
This commit is contained in:
		
							parent
							
								
									114e01701a
								
							
						
					
					
						commit
						eea3ac765c
					
				|  | @ -678,6 +678,7 @@ def test_auxiliary_channels_isolated() -> None: | ||||||
| 
 | 
 | ||||||
| def test_long_modes() -> None: | def test_long_modes() -> None: | ||||||
|     p = ImageCms.getOpenProfile("Tests/icc/sGrey-v2-nano.icc") |     p = ImageCms.getOpenProfile("Tests/icc/sGrey-v2-nano.icc") | ||||||
|  |     with pytest.warns(DeprecationWarning): | ||||||
|         ImageCms.buildTransform(p, p, "ABCDEFGHI", "ABCDEFGHI") |         ImageCms.buildTransform(p, p, "ABCDEFGHI", "ABCDEFGHI") | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -699,3 +700,9 @@ def test_deprecation() -> None: | ||||||
|         assert ImageCms.VERSION == "1.0.0 pil" |         assert ImageCms.VERSION == "1.0.0 pil" | ||||||
|     with pytest.warns(DeprecationWarning): |     with pytest.warns(DeprecationWarning): | ||||||
|         assert isinstance(ImageCms.FLAGS, dict) |         assert isinstance(ImageCms.FLAGS, dict) | ||||||
|  | 
 | ||||||
|  |     profile = ImageCmsProfile(ImageCms.createProfile("sRGB")) | ||||||
|  |     with pytest.warns(DeprecationWarning): | ||||||
|  |         ImageCms.ImageCmsTransform(profile, profile, "RGBA;16B", "RGB") | ||||||
|  |     with pytest.warns(DeprecationWarning): | ||||||
|  |         ImageCms.ImageCmsTransform(profile, profile, "RGB", "RGBA;16B") | ||||||
|  |  | ||||||
|  | @ -107,6 +107,15 @@ BGR;15, BGR 16 and BGR;24 | ||||||
| 
 | 
 | ||||||
| The experimental BGR;15, BGR;16 and BGR;24 modes have been deprecated. | The experimental BGR;15, BGR;16 and BGR;24 modes have been deprecated. | ||||||
| 
 | 
 | ||||||
|  | Non-image modes in ImageCms | ||||||
|  | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||||||
|  | 
 | ||||||
|  | .. deprecated:: 10.4.0 | ||||||
|  | 
 | ||||||
|  | The use in :py:mod:`.ImageCms` of input modes and output modes that are not Pillow | ||||||
|  | image modes has been deprecated. Defaulting to "L" or "1" if the mode cannot be mapped | ||||||
|  | is also deprecated. | ||||||
|  | 
 | ||||||
| Support for LibTIFF earlier than 4 | Support for LibTIFF earlier than 4 | ||||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -28,6 +28,13 @@ BGR;15, BGR 16 and BGR;24 | ||||||
| 
 | 
 | ||||||
| The experimental BGR;15, BGR;16 and BGR;24 modes have been deprecated. | The experimental BGR;15, BGR;16 and BGR;24 modes have been deprecated. | ||||||
| 
 | 
 | ||||||
|  | Non-image modes in ImageCms | ||||||
|  | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||||||
|  | 
 | ||||||
|  | The use in :py:mod:`.ImageCms` of input modes and output modes that are not Pillow | ||||||
|  | image modes has been deprecated. Defaulting to "L" or "1" if the mode cannot be mapped | ||||||
|  | is also deprecated. | ||||||
|  | 
 | ||||||
| Support for LibTIFF earlier than 4 | Support for LibTIFF earlier than 4 | ||||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -299,6 +299,31 @@ class ImageCmsTransform(Image.ImagePointHandler): | ||||||
|         proof_intent: Intent = Intent.ABSOLUTE_COLORIMETRIC, |         proof_intent: Intent = Intent.ABSOLUTE_COLORIMETRIC, | ||||||
|         flags: Flags = Flags.NONE, |         flags: Flags = Flags.NONE, | ||||||
|     ): |     ): | ||||||
|  |         supported_modes = ( | ||||||
|  |             "RGB", | ||||||
|  |             "RGBA", | ||||||
|  |             "RGBX", | ||||||
|  |             "CMYK", | ||||||
|  |             "I;16", | ||||||
|  |             "I;16L", | ||||||
|  |             "I;16B", | ||||||
|  |             "YCbCr", | ||||||
|  |             "LAB", | ||||||
|  |             "L", | ||||||
|  |             "1", | ||||||
|  |         ) | ||||||
|  |         for mode in (input_mode, output_mode): | ||||||
|  |             if mode not in supported_modes: | ||||||
|  |                 deprecate( | ||||||
|  |                     mode, | ||||||
|  |                     12, | ||||||
|  |                     { | ||||||
|  |                         "L;16": "I;16 or I;16L", | ||||||
|  |                         "L:16B": "I;16B", | ||||||
|  |                         "YCCA": "YCbCr", | ||||||
|  |                         "YCC": "YCbCr", | ||||||
|  |                     }.get(mode), | ||||||
|  |                 ) | ||||||
|         if proof is None: |         if proof is None: | ||||||
|             self.transform = core.buildTransform( |             self.transform = core.buildTransform( | ||||||
|                 input.profile, output.profile, input_mode, output_mode, intent, flags |                 input.profile, output.profile, input_mode, output_mode, intent, flags | ||||||
|  |  | ||||||
|  | @ -223,20 +223,22 @@ findLCMStype(char *PILmode) { | ||||||
|     if (strcmp(PILmode, "CMYK") == 0) { |     if (strcmp(PILmode, "CMYK") == 0) { | ||||||
|         return TYPE_CMYK_8; |         return TYPE_CMYK_8; | ||||||
|     } |     } | ||||||
|     if (strcmp(PILmode, "L;16") == 0) { |     if (strcmp(PILmode, "I;16") == 0 || strcmp(PILmode, "I;16L") == 0 || | ||||||
|  |         strcmp(PILmode, "L;16") == 0) { | ||||||
|         return TYPE_GRAY_16; |         return TYPE_GRAY_16; | ||||||
|     } |     } | ||||||
|     if (strcmp(PILmode, "L;16B") == 0) { |     if (strcmp(PILmode, "I;16B") == 0 || strcmp(PILmode, "L;16B") == 0) { | ||||||
|         return TYPE_GRAY_16_SE; |         return TYPE_GRAY_16_SE; | ||||||
|     } |     } | ||||||
|     if (strcmp(PILmode, "YCCA") == 0 || strcmp(PILmode, "YCC") == 0) { |     if (strcmp(PILmode, "YCbCr") == 0 || strcmp(PILmode, "YCCA") == 0 || | ||||||
|  |         strcmp(PILmode, "YCC") == 0) { | ||||||
|         return TYPE_YCbCr_8; |         return TYPE_YCbCr_8; | ||||||
|     } |     } | ||||||
|     if (strcmp(PILmode, "LAB") == 0) { |     if (strcmp(PILmode, "LAB") == 0) { | ||||||
|         // LabX equivalent like ALab, but not reversed -- no #define in lcms2
 |         // LabX equivalent like ALab, but not reversed -- no #define in lcms2
 | ||||||
|         return (COLORSPACE_SH(PT_LabV2) | CHANNELS_SH(3) | BYTES_SH(1) | EXTRA_SH(1)); |         return (COLORSPACE_SH(PT_LabV2) | CHANNELS_SH(3) | BYTES_SH(1) | EXTRA_SH(1)); | ||||||
|     } |     } | ||||||
|     /* presume "L" by default */ |     /* presume "1" or "L" by default */ | ||||||
|     return TYPE_GRAY_8; |     return TYPE_GRAY_8; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user