diff options
author | Rémi Verschelde <remi@verschelde.fr> | 2021-06-29 12:44:20 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-06-29 12:44:20 +0200 |
commit | 05336adb86574608b5ab922d20a06428331287cc (patch) | |
tree | d2b951c7c1ac7cfc7216910ea3157c7e76382dbe /core/io/image.cpp | |
parent | 9c6d7f840f6f226e5d422fc7697cb75ead6c401b (diff) | |
parent | 3dae9993acf489aa46ccb7a3420a2e67ee59362f (diff) | |
download | redot-engine-05336adb86574608b5ab922d20a06428331287cc.tar.gz |
Merge pull request #49905 from pfertyk/issue-46480-image-compress-crashes-godot
Validate image formats, check if resize_to_po2 failed
Diffstat (limited to 'core/io/image.cpp')
-rw-r--r-- | core/io/image.cpp | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/core/io/image.cpp b/core/io/image.cpp index 3e79b7efbc..3112dd217f 100644 --- a/core/io/image.cpp +++ b/core/io/image.cpp @@ -2380,6 +2380,8 @@ Error Image::decompress() { } Error Image::compress(CompressMode p_mode, CompressSource p_source, float p_lossy_quality) { + ERR_FAIL_INDEX_V_MSG(p_mode, COMPRESS_MAX, ERR_INVALID_PARAMETER, "Invalid compress mode."); + ERR_FAIL_INDEX_V_MSG(p_source, COMPRESS_SOURCE_MAX, ERR_INVALID_PARAMETER, "Invalid compress source."); return compress_from_channels(p_mode, detect_used_channels(p_source), p_lossy_quality); } @@ -2405,6 +2407,9 @@ Error Image::compress_from_channels(CompressMode p_mode, UsedChannels p_channels ERR_FAIL_COND_V(!_image_compress_bptc_func, ERR_UNAVAILABLE); _image_compress_bptc_func(this, p_lossy_quality, p_channels); } break; + case COMPRESS_MAX: { + ERR_FAIL_V(ERR_INVALID_PARAMETER); + } break; } return OK; |