Skip to content

Commit

Permalink
heif_item_add_property_uuid()
Browse files Browse the repository at this point in the history
  • Loading branch information
dukesook committed Mar 26, 2024
1 parent d08df5d commit 659c8e3
Show file tree
Hide file tree
Showing 4 changed files with 125 additions and 7 deletions.
14 changes: 8 additions & 6 deletions libheif/box.cc
Original file line number Diff line number Diff line change
Expand Up @@ -392,12 +392,14 @@ Error Box::parse(BitstreamRange& range)
}
else {
uint64_t content_size = get_box_size() - get_header_size();
if (range.prepare_read(content_size)) {
if (content_size > MAX_BOX_SIZE) {
return Error(heif_error_Invalid_input,
heif_suberror_Invalid_box_size);
}

if (content_size > MAX_BOX_SIZE) {
return Error(heif_error_Invalid_input, heif_suberror_Invalid_box_size);
}
else if (get_short_type() == fourcc("uuid")) {
m_uuid_data.resize(content_size);
range.read(m_uuid_data.data(), content_size);
}
else if (range.prepare_read(content_size)) {
range.get_istream()->seek_cur(get_box_size() - get_header_size());
}
}
Expand Down
8 changes: 7 additions & 1 deletion libheif/box.h
Original file line number Diff line number Diff line change
Expand Up @@ -125,8 +125,13 @@ class BoxHeader

std::string get_type_string() const;

std::vector<uint8_t> get_uuid_data() const { return m_uuid_data; }

void set_short_type(uint32_t type) { m_type = type; }

void set_uuid_type(const std::vector<uint8_t>& uuid_type) { m_uuid_type = uuid_type; }

void set_uuid_data(const std::vector<uint8_t>& uuid_data) { m_uuid_data = uuid_data; }

Error parse_header(BitstreamRange& range);

Expand All @@ -140,9 +145,10 @@ class BoxHeader
uint64_t m_size = 0;

uint32_t m_type = 0;
std::vector<uint8_t> m_uuid_type;

protected:
std::vector<uint8_t> m_uuid_type;
std::vector<uint8_t> m_uuid_data;
uint32_t m_header_size = 0;
};

Expand Down
87 changes: 87 additions & 0 deletions libheif/heif_properties.cc
Original file line number Diff line number Diff line change
Expand Up @@ -300,3 +300,90 @@ void heif_property_user_description_release(struct heif_property_user_descriptio
delete udes;
}


struct heif_error heif_item_add_property_uuid(const struct heif_context* context,
heif_item_id itemId,
uint8_t* uuid_type,
uint8_t* data, size_t size,
heif_property_id* out_propertyId)
{
if (!context || !uuid_type || !data) {
return {heif_error_Usage_error, heif_suberror_Null_pointer_argument, "NULL argument passed in"};
}

std::vector<uint8_t> data_vector(data, data + size);
std::vector<uint8_t> uuid_type_vector(uuid_type, uuid_type + 16);

auto uuid_box = std::make_shared<Box>();
uuid_box->set_uuid_type(uuid_type_vector);
uuid_box->set_uuid_data(data_vector);

heif_property_id id = context->context->add_property(itemId, uuid_box, false);

if (out_propertyId) {
*out_propertyId = id;
}

return heif_error_success;
}


struct heif_error heif_item_get_property_uuid_size(const struct heif_context* context,
heif_item_id itemId,
heif_property_id propertyId,
size_t* size_out)
{
auto file = context->context->get_heif_file(); if (!context || !size_out) {
return {heif_error_Usage_error, heif_suberror_Null_pointer_argument, "NULL argument passed in"};
}

std::vector<std::shared_ptr<Box>> properties;
Error err = file->get_properties(itemId, properties);
if (err) {
return err.error_struct(context->context.get());
}

if (propertyId - 1 < 0 || propertyId - 1 >= properties.size()) {
return {heif_error_Usage_error, heif_suberror_Invalid_property, "property index out of range"};
}

auto uuid_box = properties[propertyId - 1];
auto data = uuid_box->get_uuid_data();

*size_out = data.size();

return heif_error_success;
}


struct heif_error heif_item_get_property_uuid(const struct heif_context* context,
heif_item_id itemId,
heif_property_id propertyId,
uint8_t* data_out)
{
if (!context || !data_out) {
return {heif_error_Usage_error, heif_suberror_Null_pointer_argument, "NULL argument passed in"};
}

auto file = context->context->get_heif_file();

std::vector<std::shared_ptr<Box>> properties;
Error err = file->get_properties(itemId, properties);
if (err) {
return err.error_struct(context->context.get());
}

if (propertyId - 1 < 0 || propertyId - 1 >= properties.size()) {
return {heif_error_Usage_error, heif_suberror_Invalid_property, "property index out of range"};
}

auto uuid_box = properties[propertyId - 1];
auto data = uuid_box->get_uuid_data();



std::copy(data.begin(), data.end(), data_out);

return heif_error_success;
}

23 changes: 23 additions & 0 deletions libheif/heif_properties.h
Original file line number Diff line number Diff line change
Expand Up @@ -131,6 +131,29 @@ void heif_item_get_property_transform_crop_borders(const struct heif_context* co
int image_width, int image_height,
int* left, int* top, int* right, int* bottom);

LIBHEIF_API
struct heif_error heif_item_add_property_uuid(const struct heif_context* context,
heif_item_id itemId,
uint8_t* uuid_type,
uint8_t* data, size_t size,
heif_property_id* out_propertyId);

LIBHEIF_API
struct heif_error heif_item_get_property_uuid_size(const struct heif_context* context,
heif_item_id itemId,
heif_property_id propertyId,
size_t* size_out);

/**
* @param data_out User-supplied array. The size given by heif_item_get_property_uuid_size().
*/
LIBHEIF_API
struct heif_error heif_item_get_property_uuid(const struct heif_context* context,
heif_item_id itemId,
heif_property_id propertyId,
uint8_t* data_out);


#ifdef __cplusplus
}
#endif
Expand Down

0 comments on commit 659c8e3

Please sign in to comment.