From 46d64139bd21ddf89f45c2fc2467e84f3a3d0cf0 Mon Sep 17 00:00:00 2001 From: drewcassidy Date: Thu, 11 Mar 2021 02:29:08 -0800 Subject: [PATCH] MSVC what the fuck is your problem --- src/rgbcx/BlockEncoder.h | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/src/rgbcx/BlockEncoder.h b/src/rgbcx/BlockEncoder.h index 0349da7..6b1d6ec 100644 --- a/src/rgbcx/BlockEncoder.h +++ b/src/rgbcx/BlockEncoder.h @@ -64,10 +64,10 @@ template class BlockEncoderTemplate : public Block // threshold for number of blocks before multithreading is set by overriding MTThreshold() #pragma omp parallel for if (block_width * block_height >= MTThreshold()) - for (unsigned y = 0; y < block_height; y++) { - for (unsigned x = 0; x < block_width; x++) { - unsigned pixel_x = x * N; - unsigned pixel_y = y * M; + for (int y = 0; y < (int)block_height; y++) { + for (int x = 0; x < (int)block_width; x++) { + unsigned pixel_x = (unsigned)x * N; + unsigned pixel_y = (unsigned)y * M; assert(pixel_x >= 0); assert(pixel_y >= 0); @@ -75,9 +75,10 @@ template class BlockEncoderTemplate : public Block assert(pixel_x + N <= image_width); unsigned top_left = pixel_x + (pixel_y * image_width); + unsigned block_index = (unsigned)x + (block_width * (unsigned)y); auto src = DecodedBlock(&decoded[top_left], (int)image_width); - EncodeBlock(src, &blocks[x + block_width * y]); + EncodeBlock(src, &blocks[block_index]); } } }