diff --git a/examples/heif_info.cc b/examples/heif_info.cc index 96097ef3a8..905611ad06 100644 --- a/examples/heif_info.cc +++ b/examples/heif_info.cc @@ -567,7 +567,7 @@ int main(int argc, char** argv) int32_t y; uint32_t w; uint32_t h; - long unsigned int data_len = heif_region_get_inline_mask_data_len(regions[j]); + size_t data_len = heif_region_get_inline_mask_data_len(regions[j]); std::vector mask_data(data_len); heif_region_get_inline_mask_data(regions[j], &x, &y, &w, &h, mask_data.data()); printf(" inline mask [x=%i, y=%i, w=%u, h=%u, data len=%zu]\n", x, y, w, h, mask_data.size()); diff --git a/libheif/heif.cc b/libheif/heif.cc index f1359ee7f3..cbcb92f765 100644 --- a/libheif/heif.cc +++ b/libheif/heif.cc @@ -3690,7 +3690,7 @@ struct heif_error heif_region_get_referenced_mask_ID(const struct heif_region* r return heif_error_invalid_parameter_value; } -unsigned long int heif_region_get_inline_mask_data_len(const struct heif_region* region) +size_t heif_region_get_inline_mask_data_len(const struct heif_region* region) { const std::shared_ptr mask = std::dynamic_pointer_cast(region->region); if (mask) { diff --git a/libheif/heif.h b/libheif/heif.h index 1749149fe5..20dd26a16c 100644 --- a/libheif/heif.h +++ b/libheif/heif.h @@ -2786,7 +2786,7 @@ struct heif_error heif_region_get_referenced_mask_ID(const struct heif_region* r * @return the number of bytes in the mask data, or 0 on error. */ LIBHEIF_API -unsigned long heif_region_get_inline_mask_data_len(const struct heif_region* region); +size_t heif_region_get_inline_mask_data_len(const struct heif_region* region); /** diff --git a/libheif/uncompressed_image.cc b/libheif/uncompressed_image.cc index b06291d649..a0e987e62b 100644 --- a/libheif/uncompressed_image.cc +++ b/libheif/uncompressed_image.cc @@ -713,13 +713,13 @@ Error UncompressedImageCodec::decode_uncompressed_image(const std::shared_ptrget_plane(channels[c], &stride); for (uint32_t row = 0; row < height; row++) { long unsigned int tile_row_idx = row % tile_height; - long unsigned int tile_row_offset = tile_width * tile_row_idx * channels.size(); + size_t tile_row_offset = tile_width * tile_row_idx * channels.size(); uint32_t col = 0; for (col = 0; col < width; col++) { long unsigned int tile_base_offset = get_tile_base_offset(col, row, uncC, channels, width, height); long unsigned int tile_col = col % tile_width; - long unsigned int tile_offset = tile_row_offset + tile_col * pixel_stride + pixel_offset; - long unsigned int src_offset = tile_base_offset + tile_offset; + size_t tile_offset = tile_row_offset + tile_col * pixel_stride + pixel_offset; + size_t src_offset = tile_base_offset + tile_offset; uint32_t dstPixelIndex = row * stride + col; dst[dstPixelIndex] = src[src_offset]; } @@ -740,13 +740,13 @@ Error UncompressedImageCodec::decode_uncompressed_image(const std::shared_ptrget_plane(channels[c], &stride); for (uint32_t row = 0; row < height; row++) { long unsigned int tile_row_idx = row % tile_height; - long unsigned int tile_row_offset = tile_width * (tile_row_idx * channels.size() + pixel_offset); + size_t tile_row_offset = tile_width * (tile_row_idx * channels.size() + pixel_offset); uint32_t col = 0; for (col = 0; col < width; col += tile_width) { long unsigned int tile_base_offset = get_tile_base_offset(col, row, uncC, channels, width, height); long unsigned int tile_col = col % tile_width; - long unsigned int tile_offset = tile_row_offset + tile_col; - long unsigned int src_offset = tile_base_offset + tile_offset; + size_t tile_offset = tile_row_offset + tile_col; + size_t src_offset = tile_base_offset + tile_offset; uint32_t dst_offset = row * stride + col; memcpy(dst + dst_offset, uncompressed_data.data() + src_offset, tile_width); } @@ -973,7 +973,7 @@ Error UncompressedImageCodec::encode_uncompressed_image(const std::shared_ptr data; if (src_image->get_colorspace() == heif_colorspace_YCbCr) { - unsigned long offset = 0; + uint64_t offset = 0; for (heif_channel channel : {heif_channel_Y, heif_channel_Cb, heif_channel_Cr}) { int src_stride; @@ -991,7 +991,7 @@ Error UncompressedImageCodec::encode_uncompressed_image(const std::shared_ptrget_chroma_format() == heif_chroma_444) { - unsigned long offset = 0; + uint64_t offset = 0; std::vector channels = {heif_channel_R, heif_channel_G, heif_channel_B}; if (src_image->has_channel(heif_channel_Alpha)) { @@ -1053,7 +1053,7 @@ Error UncompressedImageCodec::encode_uncompressed_image(const std::shared_ptrget_colorspace() == heif_colorspace_monochrome) { - unsigned long offset = 0; + uint64_t offset = 0; std::vector channels; if (src_image->has_channel(heif_channel_Alpha)) { diff --git a/tests/region.cc b/tests/region.cc index 833b128b31..5ce6e25562 100644 --- a/tests/region.cc +++ b/tests/region.cc @@ -421,7 +421,7 @@ TEST_CASE("create inline mask region from data") { int num_regions_returned = heif_region_item_get_list_of_regions(in_region_item, regions.data(), (int)(regions.size())); REQUIRE(num_regions_returned == num_regions); REQUIRE(heif_region_get_type(regions[0]) == heif_region_type_inline_mask); - long unsigned int data_len = heif_region_get_inline_mask_data_len(regions[0]); + size_t data_len = heif_region_get_inline_mask_data_len(regions[0]); int32_t x, y; uint32_t width, height; std::vector mask_data_in(data_len);