You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
194 lines
5.2 KiB
194 lines
5.2 KiB
2 years ago
|
/* -*- c-file-style: "stroustrup" -*- */
|
||
|
|
||
|
#include "hdf5.h"
|
||
|
|
||
|
#include <stdio.h>
|
||
|
#include <stdlib.h>
|
||
|
|
||
|
#define H5P_DEFAULTx2 H5P_DEFAULT, H5P_DEFAULT
|
||
|
|
||
|
int
|
||
|
main(void)
|
||
|
{
|
||
|
int ret_val = EXIT_SUCCESS;
|
||
|
|
||
|
//! <!-- [create] -->
|
||
|
{
|
||
|
__label__ fail_file;
|
||
|
hid_t file, group;
|
||
|
char src_path[] = "/a/few/groups";
|
||
|
|
||
|
if ((file = H5Fcreate("o1.h5", H5F_ACC_TRUNC, H5P_DEFAULTx2)) == H5I_INVALID_HID) {
|
||
|
ret_val = EXIT_FAILURE;
|
||
|
goto fail_file;
|
||
|
}
|
||
|
|
||
|
// create a few groups
|
||
|
{
|
||
|
__label__ fail_group, fail_lcpl;
|
||
|
hid_t lcpl;
|
||
|
if ((lcpl = H5Pcreate(H5P_LINK_CREATE)) == H5I_INVALID_HID) {
|
||
|
ret_val = EXIT_FAILURE;
|
||
|
goto fail_lcpl;
|
||
|
}
|
||
|
if (H5Pset_create_intermediate_group(lcpl, 1) < 0) {
|
||
|
ret_val = EXIT_FAILURE;
|
||
|
goto fail_group;
|
||
|
}
|
||
|
if ((group = H5Gcreate(file, src_path, lcpl, H5P_DEFAULTx2)) == H5I_INVALID_HID) {
|
||
|
ret_val = EXIT_FAILURE;
|
||
|
goto fail_group;
|
||
|
}
|
||
|
|
||
|
H5Gclose(group);
|
||
|
fail_group:
|
||
|
H5Pclose(lcpl);
|
||
|
fail_lcpl:;
|
||
|
}
|
||
|
|
||
|
// create a copy
|
||
|
if (H5Ocopy(file, ".", file, "copy of", H5P_DEFAULTx2) < 0) {
|
||
|
ret_val = EXIT_FAILURE;
|
||
|
}
|
||
|
|
||
|
H5Fclose(file);
|
||
|
fail_file:;
|
||
|
}
|
||
|
//! <!-- [create] -->
|
||
|
|
||
|
//! <!-- [read] -->
|
||
|
{
|
||
|
__label__ fail_info, fail_file;
|
||
|
hid_t file;
|
||
|
char path[] = "/a/few/groups";
|
||
|
H5O_info2_t info;
|
||
|
|
||
|
if ((file = H5Fopen("o1.h5", H5F_ACC_RDONLY, H5P_DEFAULT)) == H5I_INVALID_HID) {
|
||
|
ret_val = EXIT_FAILURE;
|
||
|
goto fail_file;
|
||
|
}
|
||
|
|
||
|
// retrieve information about the object
|
||
|
if (H5Oget_info_by_name(file, path, &info, H5O_INFO_BASIC | H5O_INFO_NUM_ATTRS, H5P_DEFAULT) < 0) {
|
||
|
ret_val = EXIT_FAILURE;
|
||
|
goto fail_info;
|
||
|
}
|
||
|
|
||
|
// determine the object type
|
||
|
switch (info.type) {
|
||
|
case H5O_TYPE_GROUP:
|
||
|
printf("HDF5 group\n");
|
||
|
break;
|
||
|
case H5O_TYPE_DATASET:
|
||
|
printf("HDF5 dataset\n");
|
||
|
break;
|
||
|
case H5O_TYPE_NAMED_DATATYPE:
|
||
|
printf("HDF5 datatype\n");
|
||
|
break;
|
||
|
default:
|
||
|
printf("UFO?\n");
|
||
|
break;
|
||
|
}
|
||
|
// print basic information
|
||
|
printf("Reference count: %u\n", info.rc);
|
||
|
printf("Attribute count: %lld\n", info.num_attrs);
|
||
|
|
||
|
fail_info:
|
||
|
H5Fclose(file);
|
||
|
fail_file:;
|
||
|
}
|
||
|
//! <!-- [read] -->
|
||
|
|
||
|
//! <!-- [update] -->
|
||
|
{
|
||
|
__label__ fail_obj, fail_incr, fail_file;
|
||
|
hid_t file, obj;
|
||
|
char path[] = "/a/few/groups";
|
||
|
H5O_info2_t info;
|
||
|
|
||
|
if ((file = H5Fopen("o1.h5", H5F_ACC_RDWR, H5P_DEFAULT)) == H5I_INVALID_HID) {
|
||
|
ret_val = EXIT_FAILURE;
|
||
|
goto fail_file;
|
||
|
}
|
||
|
|
||
|
// open an object by path name
|
||
|
if ((obj = H5Oopen(file, path, H5P_DEFAULT)) == H5I_INVALID_HID) {
|
||
|
ret_val = EXIT_FAILURE;
|
||
|
goto fail_obj;
|
||
|
}
|
||
|
|
||
|
// bump its reference count (by 1)
|
||
|
if (H5Oincr_refcount(obj) < 0) {
|
||
|
ret_val = EXIT_FAILURE;
|
||
|
goto fail_incr;
|
||
|
}
|
||
|
|
||
|
// confirm the new reference count
|
||
|
if (H5Oget_info(obj, &info, H5O_INFO_BASIC) < 0) {
|
||
|
ret_val = EXIT_FAILURE;
|
||
|
goto fail_incr;
|
||
|
}
|
||
|
printf("Reference count: %u\n", info.rc);
|
||
|
|
||
|
fail_incr:
|
||
|
H5Oclose(obj);
|
||
|
fail_obj:
|
||
|
H5Fclose(file);
|
||
|
fail_file:;
|
||
|
}
|
||
|
//! <!-- [update] -->
|
||
|
|
||
|
//! <!-- [delete] -->
|
||
|
{
|
||
|
__label__ fail_obj, fail_delete, fail_file;
|
||
|
hid_t file, obj;
|
||
|
char path[] = "/a/few/groups";
|
||
|
H5O_info2_t info;
|
||
|
|
||
|
if ((file = H5Fopen("o1.h5", H5F_ACC_RDWR, H5P_DEFAULT)) == H5I_INVALID_HID) {
|
||
|
ret_val = EXIT_FAILURE;
|
||
|
goto fail_file;
|
||
|
}
|
||
|
|
||
|
// open an object by path name
|
||
|
if ((obj = H5Oopen(file, path, H5P_DEFAULT)) == H5I_INVALID_HID) {
|
||
|
ret_val = EXIT_FAILURE;
|
||
|
goto fail_obj;
|
||
|
}
|
||
|
|
||
|
// render it inaccessible from the root group by deleting the one and
|
||
|
// only link to it; this drops the reference count by 1
|
||
|
if (H5Ldelete(file, path, H5P_DEFAULT) < 0) {
|
||
|
ret_val = EXIT_FAILURE;
|
||
|
goto fail_delete;
|
||
|
}
|
||
|
|
||
|
// confirm the new reference count
|
||
|
if (H5Oget_info(obj, &info, H5O_INFO_BASIC) < 0) {
|
||
|
ret_val = EXIT_FAILURE;
|
||
|
goto fail_delete;
|
||
|
}
|
||
|
printf("Reference count: %u\n", info.rc);
|
||
|
|
||
|
// if we close the file at this point, we'd be creating a tombstone,
|
||
|
// an object that cannot be reached and that cannot be reclaimed by the
|
||
|
// freespace manager; decrement the reference count to zero to prevent that
|
||
|
if (H5Idec_ref(obj) < 0) {
|
||
|
ret_val = EXIT_FAILURE;
|
||
|
goto fail_delete;
|
||
|
}
|
||
|
else
|
||
|
// attempting to close the object would be like a double H5Oclose and fail
|
||
|
goto fail_obj;
|
||
|
|
||
|
fail_delete:
|
||
|
H5Oclose(obj);
|
||
|
fail_obj:
|
||
|
H5Fclose(file);
|
||
|
fail_file:;
|
||
|
}
|
||
|
//! <!-- [delete] -->
|
||
|
|
||
|
return ret_val;
|
||
|
}
|