Skip to content

Commit

Permalink
Merge pull request #948 from kmilos/fix_warn_size_t
Browse files Browse the repository at this point in the history
Use portable types to avoid cast warnings
  • Loading branch information
farindk authored Oct 9, 2023
2 parents c5c2d46 + 1ad8f64 commit 4c51939
Show file tree
Hide file tree
Showing 5 changed files with 13 additions and 13 deletions.
2 changes: 1 addition & 1 deletion examples/heif_info.cc
Original file line number Diff line number Diff line change
Expand Up @@ -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<uint8_t> 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());
Expand Down
2 changes: 1 addition & 1 deletion libheif/heif.cc
Original file line number Diff line number Diff line change
Expand Up @@ -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<RegionGeometry_InlineMask> mask = std::dynamic_pointer_cast<RegionGeometry_InlineMask>(region->region);
if (mask) {
Expand Down
2 changes: 1 addition & 1 deletion libheif/heif.h
Original file line number Diff line number Diff line change
Expand Up @@ -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);


/**
Expand Down
18 changes: 9 additions & 9 deletions libheif/uncompressed_image.cc
Original file line number Diff line number Diff line change
Expand Up @@ -713,13 +713,13 @@ Error UncompressedImageCodec::decode_uncompressed_image(const std::shared_ptr<co
uint8_t* dst = img->get_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];
}
Expand All @@ -740,13 +740,13 @@ Error UncompressedImageCodec::decode_uncompressed_image(const std::shared_ptr<co
uint8_t* dst = img->get_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);
}
Expand Down Expand Up @@ -973,7 +973,7 @@ Error UncompressedImageCodec::encode_uncompressed_image(const std::shared_ptr<He
std::vector<uint8_t> 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;
Expand All @@ -991,7 +991,7 @@ Error UncompressedImageCodec::encode_uncompressed_image(const std::shared_ptr<He
{
if (src_image->get_chroma_format() == heif_chroma_444)
{
unsigned long offset = 0;
uint64_t offset = 0;
std::vector<heif_channel> channels = {heif_channel_R, heif_channel_G, heif_channel_B};
if (src_image->has_channel(heif_channel_Alpha))
{
Expand Down Expand Up @@ -1053,7 +1053,7 @@ Error UncompressedImageCodec::encode_uncompressed_image(const std::shared_ptr<He
}
else if (src_image->get_colorspace() == heif_colorspace_monochrome)
{
unsigned long offset = 0;
uint64_t offset = 0;
std::vector<heif_channel> channels;
if (src_image->has_channel(heif_channel_Alpha))
{
Expand Down
2 changes: 1 addition & 1 deletion tests/region.cc
Original file line number Diff line number Diff line change
Expand Up @@ -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<uint8_t> mask_data_in(data_len);
Expand Down

0 comments on commit 4c51939

Please sign in to comment.