Cloned library HDF5-1.14.1 with extra build files for internal package management.
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.
 
 
 
 
 
 

17695 lines
559 KiB

/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Copyright by The HDF Group. *
* All rights reserved. *
* *
* This file is part of HDF5. The full HDF5 copyright notice, including *
* terms governing use, modification, and redistribution, is contained in *
* the COPYING file, which can be found at the root of the source code *
* distribution tree, or in https://www.hdfgroup.org/licenses. *
* If you do not have access to either file, you may request a copy from *
* help@hdfgroup.org. *
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/*
* Programmer: Peter X. Cao
* May 01, 2005
*
* Purpose: Test H5Ocopy().
*/
#include "testhdf5.h"
#include "H5srcdir.h"
#include "H5Iprivate.h"
#include "H5Pprivate.h"
#include "H5VLprivate.h" /* Virtual Object Layer */
#define H5F_FRIEND /*suppress error about including H5Fpkg */
#define H5F_TESTING
#include "H5Fpkg.h" /* File access */
/*
* This file needs to access private information from the H5S package.
* This file also needs to access the dataspace testing code.
*/
#define H5S_FRIEND /*suppress error about including H5Spkg */
#define H5S_TESTING
#include "H5Spkg.h" /* Dataspaces */
/*
* This file needs to access private information from the H5P package.
* This file also needs to access the property list testing code.
*/
#define H5P_FRIEND /*suppress error about including H5Ppkg */
#define H5P_TESTING
#include "H5Ppkg.h" /* Property Lists */
/*
* This file needs to access private information from the H5D package.
* This file also needs to access the dataset testing code.
*/
#define H5D_FRIEND /*suppress error about including H5Dpkg */
#define H5D_TESTING
#include "H5Dpkg.h" /* Datasets */
/*
* This file needs to access private information from the H5O package.
* This file also needs to access the dataspace testing code.
*/
#define H5O_FRIEND /*suppress error about including H5Opkg */
#define H5O_TESTING
#include "H5Opkg.h" /* Object header */
const char *FILENAME[] = {"objcopy_src", "objcopy_dst", "objcopy_ext", "objcopy_src2",
"verbound_src", "verbound_dst", NULL};
/* Configuration, really a series of bit flags. Maximum value is all three
* bit flags enabled.
*/
#define CONFIG_SHARE_SRC 1
#define CONFIG_SHARE_DST 2
#define CONFIG_SRC_NEW_FORMAT 4
#define CONFIG_DST_NEW_FORMAT 8
#define CONFIG_DENSE 16
#define MAX_CONFIGURATION 31
#define FILE_EXT "objcopy_ext.dat"
/* The fill_old.h5 is generated from gen_old_fill.c in HDF5 'test' directory
* for version 1.4(after 1.4.3). To get this data file, simply compile
* gen_old_fill.c with HDF5 library (before v1.5) and run it. */
#define FILE_OLD_LAYOUT "fill_old.h5"
#define NAME_DATATYPE_SIMPLE "H5T_NATIVE_INT"
#define NAME_DATATYPE_SIMPLE2 "H5T_NATIVE_INT-2"
#define NAME_DATATYPE_VL "vlen of int"
#define NAME_DATATYPE_VL_VL "vlen of vlen of int"
#define NAME_DATASET_SIMPLE "dataset_simple"
#define NAME_DATASET_SIMPLE2 "dataset_simple_copy"
#define NAME_DATASET_SIMPLE3 "dataset_simple_another_copy"
#define NAME_DATASET_COMPOUND "dataset_compound"
#define NAME_DATASET_CHUNKED "dataset_chunked"
#define NAME_DATASET_CHUNKED_SINGLE "dataset_chunked_single"
#define NAME_DATASET_CHUNKED2 "dataset_chunked2"
#define NAME_DATASET_CHUNKED2_SINGLE "dataset_chunked2_single"
#define NAME_DATASET_CHUNKED3 "dataset_chunked3"
#define NAME_DATASET_CHUNKED3_SINGLE "dataset_chunked3_single"
#define NAME_DATASET_CHUNKED4 "dataset_chunked4"
#define NAME_DATASET_CHUNKED4_SINGLE "dataset_chunked4_single"
#define NAME_DATASET_COMPACT "dataset_compact"
#define NAME_DATASET_EXTERNAL "dataset_ext"
#define NAME_DATASET_NAMED_DTYPE "dataset_named_dtype"
#define NAME_DATASET_NAMED_DTYPE2 "dataset_named_dtype2"
#define NAME_DATASET_MULTI_OHDR "dataset_multi_ohdr"
#define NAME_DATASET_MULTI_OHDR2 "dataset_multi_ohdr2"
#define NAME_DATASET_VL "dataset_vl"
#define NAME_DATASET_VL2 "dataset_vl2"
#define NAME_DATASET_VL_VL "dataset_vl_vl"
#define NAME_DATASET_VL_VL2 "dataset_vl_vl2"
#define NAME_DATASET_CMPD_VL "dataset_cmpd_vl"
#define NAME_DATASET_SUB_SUB "/g0/g00/g000/dataset_simple"
#define NAME_GROUP_UNCOPIED "/uncopied"
#define NAME_GROUP_EMPTY "/empty"
#define NAME_GROUP_TOP "/g0"
#define NAME_GROUP_TOP2 "/g1"
#define NAME_GROUP_TOP3 "/g2"
#define NAME_GROUP_TOP4 "/g3"
#define NAME_GROUP_SUB "/g0/g00"
#define NAME_GROUP_SUB_2 "/g0/g01"
#define NAME_GROUP_SUB_SUB "/g0/g00/g000"
#define NAME_GROUP_SUB_SUB2 "g000"
#define NAME_GROUP_DATASET "/g0/dataset_simple"
#define NAME_GROUP_LINK "/g_links"
#define NAME_GROUP_LINK2 "/g_links2"
#define NAME_GROUP_LOOP "g_loop"
#define NAME_GROUP_LOOP2 "g_loop2"
#define NAME_GROUP_LOOP3 "g_loop3"
#define NAME_GROUP_REF "ref_grp"
#define NAME_LINK_DATASET "/g_links/dataset_simple"
#define NAME_LINK_HARD "/g_links/hard_link_to_dataset_simple"
#define NAME_LINK_SOFT "/g_links/soft_link_to_dataset_simple"
#define NAME_LINK_SOFT2 "/g_links2/soft_link_to_dataset_simple"
#define NAME_LINK_EXTERN "/g_links/external_link_to_dataset_simple"
#define NAME_LINK_EXTERN2 "/g_links2/external_link_to_dataset_simple"
#define NAME_LINK_SOFT_DANGLE "/g_links/soft_link_to_nowhere"
#define NAME_LINK_SOFT_DANGLE2 "/g_links2/soft_link_to_nowhere"
#define NAME_LINK_EXTERN_DANGLE "/g_links/external_link_to_nowhere"
#define NAME_LINK_EXTERN_DANGLE2 "/g_links2/external_link_to_nowhere"
#define NAME_OLD_FORMAT "/dset1"
#define NAME_BUF_SIZE 1024
#define ATTR_NAME_LEN 80
#define DIM_SIZE_1 12
#define DIM_SIZE_2 6
#define MAX_DIM_SIZE_1 100
#define MAX_DIM_SIZE_2 80
#define CHUNK_SIZE_1 5 /* Not an even fraction of dimension sizes, so we test copying partial chunks */
#define CHUNK_SIZE_2 5
#define NUM_SUB_GROUPS 20
#define NUM_WIDE_LOOP_GROUPS 10
#define NUM_DATASETS 10
#define ATTR_CMPD_STRING "ThisIsAString"
char src_obj_full_name[215]; /* the full path + name of the object to be copied */
unsigned num_attributes_g; /* Number of attributes created */
/* Table containing object id and object name */
/* (Used for detecting duplicate objects when comparing groups */
static struct {
size_t nalloc; /* number of slots allocated */
size_t nobjs; /* number of objects */
H5O_token_t *obj; /* Tokens of objects seen */
} idtab_g;
/* Local function prototypes */
static int compare_data(hid_t parent1, hid_t parent2, hid_t pid, hid_t tid, size_t nelmts, const void *buf1,
const void *buf2, hid_t obj_owner);
static int compare_datasets(hid_t did, hid_t did2, hid_t pid, const void *wbuf);
static int compare_groups(hid_t gid, hid_t gid2, hid_t pid, int depth, unsigned copy_flags);
static int compare_idx_type(hid_t fapl, hid_t did, H5D_chunk_index_t new_type, H5D_chunk_index_t old_type);
static int test_copy_attribute_compound_vlstr(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl);
static int attach_attribute_compound_vlstr(hid_t loc_id);
static int compare_attribute_compound_vlstr(hid_t loc, hid_t loc2);
/*-------------------------------------------------------------------------
* Function: token_insert
*
* Purpose: Add a token to the table.
*
* Return: void
*
* Programmer: Quincey Koziol
* Saturday, November 5, 2005
*
*-------------------------------------------------------------------------
*/
static void
token_insert(H5O_info2_t *oi)
{
size_t n;
/* Don't add it if the link count is 1 because such an object can only
* be encountered once. */
if (oi->rc < 2)
return;
/* Extend the table */
if (idtab_g.nobjs >= idtab_g.nalloc) {
idtab_g.nalloc = MAX(256, 2 * idtab_g.nalloc);
idtab_g.obj = (H5O_token_t *)HDrealloc(idtab_g.obj, idtab_g.nalloc * sizeof(idtab_g.obj[0]));
} /* end if */
/* Insert the entry */
n = idtab_g.nobjs++;
idtab_g.obj[n] = oi->token;
} /* end token_insert() */
/*-------------------------------------------------------------------------
* Function: token_lookup
*
* Purpose: Check if a token has already been encountered
*
* Return: Success: TRUE/FALSE
* Failure: (can't fail)
*
* Programmer: Quincey Koziol
* Saturday, November 5, 2005
*
*-------------------------------------------------------------------------
*/
static H5_ATTR_PURE hbool_t
token_lookup(hid_t loc_id, H5O_info2_t *oi)
{
size_t n;
int token_cmp;
if (oi->rc < 2)
return FALSE; /*only one link possible*/
for (n = 0; n < idtab_g.nobjs; n++) {
if (H5Otoken_cmp(loc_id, &idtab_g.obj[n], &oi->token, &token_cmp) < 0)
return FALSE;
if (!token_cmp)
return TRUE;
}
return FALSE;
} /* end token_lookup() */
/*-------------------------------------------------------------------------
* Function: token_reset
*
* Purpose: Reset the token tracking data structures
*
* Return: void
*
* Programmer: Quincey Koziol
* Saturday, November 5, 2005
*
*-------------------------------------------------------------------------
*/
static void
token_reset(void)
{
if (idtab_g.obj)
HDfree(idtab_g.obj);
idtab_g.obj = NULL;
idtab_g.nalloc = idtab_g.nobjs = 0;
} /* end token_reset() */
/*-------------------------------------------------------------------------
* Function: attach_ref_attr
*
* Purpose: Create an attribute with object references
*
* Return: Non-negative on success/Negative on failure
*
* Programmer: Peter Cao
* Friday, August 4, 2006
*
*-------------------------------------------------------------------------
*/
static herr_t
attach_ref_attr(hid_t file_id, hid_t loc_id)
{
char dsetname1[] = "dataset1_pointed_by_ref_attr";
char dsetname2[] = "dataset2_pointed_by_ref_attr";
hid_t did1 = (-1), did2 = (-1), aid = (-1), sid = (-1), sid_ref = (-1);
hsize_t dims[2] = {2, 9};
hsize_t dims_ref[1] = {2};
hobj_ref_t ref[2];
int data1[2][9] = {{1, 1, 1, 1, 1, 1, 1, 1, 1}, {1, 1, 1, 1, 1, 1, 1, 1, 18}};
int data2[2][9] = {{2, 2, 2, 2, 2, 2, 2, 2, 2}, {2, 2, 2, 2, 2, 2, 2, 2, 18}};
/* creates two simple datasets */
if ((sid = H5Screate_simple(2, dims, NULL)) < 0)
TEST_ERROR;
if ((sid_ref = H5Screate_simple(1, dims_ref, NULL)) < 0)
TEST_ERROR;
if ((did1 = H5Dcreate2(file_id, dsetname1, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) <
0)
TEST_ERROR;
if (H5Dwrite(did1, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, data1) < 0)
TEST_ERROR;
if ((did2 = H5Dcreate2(file_id, dsetname2, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) <
0)
TEST_ERROR;
if (H5Dwrite(did2, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, data2) < 0)
TEST_ERROR;
/* create an attribute with two object references */
if (H5Rcreate(&ref[0], file_id, dsetname1, H5R_OBJECT, (hid_t)-1) < 0)
TEST_ERROR;
if (H5Rcreate(&ref[1], file_id, dsetname2, H5R_OBJECT, (hid_t)-1) < 0)
TEST_ERROR;
if ((aid = H5Acreate2(loc_id, "obj_ref_attr", H5T_STD_REF_OBJ, sid_ref, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Awrite(aid, H5T_STD_REF_OBJ, ref) < 0)
TEST_ERROR;
if (H5Sclose(sid) < 0)
TEST_ERROR;
if (H5Sclose(sid_ref) < 0)
TEST_ERROR;
if (H5Dclose(did1) < 0)
TEST_ERROR;
if (H5Dclose(did2) < 0)
TEST_ERROR;
if (H5Aclose(aid) < 0)
TEST_ERROR;
return 0;
error:
H5E_BEGIN_TRY
{
H5Sclose(sid);
H5Sclose(sid_ref);
H5Dclose(did1);
H5Dclose(did2);
H5Aclose(aid);
}
H5E_END_TRY;
return (-1);
}
/*-------------------------------------------------------------------------
* Function: attach_reg_ref_attr
*
* Purpose: Create an attribute with object references
*
* Return: Non-negative on success/Negative on failure
*
* Programmer: Peter Cao
* Monday, March 5, 2006
*
*-------------------------------------------------------------------------
*/
static herr_t
attach_reg_ref_attr(hid_t file_id, hid_t loc_id)
{
const char dsetnamev[] = "dataset_pointed_by_reg_ref_attr";
hid_t aid = (-1);
hid_t space_id = (-1); /* dataspace identifiers */
hid_t spacer_id = (-1); /* dataspace identifiers */
hid_t dsetv_id = (-1); /*dataset identifiers*/
hsize_t dims[2] = {2, 9};
hsize_t dimsr[1] = {2};
int rank = 2;
int rankr = 1;
hdset_reg_ref_t ref[2];
int data[2][9] = {{1, 1, 2, 3, 3, 4, 5, 5, 999}, {1, 2, 2, 3, 4, 4, 5, 6, 999}};
hsize_t start[2] = {0, 3};
hsize_t count[2] = {2, 3};
hsize_t coord[3][2] = {{0, 0}, {1, 6}, {0, 8}};
size_t num_points = 3;
/* create a 2D dataset */
if ((space_id = H5Screate_simple(rank, dims, NULL)) < 0)
TEST_ERROR;
if ((spacer_id = H5Screate_simple(rankr, dimsr, NULL)) < 0)
TEST_ERROR;
if ((dsetv_id = H5Dcreate2(file_id, dsetnamev, H5T_NATIVE_INT, space_id, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Dwrite(dsetv_id, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, data) < 0)
TEST_ERROR;
/* create reg_ref of block selection */
if (H5Sselect_hyperslab(space_id, H5S_SELECT_SET, start, NULL, count, NULL) < 0)
TEST_ERROR;
if (H5Rcreate(&ref[0], file_id, dsetnamev, H5R_DATASET_REGION, space_id) < 0)
TEST_ERROR;
/* create reg_ref of point selection */
if (H5Sselect_none(space_id) < 0)
TEST_ERROR;
if (H5Sselect_elements(space_id, H5S_SELECT_SET, num_points, (const hsize_t *)coord) < 0)
TEST_ERROR;
if (H5Rcreate(&ref[1], file_id, dsetnamev, H5R_DATASET_REGION, space_id) < 0)
TEST_ERROR;
/* create reg_ref attribute */
if ((aid = H5Acreate2(loc_id, "reg_ref_attr", H5T_STD_REF_DSETREG, spacer_id, H5P_DEFAULT, H5P_DEFAULT)) <
0)
TEST_ERROR;
if (H5Awrite(aid, H5T_STD_REF_DSETREG, ref) < 0)
TEST_ERROR;
/* attach the reg_ref attribute to the dataset itself */
if (H5Aclose(aid) < 0)
TEST_ERROR;
if ((aid = H5Acreate2(dsetv_id, "reg_ref_attr", H5T_STD_REF_DSETREG, spacer_id, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Awrite(aid, H5T_STD_REF_DSETREG, ref) < 0)
TEST_ERROR;
if (H5Sclose(spacer_id) < 0)
TEST_ERROR;
if (H5Sclose(space_id) < 0)
TEST_ERROR;
if (H5Dclose(dsetv_id) < 0)
TEST_ERROR;
if (H5Aclose(aid) < 0)
TEST_ERROR;
return 0;
error:
H5E_BEGIN_TRY
{
H5Sclose(spacer_id);
H5Sclose(space_id);
H5Dclose(dsetv_id);
H5Aclose(aid);
}
H5E_END_TRY;
return (-1);
}
/*-------------------------------------------------------------------------
* Function: create_reg_ref_dataset
*
* Purpose: Create a dataset with region references
*
* Return: Non-negative on success/Negative on failure
*
* Programmer: Peter Cao
* Friday, August 4, 2006
*
*-------------------------------------------------------------------------
*/
static herr_t
create_reg_ref_dataset(hid_t file_id, hid_t loc_id)
{
const char dsetnamev[] = "dataset_pointed_by_ref_dset";
const char dsetnamer[] = "dataset_with_reg_ref";
const char dsetnamer1[] = "compact_dataset_with_reg_ref";
const char dsetnamer2[] = "compressed_dataset_with_reg_ref";
hid_t space_id = (-1); /* dataspace identifiers */
hid_t spacer_id = (-1);
hid_t dsetv_id = (-1); /*dataset identifiers*/
hid_t dsetr_id = (-1);
hsize_t dims[2] = {2, 9};
hsize_t dimsr[1] = {2};
int rank = 2;
int rankr = 1;
hsize_t chunk_size = 1;
hdset_reg_ref_t ref[2];
int data[2][9] = {{1, 1, 2, 3, 3, 4, 5, 5, 6}, {1, 2, 2, 3, 4, 4, 5, 6, 6}};
hsize_t start[2];
hsize_t count[2];
hsize_t coord[3][2] = {{0, 0}, {1, 6}, {0, 8}};
size_t num_points = 3;
hid_t pid = (-1);
if ((space_id = H5Screate_simple(rank, dims, NULL)) < 0)
TEST_ERROR;
if ((spacer_id = H5Screate_simple(rankr, dimsr, NULL)) < 0)
TEST_ERROR;
if ((dsetv_id = H5Dcreate2(file_id, dsetnamev, H5T_NATIVE_INT, space_id, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Dwrite(dsetv_id, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, data) < 0)
TEST_ERROR;
if ((dsetr_id = H5Dcreate2(loc_id, dsetnamer, H5T_STD_REF_DSETREG, spacer_id, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
start[0] = 0;
start[1] = 3;
count[0] = 2;
count[1] = 3;
if (H5Sselect_hyperslab(space_id, H5S_SELECT_SET, start, NULL, count, NULL) < 0)
TEST_ERROR;
if (H5Rcreate(&ref[0], file_id, dsetnamev, H5R_DATASET_REGION, space_id) < 0)
TEST_ERROR;
if (H5Sselect_none(space_id) < 0)
TEST_ERROR;
if (H5Sselect_elements(space_id, H5S_SELECT_SET, num_points, (const hsize_t *)coord) < 0)
TEST_ERROR;
if (H5Rcreate(&ref[1], file_id, dsetnamev, H5R_DATASET_REGION, space_id) < 0)
TEST_ERROR;
if (H5Dwrite(dsetr_id, H5T_STD_REF_DSETREG, H5S_ALL, H5S_ALL, H5P_DEFAULT, ref) < 0)
TEST_ERROR;
if (H5Dclose(dsetr_id) < 0)
TEST_ERROR;
/* create and set compact plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_layout(pid, H5D_COMPACT) < 0)
TEST_ERROR;
if ((dsetr_id = H5Dcreate2(loc_id, dsetnamer1, H5T_STD_REF_DSETREG, spacer_id, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Pclose(pid) < 0)
TEST_ERROR;
if (H5Dwrite(dsetr_id, H5T_STD_REF_DSETREG, H5S_ALL, H5S_ALL, H5P_DEFAULT, ref) < 0)
TEST_ERROR;
if (H5Dclose(dsetr_id) < 0)
TEST_ERROR;
/* create and set comp & chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 1, &chunk_size) < 0)
TEST_ERROR;
if (H5Pset_deflate(pid, 9) < 0)
TEST_ERROR;
if ((dsetr_id = H5Dcreate2(loc_id, dsetnamer2, H5T_STD_REF_DSETREG, spacer_id, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Pclose(pid) < 0)
TEST_ERROR;
if (H5Dwrite(dsetr_id, H5T_STD_REF_DSETREG, H5S_ALL, H5S_ALL, H5P_DEFAULT, ref) < 0)
TEST_ERROR;
if (H5Dclose(dsetr_id) < 0)
TEST_ERROR;
if (H5Sclose(space_id) < 0)
TEST_ERROR;
if (H5Sclose(spacer_id) < 0)
TEST_ERROR;
if (H5Dclose(dsetv_id) < 0)
TEST_ERROR;
return 0;
error:
H5E_BEGIN_TRY
{
H5Sclose(space_id);
H5Sclose(spacer_id);
H5Dclose(dsetr_id);
H5Dclose(dsetv_id);
H5Pclose(pid);
}
H5E_END_TRY;
return (-1);
}
/*-------------------------------------------------------------------------
* Function: attach_attribute_vl
*
* Purpose: Attach an vlen attribute to the object to be copied
*
* Return: Non-negative on success/Negative on failure
*
* Programmer: Peter Cao
* Saturday, December 17, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_attach_attribute_vl(hid_t loc_id)
{
hid_t aid = -1, sid = -1, tid = -1;
hvl_t buf[4];
hsize_t dim1 = 4;
unsigned int i, j;
int ret_value = -1;
if ((sid = H5Screate_simple(1, &dim1, NULL)) < 0)
goto done;
if ((tid = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
goto done;
for (i = 0; i < 4; i++) {
buf[i].len = i * 3 + 1;
buf[i].p = (int *)HDmalloc(buf[i].len * sizeof(int));
for (j = 0; j < buf[i].len; j++)
((int *)buf[i].p)[j] = (int)(j + 1);
} /* end for */
if ((aid = H5Acreate2(loc_id, "vlen attribute", tid, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
goto done;
if (H5Awrite(aid, tid, buf) < 0)
goto done;
ret_value = 0;
done:
if (tid > 0 && sid > 0) {
hid_t dxpl_id = H5Pcreate(H5P_DATASET_XFER);
H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL);
H5Treclaim(tid, sid, dxpl_id, buf);
H5Pclose(dxpl_id);
}
if (sid > 0)
H5Sclose(sid);
if (tid > 0)
H5Tclose(tid);
if (aid > 0)
H5Aclose(aid);
return ret_value;
} /* end of attach_attribute_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_attach_attributes
*
* Purpose: Attach NUM_ATTRIBUTES attributes to the object to be copied
*
* Return: Non-negative on success/Negative on failure
*
* Programmer: Peter Cao
* Friday, September 30, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_attach_attributes(hid_t loc_id, hid_t type_id)
{
hid_t aid = -1, sid = -1;
char attr_name[ATTR_NAME_LEN];
int attr_data[2];
hsize_t dim1 = 2;
hid_t acpl = -1;
unsigned u;
int ret_value = -1;
if ((sid = H5Screate_simple(1, &dim1, NULL)) < 0)
goto done;
/* Create attribute creation plist */
if ((acpl = H5Pcreate(H5P_ATTRIBUTE_CREATE)) < 0)
goto done;
for (u = 0; u < num_attributes_g; u++) {
HDsnprintf(attr_name, sizeof(attr_name), "%u attr", u);
/* Set attribute data */
attr_data[0] = (int)(100 * u);
attr_data[1] = (int)(200 * u);
/* Set attribute character set (alternate) */
if (u % 2) {
if (H5Pset_char_encoding(acpl, H5T_CSET_ASCII) < 0)
goto done;
} /* end if */
else if (H5Pset_char_encoding(acpl, H5T_CSET_UTF8) < 0)
goto done;
if ((aid = H5Acreate2(loc_id, attr_name, type_id, sid, acpl, H5P_DEFAULT)) < 0)
goto done;
if (H5Awrite(aid, H5T_NATIVE_INT, attr_data) < 0)
goto done;
if (aid > 0)
H5Aclose(aid);
aid = -1;
}
ret_value = 0;
done:
if (sid > 0)
H5Sclose(sid);
if (aid > 0)
H5Aclose(aid);
if (acpl > 0)
H5Pclose(acpl);
return ret_value;
}
/*-------------------------------------------------------------------------
* Function: test_copy_attach_paired_attributes
*
* Purpose: Attach NUM_ATTRIBUTES attributes to a pair of objects to be copied
*
* Return: Non-negative on success/Negative on failure
*
* Programmer: Quincey Koziol
* Tuesday, November 1, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_attach_paired_attributes(hid_t loc_id, hid_t loc_id2, hid_t type_id)
{
hid_t aid = -1, sid = -1;
char attr_name[ATTR_NAME_LEN];
int attr_data[2];
hid_t acpl = -1;
unsigned u;
hsize_t dim1 = 2;
if ((sid = H5Screate_simple(1, &dim1, NULL)) < 0)
goto done;
/* Create attribute creation plist */
if ((acpl = H5Pcreate(H5P_ATTRIBUTE_CREATE)) < 0)
goto done;
for (u = 0; u < num_attributes_g; u++) {
HDsnprintf(attr_name, sizeof(attr_name), "%u attr", u);
/* Set attribute data */
attr_data[0] = (int)(100 * u);
attr_data[1] = (int)(200 * u);
/* Set attribute character set (alternate) */
if (u % 2) {
if (H5Pset_char_encoding(acpl, H5T_CSET_ASCII) < 0)
goto done;
} /* end if */
else if (H5Pset_char_encoding(acpl, H5T_CSET_UTF8) < 0)
goto done;
/* Add attribute to first object */
if ((aid = H5Acreate2(loc_id, attr_name, type_id, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
goto done;
if (H5Awrite(aid, H5T_NATIVE_INT, attr_data) < 0)
goto done;
if (H5Aclose(aid) < 0)
goto done;
/* Add attribute to second object */
if ((aid = H5Acreate2(loc_id2, attr_name, type_id, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
goto done;
if (H5Awrite(aid, H5T_NATIVE_INT, attr_data) < 0)
goto done;
if (H5Aclose(aid) < 0)
goto done;
}
if (H5Sclose(sid) < 0)
goto done;
if (H5Pclose(acpl) < 0)
goto done;
return 0;
done:
if (sid > 0)
H5Sclose(sid);
if (aid > 0)
H5Aclose(aid);
if (acpl > 0)
H5Pclose(acpl);
return -1;
} /* end test_copy_attach_paired_attributes() */
/*-------------------------------------------------------------------------
* Function: compare_attribute
*
* Purpose: Compare two attributes to check that they are equal
*
* Return: TRUE if attributes are equal/FALSE if they are different
*
* Programmer: Peter Cao
* Saturday, December 17, 2005
*
*-------------------------------------------------------------------------
*/
static int
compare_attribute(hid_t aid, hid_t aid2, hid_t pid, const void *wbuf, hid_t obj_owner)
{
hid_t sid = -1, sid2 = -1; /* Dataspace IDs */
hid_t tid = -1, tid2 = -1; /* Datatype IDs */
size_t elmt_size; /* Size of datatype */
htri_t is_committed; /* If the datatype is committed */
htri_t is_committed2; /* If the datatype is committed */
H5A_info_t ainfo; /* Attribute info */
H5A_info_t ainfo2; /* Attribute info */
hssize_t nelmts; /* # of elements in dataspace */
void *rbuf = NULL; /* Buffer for reading raw data */
void *rbuf2 = NULL; /* Buffer for reading raw data */
/* Check the character sets are equal */
if (H5Aget_info(aid, &ainfo) < 0)
TEST_ERROR;
if (H5Aget_info(aid2, &ainfo2) < 0)
TEST_ERROR;
if (ainfo.cset != ainfo2.cset)
TEST_ERROR;
/* Check the creation orders are equal (if appropriate) */
if (ainfo.corder_valid != ainfo2.corder_valid)
TEST_ERROR;
if (ainfo.corder_valid)
if (ainfo.corder != ainfo2.corder)
TEST_ERROR;
/* Check the datatypes are equal */
/* Open the datatype for the source attribute */
if ((tid = H5Aget_type(aid)) < 0)
TEST_ERROR;
/* Open the datatype for the destination attribute */
if ((tid2 = H5Aget_type(aid2)) < 0)
TEST_ERROR;
/* Check that both datatypes are committed/not committed */
if ((is_committed = H5Tcommitted(tid)) < 0)
TEST_ERROR;
if ((is_committed2 = H5Tcommitted(tid2)) < 0)
TEST_ERROR;
if (is_committed != is_committed2)
TEST_ERROR;
/* Compare the datatypes */
if (H5Tequal(tid, tid2) != TRUE)
TEST_ERROR;
/* Determine the size of datatype (for later) */
if ((elmt_size = H5Tget_size(tid)) == 0)
TEST_ERROR;
/* Check the dataspaces are equal */
/* Open the dataspace for the source attribute */
if ((sid = H5Aget_space(aid)) < 0)
TEST_ERROR;
/* Open the dataspace for the destination attribute */
if ((sid2 = H5Aget_space(aid2)) < 0)
TEST_ERROR;
/* Compare the dataspaces */
if (H5Sextent_equal(sid, sid2) != TRUE)
TEST_ERROR;
/* Determine the number of elements in dataspace (for later) */
if ((nelmts = H5Sget_simple_extent_npoints(sid2)) < 0)
TEST_ERROR;
/* Check the raw data is equal */
/* Allocate & initialize space for the raw data buffers */
if ((rbuf = HDcalloc(elmt_size, (size_t)nelmts)) == NULL)
TEST_ERROR;
if ((rbuf2 = HDcalloc(elmt_size, (size_t)nelmts)) == NULL)
TEST_ERROR;
/* Read data from the source attribute */
if (H5Aread(aid, tid, rbuf) < 0)
TEST_ERROR;
/* Read data from the destination attribute */
if (H5Aread(aid2, tid2, rbuf2) < 0)
TEST_ERROR;
/* Check raw data read in against data written out */
if (wbuf) {
if (!compare_data(aid, (hid_t)0, pid, tid, (size_t)nelmts, wbuf, rbuf, obj_owner))
TEST_ERROR;
if (!compare_data(aid2, (hid_t)0, pid, tid2, (size_t)nelmts, wbuf, rbuf2, obj_owner))
TEST_ERROR;
} /* end if */
/* Don't have written data, just compare data between the two attributes */
else if (!compare_data(aid, aid2, pid, tid, (size_t)nelmts, rbuf, rbuf2, obj_owner))
TEST_ERROR;
/* Reclaim vlen data, if necessary */
if (H5Tdetect_class(tid, H5T_VLEN) == TRUE)
if (H5Treclaim(tid, sid, H5P_DEFAULT, rbuf) < 0)
TEST_ERROR;
if (H5Tdetect_class(tid2, H5T_VLEN) == TRUE)
if (H5Treclaim(tid2, sid2, H5P_DEFAULT, rbuf2) < 0)
TEST_ERROR;
/* Release raw data buffers */
HDfree(rbuf);
rbuf = NULL;
HDfree(rbuf2);
rbuf2 = NULL;
/* close the source dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close the destination dataspace */
if (H5Sclose(sid2) < 0)
TEST_ERROR;
/* close the source datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the destination datatype */
if (H5Tclose(tid2) < 0)
TEST_ERROR;
return TRUE;
error:
if (rbuf)
HDfree(rbuf);
if (rbuf2)
HDfree(rbuf2);
H5E_BEGIN_TRY
{
H5Sclose(sid2);
H5Sclose(sid);
H5Tclose(tid2);
H5Tclose(tid);
}
H5E_END_TRY;
return FALSE;
} /* end compare_attribute() */
/*-------------------------------------------------------------------------
* Function: compare_std_attributes
*
* Purpose: Compare "standard" attributes on two objects to check that they are equal
*
* Return: TRUE if objects have same attributes/FALSE if they are different
*
* Programmer: Quincey Koziol
* Monday, October 31, 2005
*
* Note: This isn't very general, the attributes are assumed to be
* those written in test_copy_attach_attributes().
*
*-------------------------------------------------------------------------
*/
static int
compare_std_attributes(hid_t oid, hid_t oid2, hid_t pid)
{
hid_t aid = -1, aid2 = -1; /* Attribute IDs */
H5O_info2_t oinfo1, oinfo2; /* Object info */
unsigned cpy_flags; /* Object copy flags */
/* Retrieve the object copy flags from the property list, if it's non-DEFAULT */
if (pid != H5P_DEFAULT) {
if (H5Pget_copy_object(pid, &cpy_flags) < 0)
TEST_ERROR;
} /* end if */
else
cpy_flags = 0;
/* Check the number of attributes on source dataset */
if (H5Oget_info3(oid, &oinfo1, H5O_INFO_NUM_ATTRS) < 0)
TEST_ERROR;
/* Check the number of attributes on destination dataset */
if (H5Oget_info3(oid2, &oinfo2, H5O_INFO_NUM_ATTRS) < 0)
TEST_ERROR;
if (cpy_flags & H5O_COPY_WITHOUT_ATTR_FLAG) {
/* Check that the destination has no attributes */
if (oinfo2.num_attrs != 0)
TEST_ERROR;
} /* end if */
else {
char attr_name[ATTR_NAME_LEN]; /* Attribute name */
unsigned i; /* Local index variable */
/* Compare the number of attributes */
if (oinfo1.num_attrs != oinfo2.num_attrs)
TEST_ERROR;
/* Check the attributes are equal */
for (i = 0; i < (unsigned)oinfo1.num_attrs; i++) {
if ((aid = H5Aopen_by_idx(oid, ".", H5_INDEX_CRT_ORDER, H5_ITER_INC, (hsize_t)i, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Aget_name(aid, (size_t)ATTR_NAME_LEN, attr_name) < 0)
TEST_ERROR;
if ((aid2 = H5Aopen(oid2, attr_name, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check the attributes are equal */
if (!compare_attribute(aid, aid2, pid, NULL, oid))
TEST_ERROR;
/* Close the attributes */
if (H5Aclose(aid) < 0)
TEST_ERROR;
if (H5Aclose(aid2) < 0)
TEST_ERROR;
} /* end for */
} /* end if */
/* Objects should be the same. :-) */
return TRUE;
error:
H5E_BEGIN_TRY
{
H5Aclose(aid2);
H5Aclose(aid);
}
H5E_END_TRY;
return FALSE;
} /* end compare_std_attributes() */
/*-------------------------------------------------------------------------
* Function: compare_data
*
* Purpose: Compare two buffers of data to check that they are equal
*
* Return: TRUE if buffer are equal/FALSE if they are different
*
* Programmer: Quincey Koziol
* Monday, November 21, 2005
*
*-------------------------------------------------------------------------
*/
static int
compare_data(hid_t parent1, hid_t parent2, hid_t pid, hid_t tid, size_t nelmts, const void *buf1,
const void *buf2, hid_t obj_owner)
{
size_t elmt_size; /* Size of an element */
/* Check size of each element */
if ((elmt_size = H5Tget_size(tid)) == 0)
TEST_ERROR;
/* If the type is a compound containing a vlen, loop over all elements for
* each compound member. Compounds containing reference are not supported
* yet. */
if ((H5Tget_class(tid) == H5T_COMPOUND) && (H5Tdetect_class(tid, H5T_VLEN) == TRUE)) {
hid_t memb_id; /* Member id */
const uint8_t *memb1; /* Pointer to current member */
const uint8_t *memb2; /* Pointer to current member */
int nmembs; /* Number of members */
size_t memb_off; /* Member offset */
size_t memb_size; /* Member size */
unsigned memb_idx; /* Member index */
size_t elmt; /* Current element */
/* Get number of members in compound */
if ((nmembs = H5Tget_nmembers(tid)) < 0)
TEST_ERROR;
/* Loop over members */
for (memb_idx = 0; memb_idx < (unsigned)nmembs; memb_idx++) {
/* Get member offset. Note that we cannot check for an error here.
*/
memb_off = H5Tget_member_offset(tid, memb_idx);
/* Get member id */
if ((memb_id = H5Tget_member_type(tid, memb_idx)) < 0)
TEST_ERROR;
/* Get member size */
if ((memb_size = H5Tget_size(memb_id)) == 0)
TEST_ERROR;
/* Set up pointers to member in the first element */
memb1 = (const uint8_t *)buf1 + memb_off;
memb2 = (const uint8_t *)buf2 + memb_off;
/* Check if this member contains (or is) a vlen */
if (H5Tget_class(memb_id) == H5T_VLEN) {
hid_t base_id; /* vlen base type id */
/* Get base type of vlen datatype */
if ((base_id = H5Tget_super(memb_id)) < 0)
TEST_ERROR;
/* Iterate over all elements, recursively calling this function
* for each */
for (elmt = 0; elmt < nelmts; elmt++) {
/* Check vlen lengths */
if (((const hvl_t *)((const void *)memb1))->len !=
((const hvl_t *)((const void *)memb2))->len)
TEST_ERROR;
/* Check vlen data */
if (!compare_data(parent1, parent2, pid, base_id,
((const hvl_t *)((const void *)memb1))->len,
((const hvl_t *)((const void *)memb1))->p,
((const hvl_t *)((const void *)memb2))->p, obj_owner))
TEST_ERROR;
/* Update member pointers */
memb1 += elmt_size;
memb2 += elmt_size;
} /* end for */
}
else {
/* vlens cannot currently be nested below the top layer of a
* compound */
HDassert(H5Tdetect_class(memb_id, H5T_VLEN) == FALSE);
/* Iterate over all elements, calling memcmp() for each */
for (elmt = 0; elmt < nelmts; elmt++) {
if (HDmemcmp(memb1, memb2, memb_size) != 0)
TEST_ERROR;
/* Update member pointers */
memb1 += elmt_size;
memb2 += elmt_size;
} /* end for */
} /* end else */
} /* end for */
}
else if (H5Tdetect_class(tid, H5T_VLEN) == TRUE) {
const hvl_t *vl_buf1, *vl_buf2; /* Aliases for buffers to compare */
hid_t base_tid; /* Base type of vlen datatype */
size_t u; /* Local index variable */
/* Check for "simple" vlen datatype */
if (H5Tget_class(tid) != H5T_VLEN)
TEST_ERROR;
/* Get base type of vlen datatype */
if ((base_tid = H5Tget_super(tid)) < 0)
TEST_ERROR;
/* Loop over elements in buffers */
vl_buf1 = (const hvl_t *)buf1;
vl_buf2 = (const hvl_t *)buf2;
for (u = 0; u < nelmts; u++, vl_buf1++, vl_buf2++) {
/* Check vlen lengths */
if (vl_buf1->len != vl_buf2->len)
TEST_ERROR;
/* Check vlen data */
if (!compare_data(parent1, parent2, pid, base_tid, vl_buf1->len, vl_buf1->p, vl_buf2->p,
obj_owner))
TEST_ERROR;
} /* end for */
if (H5Tclose(base_tid) < 0)
TEST_ERROR;
} /* end if */
else if (H5Tdetect_class(tid, H5T_REFERENCE) == TRUE) {
size_t u; /* Local index variable */
/* Check for "simple" reference datatype */
if (H5Tget_class(tid) != H5T_REFERENCE)
TEST_ERROR;
/* Check for object or region reference */
if (H5Tequal(tid, H5T_STD_REF_OBJ) > 0) {
const hobj_ref_t *ref_buf1, *ref_buf2; /* Aliases for buffers to compare */
/* Loop over elements in buffers */
ref_buf1 = (const hobj_ref_t *)buf1;
ref_buf2 = (const hobj_ref_t *)buf2;
for (u = 0; u < nelmts; u++, ref_buf1++, ref_buf2++) {
hid_t obj1_id, obj2_id; /* IDs for objects referenced */
H5O_type_t obj1_type, obj2_type; /* Types of objects referenced */
/* Check for types of objects handled */
if (H5Rget_obj_type2(parent1, H5R_OBJECT, ref_buf1, &obj1_type) < 0)
TEST_ERROR;
if (H5Rget_obj_type2(parent2, H5R_OBJECT, ref_buf2, &obj2_type) < 0)
TEST_ERROR;
if (obj1_type != obj2_type)
TEST_ERROR;
/* Open referenced objects */
if ((obj1_id = H5Rdereference2(parent1, H5P_DEFAULT, H5R_OBJECT, ref_buf1)) < 0)
TEST_ERROR;
if ((obj2_id = H5Rdereference2(parent2, H5P_DEFAULT, H5R_OBJECT, ref_buf2)) < 0)
TEST_ERROR;
/* break the infinite loop when the ref_object points to itself */
if (obj_owner > 0) {
H5O_info2_t oinfo1, oinfo2;
int token_cmp;
if (H5Oget_info3(obj_owner, &oinfo1, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Oget_info3(obj1_id, &oinfo2, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(obj1_id, &oinfo1.token, &oinfo2.token, &token_cmp) < 0)
TEST_ERROR;
if (!token_cmp) {
if (H5Oclose(obj1_id) < 0)
TEST_ERROR;
if (H5Oclose(obj2_id) < 0)
TEST_ERROR;
return TRUE;
}
}
/* Check for types of objects handled */
switch (obj1_type) {
case H5O_TYPE_DATASET:
if (compare_datasets(obj1_id, obj2_id, pid, NULL) != TRUE)
TEST_ERROR;
break;
case H5O_TYPE_GROUP:
if (compare_groups(obj1_id, obj2_id, pid, -1, 0) != TRUE)
TEST_ERROR;
break;
case H5O_TYPE_NAMED_DATATYPE:
if (H5Tequal(obj1_id, obj2_id) != TRUE)
TEST_ERROR;
break;
case H5O_TYPE_MAP:
/* Maps not supported in native VOL connector */
case H5O_TYPE_UNKNOWN:
case H5O_TYPE_NTYPES:
default:
TEST_ERROR;
} /* end switch */
/* Close objects */
if (H5Oclose(obj1_id) < 0)
TEST_ERROR;
if (H5Oclose(obj2_id) < 0)
TEST_ERROR;
} /* end for */
} /* end if */
else if (H5Tequal(tid, H5T_STD_REF_DSETREG) > 0) {
const hdset_reg_ref_t *ref_buf1, *ref_buf2; /* Aliases for buffers to compare */
/* Loop over elements in buffers */
ref_buf1 = (const hdset_reg_ref_t *)buf1;
ref_buf2 = (const hdset_reg_ref_t *)buf2;
for (u = 0; u < nelmts; u++, ref_buf1++, ref_buf2++) {
hid_t obj1_id, obj2_id; /* IDs for objects referenced */
hid_t obj1_sid, obj2_sid; /* Dataspace IDs for objects referenced */
H5O_type_t obj1_type, obj2_type; /* Types of objects referenced */
/* Check for types of objects handled */
if (H5Rget_obj_type2(parent1, H5R_DATASET_REGION, ref_buf1, &obj1_type) < 0)
TEST_ERROR;
if (H5Rget_obj_type2(parent2, H5R_DATASET_REGION, ref_buf2, &obj2_type) < 0)
TEST_ERROR;
if (obj1_type != obj2_type)
TEST_ERROR;
/* Open referenced objects */
if ((obj1_id = H5Rdereference2(parent1, H5P_DEFAULT, H5R_DATASET_REGION, ref_buf1)) < 0)
TEST_ERROR;
if ((obj2_id = H5Rdereference2(parent2, H5P_DEFAULT, H5R_DATASET_REGION, ref_buf2)) < 0)
TEST_ERROR;
/* break the infinite loop when the ref_object points to itself */
if (obj_owner > 0) {
H5O_info2_t oinfo1, oinfo2;
int token_cmp;
if (H5Oget_info3(obj_owner, &oinfo1, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Oget_info3(obj1_id, &oinfo2, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(obj1_id, &oinfo1.token, &oinfo2.token, &token_cmp) < 0)
TEST_ERROR;
if (!token_cmp) {
if (H5Oclose(obj1_id) < 0)
TEST_ERROR;
if (H5Oclose(obj2_id) < 0)
TEST_ERROR;
return TRUE;
}
}
/* Check for types of objects handled */
switch (obj1_type) {
case H5O_TYPE_DATASET:
if (compare_datasets(obj1_id, obj2_id, pid, NULL) != TRUE)
TEST_ERROR;
break;
case H5O_TYPE_GROUP:
if (compare_groups(obj1_id, obj2_id, pid, -1, 0) != TRUE)
TEST_ERROR;
break;
case H5O_TYPE_NAMED_DATATYPE:
if (H5Tequal(obj1_id, obj2_id) != TRUE)
TEST_ERROR;
break;
case H5O_TYPE_MAP:
/* Maps not supported in native VOL connector */
case H5O_TYPE_UNKNOWN:
case H5O_TYPE_NTYPES:
default:
TEST_ERROR;
} /* end switch */
/* Close objects */
if (H5Oclose(obj1_id) < 0)
TEST_ERROR;
if (H5Oclose(obj2_id) < 0)
TEST_ERROR;
/* Get regions for referenced datasets */
if ((obj1_sid = H5Rget_region(parent1, H5R_DATASET_REGION, ref_buf1)) < 0)
TEST_ERROR;
if ((obj2_sid = H5Rget_region(parent2, H5R_DATASET_REGION, ref_buf2)) < 0)
TEST_ERROR;
/* Check if dataspaces are the same shape */
if (H5Sselect_shape_same(obj1_sid, obj2_sid) < 0)
TEST_ERROR;
/* Close dataspaces */
if (H5Sclose(obj1_sid) < 0)
TEST_ERROR;
if (H5Sclose(obj2_sid) < 0)
TEST_ERROR;
} /* end for */
} /* end if */
else
TEST_ERROR;
} /* end else */
else if (HDmemcmp(buf1, buf2, (elmt_size * nelmts)) != 0)
TEST_ERROR;
/* Data should be the same. :-) */
return TRUE;
error:
return FALSE;
} /* end compare_data() */
/*-------------------------------------------------------------------------
* Function: compare_datasets
*
* Purpose: Compare two datasets to check that they are equal
*
* Return: TRUE if datasets are equal/FALSE if they are different
*
* Programmer: Quincey Koziol
* Tuesday, October 25, 2005
*
*-------------------------------------------------------------------------
*/
static int
compare_datasets(hid_t did, hid_t did2, hid_t pid, const void *wbuf)
{
hid_t sid = -1, sid2 = -1; /* Dataspace IDs */
hid_t tid = -1, tid2 = -1; /* Datatype IDs */
hid_t dcpl = -1, dcpl2 = -1; /* Dataset creation property list IDs */
size_t elmt_size; /* Size of datatype */
htri_t is_committed; /* If the datatype is committed */
htri_t is_committed2; /* If the datatype is committed */
int nfilters; /* Number of filters applied to dataset */
hssize_t nelmts; /* # of elements in dataspace */
void *rbuf = NULL; /* Buffer for reading raw data */
void *rbuf2 = NULL; /* Buffer for reading raw data */
H5D_space_status_t space_status; /* Dataset's raw dataspace status */
H5D_space_status_t space_status2; /* Dataset's raw dataspace status */
/* Check the datatypes are equal */
/* Open the datatype for the source dataset */
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
/* Open the datatype for the destination dataset */
if ((tid2 = H5Dget_type(did2)) < 0)
TEST_ERROR;
/* Check that both datatypes are committed/not committed */
if ((is_committed = H5Tcommitted(tid)) < 0)
TEST_ERROR;
if ((is_committed2 = H5Tcommitted(tid2)) < 0)
TEST_ERROR;
if (is_committed != is_committed2)
TEST_ERROR;
/* Compare the datatypes */
if (H5Tequal(tid, tid2) != TRUE)
TEST_ERROR;
/* Determine the size of datatype (for later) */
if ((elmt_size = H5Tget_size(tid)) == 0)
TEST_ERROR;
/* Check the dataspaces are equal */
/* Open the dataspace for the source dataset */
if ((sid = H5Dget_space(did)) < 0)
TEST_ERROR;
/* Open the dataspace for the destination dataset */
if ((sid2 = H5Dget_space(did2)) < 0)
TEST_ERROR;
/* Compare the dataspaces */
if (H5Sextent_equal(sid, sid2) != TRUE)
TEST_ERROR;
/* Determine the number of elements in dataspace (for later) */
if ((nelmts = H5Sget_simple_extent_npoints(sid)) < 0)
TEST_ERROR;
/* Check the dataset creation property lists are equal */
/* Open the dataset creation property list for the source dataset */
if ((dcpl = H5Dget_create_plist(did)) < 0)
TEST_ERROR;
/* Open the dataset creation property list for the destination dataset */
if ((dcpl2 = H5Dget_create_plist(did2)) < 0)
TEST_ERROR;
/* Compare the rest of the dataset creation property lists */
if (H5Pequal(dcpl, dcpl2) != TRUE)
TEST_ERROR;
/* Get the number of filters on dataset (for later) */
if ((nfilters = H5Pget_nfilters(dcpl)) < 0)
TEST_ERROR;
/* close the source dataset creation property list */
if (H5Pclose(dcpl) < 0)
TEST_ERROR;
/* close the destination dataset creation property list */
if (H5Pclose(dcpl2) < 0)
TEST_ERROR;
/* Check the allocated storage is the same */
/* Check that the space allocation status is the same */
if (H5Dget_space_status(did, &space_status) < 0)
TEST_ERROR;
if (H5Dget_space_status(did2, &space_status2) < 0)
TEST_ERROR;
if (space_status != space_status2)
TEST_ERROR;
/* Check that the space used is the same */
/* (Don't check if the dataset is filtered (i.e. compressed, etc.) and
* the datatype is VLEN, since the tokens for the vlen
* data in each dataset will (probably) be different and the storage
* size will thus vary)
*/
if (!(nfilters > 0 && (H5Tdetect_class(tid, H5T_VLEN) ||
(H5Tdetect_class(tid, H5T_REFERENCE) && H5Tequal(tid, H5T_STD_REF_DSETREG))))) {
hsize_t storage_size = H5Dget_storage_size(did); /* Dataset's raw data storage size */
hsize_t storage_size2 = H5Dget_storage_size(did2); /* 2nd Dataset's raw data storage size */
if (storage_size != storage_size2)
TEST_ERROR;
} /* end if */
/* Check the raw data is equal */
/* Allocate & initialize space for the raw data buffers */
if ((rbuf = HDcalloc(elmt_size, (size_t)nelmts)) == NULL)
TEST_ERROR;
if ((rbuf2 = HDcalloc(elmt_size, (size_t)nelmts)) == NULL)
TEST_ERROR;
/* Read data from datasets */
if (H5Dread(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, rbuf) < 0)
TEST_ERROR;
if (H5Dread(did2, tid2, H5S_ALL, H5S_ALL, H5P_DEFAULT, rbuf2) < 0)
TEST_ERROR;
/* Check raw data read in against data written out */
if (wbuf) {
if (!compare_data(did, (hid_t)0, pid, tid, (size_t)nelmts, wbuf, rbuf, did))
TEST_ERROR;
if (!compare_data(did2, (hid_t)0, pid, tid2, (size_t)nelmts, wbuf, rbuf2, did2))
TEST_ERROR;
} /* end if */
/* Don't have written data, just compare data between the two datasets */
else if (!compare_data(did, did2, pid, tid, (size_t)nelmts, rbuf, rbuf2, did))
TEST_ERROR;
/* Reclaim vlen data, if necessary */
if (H5Tdetect_class(tid, H5T_VLEN) == TRUE)
if (H5Treclaim(tid, sid, H5P_DEFAULT, rbuf) < 0)
TEST_ERROR;
if (H5Tdetect_class(tid2, H5T_VLEN) == TRUE)
if (H5Treclaim(tid2, sid2, H5P_DEFAULT, rbuf2) < 0)
TEST_ERROR;
/* Release raw data buffers */
HDfree(rbuf);
rbuf = NULL;
HDfree(rbuf2);
rbuf2 = NULL;
/* close the source dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close the destination dataspace */
if (H5Sclose(sid2) < 0)
TEST_ERROR;
/* close the source datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the destination datatype */
if (H5Tclose(tid2) < 0)
TEST_ERROR;
/* Check if the attributes are equal */
if (compare_std_attributes(did, did2, pid) != TRUE)
TEST_ERROR;
/* Datasets should be the same. :-) */
return TRUE;
error:
H5E_BEGIN_TRY
{
if (rbuf)
HDfree(rbuf);
if (rbuf2)
HDfree(rbuf2);
H5Pclose(dcpl2);
H5Pclose(dcpl);
H5Sclose(sid2);
H5Sclose(sid);
H5Tclose(tid2);
H5Tclose(tid);
}
H5E_END_TRY;
return FALSE;
} /* end compare_datasets() */
/*-------------------------------------------------------------------------
* Function: compare_groups
*
* Purpose: Compare two groups to check that they are "equal"
*
* Return: TRUE if group are equal/FALSE if they are different
*
* Programmer: Quincey Koziol
* Monday, October 31, 2005
*
*-------------------------------------------------------------------------
*/
static int
compare_groups(hid_t gid, hid_t gid2, hid_t pid, int depth, unsigned copy_flags)
{
H5G_info_t ginfo; /* Group info struct */
H5G_info_t ginfo2; /* Group info struct */
hsize_t idx; /* Index over the objects in group */
unsigned cpy_flags; /* Object copy flags */
/* Retrieve the object copy flags from the property list, if it's non-DEFAULT */
if (pid != H5P_DEFAULT) {
if (H5Pget_copy_object(pid, &cpy_flags) < 0)
TEST_ERROR;
} /* end if */
else
cpy_flags = 0;
/* Check if both groups have the same # of objects */
if (H5Gget_info(gid, &ginfo) < 0)
TEST_ERROR;
if (H5Gget_info(gid2, &ginfo2) < 0)
TEST_ERROR;
if ((cpy_flags & H5O_COPY_SHALLOW_HIERARCHY_FLAG) && depth == 0) {
if (ginfo2.nlinks != 0)
TEST_ERROR;
} /* end if */
else {
if (ginfo.nlinks != ginfo2.nlinks)
TEST_ERROR;
} /* end if */
/* Check contents of groups */
if (ginfo2.nlinks > 0) {
char objname[NAME_BUF_SIZE]; /* Name of object in group */
char objname2[NAME_BUF_SIZE]; /* Name of object in group */
H5L_info2_t linfo; /* Link information */
H5L_info2_t linfo2; /* Link information */
/* Loop over contents of groups */
for (idx = 0; idx < ginfo.nlinks; idx++) {
/* Check name of objects */
if (H5Lget_name_by_idx(gid, ".", H5_INDEX_NAME, H5_ITER_INC, idx, objname, (size_t)NAME_BUF_SIZE,
H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Lget_name_by_idx(gid2, ".", H5_INDEX_NAME, H5_ITER_INC, idx, objname2,
(size_t)NAME_BUF_SIZE, H5P_DEFAULT) < 0)
TEST_ERROR;
if (HDstrcmp(objname, objname2) != 0)
TEST_ERROR;
/* Get link info */
if (H5Lget_info2(gid, objname, &linfo, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Lget_info2(gid2, objname2, &linfo2, H5P_DEFAULT) < 0)
TEST_ERROR;
if (linfo.type != linfo2.type)
TEST_ERROR;
/* Extra checks for "real" objects */
if (linfo.type == H5L_TYPE_HARD) {
hid_t oid, oid2; /* IDs of objects within group */
H5O_info2_t oinfo, oinfo2; /* Data model object info */
H5O_native_info_t ninfo, ninfo2; /* Native file format object info */
/* Compare some pieces of the object info */
/* Get data model object info */
if (H5Oget_info_by_name3(gid, objname, &oinfo, H5O_INFO_BASIC, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Oget_info_by_name3(gid2, objname2, &oinfo2, H5O_INFO_BASIC, H5P_DEFAULT) < 0)
TEST_ERROR;
/* Get native object info */
if (H5Oget_native_info_by_name(gid, objname, &ninfo, H5O_NATIVE_INFO_HDR, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Oget_native_info_by_name(gid2, objname2, &ninfo2, H5O_NATIVE_INFO_HDR, H5P_DEFAULT) < 0)
TEST_ERROR;
if (oinfo.type != oinfo2.type)
TEST_ERROR;
if (oinfo.rc != oinfo2.rc)
TEST_ERROR;
/* If NULL messages are preserved, the number of messages
* should be the same in the destination.
* Otherwise, it should simply be true that the number
* of messages hasn't increased.
*/
if (H5O_COPY_PRESERVE_NULL_FLAG & copy_flags) {
if (ninfo.hdr.nmesgs != ninfo2.hdr.nmesgs)
;
else if (ninfo.hdr.nmesgs < ninfo2.hdr.nmesgs)
TEST_ERROR;
}
/* Check for object already having been compared */
if (token_lookup(gid, &oinfo))
continue;
else
token_insert(&oinfo);
/* Open objects */
if ((oid = H5Oopen(gid, objname, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
if ((oid2 = H5Oopen(gid2, objname2, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Compare objects within group */
switch (oinfo.type) {
case H5O_TYPE_GROUP:
/* Compare groups */
if (compare_groups(oid, oid2, pid, depth - 1, copy_flags) != TRUE)
TEST_ERROR;
break;
case H5O_TYPE_DATASET:
/* Compare datasets */
if (compare_datasets(oid, oid2, pid, NULL) != TRUE)
TEST_ERROR;
break;
case H5O_TYPE_NAMED_DATATYPE:
/* Compare datatypes */
if (H5Tequal(oid, oid2) != TRUE)
TEST_ERROR;
break;
case H5O_TYPE_MAP:
HDassert(0 && "maps not supported in native VOL connector");
/* clang complains about implicit fallthrough here and
* our usual attributes and fall-through comments don't
* quiet the compiler.
*/
H5_CLANG_DIAG_OFF("implicit-fallthrough")
case H5O_TYPE_UNKNOWN:
case H5O_TYPE_NTYPES:
default:
HDassert(0 && "Unknown type of object");
break;
H5_CLANG_DIAG_ON("implicit-fallthrough")
} /* end switch */
/* Close objects */
if (H5Oclose(oid) < 0)
TEST_ERROR;
if (H5Oclose(oid2) < 0)
TEST_ERROR;
} /* end if */
else {
/* Check that both links are the same size */
if (linfo.u.val_size != linfo2.u.val_size)
TEST_ERROR;
/* Compare link values */
if (linfo.type == H5L_TYPE_SOFT ||
(linfo.type >= H5L_TYPE_UD_MIN && linfo.type <= H5L_TYPE_MAX)) {
char linkval[NAME_BUF_SIZE]; /* Link value */
char linkval2[NAME_BUF_SIZE]; /* Link value */
/* Get link values */
HDassert(linfo.u.val_size <= NAME_BUF_SIZE);
if (H5Lget_val(gid, objname, linkval, (size_t)NAME_BUF_SIZE, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Lget_val(gid2, objname2, linkval2, (size_t)NAME_BUF_SIZE, H5P_DEFAULT) < 0)
TEST_ERROR;
/* Compare link data */
if (HDmemcmp(linkval, linkval2, linfo.u.val_size) != 0)
TEST_ERROR;
} /* end else-if */
else {
HDassert(0 && "Unknown type of link");
} /* end else */
} /* end else */
} /* end for */
} /* end if */
/* Check if the attributes are equal */
if (compare_std_attributes(gid, gid2, pid) != TRUE)
TEST_ERROR;
/* Groups should be the same. :-) */
return TRUE;
error:
H5E_BEGIN_TRY
{
}
H5E_END_TRY;
return FALSE;
} /* end compare_groups() */
/*-------------------------------------------------------------------------
* Function: compare_idx_type
*
* Purpose: If using new format, the index array type should be NEW_TYPE
* If not, the index array type should be OLD_TYPE
*
* Return: TRUE if the index type retrieved for the dataset DID is
* as expected
* FALSE if not
*
* Programmer: Vailin Choi; August 2009
*
*-------------------------------------------------------------------------
*/
static int
compare_idx_type(hid_t fapl, hid_t did, H5D_chunk_index_t new_type, H5D_chunk_index_t old_type)
{
H5D_chunk_index_t idx_type; /* Dataset chunk index type */
H5F_libver_t low; /* File format low bound */
/* Get the chunk index type */
if (H5D__layout_idx_type_test(did, &idx_type) < 0)
FAIL_STACK_ERROR;
/* Check if we are using the latest version of the format */
if (H5Pget_libver_bounds(fapl, &low, NULL) < 0)
FAIL_STACK_ERROR;
/* Verify index type */
if (low == H5F_LIBVER_LATEST) {
if (idx_type != new_type)
TEST_ERROR;
}
else if (idx_type != old_type)
TEST_ERROR;
return TRUE;
error:
return FALSE;
} /* compare_idx_type() */
/*-------------------------------------------------------------------------
* Function: test_copy_named_datatype
*
* Purpose: Create name datatype in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Friday, September 30, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_named_datatype(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1, tid2 = -1; /* Datatype IDs */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): named datatype");
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* create named datatype */
if ((H5Tcommit2(fid_src, NAME_DATATYPE_SIMPLE, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the datatype from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATATYPE_SIMPLE, fid_dst, NAME_DATATYPE_SIMPLE, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the datatype for copy */
if ((tid = H5Topen2(fid_src, NAME_DATATYPE_SIMPLE, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the copied datatype */
if ((tid2 = H5Topen2(fid_dst, NAME_DATATYPE_SIMPLE, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Compare the datatypes */
if (H5Tequal(tid, tid2) != TRUE)
TEST_ERROR;
/* close the destination datatype */
if (H5Tclose(tid2) < 0)
TEST_ERROR;
/* close the source datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Tclose(tid2);
H5Tclose(tid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_named_datatype */
/*-------------------------------------------------------------------------
* Function: test_copy_named_datatype_vl
*
* Purpose: Create name vlen datatype in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Tuesday, November 22, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_named_datatype_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1, tid2 = -1; /* Datatype IDs */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): named vlen datatype");
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* create named datatype */
if ((H5Tcommit2(fid_src, NAME_DATATYPE_VL, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the datatype from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATATYPE_VL, fid_dst, NAME_DATATYPE_VL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the datatype for copy */
if ((tid = H5Topen2(fid_src, NAME_DATATYPE_VL, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the copied datatype */
if ((tid2 = H5Topen2(fid_dst, NAME_DATATYPE_VL, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Compare the datatypes */
if (H5Tequal(tid, tid2) != TRUE)
TEST_ERROR;
/* close the destination datatype */
if (H5Tclose(tid2) < 0)
TEST_ERROR;
/* close the source datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Tclose(tid2);
H5Tclose(tid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_named_datatype_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_named_datatype_vl_vl
*
* Purpose: Create named vlen of vlen datatype in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Tuesday, November 22, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_named_datatype_vl_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1, tid2 = -1; /* Datatype IDs */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): named nested vlen datatype");
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create first vlen datatype */
if ((tid = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* create second (nested) vlen datatype */
if ((tid2 = H5Tvlen_create(tid)) < 0)
TEST_ERROR;
/* create named datatype */
if ((H5Tcommit2(fid_src, NAME_DATATYPE_VL_VL, tid2, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the first datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the second datatype */
if (H5Tclose(tid2) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the datatype from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATATYPE_VL_VL, fid_dst, NAME_DATATYPE_VL_VL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the datatype for copy */
if ((tid = H5Topen2(fid_src, NAME_DATATYPE_VL_VL, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the copied datatype */
if ((tid2 = H5Topen2(fid_dst, NAME_DATATYPE_VL_VL, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Compare the datatypes */
if (H5Tequal(tid, tid2) != TRUE)
TEST_ERROR;
/* close the destination datatype */
if (H5Tclose(tid2) < 0)
TEST_ERROR;
/* close the source datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Tclose(tid2);
H5Tclose(tid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_named_datatype_vl_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_named_datatype_attr_self
*
* Purpose: Create name datatype in SRC file, with an attribute that
* uses that named datatype as its datatype, and copy it to
* DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Neil
* Friday, March 11, 2011
*
*-------------------------------------------------------------------------
*/
static int
test_copy_named_datatype_attr_self(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1, tid2 = -1; /* Datatype IDs */
hid_t aid = -1; /* Attribute ID */
hid_t sid = -1; /* Dataspace ID */
hsize_t dims[2] = {3, 4}; /* Dataspace dimensions */
H5O_info2_t oinfo, oinfo2; /* Object info */
H5G_info_t ginfo; /* Group info */
hbool_t same_type;
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): named datatype with self-referential attribute");
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* create named datatype */
if ((H5Tcommit2(fid_src, NAME_DATATYPE_SIMPLE, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create dataspace */
if ((sid = H5Screate_simple(2, dims, NULL)) < 0)
TEST_ERROR;
/* create attribute */
if ((aid = H5Acreate2(tid, "attr_self", tid, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* attach other attributes to the dataset */
if (test_copy_attach_attributes(tid, tid) < 0)
TEST_ERROR;
/* close the attribute */
if (H5Aclose(aid) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the datatype from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATATYPE_SIMPLE, fid_dst, NAME_DATATYPE_SIMPLE, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the source datatype */
if ((tid = H5Topen2(fid_src, NAME_DATATYPE_SIMPLE, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the copied datatype */
if ((tid2 = H5Topen2(fid_dst, NAME_DATATYPE_SIMPLE, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Compare the datatypes */
if (H5Tequal(tid, tid2) != TRUE)
TEST_ERROR;
/* close the source datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* open the destination attribute */
if ((aid = H5Aopen(tid2, "attr_self", H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination attribute's datatype */
if ((tid = H5Aget_type(aid)) < 0)
TEST_ERROR;
/* verify that the attribute's datatype is committed */
if (H5Tcommitted(tid) != TRUE)
TEST_ERROR;
/* verify that the tokens of the datatypes are the same */
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Oget_info3(tid2, &oinfo2, H5O_INFO_BASIC) < 0)
TEST_ERROR;
same_type = TRUE;
if (oinfo.fileno == oinfo2.fileno) {
int token_cmp;
if (H5Otoken_cmp(tid2, &oinfo.token, &oinfo2.token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
same_type = FALSE;
}
else
same_type = FALSE;
if (!same_type)
FAIL_PUTS_ERROR("destination attribute does not use the same committed datatype");
/* Verify that there are only 2 links int he destination root group */
if (H5Gget_info(fid_dst, &ginfo) < 0)
if (ginfo.nlinks != 2)
FAIL_PUTS_ERROR("unexpected number of links in destination root group");
/* close the attribute */
if (H5Aclose(aid) < 0)
TEST_ERROR;
/* close the datatypes */
if (H5Tclose(tid2) < 0)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Tclose(tid2);
H5Tclose(tid);
H5Sclose(sid);
H5Aclose(aid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_named_datatype_attr_self */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_simple
*
* Purpose: Create a simple dataset in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Friday, September 30, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_simple(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
int buf[DIM_SIZE_1][DIM_SIZE_2]; /* Buffer for writing data */
hsize_t dim2d[2]; /* Dataset dimensions */
int i, j; /* local index variables */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): simple dataset");
/* Initialize write buffer */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
buf[i][j] = 10000 + 100 * i + j;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create 2D dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create 2D int dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_SIMPLE, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_simple */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_versionbounds
*
* Purpose: Verify copying dataset works as expected in various version
* bound combination.
*
* Description:
* Create a simple dataset in SRC file using default versions.
* For each valid version bound combination, create a DST file,
* and attempt to copy the SRC dataset to the DST file.
* When copying fails, verify that the failure is a result of
* the invalid bounds, that is, DST has lower bounds than SRC.
*
* Return: Success: 0
* Failure: 1
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_versionbounds(hid_t fcpl_src, hid_t fapl_src)
{
hid_t fid_src = -1, fid_dst = -1; /* Source and destination file IDs */
hid_t fapl_dst = -1; /* File access plist for dest file */
hid_t sid = -1; /* Dataspace ID */
hid_t did_src = -1, did_dst = -1; /* Source and destination dataset IDs */
int buf[DIM_SIZE_1][DIM_SIZE_2]; /* Buffer for writing data */
hsize_t dim2d[2]; /* Dataset dimensions */
char src_fname[NAME_BUF_SIZE]; /* Name of source file */
char dst_fname[NAME_BUF_SIZE]; /* Name of destination file */
H5F_libver_t low, high; /* File format bounds */
unsigned srcdset_layoutversion; /* Layout version of source dataset */
int i, j; /* Local index variables */
H5D_t *dsetp = NULL; /* Pointer to internal dset structure */
herr_t ret; /* Generic return value */
TESTING("H5Ocopy(): simple dataset with version bounds");
/* Initialize write buffer */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
buf[i][j] = 10000 + 100 * i + j;
/* Create a file access property list for destination file */
if ((fapl_dst = h5_fileaccess()) < 0)
TEST_ERROR;
/* Initialize the filenames */
h5_fixname(FILENAME[4], fapl_src, src_fname, sizeof src_fname);
h5_fixname(FILENAME[5], fapl_dst, dst_fname, sizeof dst_fname);
/* Reset file token checking info */
token_reset();
/* Create source file */
fid_src = H5Fcreate(src_fname, H5F_ACC_TRUNC, fcpl_src, fapl_src);
if (fid_src < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* Create 2D dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* Create 2D int dataset in SRC file */
did_src =
H5Dcreate2(fid_src, NAME_DATASET_SIMPLE, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT);
if (did_src < 0)
TEST_ERROR;
/* Write data into SRC file */
ret = H5Dwrite(did_src, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf);
if (ret < 0)
TEST_ERROR;
/* Get the internal dset ptr to get the fill version for verifying later */
if ((dsetp = (H5D_t *)H5VL_object(did_src)) == NULL)
TEST_ERROR;
srcdset_layoutversion = dsetp->shared->layout.version;
/* Close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* Close the dataset */
if (H5Dclose(did_src) < 0)
TEST_ERROR;
/* Close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* Open the source file with read-only */
fid_src = H5Fopen(src_fname, H5F_ACC_RDONLY, fapl_src);
if (fid_src < 0)
TEST_ERROR;
/* Loop through all the combinations of low/high library format bounds,
skipping invalid combinations. Create a destination file and copy the
source dataset to it, then verify */
for (low = H5F_LIBVER_EARLIEST; low < H5F_LIBVER_NBOUNDS; low++) {
for (high = H5F_LIBVER_EARLIEST; high < H5F_LIBVER_NBOUNDS; high++) {
/* Set version bounds */
H5E_BEGIN_TRY
{
ret = H5Pset_libver_bounds(fapl_dst, low, high);
}
H5E_END_TRY;
if (ret < 0) /* Invalid low/high combinations */
continue;
/* Create destination file */
fid_dst = H5Fcreate(dst_fname, H5F_ACC_TRUNC, H5P_DEFAULT, fapl_dst);
if (fid_dst < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens
in source and destination files aren't the same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Try to copy the dataset */
H5E_BEGIN_TRY
{
ret = H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT,
H5P_DEFAULT);
}
H5E_END_TRY;
/* If copy failed, check if the failure is expected */
if (ret < 0) {
/* Failure is valid if layout version of source dataset is
greater than destination */
if (srcdset_layoutversion <= H5O_layout_ver_bounds[high])
TEST_ERROR;
/* Close the DST file before continue */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
continue;
}
/* Close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Open destination file */
fid_dst = H5Fopen(dst_fname, H5F_ACC_RDWR, fapl_dst);
if (fid_dst < 0)
TEST_ERROR;
/* Open the datasets to compare */
did_src = H5Dopen2(fid_src, NAME_DATASET_SIMPLE, H5P_DEFAULT);
if (did_src < 0)
TEST_ERROR;
did_dst = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT);
if (did_dst < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did_src, did_dst, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* Close the datasets */
if (H5Dclose(did_dst) < 0)
TEST_ERROR;
if (H5Dclose(did_src) < 0)
TEST_ERROR;
/* Close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
} /* for high */
} /* for low */
/* Close property list and source file */
if (H5Pclose(fapl_dst) < 0)
TEST_ERROR;
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did_dst);
H5Dclose(did_src);
H5Sclose(sid);
H5Pclose(fapl_dst);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_versionbounds */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_simple_samefile
*
* Purpose: Create a simple dataset in SRC file and copy it to SRC file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Neil Fortner
* Thursday, January 15, 2009
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_simple_samefile(hid_t fcpl, hid_t fapl)
{
hid_t fid = -1; /* File ID */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
int buf[DIM_SIZE_1][DIM_SIZE_2]; /* Buffer for writing data */
hsize_t dim2d[2]; /* Dataset dimensions */
int i, j; /* local index variables */
char filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): simple dataset within the same file");
/* Initialize write buffer */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
buf[i][j] = 10000 + 100 * i + j;
/* Initialize the filenames */
h5_fixname(FILENAME[0], fapl, filename, sizeof filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid = H5Fcreate(filename, H5F_ACC_TRUNC, fcpl, fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create 2D dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create 2D int dataset at SRC file */
if ((did = H5Dcreate2(fid, NAME_DATASET_SIMPLE, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid) < 0)
TEST_ERROR;
/* open the source file with read-write */
if ((fid = H5Fopen(filename, H5F_ACC_RDWR, fapl)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid, NAME_DATASET_SIMPLE, fid, NAME_DATASET_SIMPLE2, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid, NAME_DATASET_SIMPLE2, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Sclose(sid);
H5Fclose(fid);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_simple_samefile */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_simple_empty
*
* Purpose: Create a simple dataset in SRC file and copy it to DST file
* (Note: dataset has no data)
*
* Note: The parameter "test_open" is added to test for H5Ocopy when
* the dataset is open in the file (HDFFV-7853).
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Monday, October 31, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_simple_empty(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl,
hbool_t test_open)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hsize_t dim2d[2]; /* Dataset dimensions */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
if (test_open) {
TESTING("H5Ocopy(): empty and opened contiguous dataset");
}
else {
TESTING("H5Ocopy(): empty contiguous dataset");
}
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create 2D dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create 2D int dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_SIMPLE, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
if (!test_open) {
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
}
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (!test_open) {
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
}
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_simple_empty */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_compound
*
* Purpose: Create a compound dataset in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Friday, September 30, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_compound(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t tid = -1; /* Datatype ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hsize_t dim1d[1]; /* Dataset dimensions */
typedef struct comp_t {
int a;
double d;
} comp_t;
comp_t buf[DIM_SIZE_1]; /* Buffer for writing data */
int i; /* Local index variable */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): compound dataset");
HDmemset(buf, 0, sizeof(buf));
for (i = 0; i < DIM_SIZE_1; i++) {
buf[i].a = i;
buf[i].d = 1.0 / (double)(i + 1);
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tcreate(H5T_COMPOUND, sizeof(comp_t))) < 0)
TEST_ERROR;
if (H5Tinsert(tid, "int_name", HOFFSET(comp_t, a), H5T_NATIVE_INT) < 0)
TEST_ERROR;
if (H5Tinsert(tid, "double_name", HOFFSET(comp_t, d), H5T_NATIVE_DOUBLE) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_COMPOUND, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) <
0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_COMPOUND, fid_dst, NAME_DATASET_COMPOUND, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_COMPOUND, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_COMPOUND, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Tclose(tid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_compound */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_chunked
*
* Purpose: Create a chunked dataset in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Friday, September 30, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_chunked(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hsize_t dim1d[1]; /* Dataset dimensions */
hsize_t max_dim1d[1]; /* Dataset max. dimensions */
hsize_t dim2d[2]; /* Dataset dimensions */
hsize_t chunk_dim1d[1] = {CHUNK_SIZE_1}; /* Chunk dimensions */
hsize_t chunk_dim2d[2] = {CHUNK_SIZE_1, CHUNK_SIZE_2}; /* Chunk dimensions */
float buf1d[DIM_SIZE_1]; /* Buffer for writing data */
float buf2d[DIM_SIZE_1][DIM_SIZE_2]; /* Buffer for writing data */
int i, j; /* Local index variables */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): chunked dataset");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
buf1d[i] = (float)i / 2.0F;
for (j = 0; j < DIM_SIZE_2; j++)
buf2d[i][j] = (float)i + ((float)j / 100.0F);
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set 1-D dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
max_dim1d[0] = H5S_UNLIMITED;
/* create 1-D dataspace */
if ((sid = H5Screate_simple(1, dim1d, max_dim1d)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 1, chunk_dim1d) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf1d) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/*
* Create 1-D dataset: chunked, non-filterd, with data
* dims=max dims=chunk dims
* H5D_ALLOC_TIME_INC (default)
*/
/* create 1-D dataspace */
if ((sid = H5Screate_simple(1, dim1d, dim1d)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 1, dim1d) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED_SINGLE, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf1d) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Set 2-D dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create 2-D dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 2, chunk_dim2d) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED2, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf2d) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Set allocation time to early */
if (H5Pset_alloc_time(pid, H5D_ALLOC_TIME_EARLY) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED3, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf2d) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/*
* Create 2-D dataset: chunked, non-filterd, with data, dims=chunk dims,
* H5D_ALLOC_TIME_INC (default)
*/
/* create 2-D dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create and set chunk plist to be the same as dims2d */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 2, dim2d) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED2_SINGLE, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf2d) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/*
* Create 2-D dataset: chunked, non-filterd, with data, dims=chunk dims,
* H5D_ALLOC_TIME_EARLY
*/
if (H5Pset_alloc_time(pid, H5D_ALLOC_TIME_EARLY) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED3_SINGLE, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf2d) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/*
* Create 2-D dataset: chunked, non-filterd, with data, dims=max dims=chunk dims,
* H5D_ALLOC_TIME_LATE
*/
/* create 2-D dataspace */
if ((sid = H5Screate_simple(2, dim2d, dim2d)) < 0)
TEST_ERROR;
/* create and set chunk plist to be the same as dims2d */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 2, dim2d) < 0)
TEST_ERROR;
if (H5Pset_alloc_time(pid, H5D_ALLOC_TIME_LATE) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED4_SINGLE, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf2d) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the datasets from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED, fid_dst, NAME_DATASET_CHUNKED, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED2, fid_dst, NAME_DATASET_CHUNKED2, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED3, fid_dst, NAME_DATASET_CHUNKED3, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED_SINGLE, fid_dst, NAME_DATASET_CHUNKED_SINGLE, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED2_SINGLE, fid_dst, NAME_DATASET_CHUNKED2_SINGLE, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED3_SINGLE, fid_dst, NAME_DATASET_CHUNKED3_SINGLE, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED4_SINGLE, fid_dst, NAME_DATASET_CHUNKED4_SINGLE, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the 1-D destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_EARRAY, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf1d) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the 1-D destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_SINGLE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf1d) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the 2-D dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED2, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED2, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_FARRAY, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf2d) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the 2-D dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED3, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED3, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_NONE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf2d) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the 2-D dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED2_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED2_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_SINGLE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf2d) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the 2-D dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED3_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED3_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_SINGLE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf2d) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the 2-D dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED4_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED4_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_SINGLE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf2d) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Pclose(pid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_chunked */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_chunked_empty
*
* Purpose: Create a chunked dataset in SRC file and copy it to DST file
* (Note: dataset has no data)
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Monday, October 31, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_chunked_empty(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hsize_t dim1d[1]; /* Dataset dimensions */
hsize_t max_dim1d[1]; /* Dataset max. dimensions */
hsize_t dim2d[2]; /* Dataset dimensions */
hsize_t chunk_dim1d[1] = {CHUNK_SIZE_1}; /* Chunk dimensions */
hsize_t chunk_dim2d[2] = {CHUNK_SIZE_1, CHUNK_SIZE_2}; /* Chunk dimensions */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): empty chunked dataset");
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set 1-D dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
max_dim1d[0] = H5S_UNLIMITED;
/* create 1-D dataspace */
if ((sid = H5Screate_simple(1, dim1d, max_dim1d)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 1, chunk_dim1d) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/*
* create 1-D dataset: chunked, empty, non-filtered,
* dims=max dims=chunk dims, H5D_ALLOC_TIME_INC(default)
*/
/* Set 1-D dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create 1-D dataspace */
if ((sid = H5Screate_simple(1, dim1d, dim1d)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 1, dim1d) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED_SINGLE, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Set 2-D dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create 2-D dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 2, chunk_dim2d) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED2, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Set allocation time to early */
if (H5Pset_alloc_time(pid, H5D_ALLOC_TIME_EARLY) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED3, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/*
* create 2-D dataset: chunked, empty, non-filtered,
* dims=chunk dims, H5D_ALLOC_TIME_INC (default)
*/
/* Set 2-D dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create 2-D dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 2, dim2d) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED2_SINGLE, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/*
* create 2-D dataset: chunked, empty, non-filtered, dims=chunk dims
* H5D_ALLOC_TIME_EARLY
*/
/* Set allocation time to early */
if (H5Pset_alloc_time(pid, H5D_ALLOC_TIME_EARLY) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED3_SINGLE, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/*
* create 2-D dataset: chunked, empty, non-filtered,
* dims=max dims=chunk dims, H5D_ALLOC_TIME_LATE
*/
/* Set 2-D dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create 2-D dataspace */
if ((sid = H5Screate_simple(2, dim2d, dim2d)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 2, dim2d) < 0)
TEST_ERROR;
/* Set allocation time to late */
if (H5Pset_alloc_time(pid, H5D_ALLOC_TIME_LATE) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED4_SINGLE, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the datasets from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED, fid_dst, NAME_DATASET_CHUNKED, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED_SINGLE, fid_dst, NAME_DATASET_CHUNKED_SINGLE, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED2, fid_dst, NAME_DATASET_CHUNKED2, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED2_SINGLE, fid_dst, NAME_DATASET_CHUNKED2_SINGLE, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED3, fid_dst, NAME_DATASET_CHUNKED3, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED3_SINGLE, fid_dst, NAME_DATASET_CHUNKED3_SINGLE, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED4_SINGLE, fid_dst, NAME_DATASET_CHUNKED4_SINGLE, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset NAME_DATASET_CHUNKED in SRC file */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the copied dataset NAME_DATASET_CHUNKED at destination */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_EARRAY, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the dataset NAME_DATASET_CHUNKED_SINGLE in SRC file */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the copied dataset NAME_DATASET_CHUNKED_SINGLE at destination */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_SINGLE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the dataset NAME_DATASET_CHUNKED2 in SRC file */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED2, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the copied dataset NAME_DATASET_CHUNKED2 at destination */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED2, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_FARRAY, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the dataset "NAME_DATASET_CHUNKED2_SINGLE in SRC file */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED2_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the copied dataset NAME_DATASET_CHUNKED2_SINGLE at destination */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED2_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_SINGLE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the dataset NAME_DATASET_CHUNKED3 in SRC file */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED3, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the copied dataset NAME_DATASET_CHUNKED3 at destination */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED3, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_NONE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the dataset NAME_DATASET_CHUNKED3_SINGLE in SRC file */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED3_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the copied dataset NAME_DATASET_CHUNKED3_SINGLE at destination */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED3_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_SINGLE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the dataset NAME_DATASET_CHUNKED4_SINGLE in SRC file */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED4_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the copied dataset NAME_DATASET_CHUNKED4_SINGLE at destination */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED4_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_SINGLE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Pclose(pid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_chunked_empty */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_chunked_sparse
*
* Purpose: Create a chunked dataset with unlimited dimensions and un-written
* chunks in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Monday, October 31, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_chunked_sparse(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hsize_t dim1d[1]; /* Dataset dimensions */
hsize_t new_dim1d[1]; /* Dataset dimensions */
hsize_t max_dim1d[1]; /* Dataset max. dimensions */
hsize_t dim2d[2]; /* Dataset dimensions */
hsize_t new_dim2d[2]; /* Dataset dimensions */
hsize_t max_dim2d[2]; /* Dataset max. dimensions */
hsize_t chunk_dim1d[1] = {CHUNK_SIZE_1}; /* Chunk dimensions */
hsize_t chunk_dim2d[2] = {CHUNK_SIZE_1, CHUNK_SIZE_2}; /* Chunk dimensions */
float buf1d[DIM_SIZE_1]; /* Buffer for writing data */
float buf2d[DIM_SIZE_1][DIM_SIZE_2]; /* Buffer for writing data */
int i, j; /* Local index variables */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): sparse dataset");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
buf1d[i] = (float)i / 10.0F;
for (j = 0; j < DIM_SIZE_2; j++)
buf2d[i][j] = (float)i + ((float)j / 100.0F);
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set 1-D dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
max_dim1d[0] = H5S_UNLIMITED;
/* create 1-D dataspace */
if ((sid = H5Screate_simple(1, dim1d, max_dim1d)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 1, chunk_dim1d) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf1d) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* Set extended dataset dimensions */
new_dim1d[0] = DIM_SIZE_1 * 2;
/* Extend dataset's dimensions */
if (H5Dset_extent(did, new_dim1d) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Change 1-D dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
max_dim1d[0] = MAX_DIM_SIZE_1;
/* create 1-D dataspace */
if ((sid = H5Screate_simple(1, dim1d, max_dim1d)) < 0)
TEST_ERROR;
/* Set allocation time to early */
if (H5Pset_alloc_time(pid, H5D_ALLOC_TIME_EARLY) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED3, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf1d) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* Set extended dataset dimensions */
new_dim1d[0] = DIM_SIZE_1 * 2;
/* Extend dataset's dimensions */
if (H5Dset_extent(did, new_dim1d) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Set 2-D dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
max_dim2d[0] = H5S_UNLIMITED;
max_dim2d[1] = H5S_UNLIMITED;
/* create 2-D dataspace */
if ((sid = H5Screate_simple(2, dim2d, max_dim2d)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 2, chunk_dim2d) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED2, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf2d) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* Set extended dataset dimensions */
new_dim2d[0] = DIM_SIZE_1 * 2;
new_dim2d[1] = DIM_SIZE_2 * 2;
/* Extend dataset's dimensions */
if (H5Dset_extent(did, new_dim2d) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Change 2-D dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
max_dim2d[0] = MAX_DIM_SIZE_1;
max_dim2d[1] = MAX_DIM_SIZE_2;
/* create 2-D dataspace */
if ((sid = H5Screate_simple(2, dim2d, max_dim2d)) < 0)
TEST_ERROR;
/* Set allocation time to early */
if (H5Pset_alloc_time(pid, H5D_ALLOC_TIME_EARLY) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED4, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf2d) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* Set extended dataset dimensions */
new_dim2d[0] = DIM_SIZE_1 * 2;
new_dim2d[1] = DIM_SIZE_2 * 2;
/* Extend dataset's dimensions */
if (H5Dset_extent(did, new_dim2d) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the datasets from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED, fid_dst, NAME_DATASET_CHUNKED, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED2, fid_dst, NAME_DATASET_CHUNKED2, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED3, fid_dst, NAME_DATASET_CHUNKED3, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED4, fid_dst, NAME_DATASET_CHUNKED4, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_EARRAY, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED2, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED2, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_BT2, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED3, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED3, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_NONE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED4, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED4, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the array index type is correct */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_NONE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Pclose(pid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_chunked_sparse */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_compressed
*
* Purpose: Create a compressed, chunked dataset in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Monday, October 31, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_compressed(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
#ifdef H5_HAVE_FILTER_DEFLATE
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hsize_t dim2d[2]; /* Dataset dimensions */
hsize_t chunk_dim2d[2] = {CHUNK_SIZE_1, CHUNK_SIZE_2}; /* Chunk dimensions */
float buf[DIM_SIZE_1][DIM_SIZE_2]; /* Buffer for writing data */
int i, j; /* Local index variables */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
#endif /* H5_HAVE_FILTER_DEFLATE */
TESTING("H5Ocopy(): compressed dataset");
#ifndef H5_HAVE_FILTER_DEFLATE
(void)fcpl_src;
(void)fcpl_dst;
(void)src_fapl;
(void)dst_fapl; /* Silence compiler */
SKIPPED();
HDputs(" Deflation filter not available");
#else /* H5_HAVE_FILTER_DEFLATE */
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
buf[i][j] = 100.0F; /* Something easy to compress */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create and set comp & chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 2, chunk_dim2d) < 0)
TEST_ERROR;
if (H5Pset_deflate(pid, 9) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Set allocation time to early */
if (H5Pset_alloc_time(pid, H5D_ALLOC_TIME_EARLY) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED2, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/*
* create 2-D dataset: chunked, filtered, with data
* dims=max dims=chunk dims, H5D_ALLOC_TIME_INC(default)
*/
/* create dataspace */
if ((sid = H5Screate_simple(2, dim2d, dim2d)) < 0)
TEST_ERROR;
/* create and set comp & chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 2, dim2d) < 0)
TEST_ERROR;
if (H5Pset_deflate(pid, 9) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED2_SINGLE, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/*
* create 2-D dataset: chunked, filtered, with data
* dims=chunk dims, H5D_ALLOC_TIME_EARLY
*/
/* create dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* Set allocation time to early */
if (H5Pset_alloc_time(pid, H5D_ALLOC_TIME_EARLY) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED3_SINGLE, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/*
* create 2-D dataset: chunked, filtered, with data
* dims=chunk dims, H5D_ALLOC_TIME_LATE
*/
/* create dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create and set comp & chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 2, dim2d) < 0)
TEST_ERROR;
if (H5Pset_deflate(pid, 9) < 0)
TEST_ERROR;
/* Set allocation time to late */
if (H5Pset_alloc_time(pid, H5D_ALLOC_TIME_LATE) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED4_SINGLE, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED, fid_dst, NAME_DATASET_CHUNKED, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED2, fid_dst, NAME_DATASET_CHUNKED2, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED2_SINGLE, fid_dst, NAME_DATASET_CHUNKED2_SINGLE, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED3_SINGLE, fid_dst, NAME_DATASET_CHUNKED3_SINGLE, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED4_SINGLE, fid_dst, NAME_DATASET_CHUNKED4_SINGLE, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* Re-open the source and destination files for verification */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_FARRAY, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED2, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_FARRAY, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the dataset NAME_DATASET_CHUNKED2_SINGLE at source */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED2_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the copied dataset NAME_DATASET_CHUNKED2_SINGLE at destination */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED2_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_SINGLE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the dataset NAME_DATASET_CHUNKED3_SINGLE at source */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED3_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the copied dataset NAME_DATASET_CHUNKED3_SINGLE at destination */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED3_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_SINGLE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the dataset NAME_DATASET_CHUNKED4_SINGLE at source */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED4_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the copied dataset NAME_DATASET_CHUNKED4_SINGLE at destination */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED4_SINGLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_SINGLE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
#endif /* H5_HAVE_FILTER_DEFLATE */
return 0;
#ifdef H5_HAVE_FILTER_DEFLATE
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Pclose(pid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
#endif /* H5_HAVE_FILTER_DEFLATE */
} /* end test_copy_dataset_compressed */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_no_edge_filt
*
* Purpose: Create a compressed, chunked dataset in SRC file and copy it to DST file
*
* Note: The parameter "test_open" is added to test for H5Ocopy when
* the dataset is open in the file (HDFFV-7853).
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Neil Fortner
* Tuesday, May 11, 2010
* Mostly copied from test_copy_dataset_compressed, by
* Quincey Koziol
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_no_edge_filt(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl,
hbool_t test_open)
{
#ifdef H5_HAVE_FILTER_DEFLATE
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hsize_t dim2d[2]; /* Dataset dimensions */
hsize_t chunk_dim2d[2] = {CHUNK_SIZE_1, CHUNK_SIZE_2}; /* Chunk dimensions */
float buf[DIM_SIZE_1][DIM_SIZE_2]; /* Buffer for writing data */
int i, j; /* Local index variables */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
#endif /* H5_HAVE_FILTER_DEFLATE */
if (test_open) {
TESTING("H5Ocopy(): compressed and opened dataset with no edge filters");
}
else {
TESTING("H5Ocopy(): compressed dataset with no edge filters");
}
#ifndef H5_HAVE_FILTER_DEFLATE
(void)fcpl_src;
(void)fcpl_dst;
(void)src_fapl;
(void)dst_fapl; /* Silence compiler */
SKIPPED();
HDputs(" Deflation filter not available");
#else /* H5_HAVE_FILTER_DEFLATE */
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
buf[i][j] = 100.0F; /* Something easy to compress */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create and set comp & chunk plist, and disable partial chunk filters */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 2, chunk_dim2d) < 0)
TEST_ERROR;
if (H5Pset_deflate(pid, 9) < 0)
TEST_ERROR;
if (H5Pset_chunk_opts(pid, H5D_CHUNK_DONT_FILTER_PARTIAL_CHUNKS) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
if (!test_open) {
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
}
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED, fid_dst, NAME_DATASET_CHUNKED, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (!test_open) {
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED, H5P_DEFAULT)) < 0)
TEST_ERROR;
}
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* H5Pset_chunk_opts() will set layout version to 4 which will use latest indexing available */
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_FARRAY, H5D_CHUNK_IDX_FARRAY) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
#endif /* H5_HAVE_FILTER_DEFLATE */
return 0;
#ifdef H5_HAVE_FILTER_DEFLATE
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Pclose(pid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
#endif /* H5_HAVE_FILTER_DEFLATE */
} /* end test_copy_dataset_no_edge_filt */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_compact
*
* Purpose: Create a compact dataset in SRC file and copy it to DST file
*
* Note: The parameter "test_open" is added to test for H5Ocopy when
* the dataset is open in the file (HDFFV-7853).
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Monday, October 31, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_compact(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl, hbool_t test_open)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hsize_t dim2d[2]; /* Dataset dimensions */
float buf[DIM_SIZE_1][DIM_SIZE_2]; /* Buffer for writing data */
int i, j; /* Local index variables */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
if (test_open) {
TESTING("H5Ocopy(): compact and opened dataset");
}
else {
TESTING("H5Ocopy(): compact dataset");
}
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
buf[i][j] = (float)i + (float)j / 100.0F;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create and set compact plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_layout(pid, H5D_COMPACT) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_COMPACT, H5T_NATIVE_FLOAT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_FLOAT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
if (!test_open) {
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
}
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_COMPACT, fid_dst, NAME_DATASET_COMPACT, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (!test_open) {
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_COMPACT, H5P_DEFAULT)) < 0)
TEST_ERROR;
}
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_COMPACT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Pclose(pid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_compact */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_external
*
* Purpose: Create an external dataset in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Friday, September 30, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_external(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
int i;
hsize_t size;
hsize_t dim1d[1];
int buf[DIM_SIZE_1];
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): external dataset");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
buf[i] = i;
/* create an empty external file */
HDfclose(HDfopen(FILE_EXT, "w"));
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* set dataset creation plist */
size = DIM_SIZE_1 * sizeof(int);
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_external(pid, FILE_EXT, (off_t)0, size) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_EXTERNAL, H5T_NATIVE_INT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close external plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_EXTERNAL, fid_dst, NAME_DATASET_EXTERNAL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_EXTERNAL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_EXTERNAL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Pclose(pid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_external */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_named_dtype
*
* Purpose: Create a dataset that uses a named datatype in SRC file and
* copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Monday, October 31, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_named_dtype(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
int i;
hsize_t dim1d[1];
int buf[DIM_SIZE_1];
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): dataset that uses named datatype");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
buf[i] = i;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create named datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_src, NAME_DATATYPE_SIMPLE, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_NAMED_DTYPE, tid, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_NAMED_DTYPE, fid_dst, NAME_DATASET_NAMED_DTYPE, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_NAMED_DTYPE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_NAMED_DTYPE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Tclose(tid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_named_dtype */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_named_dtype_hier
*
* Purpose: Create a hierarchy of datasets that use a named datatype in
* SRC file and copy hierarchy to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Tuesday, October 31, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_named_dtype_hier(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1; /* Dataset ID */
hid_t gid = -1, gid2 = -1; /* Group IDs */
int i;
hsize_t dim1d[1];
int buf[DIM_SIZE_1];
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): hier. of datasets using named datatype inside hier.");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
buf[i] = i;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Create group to place all objects in */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create named datatype _inside_ hierarchy to copy */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(gid, NAME_DATATYPE_SIMPLE, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create first dataset at SRC file */
if ((did = H5Dcreate2(gid, NAME_DATASET_NAMED_DTYPE, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) <
0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* create second dataset at SRC file */
if ((did = H5Dcreate2(gid, NAME_DATASET_NAMED_DTYPE2, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) <
0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_GROUP_TOP, fid_dst, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the group for copy */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination group */
if ((gid2 = H5Gopen2(fid_dst, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Check if the groups are equal */
if (compare_groups(gid, gid2, H5P_DEFAULT, -1, 0) != TRUE)
TEST_ERROR;
/* close the destination group */
if (H5Gclose(gid2) < 0)
TEST_ERROR;
/* close the source group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did);
H5Tclose(tid);
H5Sclose(sid);
H5Gclose(gid2);
H5Gclose(gid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_named_dtype_hier */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_named_dtype_hier_outside
*
* Purpose: Create a hierarchy of datasets that use a named datatype that
* is outside of hierarchy in SRC file and copy hierarchy to DST
* file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Tuesday, October 31, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_named_dtype_hier_outside(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1; /* Dataset ID */
hid_t gid = -1, gid2 = -1; /* Group IDs */
int i;
hsize_t dim1d[1];
int buf[DIM_SIZE_1];
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): hier. of datasets using named datatype outside hier.");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
buf[i] = i;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Create group to place all objects in */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create named datatype _outside_ hierarchy to copy */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_src, NAME_DATATYPE_SIMPLE, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create first dataset at SRC file */
if ((did = H5Dcreate2(gid, NAME_DATASET_NAMED_DTYPE, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) <
0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* create second dataset at SRC file */
if ((did = H5Dcreate2(gid, NAME_DATASET_NAMED_DTYPE2, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) <
0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_GROUP_TOP, fid_dst, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the group for copy */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination group */
if ((gid2 = H5Gopen2(fid_dst, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Check if the groups are equal */
if (compare_groups(gid, gid2, H5P_DEFAULT, -1, 0) != TRUE)
TEST_ERROR;
/* close the destination group */
if (H5Gclose(gid2) < 0)
TEST_ERROR;
/* close the source group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did);
H5Tclose(tid);
H5Sclose(sid);
H5Gclose(gid2);
H5Gclose(gid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_named_dtype_hier_outside */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_multi_ohdr_chunks
*
* Purpose: Create a pair of datasets that add attributes in a way that
* creates lots of object header chunks in SRC file and copy
* datasets to DST file
*
* Note: The parameter "test_open" is added to test for H5Ocopy when
* the dataset is open in the file (HDFFV-7853).
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Tuesday, October 31, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_multi_ohdr_chunks(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl,
hbool_t test_open)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t gid = -1, gid2 = -1; /* Group IDs */
int i;
hsize_t dim1d[1];
int buf[DIM_SIZE_1];
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
if (test_open) {
TESTING("H5Ocopy(): opened datasets that have multiple ohdr chunks");
}
else {
TESTING("H5Ocopy(): datasets that have multiple ohdr chunks");
}
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
buf[i] = i;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Create group to place all objects in */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create first dataset at SRC file */
if ((did = H5Dcreate2(gid, NAME_DATASET_MULTI_OHDR, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* create second dataset at SRC file */
if ((did2 = H5Dcreate2(gid, NAME_DATASET_MULTI_OHDR2, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did2, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* Add attributes to datasets in a way that creates lots of chunks */
if (test_copy_attach_paired_attributes(did, did2, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close the first dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
if (!test_open) {
/* close the second dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
}
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_GROUP_TOP, fid_dst, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (test_open) {
/* close the second dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
}
else
/* open the group for copy */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination group */
if ((gid2 = H5Gopen2(fid_dst, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Check if the groups are equal */
if (compare_groups(gid, gid2, H5P_DEFAULT, -1, 0) != TRUE)
TEST_ERROR;
/* close the destination group */
if (H5Gclose(gid2) < 0)
TEST_ERROR;
/* close the source group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Sclose(sid);
H5Gclose(gid2);
H5Gclose(gid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_multi_ohdr_chunks */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_attr_named_dtype
*
* Purpose: Create a pair of datasets that add attributes that use
* named datatypes in SRC file and copy datasets to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Tuesday, October 31, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_attr_named_dtype(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t gid = -1, gid2 = -1; /* Group IDs */
int i;
hsize_t dim1d[1];
int buf[DIM_SIZE_1];
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): objects with attributes using named datatypes");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
buf[i] = i;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Create group to place all objects in */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create named datatype _outside_ hierarchy to copy */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_src, NAME_DATATYPE_SIMPLE, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create first dataset at SRC file */
if ((did = H5Dcreate2(gid, NAME_DATASET_MULTI_OHDR, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* create second dataset at SRC file */
if ((did2 = H5Dcreate2(gid, NAME_DATASET_MULTI_OHDR2, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) <
0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did2, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* Add attributes to datasets in a way that creates lots of chunks */
if (test_copy_attach_paired_attributes(did, did2, tid) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the first dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the second dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_GROUP_TOP, fid_dst, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the group for copy */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination group */
if ((gid2 = H5Gopen2(fid_dst, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Check if the groups are equal */
if (compare_groups(gid, gid2, H5P_DEFAULT, -1, 0) != TRUE)
TEST_ERROR;
/* close the destination group */
if (H5Gclose(gid2) < 0)
TEST_ERROR;
/* close the source group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Tclose(tid);
H5Sclose(sid);
H5Gclose(gid2);
H5Gclose(gid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_attr_named_dtype */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_contig_vl
*
* Purpose: Create a contiguous dataset w/VLEN datatype in SRC
* file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Friday, September 30, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_contig_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t dxpl_id = -1; /* Dataset transfer property list ID */
unsigned int i, j; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
hvl_t buf[DIM_SIZE_1]; /* Buffer for writing data */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): contiguous dataset with VLEN datatype");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
buf[i].len = i + 1;
buf[i].p = (int *)HDmalloc(buf[i].len * sizeof(int));
for (j = 0; j < buf[i].len; j++)
((int *)buf[i].p)[j] = (int)(i * 10 + j);
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_VL, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_VL, fid_dst, NAME_DATASET_VL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Reclaim vlen buffer */
if (H5Tdetect_class(tid, H5T_VLEN) == TRUE) {
if ((dxpl_id = H5Pcreate(H5P_DATASET_XFER)) < 0)
TEST_ERROR;
if (H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL) < 0)
TEST_ERROR;
if (H5Treclaim(tid, sid, dxpl_id, buf) < 0)
TEST_ERROR;
if (H5Pclose(dxpl_id) < 0)
TEST_ERROR;
} /* end if */
/* close datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Treclaim(tid, sid, H5P_DEFAULT, buf);
H5Pclose(dxpl_id);
H5Tclose(tid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_contig_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_chunked_vl
*
* Purpose: Create a chunked dataset w/VLEN datatype in SRC
* file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Saturday, December 10, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_chunked_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t dxpl_id = -1; /* Dataset transfer property list ID */
unsigned int i, j; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
hsize_t chunk_dim1d[1] = {CHUNK_SIZE_1}; /* Chunk dimensions */
hvl_t buf[DIM_SIZE_1]; /* Buffer for writing data */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): chunked dataset with VLEN datatype");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
buf[i].len = i + 1;
buf[i].p = (int *)HDmalloc(buf[i].len * sizeof(int));
for (j = 0; j < buf[i].len; j++)
((int *)buf[i].p)[j] = (int)(i * 10 + j);
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 1, chunk_dim1d) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_VL, tid, sid, H5P_DEFAULT, pid, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Set allocation time to early */
if (H5Pset_alloc_time(pid, H5D_ALLOC_TIME_EARLY) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_VL2, tid, sid, H5P_DEFAULT, pid, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_VL, fid_dst, NAME_DATASET_VL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_VL2, fid_dst, NAME_DATASET_VL2, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_FARRAY, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_VL2, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_VL2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_NONE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Reclaim vlen buffer */
if (H5Tdetect_class(tid, H5T_VLEN) == TRUE) {
if ((dxpl_id = H5Pcreate(H5P_DATASET_XFER)) < 0)
TEST_ERROR;
if (H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL) < 0)
TEST_ERROR;
if (H5Treclaim(tid, sid, dxpl_id, buf) < 0)
TEST_ERROR;
if (H5Pclose(dxpl_id) < 0)
TEST_ERROR;
} /* end if */
/* close datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Treclaim(tid, sid, H5P_DEFAULT, buf);
H5Pclose(dxpl_id);
H5Pclose(pid);
H5Tclose(tid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_chunked_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_compact_vl
*
* Purpose: Create a compact dataset w/VLEN datatype in SRC
* file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Sunday, December 11, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_compact_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t dxpl_id = -1; /* Dataset transfer property list ID */
unsigned int i, j; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
hvl_t buf[DIM_SIZE_1]; /* Buffer for writing data */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): compact dataset with VLEN datatype");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
buf[i].len = i + 1;
buf[i].p = (int *)HDmalloc(buf[i].len * sizeof(int));
for (j = 0; j < buf[i].len; j++)
((int *)buf[i].p)[j] = (int)(i * 10 + j);
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* create and set compact plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_layout(pid, H5D_COMPACT) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_VL, tid, sid, H5P_DEFAULT, pid, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close compact plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_VL, fid_dst, NAME_DATASET_VL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Reclaim vlen buffer */
if (H5Tdetect_class(tid, H5T_VLEN) == TRUE) {
if ((dxpl_id = H5Pcreate(H5P_DATASET_XFER)) < 0)
TEST_ERROR;
if (H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL) < 0)
TEST_ERROR;
if (H5Treclaim(tid, sid, dxpl_id, buf) < 0)
TEST_ERROR;
if (H5Pclose(dxpl_id) < 0)
TEST_ERROR;
} /* end if */
/* close datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Treclaim(tid, sid, H5P_DEFAULT, buf);
H5Pclose(dxpl_id);
H5Tclose(tid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_compact_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_attribute_vl
*
* Purpose: Create a simple dataset with vlen attributes in SRC file
* and copy it to DST file (Note: dataset has no data)
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Saturday, December , 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_attribute_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t aid = -1, aid2 = -1; /* Attribute IDs */
hsize_t dim2d[2]; /* Dataset dimensions */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): variable length attribute");
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create 2D dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create 2D int dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_SIMPLE, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach VL attribute to the dataset */
if (test_copy_attach_attribute_vl(did) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the attributes are equal */
if ((aid = H5Aopen_by_idx(did, ".", H5_INDEX_CRT_ORDER, H5_ITER_INC, (hsize_t)0, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((aid2 = H5Aopen_by_idx(did2, ".", H5_INDEX_CRT_ORDER, H5_ITER_INC, (hsize_t)0, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (compare_attribute(aid, aid2, H5P_DEFAULT, NULL, did) != TRUE)
TEST_ERROR;
if (H5Aclose(aid) < 0)
TEST_ERROR;
if (H5Aclose(aid2) < 0)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Aclose(aid2);
H5Aclose(aid);
H5Dclose(did2);
H5Dclose(did);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_simple_empty */
/*-------------------------------------------------------------------------
* Function: attach_attribute_compound_vlstr
*
* Purpose: Attach a compound datatype with a variable length string to the object
*
* Return: Non-negative on success/Negative on failure
*
* Programmer: Vailin Choi; Aug 2016
*
*-------------------------------------------------------------------------
*/
static int
attach_attribute_compound_vlstr(hid_t loc_id)
{
hid_t aid = -1; /* Attribute ID */
hid_t sid = -1; /* Dataspace ID */
hid_t tid = -1; /* Datatype ID */
hid_t vl_str_tid = -1; /* Variable length string datatype ID */
hid_t cmpd_tid = -1; /* Compound datatype ID */
hsize_t dim1 = 1; /* Dimension size */
typedef struct { /* Compound structure for the attribute */
int i;
char *v;
} s1;
size_t len;
s1 buf = {0, NULL}; /* Buffer */
int ret_value = -1; /* Return value */
/* Create dataspace */
if ((sid = H5Screate_simple(1, &dim1, NULL)) < 0)
goto done;
/* Create an integer datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
goto done;
/* Create a variable length string */
if ((vl_str_tid = H5Tcopy(H5T_C_S1)) < 0)
goto done;
if (H5Tset_size(vl_str_tid, H5T_VARIABLE) < 0)
goto done;
/* Create a compound datatype with a variable length string and an integer */
if ((cmpd_tid = H5Tcreate(H5T_COMPOUND, sizeof(s1))) < 0)
goto done;
if (H5Tinsert(cmpd_tid, "i", HOFFSET(s1, i), tid) < 0)
goto done;
if (H5Tinsert(cmpd_tid, "v", HOFFSET(s1, v), vl_str_tid) < 0)
goto done;
/* Attach an attribute to the object */
if ((aid = H5Acreate2(loc_id, "attr_cmpd_vlstr", cmpd_tid, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
goto done;
/* Write to the attribute */
len = HDstrlen(ATTR_CMPD_STRING) + 1;
buf.i = 9;
if (NULL == (buf.v = (char *)HDcalloc(len, sizeof(char))))
goto done;
HDstrncpy(buf.v, ATTR_CMPD_STRING, len);
if (H5Awrite(aid, cmpd_tid, &buf) < 0)
goto done;
ret_value = 0;
done:
if (sid > 0)
H5Sclose(sid);
if (tid > 0)
H5Tclose(tid);
if (vl_str_tid > 0)
H5Tclose(vl_str_tid);
if (cmpd_tid > 0)
H5Tclose(cmpd_tid);
if (aid > 0)
H5Aclose(aid);
HDfree(buf.v);
return ret_value;
} /* attach_attribute_compound_vlstr */
/*-------------------------------------------------------------------------
* Function: compare_attribute_compound_vlstr
*
* Purpose: Compare data of the attributes attached to the two objects.
* The attribute is a compound datatype with a variable length string.
*
* Return: Non-negative on success/Negative on failure
*
* Programmer: Vailin Choi; Aug 2016
*
*-------------------------------------------------------------------------
*/
static int
compare_attribute_compound_vlstr(hid_t loc, hid_t loc2)
{
hid_t aid = -1, aid2 = -1; /* Attribute IDs */
hid_t tid = -1, tid2 = -1; /* Datatype IDs */
hid_t sid = -1, sid2 = -1; /* Dataspace IDs */
hid_t dxpl_id = -1;
typedef struct { /* Compound structure for the attribute */
int i;
char *v;
} s1;
s1 rbuf; /* Buffer for data read */
s1 rbuf2; /* Buffer for data read */
/* Open the attributes attached to the objects */
if ((aid = H5Aopen_by_idx(loc, ".", H5_INDEX_CRT_ORDER, H5_ITER_INC, (hsize_t)0, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
if ((aid2 = H5Aopen_by_idx(loc2, ".", H5_INDEX_CRT_ORDER, H5_ITER_INC, (hsize_t)0, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Get the attributes' datatypes */
if ((tid = H5Aget_type(aid)) < 0)
FAIL_STACK_ERROR;
if ((tid2 = H5Aget_type(aid2)) < 0)
FAIL_STACK_ERROR;
/* Get the attributes' dataspaces */
if ((sid = H5Aget_space(aid)) < 0)
FAIL_STACK_ERROR;
if ((sid2 = H5Aget_space(aid2)) < 0)
FAIL_STACK_ERROR;
/* Read the attributes */
if (H5Aread(aid, tid, &rbuf) < 0)
FAIL_STACK_ERROR;
if (H5Aread(aid2, tid2, &rbuf2) < 0)
FAIL_STACK_ERROR;
/* Compare the attributes' data */
if (rbuf.i != rbuf2.i)
FAIL_STACK_ERROR;
if (HDstrlen(rbuf.v) != HDstrlen(rbuf2.v))
FAIL_STACK_ERROR;
if (HDmemcmp(rbuf.v, rbuf2.v, HDstrlen(rbuf.v)) != 0)
FAIL_STACK_ERROR;
/* Reclaim vlen buffer */
if ((dxpl_id = H5Pcreate(H5P_DATASET_XFER)) < 0)
TEST_ERROR;
if (H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL) < 0)
TEST_ERROR;
if (H5Treclaim(tid, sid, dxpl_id, &rbuf) < 0)
TEST_ERROR;
if (H5Treclaim(tid, sid, dxpl_id, &rbuf2) < 0)
TEST_ERROR;
if (H5Pclose(dxpl_id) < 0)
TEST_ERROR;
/* Close the dataspaces */
if (H5Sclose(sid) < 0)
FAIL_STACK_ERROR;
if (H5Sclose(sid2) < 0)
FAIL_STACK_ERROR;
/* Close the attributes */
if (H5Aclose(aid) < 0)
FAIL_STACK_ERROR;
if (H5Aclose(aid2) < 0)
FAIL_STACK_ERROR;
return TRUE;
error:
H5E_BEGIN_TRY
{
H5Aclose(aid);
H5Aclose(aid2);
H5Treclaim(tid, sid, H5P_DEFAULT, &rbuf);
H5Treclaim(tid, sid, H5P_DEFAULT, &rbuf2);
H5Sclose(sid);
H5Sclose(sid2);
H5Tclose(tid);
H5Tclose(tid2);
H5Pclose(dxpl_id);
}
H5E_END_TRY;
return FALSE;
} /* compare_attribute_compound_vlstr() */
/*-------------------------------------------------------------------------
* Function: test_copy_attribute_compound_vlstr
*
* Purpose: Create a simple dataset and a group in SRC file.
* Both has an attribute with a compound datatype consisting
* of a variable length string
* Copy the dataset and the group to DST file
* This is for HDFFV-7991
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer:
*
*-------------------------------------------------------------------------
*/
static int
test_copy_attribute_compound_vlstr(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t aid = -1, aid2 = -1; /* Attribute IDs */
hid_t gid = -1, gid2 = -1; /* Group IDs */
hsize_t dim2d[2]; /* Dataset dimensions */
char src_filename[NAME_BUF_SIZE]; /* Source file name */
char dst_filename[NAME_BUF_SIZE]; /* Destination file name */
TESTING("H5Ocopy(): attribute with compound datatype consisting of variable length string");
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
FAIL_STACK_ERROR;
/* set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create 2D dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
FAIL_STACK_ERROR;
/* create 2D int dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_SIMPLE, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
FAIL_STACK_ERROR;
/* attach an attribute to the dataset */
if (attach_attribute_compound_vlstr(did) < 0)
FAIL_STACK_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
FAIL_STACK_ERROR;
/* create a group */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_EMPTY, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* attach attribute to the group */
if (attach_attribute_compound_vlstr(gid) < 0)
FAIL_STACK_ERROR;
/* close the group */
if (H5Gclose(gid) < 0)
FAIL_STACK_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
FAIL_STACK_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
FAIL_STACK_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
FAIL_STACK_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT, H5P_DEFAULT) < 0)
FAIL_STACK_ERROR;
/* open the src dataset */
if ((did = H5Dopen2(fid_src, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* compare the data of the attributes attached to the two datasets */
if (compare_attribute_compound_vlstr(did, did2) < 0)
FAIL_STACK_ERROR;
/* close the datasets */
if (H5Dclose(did2) < 0)
FAIL_STACK_ERROR;
if (H5Dclose(did) < 0)
FAIL_STACK_ERROR;
/* Copy the group */
if (H5Ocopy(fid_src, NAME_GROUP_EMPTY, fid_dst, NAME_GROUP_EMPTY, H5P_DEFAULT, H5P_DEFAULT) < 0)
FAIL_STACK_ERROR;
/* Open the src group */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_EMPTY, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Open the destination group */
if ((gid2 = H5Gopen2(fid_dst, NAME_GROUP_EMPTY, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* compare the data of the attributes attached to the two groups */
if (compare_attribute_compound_vlstr(gid, gid2) < 0)
FAIL_STACK_ERROR;
/* close the groups */
if (H5Gclose(gid) < 0)
FAIL_STACK_ERROR;
if (H5Gclose(gid2) < 0)
FAIL_STACK_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
FAIL_STACK_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
FAIL_STACK_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Aclose(aid2);
H5Aclose(aid);
H5Dclose(did2);
H5Dclose(did);
H5Gclose(gid);
H5Gclose(gid2);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_attribute_compound_vlstr() */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_compressed_vl
*
* Purpose: Create a compressed, chunked, VLEN dataset in SRC
* file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Tuesday, December 27, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_compressed_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
#ifdef H5_HAVE_FILTER_DEFLATE
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t tid = -1; /* Datatype ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t dxpl_id = -1; /* Dataset transfer property list ID */
hsize_t dim2d[2]; /* Dataset dimensions */
hsize_t chunk_dim2d[2] = {CHUNK_SIZE_1, CHUNK_SIZE_2}; /* Chunk dimensions */
hvl_t buf[DIM_SIZE_1][DIM_SIZE_2]; /* Buffer for writing data */
int i, j, k; /* Local index variables */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
#endif /* H5_HAVE_FILTER_DEFLATE */
TESTING("H5Ocopy(): compressed dataset with VLEN datatype");
#ifndef H5_HAVE_FILTER_DEFLATE
(void)fcpl_src;
(void)fcpl_dst;
(void)src_fapl;
(void)dst_fapl; /* Silence compiler */
SKIPPED();
HDputs(" Deflation filter not available");
#else /* H5_HAVE_FILTER_DEFLATE */
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
for (j = 0; j < DIM_SIZE_2; j++) {
buf[i][j].len = (size_t)(j + 1);
buf[i][j].p = (int *)HDmalloc(buf[i][j].len * sizeof(int));
for (k = 0; k < (int)buf[i][j].len; k++)
((int *)buf[i][j].p)[k] = i * 10000 + j * 100 + k;
}
}
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* create and set comp & chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 2, chunk_dim2d) < 0)
TEST_ERROR;
if (H5Pset_deflate(pid, 9) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED, tid, sid, H5P_DEFAULT, pid, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED, fid_dst, NAME_DATASET_CHUNKED, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CHUNKED, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Reclaim vlen buffer */
if (H5Tdetect_class(tid, H5T_VLEN) == TRUE) {
if ((dxpl_id = H5Pcreate(H5P_DATASET_XFER)) < 0)
TEST_ERROR;
if (H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL) < 0)
TEST_ERROR;
if (H5Treclaim(tid, sid, dxpl_id, buf) < 0)
TEST_ERROR;
if (H5Pclose(dxpl_id) < 0)
TEST_ERROR;
} /* end if */
/* close datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
#endif /* H5_HAVE_FILTER_DEFLATE */
return 0;
#ifdef H5_HAVE_FILTER_DEFLATE
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Pclose(pid);
H5Treclaim(tid, sid, H5P_DEFAULT, buf);
H5Pclose(dxpl_id);
H5Tclose(tid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
#endif /* H5_HAVE_FILTER_DEFLATE */
} /* end test_copy_dataset_compressed_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_group_empty
*
* Purpose: Create an empty group in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Friday, September 30, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_group_empty(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t gid = -1, gid2 = -1; /* Group IDs */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): empty group");
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create group at the SRC file */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_EMPTY, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* attach attributes to the group */
if (test_copy_attach_attributes(gid, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the group from SRC to DST */
if (H5Ocopy(fid_src, NAME_GROUP_EMPTY, fid_dst, NAME_GROUP_EMPTY, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the group for copy */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_EMPTY, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination group */
if ((gid2 = H5Gopen2(fid_dst, NAME_GROUP_EMPTY, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Check if the groups are equal */
if (compare_groups(gid, gid2, H5P_DEFAULT, -1, 0) != TRUE)
TEST_ERROR;
/* close the destination group */
if (H5Gclose(gid2) < 0)
TEST_ERROR;
/* close the source group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Gclose(gid2);
H5Gclose(gid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_group_empty */
/*-------------------------------------------------------------------------
* Function: test_copy_root_group
*
* Purpose: Create a root group in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* August 8, 2006
*
*-------------------------------------------------------------------------
*/
static int
test_copy_root_group(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1; /* Dataset ID */
hid_t gid = -1, gid2 = -1; /* Group IDs */
hid_t gid_sub = -1; /* Sub-group ID */
hsize_t dim2d[2];
int buf[DIM_SIZE_1][DIM_SIZE_2];
int i, j;
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): root group");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
buf[i][j] = 10000 + 100 * i + j;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create group at the SRC file */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* attach attributes to the group */
if (test_copy_attach_attributes(gid, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* add a dataset to the group */
if ((did = H5Dcreate2(fid_src, NAME_GROUP_DATASET, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* create a sub-group */
if ((gid_sub = H5Gcreate2(fid_src, NAME_GROUP_SUB, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Gclose(gid_sub) < 0)
TEST_ERROR;
/* create another sub-group */
if ((gid_sub = H5Gcreate2(fid_src, NAME_GROUP_SUB_2, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Gclose(gid_sub) < 0)
TEST_ERROR;
/* close the group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the group from SRC to DST */
if (H5Ocopy(fid_src, "/", fid_dst, "/root_from_src", H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the group for copy */
if ((gid = H5Gopen2(fid_src, "/", H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination group */
if ((gid2 = H5Gopen2(fid_dst, "/root_from_src", H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Check if the groups are equal */
if (compare_groups(gid, gid2, H5P_DEFAULT, -1, 0) != TRUE)
TEST_ERROR;
/* close the destination group */
if (H5Gclose(gid2) < 0)
TEST_ERROR;
/* close the source group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Sclose(sid);
H5Dclose(did);
H5Gclose(gid_sub);
H5Gclose(gid2);
H5Gclose(gid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_root_group */
/*-------------------------------------------------------------------------
* Function: test_copy_group
*
* Purpose: Create a group in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Friday, September 30, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_group(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1; /* Dataset ID */
hid_t gid = -1, gid2 = -1; /* Group IDs */
hid_t gid_sub = -1; /* Sub-group ID */
hsize_t dim2d[2];
int buf[DIM_SIZE_1][DIM_SIZE_2];
int i, j;
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): simple nested groups");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
buf[i][j] = 10000 + 100 * i + j;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create group at the SRC file */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* attach attributes to the group */
if (test_copy_attach_attributes(gid, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* add a dataset to the group */
if ((did = H5Dcreate2(fid_src, NAME_GROUP_DATASET, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* create a sub-group */
if ((gid_sub = H5Gcreate2(fid_src, NAME_GROUP_SUB, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Gclose(gid_sub) < 0)
TEST_ERROR;
/* create another sub-group */
if ((gid_sub = H5Gcreate2(fid_src, NAME_GROUP_SUB_2, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Gclose(gid_sub) < 0)
TEST_ERROR;
/* close the group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the group from SRC to DST */
if (H5Ocopy(fid_src, NAME_GROUP_TOP, fid_dst, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the group for copy */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination group */
if ((gid2 = H5Gopen2(fid_dst, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Check if the groups are equal */
if (compare_groups(gid, gid2, H5P_DEFAULT, -1, 0) != TRUE)
TEST_ERROR;
/* close the destination group */
if (H5Gclose(gid2) < 0)
TEST_ERROR;
/* close the source group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Sclose(sid);
H5Dclose(did);
H5Gclose(gid_sub);
H5Gclose(gid2);
H5Gclose(gid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_group */
/*-------------------------------------------------------------------------
* Function: test_copy_group_deep
*
* Purpose: Create a deep group hier. in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Tuesday, November 1, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_group_deep(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1; /* Dataset ID */
hid_t gid = -1, gid2 = -1; /* Group IDs */
hid_t gid_sub = -1, gid_sub2; /* Sub-group IDs */
hsize_t dim2d[2];
int buf[DIM_SIZE_1][DIM_SIZE_2];
int i, j, k; /* Local index variables */
char objname[NAME_BUF_SIZE]; /* Sub-group & dataset name buffer */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): deep nested groups");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
buf[i][j] = 10000 + 100 * i + j;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create group at the SRC file */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* attach attributes to the group */
if (test_copy_attach_attributes(gid, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create nested sub-groups & datasets */
for (i = 0; i < NUM_SUB_GROUPS; i++) {
HDsnprintf(objname, sizeof(objname), "Group #%d", i);
if ((gid_sub = H5Gcreate2(gid, objname, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
for (j = 0; j < NUM_SUB_GROUPS; j++) {
HDsnprintf(objname, sizeof(objname), "Group #%d", j);
if ((gid_sub2 = H5Gcreate2(gid_sub, objname, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
for (k = 0; k < NUM_DATASETS; k++) {
HDsnprintf(objname, sizeof(objname), "Dataset #%d", k);
/* add a dataset to the group */
if ((did = H5Dcreate2(gid_sub2, objname, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
} /* end for */
if (H5Gclose(gid_sub2) < 0)
TEST_ERROR;
} /* end for */
if (H5Gclose(gid_sub) < 0)
TEST_ERROR;
} /* end for */
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close the group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the group from SRC to DST */
if (H5Ocopy(fid_src, NAME_GROUP_TOP, fid_dst, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the group for copy */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination group */
if ((gid2 = H5Gopen2(fid_dst, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Check if the groups are equal */
if (compare_groups(gid, gid2, H5P_DEFAULT, -1, 0) != TRUE)
TEST_ERROR;
/* close the destination group */
if (H5Gclose(gid2) < 0)
TEST_ERROR;
/* close the source group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Sclose(sid);
H5Dclose(did);
H5Gclose(gid_sub);
H5Gclose(gid2);
H5Gclose(gid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_group_deep */
/*-------------------------------------------------------------------------
* Function: test_copy_group_loop
*
* Purpose: Create a group hier. with loops in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Tuesday, November 1, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_group_loop(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t gid = -1, gid2 = -1; /* Group IDs */
hid_t gid_sub = -1, gid_sub2 = -1; /* Sub-group IDs */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): nested groups with loop");
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create group at the SRC file */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* attach attributes to the group */
if (test_copy_attach_attributes(gid, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* create sub-groups */
if ((gid_sub = H5Gcreate2(gid, NAME_GROUP_SUB, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((gid_sub2 = H5Gcreate2(gid, NAME_GROUP_SUB_SUB, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Create link to top group */
if (H5Lcreate_hard(gid, ".", gid_sub2, NAME_GROUP_LOOP, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* close sub sub group */
if (H5Gclose(gid_sub2) < 0)
TEST_ERROR;
/* close sub group */
if (H5Gclose(gid_sub) < 0)
TEST_ERROR;
/* close the group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the group from SRC to DST */
if (H5Ocopy(fid_src, NAME_GROUP_TOP, fid_dst, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the group for copy */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination group */
if ((gid2 = H5Gopen2(fid_dst, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Check if the groups are equal */
if (compare_groups(gid, gid2, H5P_DEFAULT, -1, 0) != TRUE)
TEST_ERROR;
/* close the destination group */
if (H5Gclose(gid2) < 0)
TEST_ERROR;
/* close the source group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Gclose(gid_sub2);
H5Gclose(gid_sub);
H5Gclose(gid2);
H5Gclose(gid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_group_loop */
/*-------------------------------------------------------------------------
* Function: test_copy_group_wide_loop
*
* Purpose: Create a group hier. with loops in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Tuesday, November 1, 2005
*
* Note: Create groups w/lots of entries in each level, so that "dense"
* group form is used.
*
* Note: Also tests multiple links to a locked group during copy.
*
*-------------------------------------------------------------------------
*/
static int
test_copy_group_wide_loop(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t gid = -1, gid2 = -1; /* Group IDs */
hid_t gid_sub = -1, gid_sub2 = -1; /* Sub-group IDs */
unsigned u, v; /* Local index variables */
char objname[NAME_BUF_SIZE]; /* Object name buffer */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): wide nested groups with loop");
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create group at the SRC file */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* attach attributes to the group */
if (test_copy_attach_attributes(gid, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* create wide sub-group hierarchy, with multiple links to higher groups */
for (u = 0; u < NUM_WIDE_LOOP_GROUPS; u++) {
HDsnprintf(objname, sizeof(objname), "%s-%u", NAME_GROUP_SUB, u);
if ((gid_sub = H5Gcreate2(gid, objname, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
for (v = 0; v < NUM_WIDE_LOOP_GROUPS; v++) {
HDsnprintf(objname, sizeof(objname), "%s-%u", NAME_GROUP_SUB_SUB2, v);
if ((gid_sub2 = H5Gcreate2(gid_sub, objname, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Create link to top group */
if (H5Lcreate_hard(gid, ".", gid_sub2, NAME_GROUP_LOOP, H5P_DEFAULT, H5P_DEFAULT) < 0)
FAIL_STACK_ERROR;
/* Create link to sub-group */
if (H5Lcreate_hard(gid_sub, ".", gid_sub2, NAME_GROUP_LOOP2, H5P_DEFAULT, H5P_DEFAULT) < 0)
FAIL_STACK_ERROR;
/* Create link to self :-) */
if (H5Lcreate_hard(gid_sub2, ".", gid_sub2, NAME_GROUP_LOOP3, H5P_DEFAULT, H5P_DEFAULT) < 0)
FAIL_STACK_ERROR;
/* close sub sub group */
if (H5Gclose(gid_sub2) < 0)
FAIL_STACK_ERROR;
} /* end for */
/* close sub group */
if (H5Gclose(gid_sub) < 0)
TEST_ERROR;
} /* end for */
/* close the group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the group from SRC to DST */
if (H5Ocopy(fid_src, NAME_GROUP_TOP, fid_dst, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the group for copy */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination group */
if ((gid2 = H5Gopen2(fid_dst, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Check if the groups are equal */
if (compare_groups(gid, gid2, H5P_DEFAULT, -1, 0) != TRUE)
TEST_ERROR;
/* close the destination group */
if (H5Gclose(gid2) < 0)
TEST_ERROR;
/* close the source group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Gclose(gid_sub2);
H5Gclose(gid_sub);
H5Gclose(gid2);
H5Gclose(gid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_group_wide_loop */
/*-------------------------------------------------------------------------
* Function: test_copy_group_links
*
* Purpose: Create a group and links in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Friday, September 30, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_group_links(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1, fid_ext = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1, did2 = -1; /* Dataset ID */
hid_t gid = -1, gid2 = -1; /* Group IDs */
hid_t plid = -1; /* Object copy plist ID */
hsize_t dim2d[2];
hsize_t dim1d[1];
H5L_info2_t linfo;
int buf[DIM_SIZE_1][DIM_SIZE_2];
int i, j;
unsigned expand_soft;
unsigned expand_ext;
unsigned copy_options;
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
char ext_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): group with links");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
buf[i][j] = 10000 + 100 * i + j;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], src_fapl, dst_filename, sizeof dst_filename);
h5_fixname(FILENAME[2], dst_fapl, ext_filename, sizeof ext_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create file to hold external dataset */
if ((fid_ext = H5Fcreate(ext_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create groups at the SRC file. Group 2 will hold dangling links. */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_LINK, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((gid2 = H5Gcreate2(fid_src, NAME_GROUP_LINK2, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* attach attributes to the groups */
if (test_copy_attach_attributes(gid, H5T_NATIVE_INT) < 0)
TEST_ERROR;
if (test_copy_attach_attributes(gid2, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* add a dataset to the group */
if ((did = H5Dcreate2(fid_src, NAME_LINK_DATASET, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Now create a 1-D dataset in an external file */
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_2;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* add a dataset to the external file */
if ((did = H5Dcreate2(fid_ext, NAME_DATASET_SIMPLE, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* make a hard link to the dataset */
if (H5Lcreate_hard(fid_src, NAME_LINK_DATASET, H5L_SAME_LOC, NAME_LINK_HARD, H5P_DEFAULT, H5P_DEFAULT) <
0)
FAIL_STACK_ERROR;
/* make a soft link to the dataset */
if (H5Lcreate_soft(NAME_LINK_DATASET, fid_src, NAME_LINK_SOFT, H5P_DEFAULT, H5P_DEFAULT) < 0)
FAIL_STACK_ERROR;
/* make an external link to the external dataset */
if (H5Lcreate_external(ext_filename, NAME_DATASET_SIMPLE, fid_src, NAME_LINK_EXTERN, H5P_DEFAULT,
H5P_DEFAULT) < 0)
FAIL_STACK_ERROR;
/* make a dangling soft link */
if (H5Lcreate_soft("nowhere", fid_src, NAME_LINK_SOFT_DANGLE2, H5P_DEFAULT, H5P_DEFAULT) < 0)
FAIL_STACK_ERROR;
/* make a dangling external link */
if (H5Lcreate_external("no_file", "no_object", fid_src, NAME_LINK_EXTERN_DANGLE2, H5P_DEFAULT,
H5P_DEFAULT) < 0)
FAIL_STACK_ERROR;
/* close the groups */
if (H5Gclose(gid) < 0)
TEST_ERROR;
if (H5Gclose(gid2) < 0)
TEST_ERROR;
/* close the SRC and EXT files */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
if (H5Fclose(fid_ext) < 0)
TEST_ERROR;
/* Create the object copy plist */
if ((plid = H5Pcreate(H5P_OBJECT_COPY)) < 0)
TEST_ERROR;
/* Loop over all configurations (expand soft/external links) */
for (expand_soft = 0; expand_soft <= 1; expand_soft++) {
for (expand_ext = 0; expand_ext <= 1; expand_ext++) {
/* Set the correct copy options on the obj copy plist */
copy_options = 0;
if (expand_soft)
copy_options |= H5O_COPY_EXPAND_SOFT_LINK_FLAG;
if (expand_ext)
copy_options |= H5O_COPY_EXPAND_EXT_LINK_FLAG;
if (H5Pset_copy_object(plid, copy_options) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files
* aren't the same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the group from SRC to DST */
if (H5Ocopy(fid_src, NAME_GROUP_LINK, fid_dst, NAME_GROUP_LINK, plid, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the group for copy */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_LINK, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination group */
if ((gid2 = H5Gopen2(fid_dst, NAME_GROUP_LINK, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* If expand_soft is set to true, verify that the soft link is now a
* hard link, and compare the expanded dataset, then delete it and
* re-add it as a soft link so compare_groups() works */
if (expand_soft) {
/* Check link type */
if (H5Lget_info2(fid_dst, NAME_LINK_SOFT, &linfo, H5P_DEFAULT) < 0)
TEST_ERROR;
if (linfo.type != H5L_TYPE_HARD)
FAIL_PUTS_ERROR("Soft link was not expanded to a hard link");
/* Compare datasets */
if ((did = H5Dopen2(fid_src, NAME_LINK_DATASET, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((did2 = H5Dopen2(fid_dst, NAME_LINK_SOFT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* Delete expanded dataset, add soft link */
if (H5Ldelete(fid_dst, NAME_LINK_SOFT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Lcreate_soft(NAME_LINK_DATASET, fid_dst, NAME_LINK_SOFT, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* Close datasets */
if (H5Dclose(did) < 0)
TEST_ERROR;
if (H5Dclose(did2) < 0)
TEST_ERROR;
} /* end if */
/* If expand_ext is set to true, verify that the external link is
* now a hard link, and compare the expanded dataset, then delete it
* and re-add it as an external link so compare_groups() works */
if (expand_ext) {
/* Check link type */
if (H5Lget_info2(fid_dst, NAME_LINK_EXTERN, &linfo, H5P_DEFAULT) < 0)
TEST_ERROR;
if (linfo.type != H5L_TYPE_HARD)
FAIL_PUTS_ERROR("External link was not expanded to a hard link");
/* Compare datasets */
if ((fid_ext = H5Fopen(ext_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
if ((did = H5Dopen2(fid_ext, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((did2 = H5Dopen2(fid_dst, NAME_LINK_EXTERN, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* Delete expanded dataset, add external link */
if (H5Ldelete(fid_dst, NAME_LINK_EXTERN, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Lcreate_external(ext_filename, NAME_DATASET_SIMPLE, fid_dst, NAME_LINK_EXTERN,
H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* Close datasets and external file */
if (H5Dclose(did) < 0)
TEST_ERROR;
if (H5Dclose(did2) < 0)
TEST_ERROR;
if (H5Fclose(fid_ext) < 0)
TEST_ERROR;
} /* end if */
/* Check if the groups are equal */
if (compare_groups(gid, gid2, H5P_DEFAULT, -1, 0) != TRUE)
TEST_ERROR;
/* close the destination group */
if (H5Gclose(gid2) < 0)
TEST_ERROR;
/* close the source group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* Now try to copy the group containing the dangling link. They
* should always be copied as the same type of link, never expanded
* to hard links. */
if (H5Ocopy(fid_src, NAME_GROUP_LINK2, fid_dst, NAME_GROUP_LINK2, plid, H5P_DEFAULT) < 0)
TEST_ERROR;
/* Open the original and copied groups */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_LINK2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((gid2 = H5Gopen2(fid_dst, NAME_GROUP_LINK2, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Compare the groups */
if (compare_groups(gid, gid2, H5P_DEFAULT, -1, 0) != TRUE)
TEST_ERROR;
/* Close groups */
if (H5Gclose(gid2) < 0)
TEST_ERROR;
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
} /* end for */
} /* end for */
/* Close the object copy plist */
if (H5Pclose(plid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Sclose(sid);
H5Dclose(did2);
H5Dclose(did);
H5Gclose(gid2);
H5Gclose(gid);
H5Fclose(fid_ext);
H5Fclose(fid_dst);
H5Fclose(fid_src);
H5Pclose(plid);
}
H5E_END_TRY;
return 1;
} /* end test_copy_group_links */
/*-------------------------------------------------------------------------
* Function: test_copy_soft_link
*
* Purpose: Create a soft link in SRC file and copy it to DST file
* copy a datast pointed by a soft link to DST file
*
* Note: The parameter "test_open" is added to test for H5Ocopy when
* the dataset is open in the file (HDFFV-7853).
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Tuesday, September 30, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_soft_link(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl, hbool_t test_open)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t gid = -1; /* Group ID */
hsize_t dim2d[2];
int buf[DIM_SIZE_1][DIM_SIZE_2];
int i, j;
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
if (test_open) {
TESTING("H5Ocopy(): opened object through soft link");
}
else {
TESTING("H5Ocopy(): object through soft link");
}
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
buf[i][j] = 10000 + 100 * i + j;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create group at the SRC file */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_LINK, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* attach attributes to the group */
if (test_copy_attach_attributes(gid, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* add a dataset to the group */
if ((did = H5Dcreate2(fid_src, NAME_LINK_DATASET, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
FAIL_STACK_ERROR;
/* close the group */
if (H5Gclose(gid) < 0)
FAIL_STACK_ERROR;
/* make a soft link to the dataset */
if (H5Lcreate_soft(NAME_LINK_DATASET, fid_src, NAME_LINK_SOFT, H5P_DEFAULT, H5P_DEFAULT) < 0)
FAIL_STACK_ERROR;
if (!test_open) {
/* close the dataset */
if (H5Dclose(did) < 0)
FAIL_STACK_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
FAIL_STACK_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
}
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_LINK_SOFT, fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (!test_open) {
/* open the dataset through the soft link for copy */
if ((did = H5Dopen2(fid_src, NAME_LINK_SOFT, H5P_DEFAULT)) < 0)
TEST_ERROR;
}
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Sclose(sid);
H5Dclose(did2);
H5Dclose(did);
H5Gclose(gid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_soft_link */
/*-------------------------------------------------------------------------
* Function: test_copy_ext_link
*
* Purpose: Create an external link in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: James Laird
* Friday, June 16, 2006
*
*-------------------------------------------------------------------------
*/
static int
test_copy_ext_link(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1, fid_ext = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t gid = -1; /* Group ID */
hsize_t dim2d[2];
int buf[DIM_SIZE_1][DIM_SIZE_2];
int i, j;
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
char ext_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): object through external link");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
buf[i][j] = 10000 + 100 * i + j;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], src_fapl, dst_filename, sizeof dst_filename);
h5_fixname(FILENAME[2], dst_fapl, ext_filename, sizeof ext_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create group at the SRC file */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_LINK, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* attach attributes to the group */
if (test_copy_attach_attributes(gid, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* add a dataset to the group */
if ((did = H5Dcreate2(fid_src, NAME_LINK_DATASET, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* create file to hold external links to the src file */
if ((fid_ext = H5Fcreate(ext_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create group in the file that will hold the external link */
if ((gid = H5Gcreate2(fid_ext, NAME_GROUP_LINK, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Create an external link to the dataset in the source file */
if (H5Lcreate_external(src_filename, NAME_LINK_DATASET, fid_ext, NAME_LINK_EXTERN, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
/* close the group and file */
if (H5Gclose(gid) < 0)
TEST_ERROR;
if (H5Fclose(fid_ext) < 0)
TEST_ERROR;
/* open the "extern" file with read-only */
if ((fid_ext = H5Fopen(ext_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_ext, NAME_LINK_EXTERN, fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset through the external link */
if ((did = H5Dopen2(fid_ext, NAME_LINK_EXTERN, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the EXT file */
if (H5Fclose(fid_ext) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Sclose(sid);
H5Dclose(did2);
H5Dclose(did);
H5Gclose(gid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_ext_link */
/*-------------------------------------------------------------------------
* Function: test_copy_exist
*
* Purpose: Create a simple dataset in SRC file and copy it onto an
* existing object in DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Tuesday, November 8, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_exist(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1; /* Dataset IDs */
int buf[DIM_SIZE_1][DIM_SIZE_2]; /* Buffer for writing data */
hsize_t dim2d[2]; /* Dataset dimensions */
int i, j; /* local index variables */
herr_t ret; /* Generic return value */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): existing object");
/* Initialize write buffer */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
buf[i][j] = 10000 + 100 * i + j;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create 2D dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create 2D int dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_SIMPLE, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* try to copy the dataset from SRC to DST again (should fail) */
H5E_BEGIN_TRY
{
ret = H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT, H5P_DEFAULT);
}
H5E_END_TRY;
if (ret >= 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_exist */
/*-------------------------------------------------------------------------
* Function: test_copy_path
*
* Purpose: Create a simple dataset in SRC file and copy it to DST file
* using a full path name
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Tuesday, November 8, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_path(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t gid = -1; /* Group ID */
int buf[DIM_SIZE_1][DIM_SIZE_2]; /* Buffer for writing data */
hsize_t dim2d[2]; /* Dataset dimensions */
int i, j; /* local index variables */
herr_t ret; /* Generic return value */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): full path");
/* Initialize write buffer */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
buf[i][j] = 10000 + 100 * i + j;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create 2D dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create 2D int dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_SIMPLE, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST (should fail - intermediate groups not there) */
H5E_BEGIN_TRY
{
ret = H5Ocopy(fid_src, NAME_DATASET_SUB_SUB, fid_dst, NAME_DATASET_SUB_SUB, H5P_DEFAULT, H5P_DEFAULT);
}
H5E_END_TRY;
if (ret >= 0)
TEST_ERROR;
/* Create the intermediate groups in destination file */
if ((gid = H5Gcreate2(fid_dst, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Gclose(gid) < 0)
TEST_ERROR;
if ((gid = H5Gcreate2(fid_dst, NAME_GROUP_SUB, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Gclose(gid) < 0)
TEST_ERROR;
if ((gid = H5Gcreate2(fid_dst, NAME_GROUP_SUB_SUB, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST, using full path */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SUB_SUB, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_SUB_SUB, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Sclose(sid);
H5Gclose(gid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_path */
/*-------------------------------------------------------------------------
* Function: test_copy_same_file_named_datatype
*
* Purpose: Create name datatype in SRC file and copy it to same file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Tuesday, November 8, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_same_file_named_datatype(hid_t fcpl_src, hid_t fapl)
{
hid_t fid = -1; /* File ID */
hid_t tid = -1, tid2 = -1; /* Datatype IDs */
char filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): named datatype in same file");
/* Initialize the filenames */
h5_fixname(FILENAME[0], fapl, filename, sizeof filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid = H5Fcreate(filename, H5F_ACC_TRUNC, fcpl_src, fapl)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* create named datatype */
if ((H5Tcommit2(fid, NAME_DATATYPE_SIMPLE, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the datatype from SRC to DST */
if (H5Ocopy(fid, NAME_DATATYPE_SIMPLE, fid, NAME_DATATYPE_SIMPLE2, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the copied datatype */
if ((tid2 = H5Topen2(fid, NAME_DATATYPE_SIMPLE2, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Compare the datatypes */
if (H5Tequal(tid, tid2) != TRUE)
TEST_ERROR;
/* close the destination datatype */
if (H5Tclose(tid2) < 0)
TEST_ERROR;
/* close the source datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the file */
if (H5Fclose(fid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Tclose(tid2);
H5Tclose(tid);
H5Fclose(fid);
}
H5E_END_TRY;
return 1;
} /* end test_copy_same_file_named_datatype */
/*-------------------------------------------------------------------------
* Function: test_copy_old_layout
*
* Purpose: Copy dataset that uses the "old" layout version (pre version 3)
* format.
*
* Note: This test uses the "fill_old.h5" file for convenience, since it
* has a dataset with the old layout format.
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Quincey Koziol
* Thursday, November 30, 2006
*
*-------------------------------------------------------------------------
*/
static int
test_copy_old_layout(hid_t fcpl_dst, hid_t fapl, hbool_t test_open)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t src_fapl = -1; /* Source file FAPL ID */
const char *src_filename = H5_get_srcdir_filename(FILE_OLD_LAYOUT); /* Corrected test file name */
char dst_filename[NAME_BUF_SIZE];
if (test_open) {
TESTING("H5Ocopy(): opened dataset with old layout format");
}
else {
TESTING("H5Ocopy(): dataset with old layout format");
}
/* Initialize the destination filename */
h5_fixname(FILENAME[1], fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* Setup */
if ((src_fapl = h5_fileaccess_flags(H5_FILEACCESS_LIBVER)) < 0)
TEST_ERROR;
/* open source file (read-only) */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* Close source FAPL */
if (H5Pclose(src_fapl) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (test_open) {
/* open the source dataset */
if ((did = H5Dopen2(fid_src, NAME_OLD_FORMAT, H5P_DEFAULT)) < 0)
TEST_ERROR;
}
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_OLD_FORMAT, fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (!test_open) {
/* open the source dataset */
if ((did = H5Dopen2(fid_src, NAME_OLD_FORMAT, H5P_DEFAULT)) < 0)
TEST_ERROR;
}
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, NULL) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Pclose(src_fapl);
H5Dclose(did2);
H5Dclose(did);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_old_layout */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_compact_named_vl
*
* Purpose: Create a dataset that uses a named variable length datatype
* in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Saturday, February 4, 2006
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_compact_named_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1, tid_copy = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t dxpl_id = -1; /* Dataset transfer property list ID */
unsigned int i, j; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
hvl_t buf[DIM_SIZE_1]; /* Buffer for writing data */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): compact dataset with named VLEN datatype");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
buf[i].len = i + 1;
buf[i].p = (int *)HDmalloc(buf[i].len * sizeof(int));
for (j = 0; j < buf[i].len; j++)
((int *)buf[i].p)[j] = (int)(i * 10 + j);
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* make a copy of the datatype for later use */
if ((tid_copy = H5Tcopy(tid)) < 0)
TEST_ERROR;
/* named datatype */
if ((H5Tcommit2(fid_src, NAME_DATATYPE_VL, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create and set compact plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_layout(pid, H5D_COMPACT) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_VL, tid, sid, H5P_DEFAULT, pid, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close compact plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_VL, fid_dst, NAME_DATASET_VL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Reclaim vlen buffer */
if (H5Tdetect_class(tid_copy, H5T_VLEN) == TRUE) {
if ((dxpl_id = H5Pcreate(H5P_DATASET_XFER)) < 0)
TEST_ERROR;
if (H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL) < 0)
TEST_ERROR;
if (H5Treclaim(tid_copy, sid, dxpl_id, buf) < 0)
TEST_ERROR;
if (H5Pclose(dxpl_id) < 0)
TEST_ERROR;
} /* end if */
/* close datatype */
if (H5Tclose(tid_copy) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Pclose(pid);
H5Dclose(did2);
H5Dclose(did);
H5Treclaim(tid_copy, sid, H5P_DEFAULT, buf);
H5Pclose(dxpl_id);
H5Tclose(tid);
H5Tclose(tid_copy);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_compact_named_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_contig_named_vl
*
* Purpose: Create a dataset that uses a named variable length datatype
* in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Saturday, February 11, 2006
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_contig_named_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1, tid_copy = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t dxpl_id = -1; /* Dataset transfer property list ID */
unsigned int i, j; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
hvl_t buf[DIM_SIZE_1]; /* Buffer for writing data */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): contiguous dataset with named VLEN datatype");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
buf[i].len = i + 1;
buf[i].p = (int *)HDmalloc(buf[i].len * sizeof(int));
for (j = 0; j < buf[i].len; j++)
((int *)buf[i].p)[j] = (int)(i * 10 + j);
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* make a copy of the datatype for later use */
if ((tid_copy = H5Tcopy(tid)) < 0)
TEST_ERROR;
/* named datatype */
if ((H5Tcommit2(fid_src, NAME_DATATYPE_VL, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_VL, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_VL, fid_dst, NAME_DATASET_VL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Reclaim vlen buffer */
if (H5Tdetect_class(tid_copy, H5T_VLEN) == TRUE) {
if ((dxpl_id = H5Pcreate(H5P_DATASET_XFER)) < 0)
TEST_ERROR;
if (H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL) < 0)
TEST_ERROR;
if (H5Treclaim(tid_copy, sid, dxpl_id, buf) < 0)
TEST_ERROR;
if (H5Pclose(dxpl_id) < 0)
TEST_ERROR;
} /* end if */
/* close datatype */
if (H5Tclose(tid_copy) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Treclaim(tid_copy, sid, H5P_DEFAULT, buf);
H5Pclose(dxpl_id);
H5Tclose(tid);
H5Tclose(tid_copy);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_contig_named_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_chunked_named_vl
*
* Purpose: Create a dataset that uses a named variable length datatype
* in SRC file and copy it to DST file
*
* Note: The parameter "test_open" is added to test for H5Ocopy when
* the dataset is open in the file (HDFFV-7853).
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Saturday, February 11, 2006
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_chunked_named_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl,
hbool_t test_open)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1, tid_copy = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t dxpl_id = -1; /* Dataset transfer property list ID */
unsigned int i, j; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
hvl_t buf[DIM_SIZE_1]; /* Buffer for writing data */
hsize_t chunk_dim1d[1] = {CHUNK_SIZE_1}; /* Chunk dimensions */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
if (test_open) {
TESTING("H5Ocopy(): chunked and opened dataset with named VLEN datatype");
}
else {
TESTING("H5Ocopy(): chunked dataset with named VLEN datatype");
}
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
buf[i].len = i + 1;
buf[i].p = (int *)HDmalloc(buf[i].len * sizeof(int));
for (j = 0; j < buf[i].len; j++)
((int *)buf[i].p)[j] = (int)(i * 10 + j);
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* make a copy of the datatype for later use */
if ((tid_copy = H5Tcopy(tid)) < 0)
TEST_ERROR;
/* named datatype */
if ((H5Tcommit2(fid_src, NAME_DATATYPE_VL, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 1, chunk_dim1d) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_VL, tid, sid, H5P_DEFAULT, pid, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close compact plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (!test_open) {
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
}
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_VL, fid_dst, NAME_DATASET_VL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (!test_open) {
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
}
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Reclaim vlen buffer */
if (H5Tdetect_class(tid_copy, H5T_VLEN) == TRUE) {
if ((dxpl_id = H5Pcreate(H5P_DATASET_XFER)) < 0)
TEST_ERROR;
if (H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL) < 0)
TEST_ERROR;
if (H5Treclaim(tid_copy, sid, dxpl_id, buf) < 0)
TEST_ERROR;
if (H5Pclose(dxpl_id) < 0)
TEST_ERROR;
} /* end if */
/* close datatype */
if (H5Tclose(tid_copy) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Pclose(pid);
H5Dclose(did2);
H5Dclose(did);
H5Treclaim(tid_copy, sid, H5P_DEFAULT, buf);
H5Pclose(dxpl_id);
H5Tclose(tid);
H5Tclose(tid_copy);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_chunked_named_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_compressed_named_vl
*
* Purpose: Create a dataset that uses a named variable length datatype
* in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Saturday, February 11, 2006
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_compressed_named_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1, tid_copy = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t dxpl_id = -1; /* Dataset transfer property list ID */
unsigned int i, j; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
hvl_t buf[DIM_SIZE_1]; /* Buffer for writing data */
hsize_t chunk_dim1d[1] = {CHUNK_SIZE_1}; /* Chunk dimensions */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): compressed dataset with named VLEN datatype");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
buf[i].len = i + 1;
buf[i].p = (int *)HDmalloc(buf[i].len * sizeof(int));
for (j = 0; j < buf[i].len; j++)
((int *)buf[i].p)[j] = (int)(i * 10 + j);
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* make a copy of the datatype for later use */
if ((tid_copy = H5Tcopy(tid)) < 0)
TEST_ERROR;
/* named datatype */
if ((H5Tcommit2(fid_src, NAME_DATATYPE_VL, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 1, chunk_dim1d) < 0)
TEST_ERROR;
if (H5Pset_deflate(pid, 9) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_VL, tid, sid, H5P_DEFAULT, pid, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close compact plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_VL, fid_dst, NAME_DATASET_VL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Reclaim vlen buffer */
if (H5Tdetect_class(tid_copy, H5T_VLEN) == TRUE) {
if ((dxpl_id = H5Pcreate(H5P_DATASET_XFER)) < 0)
TEST_ERROR;
if (H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL) < 0)
TEST_ERROR;
if (H5Treclaim(tid_copy, sid, dxpl_id, buf) < 0)
TEST_ERROR;
if (H5Pclose(dxpl_id) < 0)
TEST_ERROR;
} /* end if */
/* close datatype */
if (H5Tclose(tid_copy) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Pclose(pid);
H5Dclose(did2);
H5Dclose(did);
H5Treclaim(tid_copy, sid, H5P_DEFAULT, buf);
H5Pclose(dxpl_id);
H5Tclose(tid);
H5Tclose(tid_copy);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_compressed_named_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_compact_vl_vl
*
* Purpose: Create a compact dataset w/nested VLEN datatype
* in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Saturday, February 11, 2006
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_compact_vl_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1, tid2 = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t dxpl_id = -1; /* Dataset transfer property list ID */
unsigned int i, j, k; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
hvl_t buf[DIM_SIZE_1]; /* Buffer for writing data */
hvl_t *tvl; /* Temporary pointer to VL information */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): compact dataset with nested VLEN datatype");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
buf[i].p = HDmalloc((i + 1) * sizeof(hvl_t));
if (buf[i].p == NULL) {
TestErrPrintf("Cannot allocate memory for VL data! i=%u\n", i);
return 1;
} /* end if */
buf[i].len = i + 1;
for (tvl = (hvl_t *)buf[i].p, j = 0; j < (i + 1); j++, tvl++) {
tvl->p = HDmalloc((j + 1) * sizeof(unsigned int));
if (tvl->p == NULL) {
TestErrPrintf("Cannot allocate memory for VL data! i=%u, j=%u\n", i, j);
return 1;
} /* end if */
tvl->len = j + 1;
for (k = 0; k < (j + 1); k++)
((unsigned int *)tvl->p)[k] = i * 100 + j * 10 + k;
} /* end for */
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* create nested VL datatype */
if ((tid2 = H5Tvlen_create(tid)) < 0)
TEST_ERROR;
/* create and set compact plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_layout(pid, H5D_COMPACT) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_VL_VL, tid2, sid, H5P_DEFAULT, pid, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid2, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close compact plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_VL_VL, fid_dst, NAME_DATASET_VL_VL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_VL_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_VL_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Reclaim vlen buffer */
if (H5Tdetect_class(tid2, H5T_VLEN) == TRUE) {
if ((dxpl_id = H5Pcreate(H5P_DATASET_XFER)) < 0)
TEST_ERROR;
if (H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL) < 0)
TEST_ERROR;
if (H5Treclaim(tid2, sid, dxpl_id, buf) < 0)
TEST_ERROR;
if (H5Pclose(dxpl_id) < 0)
TEST_ERROR;
} /* end if */
/* close datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Tclose(tid2) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Treclaim(tid2, sid, H5P_DEFAULT, buf);
H5Pclose(dxpl_id);
H5Pclose(pid);
H5Tclose(tid);
H5Tclose(tid2);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_compact_vl_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_contig_vl_vl
*
* Purpose: Create a compact dataset w/nested VLEN datatype
* in SRC file and copy it to DST file
*
* Note: The parameter "test_open" is added to test for H5Ocopy when
* the dataset is open in the file (HDFFV-7853).
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Saturday, February 11, 2006
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_contig_vl_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl,
hbool_t test_open)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1, tid2 = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t dxpl_id = -1; /* Dataset transfer property list ID */
unsigned int i, j, k; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
hvl_t buf[DIM_SIZE_1]; /* Buffer for writing data */
hvl_t *tvl; /* Temporary pointer to VL information */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
if (test_open) {
TESTING("H5Ocopy(): contiguous and opened dataset with nested VLEN datatype");
}
else {
TESTING("H5Ocopy(): contiguous dataset with nested VLEN datatype");
}
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
buf[i].p = HDmalloc((i + 1) * sizeof(hvl_t));
if (buf[i].p == NULL) {
TestErrPrintf("Cannot allocate memory for VL data! i=%u\n", i);
TEST_ERROR;
} /* end if */
buf[i].len = i + 1;
for (tvl = (hvl_t *)buf[i].p, j = 0; j < (i + 1); j++, tvl++) {
tvl->p = HDmalloc((j + 1) * sizeof(unsigned int));
if (tvl->p == NULL) {
TestErrPrintf("Cannot allocate memory for VL data! i=%u, j=%u\n", i, j);
TEST_ERROR;
} /* end if */
tvl->len = j + 1;
for (k = 0; k < (j + 1); k++)
((unsigned int *)tvl->p)[k] = i * 100 + j * 10 + k;
} /* end for */
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* create nested VL datatype */
if ((tid2 = H5Tvlen_create(tid)) < 0)
TEST_ERROR;
/* create and set compact plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_VL_VL, tid2, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid2, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close compact plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
if (!test_open) {
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
}
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_VL_VL, fid_dst, NAME_DATASET_VL_VL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (!test_open) {
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_VL_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
}
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_VL_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Reclaim vlen buffer */
if (H5Tdetect_class(tid2, H5T_VLEN) == TRUE) {
if ((dxpl_id = H5Pcreate(H5P_DATASET_XFER)) < 0)
TEST_ERROR;
if (H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL) < 0)
TEST_ERROR;
if (H5Treclaim(tid2, sid, dxpl_id, buf) < 0)
TEST_ERROR;
if (H5Pclose(dxpl_id) < 0)
TEST_ERROR;
} /* end if */
/* close datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Tclose(tid2) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Treclaim(tid2, sid, H5P_DEFAULT, buf);
H5Pclose(dxpl_id);
H5Pclose(pid);
H5Tclose(tid);
H5Tclose(tid2);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_contig_vl_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_chunked_vl_vl
*
* Purpose: Create a dataset that uses a named variable length datatype
* in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Saturday, March 11, 2006
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_chunked_vl_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1, tid2 = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t dxpl_id = -1; /* Dataset transfer property list ID */
unsigned int i, j, k; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
hvl_t buf[DIM_SIZE_1]; /* Buffer for writing data */
hvl_t *tvl; /* Temporary pointer to VL information */
hsize_t chunk_dim1d[1] = {CHUNK_SIZE_1}; /* Chunk dimensions */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): chunked dataset with nested VLEN datatype");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
buf[i].p = HDmalloc((i + 1) * sizeof(hvl_t));
if (buf[i].p == NULL) {
TestErrPrintf("Cannot allocate memory for VL data! i=%u\n", i);
TEST_ERROR;
} /* end if */
buf[i].len = i + 1;
for (tvl = (hvl_t *)buf[i].p, j = 0; j < (i + 1); j++, tvl++) {
tvl->p = HDmalloc((j + 1) * sizeof(unsigned int));
if (tvl->p == NULL) {
TestErrPrintf("Cannot allocate memory for VL data! i=%u, j=%u\n", i, j);
TEST_ERROR;
} /* end if */
tvl->len = j + 1;
for (k = 0; k < (j + 1); k++)
((unsigned int *)tvl->p)[k] = i * 100 + j * 10 + k;
} /* end for */
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* create nested VL datatype */
if ((tid2 = H5Tvlen_create(tid)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 1, chunk_dim1d) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_VL_VL, tid2, sid, H5P_DEFAULT, pid, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid2, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Set allocation time to early */
if (H5Pset_alloc_time(pid, H5D_ALLOC_TIME_EARLY) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_VL_VL2, tid2, sid, H5P_DEFAULT, pid, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid2, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_VL_VL, fid_dst, NAME_DATASET_VL_VL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_VL_VL2, fid_dst, NAME_DATASET_VL_VL2, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_VL_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_VL_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_FARRAY, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_VL_VL2, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_VL_VL2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (compare_idx_type(src_fapl, did2, H5D_CHUNK_IDX_NONE, H5D_CHUNK_IDX_BTREE) != TRUE)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Reclaim vlen buffer */
if (H5Tdetect_class(tid2, H5T_VLEN) == TRUE) {
if ((dxpl_id = H5Pcreate(H5P_DATASET_XFER)) < 0)
TEST_ERROR;
if (H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL) < 0)
TEST_ERROR;
if (H5Treclaim(tid2, sid, dxpl_id, buf) < 0)
TEST_ERROR;
if (H5Pclose(dxpl_id) < 0)
TEST_ERROR;
} /* end if */
/* close datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Tclose(tid2) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Pclose(pid);
H5Dclose(did2);
H5Dclose(did);
H5Treclaim(tid2, sid, H5P_DEFAULT, buf);
H5Pclose(dxpl_id);
H5Tclose(tid);
H5Tclose(tid2);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_chunked_vl_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_compressed_vl_vl
*
* Purpose: Create a dataset that uses a named variable length datatype
* in SRC file and copy it to DST file
*
* Note: The parameter "test_open" is added to test for H5Ocopy when
* the dataset is open in the file (HDFFV-7853).
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Saturday, March 11, 2006
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_compressed_vl_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl,
hbool_t test_open)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1, tid2 = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t dxpl_id = -1; /* Dataset transfer property list ID */
unsigned int i, j, k; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
hvl_t buf[DIM_SIZE_1]; /* Buffer for writing data */
hvl_t *tvl; /* Temporary pointer to VL information */
hsize_t chunk_dim1d[1] = {CHUNK_SIZE_1}; /* Chunk dimensions */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
if (test_open) {
TESTING("H5Ocopy(): compressed and opened dataset with nested VLEN datatype");
}
else {
TESTING("H5Ocopy(): compressed dataset with nested VLEN datatype");
}
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
buf[i].p = HDmalloc((i + 1) * sizeof(hvl_t));
if (buf[i].p == NULL) {
TestErrPrintf("Cannot allocate memory for VL data! i=%u\n", i);
TEST_ERROR;
} /* end if */
buf[i].len = i + 1;
for (tvl = (hvl_t *)buf[i].p, j = 0; j < (i + 1); j++, tvl++) {
tvl->p = HDmalloc((j + 1) * sizeof(unsigned int));
if (tvl->p == NULL) {
TestErrPrintf("Cannot allocate memory for VL data! i=%u, j=%u\n", i, j);
TEST_ERROR;
} /* end if */
tvl->len = j + 1;
for (k = 0; k < (j + 1); k++)
((unsigned int *)tvl->p)[k] = i * 100 + j * 10 + k;
} /* end for */
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* create nested VL datatype */
if ((tid2 = H5Tvlen_create(tid)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 1, chunk_dim1d) < 0)
TEST_ERROR;
if (H5Pset_deflate(pid, 9) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_VL_VL, tid2, sid, H5P_DEFAULT, pid, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid2, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close compact plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
if (!test_open) {
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
}
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_VL_VL, fid_dst, NAME_DATASET_VL_VL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (!test_open) {
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_VL_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
}
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_VL_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Reclaim vlen buffer */
if (H5Tdetect_class(tid2, H5T_VLEN) == TRUE) {
if ((dxpl_id = H5Pcreate(H5P_DATASET_XFER)) < 0)
TEST_ERROR;
if (H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL) < 0)
TEST_ERROR;
if (H5Treclaim(tid2, sid, dxpl_id, buf) < 0)
TEST_ERROR;
if (H5Pclose(dxpl_id) < 0)
TEST_ERROR;
} /* end if */
/* close datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Tclose(tid2) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Pclose(pid);
H5Dclose(did2);
H5Dclose(did);
H5Treclaim(tid2, sid, H5P_DEFAULT, buf);
H5Pclose(dxpl_id);
H5Tclose(tid);
H5Tclose(tid2);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_compressed_vl_vl */
/*
* Common data structure for the copy_dataset_*_cmpd_vl tests.
*/
typedef struct cmpd_vl_t {
int a;
hvl_t b;
double c;
} cmpd_vl_t;
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_contig_cmpd_vl
*
* Purpose: Create a contiguous dataset w/VLEN datatype contained in
* a compound in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Neil Fortner
* Tuesday, September 29, 2009
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_contig_cmpd_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1; /* Datatype ID */
hid_t tid2 = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1; /* Dataset ID */
hid_t did2 = -1; /* Dataset ID */
hid_t dxpl_id = -1; /* Dataset transfer property list ID */
unsigned int i, j; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
cmpd_vl_t buf[DIM_SIZE_1]; /* Buffer for writing data */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): contiguous dataset with compound VLEN datatype");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
buf[i].a = (int)(i * (i - 1));
buf[i].b.len = i + 1;
buf[i].b.p = (int *)HDmalloc(buf[i].b.len * sizeof(int));
for (j = 0; j < buf[i].b.len; j++)
((int *)buf[i].b.p)[j] = (int)(i * 10 + j);
buf[i].c = 1.0 / ((double)i + 1.0);
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid2 = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((tid = H5Tcreate(H5T_COMPOUND, sizeof(cmpd_vl_t))) < 0)
TEST_ERROR;
if (H5Tinsert(tid, "a", HOFFSET(cmpd_vl_t, a), H5T_NATIVE_INT) < 0)
TEST_ERROR;
if (H5Tinsert(tid, "b", HOFFSET(cmpd_vl_t, b), tid2) < 0)
TEST_ERROR;
if (H5Tinsert(tid, "c", HOFFSET(cmpd_vl_t, c), H5T_NATIVE_DOUBLE) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CMPD_VL, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) <
0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_CMPD_VL, fid_dst, NAME_DATASET_CMPD_VL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CMPD_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CMPD_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Reclaim vlen buffer */
if (H5Tdetect_class(tid, H5T_VLEN) == TRUE) {
if ((dxpl_id = H5Pcreate(H5P_DATASET_XFER)) < 0)
TEST_ERROR;
if (H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL) < 0)
TEST_ERROR;
if (H5Treclaim(tid, sid, dxpl_id, buf) < 0)
TEST_ERROR;
if (H5Pclose(dxpl_id) < 0)
TEST_ERROR;
} /* end if */
/* close datatype */
if (H5Tclose(tid2) < 0)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Treclaim(tid, sid, H5P_DEFAULT, buf);
H5Pclose(dxpl_id);
H5Tclose(tid2);
H5Tclose(tid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_contig_cmpd_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_chunked_cmpd_vl
*
* Purpose: Create a chunked dataset w/VLEN datatype contained in a
* compound in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Neil Fortner
* Wednesdat, September 30 , 2009
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_chunked_cmpd_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1, tid2 = -1; /* Datatype IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t dxpl_id = -1; /* Dataset transfer property list ID */
unsigned int i, j; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
hsize_t chunk_dim1d[1] = {CHUNK_SIZE_1}; /* Chunk dimensions */
cmpd_vl_t buf[DIM_SIZE_1]; /* Buffer for writing data */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): chunked dataset with compound VLEN datatype");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
buf[i].a = (int)(i * (i - 1));
buf[i].b.len = i + 1;
buf[i].b.p = (int *)HDmalloc(buf[i].b.len * sizeof(int));
for (j = 0; j < buf[i].b.len; j++)
((int *)buf[i].b.p)[j] = (int)(i * 10 + j);
buf[i].c = 1.0 / ((double)i + 1.0);
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid2 = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((tid = H5Tcreate(H5T_COMPOUND, sizeof(cmpd_vl_t))) < 0)
TEST_ERROR;
if (H5Tinsert(tid, "a", HOFFSET(cmpd_vl_t, a), H5T_NATIVE_INT) < 0)
TEST_ERROR;
if (H5Tinsert(tid, "b", HOFFSET(cmpd_vl_t, b), tid2) < 0)
TEST_ERROR;
if (H5Tinsert(tid, "c", HOFFSET(cmpd_vl_t, c), H5T_NATIVE_DOUBLE) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 1, chunk_dim1d) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CMPD_VL, tid, sid, H5P_DEFAULT, pid, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close chunk plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_CMPD_VL, fid_dst, NAME_DATASET_CMPD_VL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CMPD_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CMPD_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Reclaim vlen buffer */
if (H5Tdetect_class(tid, H5T_VLEN) == TRUE) {
if ((dxpl_id = H5Pcreate(H5P_DATASET_XFER)) < 0)
TEST_ERROR;
if (H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL) < 0)
TEST_ERROR;
if (H5Treclaim(tid, sid, dxpl_id, buf) < 0)
TEST_ERROR;
if (H5Pclose(dxpl_id) < 0)
TEST_ERROR;
} /* end if */
/* close datatype */
if (H5Tclose(tid2) < 0)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Treclaim(tid, sid, H5P_DEFAULT, buf);
H5Pclose(dxpl_id);
H5Pclose(pid);
H5Tclose(tid2);
H5Tclose(tid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_chunked_cmpd_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_compact_cmpd_vl
*
* Purpose: Create a compact dataset w/VLEN datatype contained in a
* compound in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* Sunday, December 11, 2005
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_compact_cmpd_vl(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1, tid2 = -1; /* Datatype IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Dataset creation property list ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t dxpl_id = -1; /* Dataset transfer property list ID */
unsigned int i, j; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
cmpd_vl_t buf[DIM_SIZE_1]; /* Buffer for writing data */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): compact dataset with compound VLEN datatype");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++) {
buf[i].a = (int)(i * (i - 1));
buf[i].b.len = i + 1;
buf[i].b.p = (int *)HDmalloc(buf[i].b.len * sizeof(int));
for (j = 0; j < buf[i].b.len; j++)
((int *)buf[i].b.p)[j] = (int)(i * 10 + j);
buf[i].c = 1.0 / ((double)i + 1.0);
} /* end for */
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid2 = H5Tvlen_create(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((tid = H5Tcreate(H5T_COMPOUND, sizeof(cmpd_vl_t))) < 0)
TEST_ERROR;
if (H5Tinsert(tid, "a", HOFFSET(cmpd_vl_t, a), H5T_NATIVE_INT) < 0)
TEST_ERROR;
if (H5Tinsert(tid, "b", HOFFSET(cmpd_vl_t, b), tid2) < 0)
TEST_ERROR;
if (H5Tinsert(tid, "c", HOFFSET(cmpd_vl_t, c), H5T_NATIVE_DOUBLE) < 0)
TEST_ERROR;
/* create and set compact plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_layout(pid, H5D_COMPACT) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_CMPD_VL, tid, sid, H5P_DEFAULT, pid, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close compact plist */
if (H5Pclose(pid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy the dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_CMPD_VL, fid_dst, NAME_DATASET_CMPD_VL, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the dataset for copy */
if ((did = H5Dopen2(fid_src, NAME_DATASET_CMPD_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open the destination dataset */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_CMPD_VL, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the destination dataset */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the source dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Reclaim vlen buffer */
if (H5Tdetect_class(tid, H5T_VLEN) == TRUE) {
if ((dxpl_id = H5Pcreate(H5P_DATASET_XFER)) < 0)
TEST_ERROR;
if (H5Pset_vlen_mem_manager(dxpl_id, NULL, NULL, NULL, NULL) < 0)
TEST_ERROR;
if (H5Treclaim(tid, sid, dxpl_id, buf) < 0)
TEST_ERROR;
if (H5Pclose(dxpl_id) < 0)
TEST_ERROR;
} /* end if */
/* close datatype */
if (H5Tclose(tid2) < 0)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did2);
H5Dclose(did);
H5Treclaim(tid, sid, H5P_DEFAULT, buf);
H5Pclose(dxpl_id);
H5Pclose(pid);
H5Tclose(tid2);
H5Tclose(tid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_compact_cmpd_vl */
/*-------------------------------------------------------------------------
* Function: test_copy_null_ref
*
* Purpose: Creates 2 datasets with references, one with object and
* the other with region references. Copies these datasets
* to a new file without expanding references, causing them
* to become NULL. Next, copies these references to a third
* file with expanding references, to verify that NULL
* references are handled correctly.
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Neil Fortner
* Wednesday, March 31, 2010
*
*-------------------------------------------------------------------------
*/
static int
test_copy_null_ref(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid1 = -1, fid2 = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Object copy property list ID */
hid_t did1 = -1, did2 = -1; /* Dataset IDs */
hsize_t dim1d[1] = {2}; /* Dataset dimensions */
hobj_ref_t obj_buf[2]; /* Buffer for object refs */
hdset_reg_ref_t reg_buf[2]; /* Buffer for region refs */
char zeros[MAX(sizeof(obj_buf), sizeof(reg_buf))]; /* Array of zeros, for memcmp */
char src_filename[NAME_BUF_SIZE];
char mid_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): NULL references");
/* Initialize "zeros" array */
HDmemset(zeros, 0, sizeof(zeros));
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], src_fapl, mid_filename, sizeof mid_filename);
h5_fixname(FILENAME[2], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* Create source file */
if ((fid1 = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* Create object reference dataset at SRC file */
if ((did1 = H5Dcreate2(fid1, "obj_ref_dset", H5T_STD_REF_OBJ, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Create region reference dataset at SRC file */
if ((did2 = H5Dcreate2(fid1, "reg_ref_dset", H5T_STD_REF_DSETREG, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Create references */
if (H5Rcreate(&obj_buf[0], did1, ".", H5R_OBJECT, (hid_t)-1) < 0)
TEST_ERROR;
if (H5Rcreate(&obj_buf[1], did2, ".", H5R_OBJECT, (hid_t)-1) < 0)
TEST_ERROR;
if (H5Rcreate(&reg_buf[0], did1, ".", H5R_DATASET_REGION, sid) < 0)
TEST_ERROR;
if (H5Rcreate(&reg_buf[1], did2, ".", H5R_DATASET_REGION, sid) < 0)
TEST_ERROR;
/* Write data into file */
if (H5Dwrite(did1, H5T_STD_REF_OBJ, H5S_ALL, H5S_ALL, H5P_DEFAULT, obj_buf) < 0)
TEST_ERROR;
if (H5Dwrite(did2, H5T_STD_REF_DSETREG, H5S_ALL, H5S_ALL, H5P_DEFAULT, reg_buf) < 0)
TEST_ERROR;
/* Close datasets */
if (H5Dclose(did1) < 0)
TEST_ERROR;
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* Create middle file */
if ((fid2 = H5Fcreate(mid_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Copy the source file to the middle file. Note the expand references
* flag is not set. */
if (H5Ocopy(fid1, "/", fid2, "/A", H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* Close source file */
if (H5Fclose(fid1) < 0)
TEST_ERROR;
/* Open copied datasets */
if ((did1 = H5Dopen2(fid2, "/A/obj_ref_dset", H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((did2 = H5Dopen2(fid2, "/A/reg_ref_dset", H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Read copied datasets */
if (H5Dread(did1, H5T_STD_REF_OBJ, H5S_ALL, H5S_ALL, H5P_DEFAULT, obj_buf) < 0)
TEST_ERROR;
if (H5Dread(did2, H5T_STD_REF_DSETREG, H5S_ALL, H5S_ALL, H5P_DEFAULT, reg_buf) < 0)
TEST_ERROR;
/* Verify that the references contain only "0" bytes */
if (HDmemcmp(obj_buf, zeros, sizeof(obj_buf)) != 0)
TEST_ERROR;
if (HDmemcmp(reg_buf, zeros, sizeof(reg_buf)) != 0)
TEST_ERROR;
/* Close datasets */
if (H5Dclose(did1) < 0)
TEST_ERROR;
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* Create destination file */
if ((fid1 = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create object copy property list */
if ((pid = H5Pcreate(H5P_OBJECT_COPY)) < 0)
TEST_ERROR;
/* Set the "expand references" flag */
if (H5Pset_copy_object(pid, H5O_COPY_EXPAND_REFERENCE_FLAG) < 0)
TEST_ERROR;
/* Copy the middle file to the destination file. Note the expand references
* flag *is* set, even though the references are now NULL. */
if (H5Ocopy(fid2, "/", fid1, "/AA", pid, H5P_DEFAULT) < 0)
TEST_ERROR;
/* Close source file */
if (H5Fclose(fid2) < 0)
TEST_ERROR;
/* Open copied datasets */
if ((did1 = H5Dopen2(fid1, "/AA/A/obj_ref_dset", H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((did2 = H5Dopen2(fid1, "/AA/A/reg_ref_dset", H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Read copied datasets */
if (H5Dread(did1, H5T_STD_REF_OBJ, H5S_ALL, H5S_ALL, H5P_DEFAULT, obj_buf) < 0)
TEST_ERROR;
if (H5Dread(did2, H5T_STD_REF_DSETREG, H5S_ALL, H5S_ALL, H5P_DEFAULT, reg_buf) < 0)
TEST_ERROR;
/* Verify that the references contain only "0" bytes */
if (HDmemcmp(obj_buf, zeros, sizeof(obj_buf)) != 0)
TEST_ERROR;
if (HDmemcmp(reg_buf, zeros, sizeof(reg_buf)) != 0)
TEST_ERROR;
/* Close */
if (H5Pclose(pid) < 0)
TEST_ERROR;
if (H5Dclose(did1) < 0)
TEST_ERROR;
if (H5Dclose(did2) < 0)
TEST_ERROR;
if (H5Fclose(fid1) < 0)
TEST_ERROR;
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Pclose(pid);
H5Dclose(did1);
H5Dclose(did2);
H5Fclose(fid1);
H5Fclose(fid2);
H5Sclose(sid);
}
H5E_END_TRY;
return 1;
} /* end test_copy_null_ref */
/*-------------------------------------------------------------------------
* Function: test_copy_null_ref_open
*
* Purpose: Creates 2 datasets with references, one with object and
* the other with region references. Copies these datasets
* to a new file without expanding references, causing them
* to become NULL. Next, copies these references to a third
* file with expanding references, to verify that NULL
* references are handled correctly.
*
* Note: this is copied from test_copy_null_ref() with modifications
* to test for opened datasets in the files.
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Neil Fortner
* Wednesday, March 31, 2010
*
*-------------------------------------------------------------------------
*/
static int
test_copy_null_ref_open(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid1 = -1, fid2 = -1, fid3 = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t pid = -1; /* Object copy property list ID */
hid_t did1 = -1, did2 = -1; /* Dataset IDs */
hid_t did3 = -1, did4 = -1; /* Dataset IDs */
hid_t did5 = -1, did6 = -1; /* Dataset IDs */
hid_t dcpl = -1; /* Dataset creation property list */
hsize_t chunk_dim1d[1] = {2}; /* Chunk dimensions */
hsize_t dim1d[1] = {3}; /* Dataset dimensions */
hobj_ref_t obj_buf[3]; /* Buffer for object refs */
hdset_reg_ref_t reg_buf[3]; /* Buffer for region refs */
char zeros[MAX(sizeof(obj_buf), sizeof(reg_buf))]; /* Array of zeros, for memcmp */
char src_filename[NAME_BUF_SIZE];
char mid_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): NULL references for opened datasets");
/* Initialize "zeros" array */
HDmemset(zeros, 0, sizeof(zeros));
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], src_fapl, mid_filename, sizeof mid_filename);
h5_fixname(FILENAME[2], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* Create source file */
if ((fid1 = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((dcpl = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(dcpl, 1, chunk_dim1d) < 0)
TEST_ERROR;
if (H5Pset_deflate(dcpl, 9) < 0)
TEST_ERROR;
if (H5Pset_chunk_opts(dcpl, H5D_CHUNK_DONT_FILTER_PARTIAL_CHUNKS) < 0)
TEST_ERROR;
/* Create object reference dataset at SRC file */
if ((did1 = H5Dcreate2(fid1, "obj_ref_dset", H5T_STD_REF_OBJ, sid, H5P_DEFAULT, dcpl, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Create region reference dataset at SRC file */
if ((did2 = H5Dcreate2(fid1, "reg_ref_dset", H5T_STD_REF_DSETREG, sid, H5P_DEFAULT, dcpl, H5P_DEFAULT)) <
0)
TEST_ERROR;
/* Create references */
if (H5Rcreate(&obj_buf[0], did1, ".", H5R_OBJECT, (hid_t)-1) < 0)
TEST_ERROR;
if (H5Rcreate(&obj_buf[1], did2, ".", H5R_OBJECT, (hid_t)-1) < 0)
TEST_ERROR;
if (H5Rcreate(&reg_buf[0], did1, ".", H5R_DATASET_REGION, sid) < 0)
TEST_ERROR;
if (H5Rcreate(&reg_buf[1], did2, ".", H5R_DATASET_REGION, sid) < 0)
TEST_ERROR;
/* Write data into file */
if (H5Dwrite(did1, H5T_STD_REF_OBJ, H5S_ALL, H5S_ALL, H5P_DEFAULT, obj_buf) < 0)
TEST_ERROR;
if (H5Dwrite(did2, H5T_STD_REF_DSETREG, H5S_ALL, H5S_ALL, H5P_DEFAULT, reg_buf) < 0)
TEST_ERROR;
/* Create middle file */
if ((fid2 = H5Fcreate(mid_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Copy the source file to the middle file. Note the expand references
* flag is not set. */
if (H5Ocopy(fid1, "/", fid2, "/A", H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* Close datasets in source file */
if (H5Dclose(did1) < 0)
TEST_ERROR;
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* Close source file */
if (H5Fclose(fid1) < 0)
TEST_ERROR;
/* Open copied datasets */
if ((did3 = H5Dopen2(fid2, "/A/obj_ref_dset", H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((did4 = H5Dopen2(fid2, "/A/reg_ref_dset", H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Read copied datasets */
if (H5Dread(did3, H5T_STD_REF_OBJ, H5S_ALL, H5S_ALL, H5P_DEFAULT, obj_buf) < 0)
TEST_ERROR;
if (H5Dread(did4, H5T_STD_REF_DSETREG, H5S_ALL, H5S_ALL, H5P_DEFAULT, reg_buf) < 0)
TEST_ERROR;
/* Verify that the references contain only "0" bytes */
if (HDmemcmp(obj_buf, zeros, sizeof(obj_buf)) != 0)
TEST_ERROR;
if (HDmemcmp(reg_buf, zeros, sizeof(reg_buf)) != 0)
TEST_ERROR;
/* Create destination file */
if ((fid3 = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create object copy property list */
if ((pid = H5Pcreate(H5P_OBJECT_COPY)) < 0)
TEST_ERROR;
/* Set the "expand references" flag */
if (H5Pset_copy_object(pid, H5O_COPY_EXPAND_REFERENCE_FLAG) < 0)
TEST_ERROR;
/* Copy the middle file to the destination file. Note the expand references
* flag *is* set, even though the references are now NULL. */
if (H5Ocopy(fid2, "/", fid3, "/AA", pid, H5P_DEFAULT) < 0)
TEST_ERROR;
/* Close datasets in middle file */
if (H5Dclose(did3) < 0)
TEST_ERROR;
if (H5Dclose(did4) < 0)
TEST_ERROR;
/* Close the middle file */
if (H5Fclose(fid2) < 0)
TEST_ERROR;
/* Open copied datasets */
if ((did5 = H5Dopen2(fid3, "/AA/A/obj_ref_dset", H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((did6 = H5Dopen2(fid3, "/AA/A/reg_ref_dset", H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Read copied datasets */
if (H5Dread(did5, H5T_STD_REF_OBJ, H5S_ALL, H5S_ALL, H5P_DEFAULT, obj_buf) < 0)
TEST_ERROR;
if (H5Dread(did6, H5T_STD_REF_DSETREG, H5S_ALL, H5S_ALL, H5P_DEFAULT, reg_buf) < 0)
TEST_ERROR;
/* Verify that the references contain only "0" bytes */
if (HDmemcmp(obj_buf, zeros, sizeof(obj_buf)) != 0)
TEST_ERROR;
if (HDmemcmp(reg_buf, zeros, sizeof(reg_buf)) != 0)
TEST_ERROR;
/* Close */
if (H5Pclose(pid) < 0)
TEST_ERROR;
if (H5Pclose(dcpl) < 0)
TEST_ERROR;
if (H5Dclose(did5) < 0)
TEST_ERROR;
if (H5Dclose(did6) < 0)
TEST_ERROR;
if (H5Fclose(fid3) < 0)
TEST_ERROR;
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Pclose(pid);
H5Pclose(dcpl);
H5Sclose(sid);
H5Dclose(did1);
H5Dclose(did2);
H5Dclose(did3);
H5Dclose(did4);
H5Dclose(did5);
H5Dclose(did6);
H5Fclose(fid1);
H5Fclose(fid2);
H5Fclose(fid3);
}
H5E_END_TRY;
return 1;
} /* end test_copy_null_ref_open */
/*-------------------------------------------------------------------------
* Function: test_copy_attr_crt_order
*
* Purpose: Tests copying attributes with creation order tracked, with
* and without creation order being indexed.
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Neil Fortner
* Friday, January 20, 2012
*
*-------------------------------------------------------------------------
*/
static int
test_copy_attr_crt_order(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid1 = -1, fid2 = -1; /* File IDs */
hid_t gcplid = -1; /* Group creation property list ID */
hid_t gid1 = -1, gid2 = -1; /* Group IDs */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): attributes with creation order");
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], src_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* Create source file */
if ((fid1 = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Create GCPL */
if ((gcplid = H5Pcreate(H5P_GROUP_CREATE)) < 0)
TEST_ERROR;
/* Create group with creation order tracked */
if (H5Pset_attr_creation_order(gcplid, H5P_CRT_ORDER_TRACKED) < 0)
TEST_ERROR;
if ((gid1 = H5Gcreate2(fid1, NAME_GROUP_TOP, H5P_DEFAULT, gcplid, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Add attributes to group */
if (test_copy_attach_attributes(gid1, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* Close group */
if (H5Gclose(gid1) < 0)
TEST_ERROR;
/* Create group with creation order tracked and indexed */
if (H5Pset_attr_creation_order(gcplid, H5P_CRT_ORDER_TRACKED | H5P_CRT_ORDER_INDEXED) < 0)
TEST_ERROR;
if ((gid1 = H5Gcreate2(fid1, NAME_GROUP_TOP2, H5P_DEFAULT, gcplid, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Add attributes to group */
if (test_copy_attach_attributes(gid1, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* Close group */
if (H5Gclose(gid1) < 0)
TEST_ERROR;
/* Close GCPL */
if (H5Pclose(gcplid) < 0)
TEST_ERROR;
/* Create destination file */
if ((fid2 = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Copy the groups to the destination file */
if (H5Ocopy(fid1, NAME_GROUP_TOP, fid2, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid1, NAME_GROUP_TOP2, fid2, NAME_GROUP_TOP2, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* Open groups with creation order tracked */
if ((gid1 = H5Gopen2(fid1, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((gid2 = H5Gopen2(fid2, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Compare the attributes */
if (compare_std_attributes(gid1, gid2, H5P_DEFAULT) != TRUE)
TEST_ERROR;
/* Close groups */
if (H5Gclose(gid1) < 0)
TEST_ERROR;
if (H5Gclose(gid2) < 0)
TEST_ERROR;
/* Open groups with creation order tracked and indexed */
if ((gid1 = H5Gopen2(fid1, NAME_GROUP_TOP2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((gid2 = H5Gopen2(fid2, NAME_GROUP_TOP2, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Compare the attributes */
if (compare_std_attributes(gid1, gid2, H5P_DEFAULT) != TRUE)
TEST_ERROR;
/* Close groups */
if (H5Gclose(gid1) < 0)
TEST_ERROR;
if (H5Gclose(gid2) < 0)
TEST_ERROR;
/* Close */
if (H5Fclose(fid1) < 0)
TEST_ERROR;
if (H5Fclose(fid2) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Gclose(gid1);
H5Gclose(gid2);
H5Pclose(gcplid);
H5Fclose(fid1);
H5Fclose(fid2);
}
H5E_END_TRY;
return 1;
} /* end test_copy_attr_crt_order */
/*-------------------------------------------------------------------------
* Function: test_copy_committed_datatype_merge
*
* Purpose: Tests the "merge committed datatypes" feature of H5Ocopy.
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Neil Fortner
* Tuesday, October 11, 2011
*
*-------------------------------------------------------------------------
*/
static int
test_copy_committed_datatype_merge(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl,
hbool_t reopen)
{
hid_t fid_src1 = -1, fid_src2 = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1; /* Dataset ID */
hid_t ocpypl_id = -1; /* Object copy plist ID */
unsigned int i; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
int buf[DIM_SIZE_1]; /* Buffer for writing data */
H5O_info2_t oinfo; /* Object info */
H5O_token_t exp_token; /* Expected object token */
char src1_filename[NAME_BUF_SIZE];
char src2_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
int token_cmp;
if (reopen) {
TESTING("H5Ocopy(): merging committed datatypes with reopen");
} /* end if */
else
TESTING("H5Ocopy(): merging committed datatypes");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
buf[i] = (int)i;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src1_filename, sizeof src1_filename);
h5_fixname(FILENAME[3], src_fapl, src2_filename, sizeof src2_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source files */
if ((fid_src1 = H5Fcreate(src1_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
if ((fid_src2 = H5Fcreate(src2_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/*
* Populate source file 1
*/
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* committed datatype */
if ((H5Tcommit2(fid_src1, NAME_DATATYPE_SIMPLE, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src1, NAME_DATASET_SIMPLE, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) <
0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file 1 */
if (H5Fclose(fid_src1) < 0)
TEST_ERROR;
/*
* Populate source file 2
*/
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* committed datatype */
if ((H5Tcommit2(fid_src2, NAME_DATATYPE_SIMPLE, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src2, NAME_DATASET_SIMPLE, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) <
0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file 1 */
if (H5Fclose(fid_src2) < 0)
TEST_ERROR;
/* open the source files with read-only */
if ((fid_src1 = H5Fopen(src1_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
if ((fid_src2 = H5Fopen(src2_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* Create ocpl and set merge named dtype flag */
if ((ocpypl_id = H5Pcreate(H5P_OBJECT_COPY)) < 0)
TEST_ERROR;
if (H5Pset_copy_object(ocpypl_id, H5O_COPY_MERGE_COMMITTED_DTYPE_FLAG) < 0)
TEST_ERROR;
/*
* First copy each entire file to the destination file (each with their own
* group), and verify the committed datatypes are merged
*/
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy SRC1 to DST */
if (H5Ocopy(fid_src1, "/", fid_dst, NAME_GROUP_TOP, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
/* copy SRC2 to DST */
if (H5Ocopy(fid_src2, "/", fid_dst, NAME_GROUP_TOP2, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* Open SRC1 committed dtype, get token */
if ((tid = H5Topen2(fid_dst, NAME_GROUP_TOP "/" NAME_DATATYPE_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* Open SRC1 dset dtype, check token */
if ((did = H5Dopen2(fid_dst, NAME_GROUP_TOP "/" NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Open SRC2 committed dtype, check token */
if ((tid = H5Topen2(fid_dst, NAME_GROUP_TOP2 "/" NAME_DATATYPE_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* Open SRC2 dset dtype, check token */
if ((did = H5Dopen2(fid_dst, NAME_GROUP_TOP2 "/" NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Close destination file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Now copy only the datasets to the destination file, and verify the committed
* datatypes are merged
*/
/* recreate destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* copy SRC1 to DST */
if (H5Ocopy(fid_src1, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
/* copy SRC2 to DST */
if (H5Ocopy(fid_src2, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE2, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* Open SRC1 dset dtype, get token */
if ((did = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Open SRC2 dset dtype, check token */
if ((did = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Close destination file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* close the SRC files */
if (H5Fclose(fid_src1) < 0)
TEST_ERROR;
if (H5Fclose(fid_src2) < 0)
TEST_ERROR;
/* close property list */
if (H5Pclose(ocpypl_id) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Fclose(fid_src1);
H5Fclose(fid_src2);
H5Fclose(fid_dst);
H5Tclose(tid);
H5Sclose(sid);
H5Dclose(did);
H5Pclose(ocpypl_id);
}
H5E_END_TRY;
return 1;
} /* end test_copy_committed_datatype_merge */
/*-------------------------------------------------------------------------
* Function: test_copy_committed_datatype_merge_same_file
*
* Purpose: Tests the "merge committed datatypes" feature of H5Ocopy,
* while copying to the same file.
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Neil Fortner
* Tuesday, October 11, 2011
*
*-------------------------------------------------------------------------
*/
static int
test_copy_committed_datatype_merge_same_file(hid_t fcpl, hid_t fapl, hbool_t reopen)
{
hid_t fid = -1; /* File ID */
hid_t tid = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1; /* Dataset ID */
hid_t gid = -1; /* Group ID */
hid_t ocpypl_id = -1; /* Object copy plist ID */
unsigned int i; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
int buf[DIM_SIZE_1]; /* Buffer for writing data */
H5O_info2_t oinfo; /* Object info */
H5O_token_t exp_token; /* Expected object token */
char filename[NAME_BUF_SIZE];
int token_cmp;
if (reopen)
TESTING("H5Ocopy(): merging committed datatypes to the source file with reopen");
else
TESTING("H5Ocopy(): merging committed datatypes to the source file");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
buf[i] = (int)i;
/* Initialize the filename */
h5_fixname(FILENAME[0], fapl, filename, sizeof filename);
/* Reset file token checking info */
token_reset();
/* create file */
if ((fid = H5Fcreate(filename, H5F_ACC_TRUNC, fcpl, fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/*
* Populate first group
*/
/* Create group */
if ((gid = H5Gcreate2(fid, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* committed datatype */
if ((H5Tcommit2(fid, NAME_GROUP_TOP "/" NAME_DATATYPE_SIMPLE, tid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid, NAME_GROUP_TOP "/" NAME_DATASET_SIMPLE, tid, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/*
* Populate second group
*/
/* Create group */
if ((gid = H5Gcreate2(fid, NAME_GROUP_TOP2, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* committed datatype */
if ((H5Tcommit2(fid, NAME_GROUP_TOP2 "/" NAME_DATATYPE_SIMPLE, tid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid, NAME_GROUP_TOP2 "/" NAME_DATASET_SIMPLE, tid, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* Create ocpl and set merge committed dtype flag */
if ((ocpypl_id = H5Pcreate(H5P_OBJECT_COPY)) < 0)
TEST_ERROR;
if (H5Pset_copy_object(ocpypl_id, H5O_COPY_MERGE_COMMITTED_DTYPE_FLAG) < 0)
TEST_ERROR;
/*
* First copy each group to the destination group 3 (each with their own
* group), and verify the committed datatypes are merged as expected. All
* datatypes copied should reference (share a token with) the
* corresponding source datatype.
*/
/* Create destination group */
if ((gid = H5Gcreate2(fid, NAME_GROUP_TOP3, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* copy group 1 to DST */
if (H5Ocopy(fid, NAME_GROUP_TOP, fid, NAME_GROUP_TOP3 "/" NAME_GROUP_TOP, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
/* copy group 2 to DST */
if (H5Ocopy(fid, NAME_GROUP_TOP2, fid, NAME_GROUP_TOP3 "/" NAME_GROUP_TOP2, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid) < 0)
TEST_ERROR;
if ((fid = H5Fopen(filename, H5F_ACC_RDWR, fapl)) < 0)
TEST_ERROR;
} /* end if */
/* Open group 1 source committed dtype, get token */
if ((tid = H5Topen2(fid, NAME_GROUP_TOP "/" NAME_DATATYPE_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* Open group 1 source dset dtype, check token */
if ((did = H5Dopen2(fid, NAME_GROUP_TOP "/" NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Open group 1 committed dtype, check token */
if ((tid = H5Topen2(fid, NAME_GROUP_TOP3 "/" NAME_GROUP_TOP "/" NAME_DATATYPE_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* Open group 1 dset dtype, check token */
if ((did = H5Dopen2(fid, NAME_GROUP_TOP3 "/" NAME_GROUP_TOP "/" NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Open group 2 source committed dtype, get token and make sure it is
* different from group 1 source committed dtype */
if ((tid = H5Topen2(fid, NAME_GROUP_TOP2 "/" NAME_DATATYPE_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (!token_cmp)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* Open group 2 source dset dtype, check token */
if ((did = H5Dopen2(fid, NAME_GROUP_TOP2 "/" NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Open group 2 committed dtype, check token */
if ((tid = H5Topen2(fid, NAME_GROUP_TOP3 "/" NAME_GROUP_TOP2 "/" NAME_DATATYPE_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* Open group 2 dset dtype, check token */
if ((did = H5Dopen2(fid, NAME_GROUP_TOP3 "/" NAME_GROUP_TOP2 "/" NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/*
* Now copy only the datasets to the destination group, and verify the committed
* datatypes are merged as expected
*/
/* Create destination group */
if ((gid = H5Gcreate2(fid, NAME_GROUP_TOP4, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* copy SRC1 to DST */
if (H5Ocopy(fid, NAME_GROUP_TOP "/" NAME_DATASET_SIMPLE, fid, NAME_GROUP_TOP4 "/" NAME_DATASET_SIMPLE,
ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
/* copy SRC2 to DST */
if (H5Ocopy(fid, NAME_GROUP_TOP2 "/" NAME_DATASET_SIMPLE, fid, NAME_GROUP_TOP4 "/" NAME_DATASET_SIMPLE2,
ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid) < 0)
TEST_ERROR;
if ((fid = H5Fopen(filename, H5F_ACC_RDONLY, fapl)) < 0)
TEST_ERROR;
} /* end if */
/* Open group 1 source dset dtype, get token */
if ((did = H5Dopen2(fid, NAME_GROUP_TOP "/" NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Open group 1 dset dtype, check token */
if ((did = H5Dopen2(fid, NAME_GROUP_TOP4 "/" NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Open group 2 source dset dtype, get token and make sure it is
* different from group 1 source dset dtype */
if ((did = H5Dopen2(fid, NAME_GROUP_TOP2 "/" NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (!token_cmp)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Open group 2 dset dtype, check token */
if ((did = H5Dopen2(fid, NAME_GROUP_TOP4 "/" NAME_DATASET_SIMPLE2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Close file */
if (H5Fclose(fid) < 0)
TEST_ERROR;
/* close property list */
if (H5Pclose(ocpypl_id) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Fclose(fid);
H5Tclose(tid);
H5Sclose(sid);
H5Dclose(did);
H5Pclose(ocpypl_id);
}
H5E_END_TRY;
return 1;
} /* end test_copy_committed_datatype_merge_same_file */
/*-------------------------------------------------------------------------
* Function: test_copy_committed_dt_merge_sugg
*
* Purpose: Tests the "merge committed datatypes" feature of H5Ocopy, and
* uses the suggestion list feature
* (H5Padd_merge_committed_dtype_path).
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Neil Fortner
* Thursday, November 3, 2011
*
*-------------------------------------------------------------------------
*/
static int
test_copy_committed_dt_merge_sugg(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl,
hbool_t reopen)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1; /* Dataset ID */
hid_t ocpypl_id = -1; /* Object copy plist ID */
unsigned int i; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
int buf[DIM_SIZE_1]; /* Buffer for writing data */
H5O_info2_t oinfo; /* Object info */
H5O_token_t exp_token; /* Expected object token */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
int token_cmp;
if (reopen)
TESTING("H5Ocopy(): merging committed datatypes with suggestions and reopen");
else
TESTING("H5Ocopy(): merging committed datatypes with suggestions");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
buf[i] = (int)i;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/*
* Populate source file
*/
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* committed datatype */
if ((H5Tcommit2(fid_src, NAME_DATATYPE_SIMPLE, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_SIMPLE, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/*
* Populate destination file
*/
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* committed datatype "a" */
if ((H5Tcommit2(fid_dst, "/a", tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* committed datatype "b" */
if ((H5Tcommit2(fid_dst, "/b", tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* Create ocpl and set merge committed dtype flag */
if ((ocpypl_id = H5Pcreate(H5P_OBJECT_COPY)) < 0)
TEST_ERROR;
if (H5Pset_copy_object(ocpypl_id, H5O_COPY_MERGE_COMMITTED_DTYPE_FLAG) < 0)
TEST_ERROR;
/*
* First copy dataset using "/b" as a suggestion, and verify that it uses
* datatype "b" in the destination file
*/
/* Add datatype suggestion */
if (H5Padd_merge_committed_dtype_path(ocpypl_id, "/b") < 0)
TEST_ERROR;
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* copy SRC dset to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* Open committed dtype "b", get token */
if ((tid = H5Topen2(fid_dst, "/b", H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* Open dset dtype, check token */
if ((did = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Close destination file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Now free suggestions, copy dataset without any suggestions, and verify
* that it uses datatype "a" in the destination file
*/
/* Free suggestions */
if (H5Pfree_merge_committed_dtype_paths(ocpypl_id) < 0)
TEST_ERROR;
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* Delete destination dataset */
/* copy SRC dset to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE2, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* Open committed dtype "a", get token */
if ((tid = H5Topen2(fid_dst, "/a", H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* Open dset 2 dtype, check token */
if ((did = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Open committed dtype "b", get token */
if ((tid = H5Topen2(fid_dst, "/b", H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* Open dset dtype, check token */
if ((did = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Close destination file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close property list */
if (H5Pclose(ocpypl_id) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Fclose(fid_src);
H5Fclose(fid_dst);
H5Tclose(tid);
H5Sclose(sid);
H5Dclose(did);
H5Pclose(ocpypl_id);
}
H5E_END_TRY;
return 1;
} /* end test_copy_committed_dt_merge_sugg */
/*-------------------------------------------------------------------------
* Function: test_copy_committed_dt_merge_attr
*
* Purpose: Tests the "merge committed datatypes" feature of H5Ocopy, with
* an attribute using an anonymous committed type in the
* destination.
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Neil Fortner
* Thursday, November 3, 2011
*
*-------------------------------------------------------------------------
*/
static int
test_copy_committed_dt_merge_attr(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl,
hbool_t reopen)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1; /* Dataset ID */
hid_t aid = -1; /* Attribute ID */
hid_t gid = -1; /* Group ID */
hid_t ocpypl_id = -1; /* Object copy plist ID */
unsigned int i; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
int buf[DIM_SIZE_1]; /* Buffer for writing data */
H5O_info2_t oinfo; /* Object info */
H5O_token_t exp_token; /* Expected object token */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
int token_cmp;
if (reopen)
TESTING("H5Ocopy(): merging committed datatypes with attributes and reopen");
else
TESTING("H5Ocopy(): merging committed datatypes with attributes");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
buf[i] = (int)i;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/*
* Populate source file
*/
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* committed datatype */
if ((H5Tcommit2(fid_src, NAME_DATATYPE_SIMPLE, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_SIMPLE, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/*
* Populate destination file
*/
/* Create group */
if ((gid = H5Gcreate2(fid_dst, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* create anonymous committed datatype */
if ((H5Tcommit_anon(fid_dst, tid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create attribute at SRC file */
if ((aid = H5Acreate2(gid, "attr", tid, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Awrite(aid, tid, buf) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the attribute */
if (H5Aclose(aid) < 0)
TEST_ERROR;
/* close the group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* Create ocpl and set merge committed dtype flag */
if ((ocpypl_id = H5Pcreate(H5P_OBJECT_COPY)) < 0)
TEST_ERROR;
if (H5Pset_copy_object(ocpypl_id, H5O_COPY_MERGE_COMMITTED_DTYPE_FLAG) < 0)
TEST_ERROR;
/*
* Copy dataset and verify that it uses the same committed datatype as the
* already existing attribute in the destination file.
*/
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* copy SRC dset to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* Open attribute dtype, get token */
if ((aid = H5Aopen_by_name(fid_dst, NAME_GROUP_TOP, "attr", H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Aget_type(aid)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Aclose(aid) < 0)
TEST_ERROR;
/* Open dset dtype, check token */
if ((did = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Close destination file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close property list */
if (H5Pclose(ocpypl_id) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Fclose(fid_src);
H5Fclose(fid_dst);
H5Tclose(tid);
H5Sclose(sid);
H5Dclose(did);
H5Aclose(aid);
H5Gclose(gid);
H5Pclose(ocpypl_id);
}
H5E_END_TRY;
return 1;
} /* end test_copy_committed_dt_merge_attr */
/*
* Defines used for the committed datatype tests
*/
#define SRC_ROOT_GROUP "src_root"
#define ROOT_NDT_INT "root_ndt_int"
#define GROUP_NDT_SHORT "group_ndt_short"
#define SRC_GRP "src_grp"
#define DST_GRP "dst_grp"
#define DST_GRP2 "dst_grp2"
#define SRC_NDT_SHORT "src_ndt_short"
#define SRC_NDT_INT "src_ndt_int"
#define SRC_NDT_INT2 "src_ndt_int2"
#define SRC_NDT_FLOAT "src_ndt_float"
#define SRC_NDT_DOUBLE "src_ndt_double"
#define DST_NDT_SHORT "dst_ndt_short"
#define DST_NDT_INT "dst_ndt_int"
#define DST_NDT_FLOAT "dst_ndt_float"
#define DST_NDT_DOUBLE "dst_ndt_double"
#define SRC_NDT_DSET "src_ndt_dset"
#define SRC_NDT_DSET2 "src_ndt_dset2"
#define SRC_NDT_DSET3 "src_ndt_dset3"
#define SRC_DSET "src_dset"
#define SRC_DSET1 "src_dset1"
#define SRC_ATTR "src_attr"
#define DST_ATTR_ANON_SHORT "dst_attr_anon_short"
#define DST_ATTR_ANON_INT "dst_attr_anon_int"
#define DST_ATTR "dst_attr"
#define DST_ATTR2 "dst_attr2"
/*-------------------------------------------------------------------------
* Function: test_copy_cdt_hier_merge
*
* Purpose: Tests the "merge committed datatypes" feature of H5Ocopy:
* SRC file:
* Create committed datatypes at / and /g0
* Create datasets with native type and committed datatypes at /g0
* DST file:
* Create attributes with anonymous committed datatypes at /uncopied
*
* Copy / at SRC to DST
* Copy /g0 at SRC to DST
* Copy the datasets in /g0 at SRC to DST /uncopied
* Verify that committed datatypes are copied and merged correctly
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Vailin Choi; January 2012
*
*-------------------------------------------------------------------------
*/
static int
test_copy_cdt_hier_merge(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl, hbool_t reopen)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1; /* Dataset ID */
hid_t gid = -1; /* Group IDs */
hid_t f_tid = -1; /* Datatype ID for root group */
hid_t g_tid = -1; /* Datatype ID for group */
hid_t anon_tid = -1; /* Anonymous datatype */
hid_t aid = -1; /* Attribute ID */
hid_t ocpypl_id = -1; /* Object copy plist ID */
int i; /* Local index variable */
hsize_t dim1d[1]; /* dimension sizes */
int buf[DIM_SIZE_1]; /* Buffer for data */
H5O_token_t exp_token_int, exp_token_short; /* Expected object tokenes */
H5O_info2_t oinfo; /* Object info */
char src_filename[NAME_BUF_SIZE]; /* Source file name */
char dst_filename[NAME_BUF_SIZE]; /* Destination file name */
int token_cmp;
if (reopen)
TESTING("H5Ocopy(): hier. of committed datatypes and merging with reopen");
else
TESTING("H5Ocopy(): hier. of committed datatypes and merging ");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
buf[i] = i;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/*
* Populate source file
*/
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create and commit committed datatype (int) to root group */
if ((f_tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_src, ROOT_NDT_INT, f_tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Create group /g0 */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create and commit committed datatype (short) to group /g0 */
if ((g_tid = H5Tcopy(H5T_NATIVE_SHORT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(gid, GROUP_NDT_SHORT, g_tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create dataset of native int in /g0 */
if ((did = H5Dcreate2(gid, SRC_DSET1, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data to dataset */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* create dataset of committed datatype (short) in /g0 */
if ((did = H5Dcreate2(gid, SRC_NDT_DSET2, g_tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data to dataset */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* create dataset of committed datatype (int) in /g0 */
if ((did = H5Dcreate2(gid, SRC_NDT_DSET3, f_tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data to dataset */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the datatypes */
if (H5Tclose(f_tid) < 0)
TEST_ERROR;
if (H5Tclose(g_tid) < 0)
TEST_ERROR;
/* close group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/*
* Populate destination file
*/
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* create group /uncopied */
if ((gid = H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create and commit anonymous datatype (short) to /uncopied */
if ((anon_tid = H5Tcopy(H5T_NATIVE_SHORT)) < 0)
TEST_ERROR;
if ((H5Tcommit_anon(gid, anon_tid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create attribute of anon ndt (short) in /uncopied */
if ((aid = H5Acreate2(gid, DST_ATTR_ANON_SHORT, anon_tid, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the attribute */
if (H5Aclose(aid) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(anon_tid) < 0)
TEST_ERROR;
/* create and commit anonymous datatype (int) to /uncopied */
if ((anon_tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((H5Tcommit_anon(gid, anon_tid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create attribute of anon ndt (int) in /uncopied */
if ((aid = H5Acreate2(gid, DST_ATTR_ANON_INT, anon_tid, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the attribute */
if (H5Aclose(aid) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(anon_tid) < 0)
TEST_ERROR;
/* close the group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
if (reopen) {
/* reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
}
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create ocpl and set merge committed datatype flag */
if ((ocpypl_id = H5Pcreate(H5P_OBJECT_COPY)) < 0)
TEST_ERROR;
if (H5Pset_copy_object(ocpypl_id, H5O_COPY_MERGE_COMMITTED_DTYPE_FLAG) < 0)
TEST_ERROR;
/*
* Test 1 : copy / in SRC file to DST file
*/
if (H5Ocopy(fid_src, "/", fid_dst, SRC_ROOT_GROUP, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
/* get token of committed datatype at root group */
if ((tid = H5Topen2(fid_dst, SRC_ROOT_GROUP "/" ROOT_NDT_INT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token_int, &oinfo.token, sizeof(exp_token_int));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* get token of committed datatype at /g0 */
if ((tid = H5Topen2(fid_dst, SRC_ROOT_GROUP NAME_GROUP_TOP "/" GROUP_NDT_SHORT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token_short, &oinfo.token, sizeof(exp_token_short));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* verify the datatype of first dataset is not committed */
if ((did = H5Dopen2(fid_dst, SRC_ROOT_GROUP NAME_GROUP_TOP "/" SRC_DSET1, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Tcommitted(tid))
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* check token of datatype for second dataset */
if ((did = H5Dopen2(fid_dst, SRC_ROOT_GROUP NAME_GROUP_TOP "/" SRC_NDT_DSET2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token_short, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* check token of datatype for third dataset */
if ((did = H5Dopen2(fid_dst, SRC_ROOT_GROUP NAME_GROUP_TOP "/" SRC_NDT_DSET3, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token_int, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/*
* Test 2: copy /g0 in SRC to DST
*/
if (H5Ocopy(fid_src, NAME_GROUP_TOP, fid_dst, NAME_GROUP_TOP, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
/* get token of committed datatype at /g0 */
if ((tid = H5Topen2(fid_dst, NAME_GROUP_TOP "/" GROUP_NDT_SHORT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token_short, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* verify the datatype of first dataset is not committed */
if ((did = H5Dopen2(fid_dst, NAME_GROUP_TOP "/" SRC_DSET1, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Tcommitted(tid))
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* check token of datatype for second dataset */
if ((did = H5Dopen2(fid_dst, NAME_GROUP_TOP "/" SRC_NDT_DSET2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token_short, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* check token of datatype for third dataset */
if ((did = H5Dopen2(fid_dst, NAME_GROUP_TOP "/" SRC_NDT_DSET3, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token_int, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/*
* Test 3: copy datasets in /g0 at SRC to DST group /uncopied
*/
if (H5Ocopy(fid_src, NAME_GROUP_TOP "/" SRC_DSET1, fid_dst, NAME_GROUP_UNCOPIED "/" SRC_DSET1, ocpypl_id,
H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_GROUP_TOP "/" SRC_NDT_DSET2, fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_DSET2,
ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_GROUP_TOP "/" SRC_NDT_DSET3, fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_DSET3,
ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
/* Open attribute with anon ndt (short), get token */
if ((aid = H5Aopen_by_name(fid_dst, NAME_GROUP_UNCOPIED, DST_ATTR_ANON_SHORT, H5P_DEFAULT, H5P_DEFAULT)) <
0)
TEST_ERROR;
if ((tid = H5Aget_type(aid)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token_short, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Aclose(aid) < 0)
TEST_ERROR;
/* Open attribute with anon ndt (int), get token */
if ((aid = H5Aopen_by_name(fid_dst, NAME_GROUP_UNCOPIED, DST_ATTR_ANON_INT, H5P_DEFAULT, H5P_DEFAULT)) <
0)
TEST_ERROR;
if ((tid = H5Aget_type(aid)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token_int, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Aclose(aid) < 0)
TEST_ERROR;
/* verify the datatype of first dataset is not committed */
if ((did = H5Dopen2(fid_dst, NAME_GROUP_UNCOPIED "/" SRC_DSET1, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Tcommitted(tid))
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* check token of datatype for second dataset */
if ((did = H5Dopen2(fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_DSET2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token_short, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* check token of datatype for third dataset */
if ((did = H5Dopen2(fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_DSET3, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token_int, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* close property list */
if (H5Pclose(ocpypl_id) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Tclose(tid);
H5Tclose(f_tid);
H5Tclose(g_tid);
H5Tclose(anon_tid);
H5Pclose(ocpypl_id);
H5Aclose(aid);
H5Dclose(did);
H5Sclose(sid);
H5Gclose(gid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_cdt_hier_merge */
/*-------------------------------------------------------------------------
* Function: test_copy_cdt_merge_cdt
*
* Purpose: Tests the "merge committed datatypes" feature of H5Ocopy:
* SRC file:
* Create committed datatype (short)
* Create committed datatype (float)
* Create committed datatype (int), with attribute of ndt int
* Create committed datatype (double), with attribute of anon ndt short
* DST file:
* Create committed datatype (int)
* Create committed datatype (float), with attribute of native int
* Create committed datatype (double), with attribute of anon ndt short
*
* Copy / at SRC to DST
* Verify that committed datatypes are copied and merged correctly
*
* NOTE:
* Comparison of attributes are not implemented yet.
* Further tests will be added in the future.
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Vailin Choi; January 2012
*
*-------------------------------------------------------------------------
*/
static int
test_copy_cdt_merge_cdt(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl, hbool_t reopen)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid1 = -1, tid2 = -1; /* Datatype IDs */
hid_t tid3 = -1, tid4 = -1; /* Datatype IDs */
hid_t tid5 = -1, tid = -1; /* Datatype IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t aid = -1; /* Attribute ID */
hid_t ocpypl_id = -1; /* Object copy plist ID */
hsize_t dim1d[1]; /* dimension sizes */
H5O_info2_t oinfo; /* Object info */
H5O_token_t exp_token; /* Expected object token */
char src_filename[NAME_BUF_SIZE]; /* Source file name */
char dst_filename[NAME_BUF_SIZE]; /* Destination file name */
int token_cmp;
if (reopen)
TESTING("H5Ocopy(): merging various committed datatypes with reopen");
else
TESTING("H5Ocopy(): merging various committed datatypes");
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/*
* Populate source file
*/
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create committed datatype (short) */
if ((tid1 = H5Tcopy(H5T_NATIVE_SHORT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_src, SRC_NDT_SHORT, tid1, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create committed datatype (float) */
if ((tid2 = H5Tcopy(H5T_NATIVE_FLOAT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_src, SRC_NDT_FLOAT, tid2, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create committed datatype (int) */
if ((tid3 = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_src, SRC_NDT_INT, tid3, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create an attribute of committed datatype (int); attach to committed datatype (int) */
if ((aid = H5Acreate2(tid3, SRC_ATTR, tid3, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Aclose(aid) < 0)
TEST_ERROR;
/* create committed datatype (double) */
if ((tid4 = H5Tcopy(H5T_NATIVE_DOUBLE)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_src, SRC_NDT_DOUBLE, tid4, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create an anonymous committed datatype (short) */
if ((tid5 = H5Tcopy(H5T_NATIVE_SHORT)) < 0)
TEST_ERROR;
if ((H5Tcommit_anon(fid_src, tid5, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create an attribute of anon ndt (short); attach to committed datatype (double) */
if ((aid = H5Acreate2(tid4, SRC_ATTR, tid5, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Aclose(aid) < 0)
TEST_ERROR;
/* close the committed datatypes */
if (H5Tclose(tid1) < 0)
TEST_ERROR;
if (H5Tclose(tid2) < 0)
TEST_ERROR;
if (H5Tclose(tid3) < 0)
TEST_ERROR;
if (H5Tclose(tid4) < 0)
TEST_ERROR;
if (H5Tclose(tid5) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/*
* Populate destination file
*/
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* create committed datatype (integer) */
if ((tid1 = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_dst, DST_NDT_INT, tid1, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create committed datatype (float) */
if ((tid2 = H5Tcopy(H5T_NATIVE_FLOAT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_dst, DST_NDT_FLOAT, tid2, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create an attribute of native integer; attach to committed datatype (float) */
if ((aid = H5Acreate2(tid2, DST_ATTR, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Aclose(aid) < 0)
TEST_ERROR;
/* create committed datatype (double) */
if ((tid3 = H5Tcopy(H5T_NATIVE_DOUBLE)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_dst, DST_NDT_DOUBLE, tid3, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create anonymous committed datatype (short) */
if ((tid4 = H5Tcopy(H5T_NATIVE_SHORT)) < 0)
TEST_ERROR;
if ((H5Tcommit_anon(fid_dst, tid4, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create an attribute of anon ndt (short); attach to ndt (double) */
if ((aid = H5Acreate2(tid3, DST_ATTR, tid4, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Aclose(aid) < 0)
TEST_ERROR;
/* close the committed datatypes */
if (H5Tclose(tid1) < 0)
TEST_ERROR;
if (H5Tclose(tid2) < 0)
TEST_ERROR;
if (H5Tclose(tid3) < 0)
TEST_ERROR;
if (H5Tclose(tid4) < 0)
TEST_ERROR;
/* close the dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create ocpl and set merge committed dtype flag */
if ((ocpypl_id = H5Pcreate(H5P_OBJECT_COPY)) < 0)
TEST_ERROR;
if (H5Pset_copy_object(ocpypl_id, H5O_COPY_MERGE_COMMITTED_DTYPE_FLAG) < 0)
TEST_ERROR;
/* copy everything in SRC to DST */
if (H5Ocopy(fid_src, "/", fid_dst, SRC_ROOT_GROUP, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
/*
* Verification
*/
/* get token of committed datatype: /src_root/src_ndt_double */
if ((tid = H5Topen2(fid_dst, "/" SRC_ROOT_GROUP "/" SRC_NDT_DOUBLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* get token of committed datatype: /dst_ndt_double */
if ((tid = H5Topen2(fid_dst, "/" DST_NDT_DOUBLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* get token of committed datatype: /src_root/src_ndt_float */
if ((tid = H5Topen2(fid_dst, "/" SRC_ROOT_GROUP "/" SRC_NDT_FLOAT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* get token of committed datatype: /dst_ndt_float */
if ((tid = H5Topen2(fid_dst, "/" DST_NDT_FLOAT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* get token of committed datatype: /src_root/src_ndt_int */
if ((tid = H5Topen2(fid_dst, "/" SRC_ROOT_GROUP "/" SRC_NDT_INT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* get token of committed datatype: /dst_ndt_int */
if ((tid = H5Topen2(fid_dst, "/" DST_NDT_INT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* get token of committed datatype: /src_root/src_ndt_short */
if ((tid = H5Topen2(fid_dst, "/" SRC_ROOT_GROUP "/" SRC_NDT_SHORT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* open attribute; get its dtype; get dtype's token: /src_root/src_ndt_double/dst_attr */
if ((aid = H5Aopen_by_name(fid_dst, "/" SRC_ROOT_GROUP "/" SRC_NDT_DOUBLE, DST_ATTR, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Aget_type(aid)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Aclose(aid) < 0)
TEST_ERROR;
/* close the files */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* close the object copy property list */
if (H5Pclose(ocpypl_id) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Pclose(ocpypl_id);
H5Tclose(tid);
H5Tclose(tid1);
H5Tclose(tid2);
H5Tclose(tid3);
H5Tclose(tid4);
H5Tclose(tid5);
H5Aclose(aid);
H5Sclose(sid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_cdt_merge_cdt */
/*-------------------------------------------------------------------------
* Function: test_copy_cdt_merge_suggs
*
* Purpose: Tests the suggested searching paths feature (H5Padd_merge_committed_dtype_path)
* is correctly applied in merging the committed datatypes.
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Vailin Choi; January 2012
*
*-------------------------------------------------------------------------
*/
static int
test_copy_cdt_merge_suggs(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl, hbool_t reopen)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1; /* Datatype ID */
hid_t ocpypl_id = -1; /* Object copy plist ID */
H5O_info2_t oinfo; /* Object info */
H5O_token_t exp_token; /* Expected object token */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
int token_cmp;
if (reopen)
TESTING("H5Ocopy(): merging committed datatypes with suggestions and reopen");
else
TESTING("H5Ocopy(): merging committed datatypes with suggestions");
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/*
* Populate source file
*/
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create committed datatype: "/src_ndt_int" */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_src, SRC_NDT_INT, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/*
* Populate destination file
*/
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* create committed datatype: "/dst_ndt_int" */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_dst, DST_NDT_INT, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* Create a group /uncopied */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Test 1
*/
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* Create ocpl and set merge committed dtype flag */
if ((ocpypl_id = H5Pcreate(H5P_OBJECT_COPY)) < 0)
TEST_ERROR;
if (H5Pset_copy_object(ocpypl_id, H5O_COPY_MERGE_COMMITTED_DTYPE_FLAG) < 0)
TEST_ERROR;
/* copy "/src_ndt_int" from SRC file to "/uncopied/src_ndt_int" at DST file */
if (H5Ocopy(fid_src, SRC_NDT_INT, fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_INT, ocpypl_id, H5P_DEFAULT) <
0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* open committed dtype "/dst_ndt_int", get its token */
if ((tid = H5Topen2(fid_dst, DST_NDT_INT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* check token of "/uncopied/src_ndt_int" */
if ((tid = H5Topen2(fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_INT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Test 2
*/
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* add committed datatype search suggestion: "/uncopied/src_ndt_int" */
if (H5Padd_merge_committed_dtype_path(ocpypl_id, NAME_GROUP_UNCOPIED "/" SRC_NDT_INT) < 0)
TEST_ERROR;
/* copy "/src_ndt_int" from SRC file to "/src_ndt_int" at DST file */
if (H5Ocopy(fid_src, SRC_NDT_INT, fid_dst, SRC_NDT_INT, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* open committed dtype "/uncopied/src_ndt_int", get its token */
if ((tid = H5Topen2(fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_INT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* check token of "/src_ndt_int" */
if ((tid = H5Topen2(fid_dst, SRC_NDT_INT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Test 3
*/
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* remove "/uncopied/src_ndt_int" from DST file */
if (H5Ldelete(fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_INT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* copy "/src_ndt_int" from SRC file to "/uncopied/src_ndt_int" at DST file */
/* use default ocpypl_id -- without merging and suggestion */
if (H5Ocopy(fid_src, SRC_NDT_INT, fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_INT, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
/* copy "/src_ndt_int" from SRC file to "/src_ndt_int2" at DST file */
/* copy with merging and search suggestion: "/uncopied/src_ndt_int" */
if (H5Ocopy(fid_src, SRC_NDT_INT, fid_dst, SRC_NDT_INT2, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* Open committed dtype "/uncopied/src_ndt_int", get its token */
if ((tid = H5Topen2(fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_INT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* check token of "/src_ndt_int2" */
if ((tid = H5Topen2(fid_dst, SRC_NDT_INT2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Test 4
*/
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* add committed datatype search suggestion */
if (H5Padd_merge_committed_dtype_path(ocpypl_id, DST_NDT_INT) < 0)
TEST_ERROR;
/* copy "src_ndt_int" from SRC file to "/uncopied/src_ndt_int2" at DST file */
/* copy with merging and search suggestion: "/dst_ndt_int, /uncopied/src_ndt_int" */
if (H5Ocopy(fid_src, SRC_NDT_INT, fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_INT2, ocpypl_id, H5P_DEFAULT) <
0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* Open committed dtype "/dst_dt_int", get its token */
if ((tid = H5Topen2(fid_dst, DST_NDT_INT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* check token of "/uncopied/src_ndt_int2" */
if ((tid = H5Topen2(fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_INT2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close property list */
if (H5Pclose(ocpypl_id) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Fclose(fid_src);
H5Fclose(fid_dst);
H5Tclose(tid);
H5Pclose(ocpypl_id);
}
H5E_END_TRY;
return 1;
} /* end test_copy_cdt_merge_suggs */
/*-------------------------------------------------------------------------
* Function: test_copy_cdt_merge_dset_suggs
*
* Purpose: Tests the suggested searching paths feature (H5Padd_merge_committed_dtype_path)
* is correctly applied in merging the committed datatypes of datasets.
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Vailin Choi; Dec 12, 2011
*
*-------------------------------------------------------------------------
*/
static int
test_copy_cdt_merge_dset_suggs(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl, hbool_t reopen)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1; /* Dataset ID */
hid_t ocpypl_id = -1; /* Object copy plist ID */
unsigned int i; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
int buf[DIM_SIZE_1]; /* Buffer for writing data */
H5O_info2_t oinfo; /* Object info */
H5O_token_t exp_token; /* Expected object token */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
int token_cmp;
if (reopen)
TESTING("H5Ocopy(): merging committed datatypes of datasets with suggestions and reopen");
else
TESTING("H5Ocopy(): merging committed datatypes of datasets with suggestions");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
buf[i] = (int)i;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/*
* Populate source file
*/
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create committed datatype: "/src_ndt_int" */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_src, SRC_NDT_INT, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create dataset */
if ((did = H5Dcreate2(fid_src, SRC_NDT_DSET, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data to dataset */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/*
* Populate destination file
*/
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* create committed datatype: "/dst_ndt_int" */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_dst, DST_NDT_INT, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Create a group "/uncopied" */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/*
* Test 1
*/
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* Create ocpl and set merge committed dtype flag */
if ((ocpypl_id = H5Pcreate(H5P_OBJECT_COPY)) < 0)
TEST_ERROR;
if (H5Pset_copy_object(ocpypl_id, H5O_COPY_MERGE_COMMITTED_DTYPE_FLAG) < 0)
TEST_ERROR;
/* copy "/src_ndt_dset" from SRC file to "/uncopied/src_ndt_dset" at DST file */
if (H5Ocopy(fid_src, SRC_NDT_DSET, fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_DSET, ocpypl_id,
H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* Open committed dtype "/dst_ndt_int", get its token */
if ((tid = H5Topen2(fid_dst, DST_NDT_INT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* check token of datatype for the copied dataset: "/uncopied/src_ndt_dset" */
if ((did = H5Dopen2(fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_DSET, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Test 2
*/
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* add committed datatype search suggestion: "/uncopied/src_ndt_dset" */
if (H5Padd_merge_committed_dtype_path(ocpypl_id, NAME_GROUP_UNCOPIED "/" SRC_NDT_DSET) < 0)
TEST_ERROR;
/* copy "/src_ndt_dset" from SRC file to "/src_ndt_dset" at DST file */
if (H5Ocopy(fid_src, SRC_NDT_DSET, fid_dst, SRC_NDT_DSET, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* Open committed dtype dataset "/uncopied/src_ndt_dset", get its datatype token */
if ((did = H5Dopen2(fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_DSET, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* check token of datatype for the copied dataset: "/src_ndt_dset" */
if ((did = H5Dopen2(fid_dst, SRC_NDT_DSET, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Test 3
*/
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* remove "/uncopied/src_ndt_dset" */
if (H5Ldelete(fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_DSET, H5P_DEFAULT) < 0)
TEST_ERROR;
/* copy "src_ndt_dset" from SRC file to "/uncopied/src_ndt_dset" at DST file */
/* use default ocpypl_id -- without merging and suggestion */
if (H5Ocopy(fid_src, SRC_NDT_DSET, fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_DSET, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
/* copy "src_ndt_dset" from SRC file to "/src_ndt_dset2" at DST file */
/* use merging and suggested searching path: "/uncopied/src_ndt_dset" */
if (H5Ocopy(fid_src, SRC_NDT_DSET, fid_dst, SRC_NDT_DSET2, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* open the copied dataset: /uncopied/src_ndt_dset", get its token */
if ((did = H5Dopen2(fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_DSET, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* check token of datatype for the copied dataset: "/src_ndt_dset2" */
if ((did = H5Dopen2(fid_dst, SRC_NDT_DSET2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Test 4
*/
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* add committed datatype search suggestion: "/src_ndt_dset" */
if (H5Padd_merge_committed_dtype_path(ocpypl_id, SRC_NDT_DSET) < 0)
TEST_ERROR;
/* copy /src_ndt_dset from SRC file to /uncopied/src_ndt_dset2 at DST */
/* use merging and suggested search paths: "/src_ndt_dset, /uncopied/src_ndt_dset" */
if (H5Ocopy(fid_src, SRC_NDT_DSET, fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_DSET2, ocpypl_id,
H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* open the copied dataset: "/src_ndt_dset", get its datatype token */
if ((did = H5Dopen2(fid_dst, SRC_NDT_DSET, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* check token of datatype for the copied dataset: /uncopied/src_ndt_dset2 */
if ((did = H5Dopen2(fid_dst, NAME_GROUP_UNCOPIED "/" SRC_NDT_DSET2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close property list */
if (H5Pclose(ocpypl_id) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Fclose(fid_src);
H5Fclose(fid_dst);
H5Tclose(tid);
H5Sclose(sid);
H5Dclose(did);
H5Pclose(ocpypl_id);
}
H5E_END_TRY;
return 1;
} /* end test_copy_cdt_merge_dset_suggs */
/*-------------------------------------------------------------------------
* Function: test_copy_cdt_merge_all_suggs
*
* Purpose: Tests the merging committed datatype + search suggestion feature.
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Vailin Choi; January 2012
*
*-------------------------------------------------------------------------
*/
static int
test_copy_cdt_merge_all_suggs(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl, hbool_t reopen)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t gid = -1; /* Group ID */
hid_t sid = -1; /* Dataspace ID */
hid_t tid = -1; /* Datatype ID */
hid_t aid = -1; /* Attribute ID */
hid_t did = -1; /* Dataset ID */
hid_t exp_did = -1; /* Dataset ID */
hid_t tid_short = -1; /* Datatype ID */
hid_t exp_tid = -1; /* Expected datatype ID */
hid_t ocpypl_id = -1; /* Object copy plist ID */
hsize_t dim1d[1]; /* Dataset dimensions */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
if (reopen)
TESTING("H5Ocopy(): merging different committed datatypes with suggestions and reopen");
else
TESTING("H5Ocopy(): merging different committed datatypes with suggestions");
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/*
* Populate source file
*/
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* set dataspace dimension, create dataspace */
dim1d[0] = DIM_SIZE_1;
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create a group */
if ((gid = H5Gcreate2(fid_src, SRC_GRP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create committed datatype in group */
if ((tid = H5Tcopy(H5T_NATIVE_SHORT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(gid, SRC_NDT_SHORT, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create first dataset in group */
if ((did = H5Dcreate2(gid, SRC_NDT_DSET, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* closing */
if (H5Dclose(did) < 0)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* create committed datatype in group */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(gid, SRC_NDT_INT, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create second dataset in group */
if ((did = H5Dcreate2(gid, SRC_NDT_DSET2, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* closing */
if (H5Dclose(did) < 0)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* create third dataset in group */
if ((did = H5Dcreate2(gid, SRC_DSET, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* get datatype */
if ((tid_short = H5Topen2(fid_src, "/" SRC_GRP "/" SRC_NDT_SHORT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create an attribute attached to the dataset */
if ((aid = H5Acreate2(did, SRC_ATTR, tid_short, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* closing */
if (H5Aclose(aid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
if (H5Tclose(tid_short) < 0)
TEST_ERROR;
/* close the group */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/*
* Populate DST file
*/
/* create DST file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* set dataspace dimension, create dataspace */
dim1d[0] = DIM_SIZE_2;
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/* create committed datatype in root group */
if ((tid = H5Tcopy(H5T_NATIVE_SHORT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_dst, DST_NDT_SHORT, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* create committed datatype in root group */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_dst, DST_NDT_INT, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create an attribute attached to committed datatype */
if ((aid = H5Acreate2(tid, DST_ATTR, tid, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* closing */
if (H5Aclose(aid) < 0)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* create committed datatype in root group */
if ((tid = H5Tcopy(H5T_NATIVE_FLOAT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_dst, DST_NDT_FLOAT, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create an attribute attached to committed datatype */
if ((aid = H5Acreate2(tid, DST_ATTR, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Aclose(aid) < 0)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* create a group */
if ((gid = H5Gcreate2(fid_dst, DST_GRP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create a committed datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(gid, DST_NDT_INT, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create an attribute attached to committed datatype */
if ((aid = H5Acreate2(gid, DST_ATTR, tid, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* closing */
if (H5Aclose(aid) < 0)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* create an attribute attached to group */
if ((aid = H5Acreate2(gid, DST_ATTR2, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* closing */
if (H5Aclose(aid) < 0)
TEST_ERROR;
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* create a group */
if ((gid = H5Gcreate2(fid_dst, DST_GRP2, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create a committed datatype in group */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(gid, DST_NDT_INT, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create an attribute attached to group */
if ((aid = H5Acreate2(gid, DST_ATTR, tid, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* closing */
if (H5Aclose(aid) < 0)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* create a committed datatype in group */
if ((tid = H5Tcopy(H5T_NATIVE_SHORT)) < 0)
TEST_ERROR;
if ((H5Tcommit2(gid, DST_NDT_SHORT, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* closing */
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* create a committed datatype at root group */
if ((tid = H5Tcopy(H5T_NATIVE_DOUBLE)) < 0)
TEST_ERROR;
if ((H5Tcommit2(fid_dst, DST_NDT_DOUBLE, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* get datatype */
if ((tid_short = H5Topen2(fid_dst, "/" DST_GRP2 "/" DST_NDT_SHORT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create an attribute attached to committed datatype */
if ((aid = H5Acreate2(tid, DST_ATTR, tid_short, sid, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* closing */
if (H5Aclose(aid) < 0)
TEST_ERROR;
if (H5Tclose(tid_short) < 0)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Test 1
*/
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* Create ocpl and set merge committed dtype flag */
if ((ocpypl_id = H5Pcreate(H5P_OBJECT_COPY)) < 0)
TEST_ERROR;
if (H5Pset_copy_object(ocpypl_id, H5O_COPY_MERGE_COMMITTED_DTYPE_FLAG) < 0)
TEST_ERROR;
/* copy "/src_grp/src_ndt_dset2" from SRC file to DST file */
if (H5Ocopy(fid_src, "/" SRC_GRP "/" SRC_NDT_DSET2, fid_dst, "A_src_dset2", ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* get datatype for attribute attached to the group */
if ((aid = H5Aopen_by_name(fid_dst, DST_GRP, DST_ATTR, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((exp_tid = H5Aget_type(aid)) < 0)
TEST_ERROR;
/* open datatype of dataset */
if ((did = H5Dopen2(fid_dst, "A_src_dset2", H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
/* should be the same */
if (!H5Tequal(exp_tid, tid))
TEST_ERROR;
/* closing */
if (H5Tclose(exp_tid) < 0)
TEST_ERROR;
if (H5Aclose(aid) < 0)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Test 2
*/
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* add committed datatype search suggestion */
if (H5Padd_merge_committed_dtype_path(ocpypl_id, "/" DST_GRP2) < 0)
TEST_ERROR;
/* copy "/src_grp/src_ndt_dset2" from SRC file to DST file */
if (H5Ocopy(fid_src, "/" SRC_GRP "/" SRC_NDT_DSET2, fid_dst, "B_src_dset2", ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* get datatype for attribute attached to the group */
if ((aid = H5Aopen_by_name(fid_dst, DST_GRP2, DST_ATTR, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((exp_tid = H5Aget_type(aid)) < 0)
TEST_ERROR;
/* open datatype of dataset */
if ((did = H5Dopen2(fid_dst, "B_src_dset2", H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
/* should be the same */
if (!H5Tequal(exp_tid, tid))
TEST_ERROR;
/* closing */
if (H5Tclose(exp_tid) < 0)
TEST_ERROR;
if (H5Aclose(aid) < 0)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Test 3
*/
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* add another committed datatype search suggestion */
if (H5Padd_merge_committed_dtype_path(ocpypl_id, "/" DST_GRP "/" DST_NDT_INT) < 0)
TEST_ERROR;
/* copy "/src_grp/src_ndt_dset2" from SRC file to DST file */
if (H5Ocopy(fid_src, "/" SRC_GRP "/" SRC_NDT_DSET2, fid_dst, "C_src_dset2", ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* open committed dtype "/dst_grp/dst_dt_int", get its token */
if ((exp_tid = H5Topen2(fid_dst, "/" DST_GRP "/" DST_NDT_INT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open datatype of dataset */
if ((did = H5Dopen2(fid_dst, "C_src_dset2", H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
/* should be the same */
if (!H5Tequal(exp_tid, tid))
TEST_ERROR;
/* closing */
if (H5Tclose(exp_tid) < 0)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Test 4
*/
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* delete the group */
if (H5Ldelete(fid_dst, "/" DST_GRP, H5P_DEFAULT) < 0)
TEST_ERROR;
/* free the search suggestion paths */
if (H5Pfree_merge_committed_dtype_paths(ocpypl_id) < 0)
TEST_ERROR;
/* copy "/src_grp/src_ndt_dset2" from SRC file to DST file */
if (H5Ocopy(fid_src, "/" SRC_GRP "/" SRC_NDT_DSET2, fid_dst, "D_src_dset2", ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* open datatype of dataset */
if ((exp_did = H5Dopen2(fid_dst, "A_src_dset2", H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((exp_tid = H5Dget_type(exp_did)) < 0)
TEST_ERROR;
/* Open datatype of dataset */
if ((did = H5Dopen2(fid_dst, "C_src_dset2", H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
/* should be the same */
if (!H5Tequal(exp_tid, tid))
TEST_ERROR;
/* closing */
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* open datatype of dataset */
if ((did = H5Dopen2(fid_dst, "D_src_dset2", H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
/* should be the same */
if (!H5Tequal(exp_tid, tid))
TEST_ERROR;
/* closing */
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* closing */
if (H5Tclose(exp_tid) < 0)
TEST_ERROR;
if (H5Dclose(exp_did) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Test 5
*/
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* Add committed datatype search suggestion */
if (H5Padd_merge_committed_dtype_path(ocpypl_id, "/" DST_NDT_DOUBLE) < 0)
TEST_ERROR;
/* copy "/src_grp/src_ndt_dset" from SRC file to DST file */
if (H5Ocopy(fid_src, "/" SRC_GRP "/" SRC_NDT_DSET, fid_dst, "A_src_dset", ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* open attribute's dtype attached to committed datatype /dst_ndt_double */
if ((aid = H5Aopen_by_name(fid_dst, DST_NDT_DOUBLE, DST_ATTR, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((exp_tid = H5Aget_type(aid)) < 0)
TEST_ERROR;
/* Open datatype of dataset, check token */
if ((did = H5Dopen2(fid_dst, "A_src_dset", H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
/* should be the same */
if (!H5Tequal(exp_tid, tid))
TEST_ERROR;
/* closing */
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
if (H5Aclose(aid) < 0)
TEST_ERROR;
if (H5Tclose(exp_tid) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Test 6
*/
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* Add committed datatype search suggestion */
if (H5Padd_merge_committed_dtype_path(ocpypl_id, "/" DST_NDT_SHORT) < 0)
TEST_ERROR;
/* copy "/src_grp/src_ndt_dset" from SRC file to DST file */
if (H5Ocopy(fid_src, "/" SRC_GRP "/" SRC_NDT_DSET, fid_dst, "B_src_dset", ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* open committed dtype "/dst_ndt_short" */
if ((exp_tid = H5Topen2(fid_dst, "/" DST_NDT_SHORT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* open datatype of dataset, check token */
if ((did = H5Dopen2(fid_dst, "B_src_dset", H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
/* should be the same */
if (!H5Tequal(exp_tid, tid))
TEST_ERROR;
/* closing */
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
if (H5Tclose(exp_tid) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close property list */
if (H5Pclose(ocpypl_id) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Fclose(fid_src);
H5Fclose(fid_dst);
H5Tclose(tid);
H5Tclose(tid_short);
H5Tclose(exp_tid);
H5Dclose(did);
H5Dclose(exp_did);
H5Aclose(aid);
H5Sclose(sid);
H5Pclose(ocpypl_id);
}
H5E_END_TRY;
return 1;
} /* end test_copy_cdt_merge_all_suggs */
/*-------------------------------------------------------------------------
* Function: test_copy_set_mcdt_search_cb
*
* Purpose: Tests the "H5Pset_mcdt_search_cb" feature of H5Ocopy to
* stop or continue the search of global list
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Vailin Choi; January 2012
*
*-------------------------------------------------------------------------
*/
/* User data struct for the callback */
typedef struct mcdt_search_cb_ud {
H5O_mcdt_search_ret_t search_action; /* Return value for callback */
unsigned called; /* # of times callback has been called */
} mcdt_search_cb_ud;
/* The user callback function */
static H5O_mcdt_search_ret_t
mcdt_search_cb(void *_udata)
{
mcdt_search_cb_ud *udata = (mcdt_search_cb_ud *)_udata;
udata->called++;
return (udata->search_action);
} /* mcdt_search_cb() */
static int
test_copy_set_mcdt_search_cb(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl, hbool_t reopen)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1; /* Dataset ID */
hid_t ocpypl_id = -1; /* Object copy plist ID */
unsigned int i; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
int buf[DIM_SIZE_1]; /* Buffer for writing data */
H5O_info2_t oinfo; /* Object info */
H5O_token_t exp_token; /* Expected object token */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
mcdt_search_cb_ud cb_udata; /* User data for callback */
int token_cmp;
if (reopen)
TESTING("H5Ocopy(): H5Pset_mcdt_search_cb and reopen");
else
TESTING("H5Ocopy(): H5Pset_mcdt_search_cb");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
buf[i] = (int)i;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/*
* Populate source file
*/
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* named datatype */
if ((H5Tcommit2(fid_src, NAME_DATATYPE_SIMPLE, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_SIMPLE, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied group in destination file */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/*
* Populate destination file
*/
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* committed datatype "a" */
if ((H5Tcommit2(fid_dst, "/a", tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* committed datatype "b" */
if ((H5Tcommit2(fid_dst, "/b", tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* Create ocpl and set merge committed dtype flag */
if ((ocpypl_id = H5Pcreate(H5P_OBJECT_COPY)) < 0)
TEST_ERROR;
if (H5Pset_copy_object(ocpypl_id, H5O_COPY_MERGE_COMMITTED_DTYPE_FLAG) < 0)
TEST_ERROR;
/*
* First copy dataset using "/b" as a suggestion, and verify that it uses
* datatype "b" in the destination file
*/
/* Add datatype suggestion */
if (H5Padd_merge_committed_dtype_path(ocpypl_id, "/b") < 0)
TEST_ERROR;
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* copy SRC dset to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* Open committed dtype "b", get token */
if ((tid = H5Topen2(fid_dst, "/b", H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* Open dset dtype, check token */
if ((did = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Close destination file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Set callback to continue the search
*/
cb_udata.search_action = H5O_MCDT_SEARCH_CONT;
cb_udata.called = 0;
/* Free suggestions */
if (H5Pfree_merge_committed_dtype_paths(ocpypl_id) < 0)
TEST_ERROR;
/* Add datatype suggestion to group "/uncopied" */
if (H5Padd_merge_committed_dtype_path(ocpypl_id, NAME_GROUP_UNCOPIED) < 0)
TEST_ERROR;
/* Continue the global search */
if (H5Pset_mcdt_search_cb(ocpypl_id, mcdt_search_cb, &cb_udata) < 0)
TEST_ERROR;
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* copy SRC dset to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE2, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
/* Verify callback has been called exactly once */
if (cb_udata.called != 1)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* Open committed dtype "a", get token */
if ((tid = H5Topen2(fid_dst, "/a", H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* Open copied dataset and its dtype, check token */
if ((did = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Close destination file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Stop the search, default action is to create an anonymous committed datatype
*/
cb_udata.search_action = H5O_MCDT_SEARCH_STOP;
cb_udata.called = 0;
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* copy SRC dset to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE3, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
/* Verify callback has been called exactly once */
if (cb_udata.called != 1)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* Open committed dtype "a", get token */
if ((tid = H5Topen2(fid_dst, "/a", H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* Open the copied dataset and get its dtype, tokens should not be equal */
if ((did = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE3, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (!token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Open committed dtype "b", get token */
if ((tid = H5Topen2(fid_dst, "/b", H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* Open the copied dataset and get its dtype, tokens should not be equal */
if ((did = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE3, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (!token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Close destination file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Stop the search, default action is to create an anonymous committed datatype.
* Disable suggestion list.
*/
cb_udata.search_action = H5O_MCDT_SEARCH_STOP;
cb_udata.called = 0;
/* Free suggestions */
if (H5Pfree_merge_committed_dtype_paths(ocpypl_id) < 0)
TEST_ERROR;
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* Delete dataset */
if (H5Ldelete(fid_dst, NAME_DATASET_SIMPLE3, H5P_DEFAULT) < 0)
TEST_ERROR;
/* copy SRC dset to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE3, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
/* Verify callback has been called exactly once */
if (cb_udata.called != 1)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* Open committed dtype "a", get token */
if ((tid = H5Topen2(fid_dst, "/a", H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* Open the copied dataset and get its dtype, tokens should not be equal */
if ((did = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE3, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (!token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Open committed dtype "b", get token */
if ((tid = H5Topen2(fid_dst, "/b", H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
HDmemcpy(&exp_token, &oinfo.token, sizeof(exp_token));
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* Open the copied dataset and get its dtype, tokens should not be equal */
if ((did = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE3, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((tid = H5Dget_type(did)) < 0)
TEST_ERROR;
if (H5Oget_info3(tid, &oinfo, H5O_INFO_BASIC) < 0)
TEST_ERROR;
if (H5Otoken_cmp(tid, &oinfo.token, &exp_token, &token_cmp) < 0)
TEST_ERROR;
if (!token_cmp)
TEST_ERROR;
if (H5Tclose(tid) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* Close destination file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close property list */
if (H5Pclose(ocpypl_id) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Fclose(fid_src);
H5Fclose(fid_dst);
H5Tclose(tid);
H5Sclose(sid);
H5Dclose(did);
H5Pclose(ocpypl_id);
}
H5E_END_TRY;
return 1;
} /* end test_copy_set_mcdt_search_cb */
/*-------------------------------------------------------------------------
* Function: test_copy_set_get_mcdt_cb
*
* Purpose: Tests for the "H5Pset/get_mcdt_search_cb" feature of H5Ocopy.
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Vailin Choi; January 2012
*
*-------------------------------------------------------------------------
*/
/* The user callback functions */
static H5O_mcdt_search_ret_t
mcdt_search_cbA(void *_udata)
{
H5O_mcdt_search_ret_t *action = (H5O_mcdt_search_ret_t *)_udata;
return (*action);
} /* mcdt_search_cb() */
static H5O_mcdt_search_ret_t
mcdt_search_cbB(void *_udata)
{
H5O_mcdt_search_ret_t *action = (H5O_mcdt_search_ret_t *)_udata;
return (*action);
} /* mnt_search_cb() */
/* The main test function */
static int
test_copy_set_get_mcdt_search_cb(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl,
hbool_t reopen)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t tid = -1; /* Datatype ID */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1; /* Dataset ID */
hid_t ocpypl_id = -1; /* Object copy plist ID */
unsigned int i; /* Local index variables */
hsize_t dim1d[1]; /* Dataset dimensions */
int buf[DIM_SIZE_1]; /* Buffer for writing data */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
H5O_mcdt_search_cb_t mcdt_cb = NULL; /* The callback function */
H5O_mcdt_search_ret_t mcdt_udataA; /* User data for callback */
H5O_mcdt_search_ret_t mcdt_udataB; /* User data for callback */
H5O_mcdt_search_ret_t *mcdt_udata_p = NULL; /* Pointer to user data for callback */
if (reopen)
TESTING("H5Ocopy(): H5Pset/get_mcdt_search_cb and reopen");
else
TESTING("H5Ocopy(): H5Pset/get_mcdt_search_cb");
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
buf[i] = (int)i;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim1d[0] = DIM_SIZE_1;
/* create dataspace */
if ((sid = H5Screate_simple(1, dim1d, NULL)) < 0)
TEST_ERROR;
/*
* Populate source file
*/
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* committed datatype */
if ((H5Tcommit2(fid_src, NAME_DATATYPE_SIMPLE, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create dataset at SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_SIMPLE, tid, sid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data into file */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied group in destination file */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/*
* Populate destination file
*/
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* committed datatype "a" */
if ((H5Tcommit2(fid_dst, "/a", tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* create datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* committed datatype "b" */
if ((H5Tcommit2(fid_dst, "/b", tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* open the source file with read-only */
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* Create ocpl and set merge committed dtype flag */
if ((ocpypl_id = H5Pcreate(H5P_OBJECT_COPY)) < 0)
TEST_ERROR;
if (H5Pset_copy_object(ocpypl_id, H5O_COPY_MERGE_COMMITTED_DTYPE_FLAG) < 0)
TEST_ERROR;
/*
* First copy dataset using "/b" as a suggestion, and verify that it uses
* datatype "b" in the destination file
*/
/* Add datatype suggestion */
if (H5Padd_merge_committed_dtype_path(ocpypl_id, "/b") < 0)
TEST_ERROR;
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* copy SRC dset to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
/* Verify "get" routine functionality */
if (H5Pget_mcdt_search_cb(ocpypl_id, &mcdt_cb, (void **)&mcdt_udata_p) < 0)
TEST_ERROR;
if (mcdt_cb != NULL)
TEST_ERROR;
if (mcdt_udata_p != NULL)
TEST_ERROR;
/* Close destination file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Set callback to continue the search
*/
mcdt_udataA = H5O_MCDT_SEARCH_CONT;
/* Free suggestions */
if (H5Pfree_merge_committed_dtype_paths(ocpypl_id) < 0)
TEST_ERROR;
/* Add datatype suggestion to group "/uncopied" */
if (H5Padd_merge_committed_dtype_path(ocpypl_id, NAME_GROUP_UNCOPIED) < 0)
TEST_ERROR;
/* Continue the global search */
if (H5Pset_mcdt_search_cb(ocpypl_id, mcdt_search_cbA, &mcdt_udataA) < 0)
TEST_ERROR;
/* open the destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* copy SRC dset to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE2, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
mcdt_cb = NULL;
mcdt_udata_p = NULL;
/* Verify "get" routine functionality */
if (H5Pget_mcdt_search_cb(ocpypl_id, &mcdt_cb, (void **)&mcdt_udata_p) < 0)
TEST_ERROR;
if (mcdt_cb != mcdt_search_cbA)
TEST_ERROR;
if (mcdt_udata_p != &mcdt_udataA)
TEST_ERROR;
/* Close destination file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/*
* Stop the search, default action is to create an anonymous committed datatype
*/
mcdt_udataB = H5O_MCDT_SEARCH_STOP;
if (H5Pset_mcdt_search_cb(ocpypl_id, mcdt_search_cbA, &mcdt_udataB) < 0)
TEST_ERROR;
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* copy SRC dset to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE3, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
mcdt_cb = NULL;
mcdt_udata_p = NULL;
/* Verify "get" routine functionality */
if (H5Pget_mcdt_search_cb(ocpypl_id, &mcdt_cb, (void **)&mcdt_udata_p) < 0)
TEST_ERROR;
if (mcdt_cb != mcdt_search_cbA)
TEST_ERROR;
if (mcdt_udata_p != &mcdt_udataB)
TEST_ERROR;
/* Close destination file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* Free suggestions */
if (H5Pfree_merge_committed_dtype_paths(ocpypl_id) < 0)
TEST_ERROR;
if (H5Pset_mcdt_search_cb(ocpypl_id, mcdt_search_cbB, &mcdt_udataB) < 0)
TEST_ERROR;
/* open destination file */
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* Delete dataset */
if (H5Ldelete(fid_dst, NAME_DATASET_SIMPLE3, H5P_DEFAULT) < 0)
TEST_ERROR;
/* copy SRC dset to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE3, ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (reopen) {
/* Reopen file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
if ((fid_dst = H5Fopen(dst_filename, H5F_ACC_RDONLY, dst_fapl)) < 0)
TEST_ERROR;
} /* end if */
mcdt_cb = NULL;
mcdt_udata_p = NULL;
/* Verify "get" routine functionality */
if (H5Pget_mcdt_search_cb(ocpypl_id, &mcdt_cb, (void **)&mcdt_udata_p) < 0)
TEST_ERROR;
if (mcdt_cb != mcdt_search_cbB)
TEST_ERROR;
if (mcdt_udata_p != &mcdt_udataB)
TEST_ERROR;
/* Close destination file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close property list */
if (H5Pclose(ocpypl_id) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Fclose(fid_src);
H5Fclose(fid_dst);
H5Tclose(tid);
H5Sclose(sid);
H5Dclose(did);
H5Pclose(ocpypl_id);
}
H5E_END_TRY;
return 1;
} /* end test_copy_set_get_mcdt_search_cb */
/*-------------------------------------------------------------------------
* Function: test_copy_iterate
*
* Purpose: Tests iterating over objects in the root group, copying
* all of them.
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Neil Fortner
* Thursday, July 12, 2012
*
*-------------------------------------------------------------------------
*/
static herr_t
test_copy_iterate_cb(hid_t loc_id, const char *name, const H5L_info2_t H5_ATTR_UNUSED *link_info,
void *op_data)
{
hid_t dst_loc_id = *((hid_t *)op_data);
if (H5Ocopy(loc_id, name, dst_loc_id, name, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
return (H5_ITER_CONT);
error:
return (H5_ITER_ERROR);
} /* end test_copy_iterate_cb */
/*
* Test for a bug with copying of v1 object headers where the
* new object header would end up with a gap in the header data,
* which v1 object header shouldn't have.
*/
static int
test_copy_cdt_v1_header_bug(hid_t fcpl_src, hid_t src_fapl)
{
hid_t file_id = H5I_INVALID_HID;
hid_t type_id = H5I_INVALID_HID;
hid_t ocpypl_id = H5I_INVALID_HID;
char src_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): bug with copying v1 object headers");
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
if ((file_id = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
if ((type_id = H5Tcreate(H5T_STRING, 385)) < 0)
TEST_ERROR;
if (H5Tset_strpad(type_id, H5T_STR_NULLPAD) < 0)
TEST_ERROR;
if (H5Tset_cset(type_id, H5T_CSET_ASCII) < 0)
TEST_ERROR;
if (H5Tcommit2(file_id, "committed_str_type", type_id, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if ((ocpypl_id = H5Pcreate(H5P_OBJECT_COPY)) < 0)
TEST_ERROR;
if (H5Pset_copy_object(ocpypl_id, H5O_COPY_WITHOUT_ATTR_FLAG) < 0)
TEST_ERROR;
if (H5Ocopy(file_id, "committed_str_type", file_id, "committed_str_type2", ocpypl_id, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Tclose(type_id) < 0)
TEST_ERROR;
if (H5Pclose(ocpypl_id) < 0)
TEST_ERROR;
if (H5Fclose(file_id) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Tclose(type_id);
H5Pclose(ocpypl_id);
H5Fclose(file_id);
}
H5E_END_TRY;
return 1;
}
static int
test_copy_iterate(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid1 = -1, fid2 = -1; /* File IDs */
hid_t gid = -1; /* Group ID */
int i;
char grp_name[16];
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): inside H5Literate() callback");
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], src_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* Create source file */
if ((fid1 = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* Create groups */
for (i = 0; i < 9; i++) {
HDsnprintf(grp_name, sizeof(grp_name), "grp%d", i);
if ((gid = H5Gcreate2(fid1, grp_name, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Gclose(gid) < 0)
TEST_ERROR;
} /* end for */
/* Create destination file */
if ((fid2 = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Close files */
if (H5Fclose(fid1) < 0)
TEST_ERROR;
if (H5Fclose(fid2) < 0)
TEST_ERROR;
/* Reopen files */
if ((fid1 = H5Fopen(src_filename, H5F_ACC_RDWR, src_fapl)) < 0)
TEST_ERROR;
if ((fid2 = H5Fopen(dst_filename, H5F_ACC_RDWR, dst_fapl)) < 0)
TEST_ERROR;
/* Iterate over links in the root group, copying each object */
if ((gid = H5Gopen2(fid1, "/", H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Literate2(gid, H5_INDEX_NAME, H5_ITER_INC, NULL, test_copy_iterate_cb, &fid2) < 0)
TEST_ERROR;
/* Close */
if (H5Gclose(gid) < 0)
TEST_ERROR;
if (H5Fclose(fid1) < 0)
TEST_ERROR;
if (H5Fclose(fid2) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Gclose(gid);
H5Fclose(fid1);
H5Fclose(fid2);
}
H5E_END_TRY;
return 1;
} /* end test_copy_iterate */
/*-------------------------------------------------------------------------
* Function: test_copy_option
*
* Purpose: Create a group in SRC file and copy it to DST file
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Peter Cao
* March 11, 2006
*
*-------------------------------------------------------------------------
*/
static int
test_copy_option(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl, unsigned flag,
hbool_t crt_intermediate_grp, const char *test_desciption)
{
hid_t fid_src = -1, fid_dst = -1, fid_ext = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t did = -1; /* Dataset ID */
hid_t gid = -1, gid2 = -1, gid_ref = -1; /* Group IDs */
hid_t gid_sub = -1, gid_sub_sub = -1; /* Sub-group ID */
hid_t pid = -1, lcpl_id = -1; /* Property IDs */
unsigned cpy_flags; /* Object copy flags */
int depth = -1; /* Copy depth */
hsize_t dim2d[2];
int buf[DIM_SIZE_1][DIM_SIZE_2];
int i, j;
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING(test_desciption);
/* set initial data values */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
buf[i][j] = 10000 + 100 * i + j;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create group at the SRC file */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* attach attributes to the group */
if (test_copy_attach_attributes(gid, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* add a dataset to the top group */
if ((did = H5Dcreate2(gid, NAME_DATASET_SIMPLE, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* create a sub-group */
if ((gid_sub = H5Gcreate2(fid_src, NAME_GROUP_SUB, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* add a dataset to the sub group */
if ((did = H5Dcreate2(gid_sub, NAME_DATASET_SIMPLE, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
/* create sub-sub-group */
if ((gid_sub_sub = H5Gcreate2(gid_sub, NAME_GROUP_SUB_SUB2, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* add a dataset to the sub sub group */
if ((did = H5Dcreate2(gid_sub_sub, NAME_DATASET_SIMPLE, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* close dataset */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
if (H5Gclose(gid_sub_sub) < 0)
TEST_ERROR;
if (H5Gclose(gid_sub) < 0)
TEST_ERROR;
/* close the group */
if (H5Gclose(gid) < 0)
FAIL_STACK_ERROR;
if ((flag & H5O_COPY_EXPAND_SOFT_LINK_FLAG) > 0) {
/* Create group to copy */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_LINK, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
if (H5Lcreate_soft(NAME_DATASET_SUB_SUB, fid_src, NAME_LINK_SOFT, H5P_DEFAULT, H5P_DEFAULT) < 0)
FAIL_STACK_ERROR;
if (H5Lcreate_soft("nowhere", fid_src, NAME_LINK_SOFT_DANGLE, H5P_DEFAULT, H5P_DEFAULT) < 0)
FAIL_STACK_ERROR;
if (H5Gclose(gid) < 0)
FAIL_STACK_ERROR;
/* Create group to compare with */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_LINK2, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
if (H5Lcreate_hard(fid_src, NAME_DATASET_SUB_SUB, H5L_SAME_LOC, NAME_LINK_SOFT2, H5P_DEFAULT,
H5P_DEFAULT) < 0)
FAIL_STACK_ERROR;
if (H5Lcreate_soft("nowhere", fid_src, NAME_LINK_SOFT_DANGLE2, H5P_DEFAULT, H5P_DEFAULT) < 0)
FAIL_STACK_ERROR;
if (H5Gclose(gid) < 0)
FAIL_STACK_ERROR;
} /* end if */
if ((flag & H5O_COPY_EXPAND_EXT_LINK_FLAG) > 0) {
char ext_filename[NAME_BUF_SIZE];
h5_fixname(FILENAME[2], src_fapl, ext_filename, sizeof ext_filename);
/* Create the external file and dataset */
if ((fid_ext = H5Fcreate(ext_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
if ((did = H5Dcreate2(fid_ext, NAME_DATASET_SIMPLE, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
if (H5Fclose(fid_ext) < 0)
TEST_ERROR;
/* Create group to copy */
if (!(flag & H5O_COPY_EXPAND_SOFT_LINK_FLAG)) {
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_LINK, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
} /* end if */
else if ((gid = H5Gopen2(fid_src, NAME_GROUP_LINK, H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Lcreate_external(ext_filename, NAME_DATASET_SIMPLE, fid_src, NAME_LINK_EXTERN, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Lcreate_external("no_file", "no_object", fid_src, NAME_LINK_EXTERN_DANGLE, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* Create group to compare with */
if (!(flag & H5O_COPY_EXPAND_SOFT_LINK_FLAG)) {
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_LINK2, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
} /* end if */
else if ((gid = H5Gopen2(fid_src, NAME_GROUP_LINK2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((did = H5Dcreate2(fid_src, NAME_LINK_EXTERN2, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
if (H5Lcreate_external("no_file", "no_object", fid_src, NAME_LINK_EXTERN_DANGLE2, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Dclose(did) < 0)
TEST_ERROR;
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* Close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
} /* end if */
if ((flag & H5O_COPY_EXPAND_REFERENCE_FLAG) > 0) {
if ((gid_ref = H5Gcreate2(fid_src, NAME_GROUP_REF, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create an attribute of object references */
if (attach_ref_attr(fid_src, gid_ref) < 0)
TEST_ERROR;
/* create an attribute of region references */
if (attach_reg_ref_attr(fid_src, gid_ref) < 0)
TEST_ERROR;
/* create a dataset of region references */
if (create_reg_ref_dataset(fid_src, gid_ref) < 0)
TEST_ERROR;
/* Close group holding reference objects */
if (H5Gclose(gid_ref) < 0)
TEST_ERROR;
} /* end if */
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* open the source file with read-only */
/* (except when expanding soft links */
if ((flag & H5O_COPY_EXPAND_SOFT_LINK_FLAG) > 0) {
if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDWR, src_fapl)) < 0)
TEST_ERROR;
} /* end if */
else if ((fid_src = H5Fopen(src_filename, H5F_ACC_RDONLY, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination
files aren't the same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create property to pass copy options */
if ((pid = H5Pcreate(H5P_OBJECT_COPY)) < 0)
TEST_ERROR;
/* set options for object copy */
if (H5Pset_copy_object(pid, flag) < 0)
TEST_ERROR;
/* Verify object copy flags */
if (H5Pget_copy_object(pid, &cpy_flags) < 0)
TEST_ERROR;
if (cpy_flags != flag)
TEST_ERROR;
/* copy the group from SRC to DST */
if (crt_intermediate_grp) {
/* Create link creation plist to pass in intermediate group creation */
if ((lcpl_id = H5Pcreate(H5P_LINK_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_create_intermediate_group(lcpl_id, TRUE) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_GROUP_TOP, fid_dst, "/new_g0/new_g00", pid, lcpl_id) < 0)
TEST_ERROR;
if (H5Pclose(lcpl_id) < 0)
TEST_ERROR;
/* open the group for copy */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination group */
if ((gid2 = H5Gopen2(fid_dst, "/new_g0/new_g00", H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
}
else if (((flag & H5O_COPY_EXPAND_SOFT_LINK_FLAG) > 0) || ((flag & H5O_COPY_EXPAND_EXT_LINK_FLAG) > 0)) {
if (H5Ocopy(fid_src, NAME_GROUP_LINK, fid_dst, NAME_GROUP_LINK, pid, H5P_DEFAULT) < 0)
TEST_ERROR;
if ((flag & H5O_COPY_EXPAND_SOFT_LINK_FLAG) > 0)
/* Unlink dataset to copy from original location */
/* (So group comparison works properly) */
if (H5Ldelete(fid_src, NAME_DATASET_SUB_SUB, H5P_DEFAULT) < 0)
FAIL_STACK_ERROR;
/* open the group for copy */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_LINK2, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination group */
if ((gid2 = H5Gopen2(fid_dst, NAME_GROUP_LINK, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
}
else if (flag & (H5O_COPY_WITHOUT_ATTR_FLAG | H5O_COPY_PRESERVE_NULL_FLAG)) {
if (H5Ocopy(fid_src, NAME_GROUP_TOP, fid_dst, NAME_GROUP_TOP, pid, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the group for copy */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination group */
if ((gid2 = H5Gopen2(fid_dst, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
}
else if (flag & H5O_COPY_SHALLOW_HIERARCHY_FLAG) {
if (H5Ocopy(fid_src, NAME_GROUP_TOP, fid_dst, NAME_GROUP_TOP, pid, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the group for copy */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination group */
if ((gid2 = H5Gopen2(fid_dst, NAME_GROUP_TOP, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* Set the copy depth */
depth = 1;
}
else if ((flag & H5O_COPY_EXPAND_REFERENCE_FLAG) > 0) {
if (H5Ocopy(fid_src, NAME_GROUP_REF, fid_dst, NAME_GROUP_REF, pid, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the group for copy */
if ((gid = H5Gopen2(fid_src, NAME_GROUP_REF, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
/* open the destination group */
if ((gid2 = H5Gopen2(fid_dst, NAME_GROUP_REF, H5P_DEFAULT)) < 0)
FAIL_STACK_ERROR;
}
else {
/* Unknown flag */
TEST_ERROR;
} /* end else */
/* Check if the groups are equal */
if (compare_groups(gid, gid2, pid, depth, flag) != TRUE)
TEST_ERROR;
if (H5Gclose(gid2) < 0)
TEST_ERROR;
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
/* close properties */
if (H5Pclose(pid) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Pclose(lcpl_id);
H5Pclose(pid);
H5Sclose(sid);
H5Dclose(did);
H5Gclose(gid_ref);
H5Gclose(gid_sub);
H5Gclose(gid2);
H5Gclose(gid);
H5Fclose(fid_dst);
H5Fclose(fid_src);
H5Fclose(fid_ext);
}
H5E_END_TRY;
return 1;
} /* end test_copy_option */
/*-------------------------------------------------------------------------
* Function: test_copy_dataset_open
*
* Purpose: To ensure that H5Ocopy() copies data of opened dataset correctly.
* This is for bug fix HDFFV-7853.
*
* Test Case 1:
* Create a dataset with attributes in SRC file
* Copy the opened dataset to another location in the same file
* Copy the opened dataset to DST file
* Close the dataset
*
* Test Case 2:
* Reopen the dataset, write new data to the dataset
* Copy the opened dataset to another location in the same file
* Copy the opened dataset to to DST file
* Close the dataset
*
* Test Case 3:
* Create a committed datatype
* Create a dataset with the committed datatype in SRC file
* Open the committed datatype
* Copy the opened dataset (with the opened committed datatype) to another location in the same file
* Copy the opened dataset (with the opened committed datatype) to DST file
* Close the dataset and the committed datatype
*
* Test Case 4:
* Create a group with attributes, create a dataset in the group
* Copy the opened group (together with the opened dataset) to another location in the same file
* Copy the opened group (together with the opened dataset) to DST file
* Close the group and the dataset
*
* Return: Success: 0
* Failure: number of errors
*
* Programmer: Vailin Choi
* Feb 7, 2012
*
*-------------------------------------------------------------------------
*/
static int
test_copy_dataset_open(hid_t fcpl_src, hid_t fcpl_dst, hid_t src_fapl, hid_t dst_fapl)
{
hid_t fid_src = -1, fid_dst = -1; /* File IDs */
hid_t sid = -1; /* Dataspace ID */
hid_t tid = -1; /* Datatype ID */
hid_t did = -1, did2 = -1; /* Dataset IDs */
hid_t did3 = -1, did4 = -1; /* Dataset IDs */
hid_t gid = -1, gid2 = -1; /* Group IDs */
hid_t pid = -1; /* Dataset creation property list */
hsize_t chunk_dim2d[2] = {CHUNK_SIZE_1, CHUNK_SIZE_2}; /* Chunk dimension sizes */
int buf[DIM_SIZE_1][DIM_SIZE_2]; /* Buffer for writing data */
int newbuf[DIM_SIZE_1][DIM_SIZE_2]; /* Buffer for writing data */
hsize_t dim2d[2]; /* Dataset dimensions */
int i, j; /* local index variables */
char src_filename[NAME_BUF_SIZE];
char dst_filename[NAME_BUF_SIZE];
TESTING("H5Ocopy(): copying objects while opened");
/* Initialize write buffer */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
buf[i][j] = 10000 + 100 * i + j;
/* Initialize another write buffer */
for (i = 0; i < DIM_SIZE_1; i++)
for (j = 0; j < DIM_SIZE_2; j++)
newbuf[i][j] = 100 * i + j;
/* Initialize the filenames */
h5_fixname(FILENAME[0], src_fapl, src_filename, sizeof src_filename);
h5_fixname(FILENAME[1], dst_fapl, dst_filename, sizeof dst_filename);
/* Reset file token checking info */
token_reset();
/* create source file */
if ((fid_src = H5Fcreate(src_filename, H5F_ACC_TRUNC, fcpl_src, src_fapl)) < 0)
TEST_ERROR;
/* create destination file */
if ((fid_dst = H5Fcreate(dst_filename, H5F_ACC_TRUNC, fcpl_dst, dst_fapl)) < 0)
TEST_ERROR;
/* Create an uncopied object in destination file so that tokens in source and destination files aren't the
* same */
if (H5Gclose(H5Gcreate2(fid_dst, NAME_GROUP_UNCOPIED, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Set dataspace dimensions */
dim2d[0] = DIM_SIZE_1;
dim2d[1] = DIM_SIZE_2;
/* create 2D dataspace */
if ((sid = H5Screate_simple(2, dim2d, NULL)) < 0)
TEST_ERROR;
/* create and set chunk plist */
if ((pid = H5Pcreate(H5P_DATASET_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_chunk(pid, 2, chunk_dim2d) < 0)
TEST_ERROR;
/* create 2D dataset in SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_SIMPLE, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* create 2D chunked dataset in SRC file */
if ((did2 = H5Dcreate2(fid_src, NAME_DATASET_CHUNKED, H5T_NATIVE_INT, sid, H5P_DEFAULT, pid,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data to the dataset */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
if (H5Dwrite(did2, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/* attach attributes to the dataset */
if (test_copy_attach_attributes(did, H5T_NATIVE_INT) < 0)
TEST_ERROR;
if (test_copy_attach_attributes(did2, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/*
* Test case 1
*/
/*
* Copy within the same file
*/
/* copy the opened dataset to another location in SRC file */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_src, NAME_DATASET_SIMPLE2, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED, fid_src, NAME_DATASET_CHUNKED2, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the copied dataset */
if ((did3 = H5Dopen2(fid_src, NAME_DATASET_SIMPLE2, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((did4 = H5Dopen2(fid_src, NAME_DATASET_CHUNKED2, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did3, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
if (compare_datasets(did2, did4, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the copied dataset */
if (H5Dclose(did3) < 0)
TEST_ERROR;
if (H5Dclose(did4) < 0)
TEST_ERROR;
/*
* Copy to another file
*/
/* copy the opened dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED, fid_dst, NAME_DATASET_CHUNKED, H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the copied dataset in DST file */
if ((did3 = H5Dopen2(fid_dst, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((did4 = H5Dopen2(fid_dst, NAME_DATASET_CHUNKED, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did3, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
if (compare_datasets(did2, did4, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the copied dataset in DST file */
if (H5Dclose(did3) < 0)
TEST_ERROR;
if (H5Dclose(did4) < 0)
TEST_ERROR;
/* close the dataset in SRC file */
if (H5Dclose(did) < 0)
TEST_ERROR;
if (H5Dclose(did2) < 0)
TEST_ERROR;
/*
* Test case 2
*/
/* reopen the dataset in SRC file */
if ((did = H5Dopen2(fid_src, NAME_DATASET_SIMPLE, H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((did2 = H5Dopen2(fid_src, NAME_DATASET_CHUNKED, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write another set of data to the dataset */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, newbuf) < 0)
TEST_ERROR;
if (H5Dwrite(did2, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, newbuf) < 0)
TEST_ERROR;
/*
* Copy within the same file
*/
/* copy the opened dataset to another location in SRC file */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_src, "NEW_DATASET_SIMPLE", H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED, fid_src, "NEW_DATASET_CHUNKED", H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the copied dataset */
if ((did3 = H5Dopen2(fid_src, "NEW_DATASET_SIMPLE", H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((did4 = H5Dopen2(fid_src, "NEW_DATASET_CHUNKED", H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did3, H5P_DEFAULT, newbuf) != TRUE)
TEST_ERROR;
if (compare_datasets(did2, did4, H5P_DEFAULT, newbuf) != TRUE)
TEST_ERROR;
/* close the copied dataset in SRC file */
if (H5Dclose(did3) < 0)
TEST_ERROR;
if (H5Dclose(did4) < 0)
TEST_ERROR;
/*
* Copy to another file
*/
/* copy the opened dataset from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_SIMPLE, fid_dst, "NEW_DATASET_SIMPLE", H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
if (H5Ocopy(fid_src, NAME_DATASET_CHUNKED, fid_dst, "NEW_DATASET_CHUNKED", H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the copied dataset in DST file */
if ((did3 = H5Dopen2(fid_dst, "NEW_DATASET_SIMPLE", H5P_DEFAULT)) < 0)
TEST_ERROR;
if ((did4 = H5Dopen2(fid_dst, "NEW_DATASET_CHUNKED", H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did3, H5P_DEFAULT, newbuf) != TRUE)
TEST_ERROR;
if (compare_datasets(did2, did4, H5P_DEFAULT, newbuf) != TRUE)
TEST_ERROR;
/* close the copied dataset in DST file */
if (H5Dclose(did3) < 0)
TEST_ERROR;
if (H5Dclose(did4) < 0)
TEST_ERROR;
/* close the dataset at SRC file */
if (H5Dclose(did) < 0)
TEST_ERROR;
if (H5Dclose(did2) < 0)
TEST_ERROR;
/*
* Test case 3
*/
/* make a copy of the datatype */
if ((tid = H5Tcopy(H5T_NATIVE_INT)) < 0)
TEST_ERROR;
/* commit the datatype */
if ((H5Tcommit2(fid_src, NAME_DATATYPE_SIMPLE, tid, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* close the datatype */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/* open the committed datatype */
tid = H5Topen2(fid_src, NAME_DATATYPE_SIMPLE, H5P_DEFAULT);
/* create 2D dataset with the opened committed datatype in SRC file */
if ((did = H5Dcreate2(fid_src, NAME_DATASET_NAMED_DTYPE, tid, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data to the dataset */
if (H5Dwrite(did, tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/*
* Copy within the same file
*/
/* copy the opened dataset (with the opened committed datatype) to another location in SRC file */
if (H5Ocopy(fid_src, NAME_DATASET_NAMED_DTYPE, fid_src, NAME_DATASET_NAMED_DTYPE2, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the copied dataset */
if ((did2 = H5Dopen2(fid_src, NAME_DATASET_NAMED_DTYPE2, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the copied dataset in SRC file */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/*
* Copy to another file
*/
/* copy the opened dataset (with the opened committed datatype) from SRC to DST */
if (H5Ocopy(fid_src, NAME_DATASET_NAMED_DTYPE, fid_dst, NAME_DATASET_NAMED_DTYPE2, H5P_DEFAULT,
H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the copied dataset in DST file */
if ((did2 = H5Dopen2(fid_dst, NAME_DATASET_NAMED_DTYPE2, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the datasets are equal */
if (compare_datasets(did, did2, H5P_DEFAULT, buf) != TRUE)
TEST_ERROR;
/* close the copied dataset in DST file */
if (H5Dclose(did2) < 0)
TEST_ERROR;
/* close the dataset at SRC file */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close the committed datatype at SRC file */
if (H5Tclose(tid) < 0)
TEST_ERROR;
/*
* Test case 4
*/
/* create a group in SRC file */
if ((gid = H5Gcreate2(fid_src, NAME_GROUP_TOP, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0)
TEST_ERROR;
/* attach attributes to the group */
if (test_copy_attach_attributes(gid, H5T_NATIVE_INT) < 0)
TEST_ERROR;
/* create 2D int dataset in the group at SRC file */
if ((did = H5Dcreate2(gid, NAME_DATASET_SIMPLE, H5T_NATIVE_INT, sid, H5P_DEFAULT, H5P_DEFAULT,
H5P_DEFAULT)) < 0)
TEST_ERROR;
/* write data to the dataset */
if (H5Dwrite(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) < 0)
TEST_ERROR;
/*
* Copy within the same file
*/
/* copy the opened group (together with opened dataset) to another location in SRC file */
if (H5Ocopy(fid_src, NAME_GROUP_TOP, fid_src, "COPIED_GROUP", H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the copied group at SRC */
if ((gid2 = H5Gopen2(fid_src, "COPIED_GROUP", H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the groups are equal */
if (compare_groups(gid, gid2, H5P_DEFAULT, -1, 0) != TRUE)
TEST_ERROR;
/* close the DST dataset */
if (H5Gclose(gid2) < 0)
TEST_ERROR;
/*
* Copy to another file
*/
/* copy the opened group (together with opened dataset) to DST file */
if (H5Ocopy(fid_src, NAME_GROUP_TOP, fid_dst, "COPIED_GROUP", H5P_DEFAULT, H5P_DEFAULT) < 0)
TEST_ERROR;
/* open the copied group at DST */
if ((gid2 = H5Gopen2(fid_dst, "COPIED_GROUP", H5P_DEFAULT)) < 0)
TEST_ERROR;
/* Check if the groups are equal */
if (compare_groups(gid, gid2, H5P_DEFAULT, -1, 0) != TRUE)
TEST_ERROR;
/* close the group in DST file */
if (H5Gclose(gid2) < 0)
TEST_ERROR;
/* close the group in SRC file */
if (H5Gclose(gid) < 0)
TEST_ERROR;
/* close the dataset in SRC file */
if (H5Dclose(did) < 0)
TEST_ERROR;
/* close dataspace */
if (H5Sclose(sid) < 0)
TEST_ERROR;
/* close the SRC file */
if (H5Fclose(fid_src) < 0)
TEST_ERROR;
/* close the DST file */
if (H5Fclose(fid_dst) < 0)
TEST_ERROR;
PASSED();
return 0;
error:
H5E_BEGIN_TRY
{
H5Dclose(did);
H5Dclose(did2);
H5Sclose(sid);
H5Gclose(gid);
H5Gclose(gid2);
H5Fclose(fid_dst);
H5Fclose(fid_src);
}
H5E_END_TRY;
return 1;
} /* end test_copy_dataset_open */
/*-------------------------------------------------------------------------
* Function: main
*
* Purpose: Test H5Ocopy()
*
* Tests a number of cases: messages can be stored in the
* new or old format, messages can be shared in either,
* both, or neither of the source and destination files.
*
* Return: EXIT_SUCCESS/EXIT_FAILURE
*
* Programmer: Peter Cao
* Friday, September 30, 2005
*
*-------------------------------------------------------------------------
*/
int
main(void)
{
int nerrors = 0;
hid_t fapl, fapl2;
hid_t fcpl_shared, ocpl;
unsigned max_compact, min_dense;
int configuration; /* Configuration of tests. */
int ExpressMode;
const char *env_h5_drvr; /* File Driver value from environment */
hbool_t same_file; /* Whether to run tests that only use one file */
hbool_t driver_is_default_compatible;
env_h5_drvr = HDgetenv(HDF5_DRIVER);
if (env_h5_drvr == NULL)
env_h5_drvr = "nomatch";
/* Setup */
h5_reset();
fapl = h5_fileaccess();
if (h5_driver_is_default_vfd_compatible(fapl, &driver_is_default_compatible) < 0)
TEST_ERROR;
ExpressMode = GetTestExpress();
if (ExpressMode > 1)
HDprintf("***Express test mode on. Some tests may be skipped\n");
/* Copy the file access property list */
if ((fapl2 = H5Pcopy(fapl)) < 0)
TEST_ERROR;
/* Set the "use the latest version of the format" bounds for creating objects in the file */
if (H5Pset_libver_bounds(fapl2, H5F_LIBVER_LATEST, H5F_LIBVER_LATEST) < 0)
TEST_ERROR;
/* Create an FCPL with sharing enabled */
if ((fcpl_shared = H5Pcreate(H5P_FILE_CREATE)) < 0)
TEST_ERROR;
if (H5Pset_shared_mesg_nindexes(fcpl_shared, 1) < 0)
TEST_ERROR;
if (H5Pset_shared_mesg_index(fcpl_shared, 0, H5O_SHMESG_ALL_FLAG, 10) < 0)
TEST_ERROR;
/* Obtain the default attribute storage phase change values */
if ((ocpl = H5Pcreate(H5P_OBJECT_CREATE)) < 0)
TEST_ERROR;
if (H5Pget_attr_phase_change(ocpl, &max_compact, &min_dense) < 0)
TEST_ERROR;
if (H5Pclose(ocpl) < 0)
TEST_ERROR;
/* Test in all configurations */
for (configuration = 0; configuration <= MAX_CONFIGURATION; configuration++) {
hid_t src_fapl;
hid_t dst_fapl;
hid_t fcpl_src;
hid_t fcpl_dst;
/* Start with same_file == TRUE. Use source file settings for these
* tests. Don't run with a non-default destination file setting, as
* destination settings have no effect. */
same_file = TRUE;
/* No need to test dense attributes with old format */
if (!(configuration & CONFIG_SRC_NEW_FORMAT) && (configuration & CONFIG_DENSE))
continue;
/* Test with and without shared messages */
if (configuration & CONFIG_SHARE_SRC) {
HDputs("\nTesting with shared src messages:");
fcpl_src = fcpl_shared;
}
else {
HDputs("\nTesting without shared src messages:");
fcpl_src = H5P_DEFAULT;
}
if (configuration & CONFIG_SHARE_DST) {
HDputs("Testing with shared dst messages:");
fcpl_dst = fcpl_shared;
same_file = FALSE;
}
else {
HDputs("Testing without shared dst messages:");
fcpl_dst = H5P_DEFAULT;
}
/* Set the FAPL for the source file's type of format */
if (configuration & CONFIG_SRC_NEW_FORMAT) {
HDputs("Testing with latest format for source file:");
src_fapl = fapl2;
/* Test with and without dense attributes */
if (configuration & CONFIG_DENSE) {
HDputs("Testing with dense attributes:");
num_attributes_g = max_compact + 1;
}
else {
HDputs("Testing without dense attributes:");
num_attributes_g = MAX(min_dense, 2) - 2;
}
} /* end if */
else {
HDputs("Testing with oldest file format for source file:");
src_fapl = fapl;
num_attributes_g = 4;
} /* end else */
/* Set the FAPL for the destination file's type of format */
if (configuration & CONFIG_DST_NEW_FORMAT) {
HDputs("Testing with latest format for destination file:");
dst_fapl = fapl2;
same_file = FALSE;
} /* end if */
else {
HDputs("Testing with oldest file format for destination file:");
dst_fapl = fapl;
} /* end else */
/* The tests... */
nerrors += test_copy_dataset_simple(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_versionbounds(fcpl_src, src_fapl);
nerrors += test_copy_dataset_simple_samefile(fcpl_src, src_fapl);
/* Test with dataset opened in the file or not */
nerrors += test_copy_dataset_simple_empty(fcpl_src, fcpl_dst, src_fapl, dst_fapl, FALSE);
nerrors += test_copy_dataset_simple_empty(fcpl_src, fcpl_dst, src_fapl, dst_fapl, TRUE);
nerrors += test_copy_dataset_compound(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_chunked(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_chunked_empty(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_chunked_sparse(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_compressed(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
/* Test with dataset opened in the file or not */
nerrors += test_copy_dataset_no_edge_filt(fcpl_src, fcpl_dst, src_fapl, dst_fapl, FALSE);
nerrors += test_copy_dataset_no_edge_filt(fcpl_src, fcpl_dst, src_fapl, dst_fapl, TRUE);
/* Test with dataset opened in the file or not */
nerrors += test_copy_dataset_compact(fcpl_src, fcpl_dst, src_fapl, dst_fapl, FALSE);
nerrors += test_copy_dataset_compact(fcpl_src, fcpl_dst, src_fapl, dst_fapl, TRUE);
nerrors += test_copy_dataset_multi_ohdr_chunks(fcpl_src, fcpl_dst, src_fapl, dst_fapl, FALSE);
nerrors += test_copy_dataset_multi_ohdr_chunks(fcpl_src, fcpl_dst, src_fapl, dst_fapl, TRUE);
nerrors += test_copy_dataset_attr_named_dtype(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_group_empty(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_root_group(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_group(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_group_deep(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_group_loop(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_group_wide_loop(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_group_links(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
/* Test with dataset opened in the file or not */
nerrors += test_copy_soft_link(fcpl_src, fcpl_dst, src_fapl, dst_fapl, FALSE);
nerrors += test_copy_soft_link(fcpl_src, fcpl_dst, src_fapl, dst_fapl, TRUE);
nerrors += test_copy_ext_link(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_exist(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_path(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_named_datatype_attr_self(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_attr_crt_order(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_option(fcpl_src, fcpl_dst, src_fapl, dst_fapl, H5O_COPY_WITHOUT_ATTR_FLAG, FALSE,
"H5Ocopy(): without attributes");
nerrors += test_copy_option(fcpl_src, fcpl_dst, src_fapl, dst_fapl, 0, TRUE,
"H5Ocopy(): with missing groups");
nerrors += test_copy_option(fcpl_src, fcpl_dst, src_fapl, dst_fapl, H5O_COPY_EXPAND_SOFT_LINK_FLAG,
FALSE, "H5Ocopy(): expand soft link");
nerrors += test_copy_option(fcpl_src, fcpl_dst, src_fapl, dst_fapl, H5O_COPY_EXPAND_EXT_LINK_FLAG,
FALSE, "H5Ocopy(): expand external link");
/* Splitter VFD currently has external link-related bugs */
if (HDstrcmp(env_h5_drvr, "splitter")) {
nerrors += test_copy_option(fcpl_src, fcpl_dst, src_fapl, dst_fapl,
H5O_COPY_EXPAND_SOFT_LINK_FLAG | H5O_COPY_EXPAND_EXT_LINK_FLAG, FALSE,
"H5Ocopy(): expand soft and external links");
}
nerrors += test_copy_option(fcpl_src, fcpl_dst, src_fapl, dst_fapl, H5O_COPY_SHALLOW_HIERARCHY_FLAG,
FALSE, "H5Ocopy(): shallow group copy");
nerrors += test_copy_option(fcpl_src, fcpl_dst, src_fapl, dst_fapl, H5O_COPY_EXPAND_REFERENCE_FLAG,
FALSE, "H5Ocopy(): expand object reference");
nerrors += test_copy_option(fcpl_src, fcpl_dst, src_fapl, dst_fapl, H5O_COPY_PRESERVE_NULL_FLAG,
FALSE, "H5Ocopy(): preserve NULL messages");
nerrors += test_copy_option(fcpl_src, fcpl_dst, src_fapl, dst_fapl,
H5O_COPY_WITHOUT_ATTR_FLAG | H5O_COPY_PRESERVE_NULL_FLAG, TRUE,
"H5Ocopy(): preserve NULL messages");
nerrors += test_copy_dataset_open(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
/* Tests that do not use attributes and do not need to be tested
* multiple times for different attribute configurations */
if (configuration < CONFIG_DENSE) {
unsigned reopen;
nerrors += test_copy_named_datatype(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_named_datatype_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_named_datatype_vl_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
/* Loop over reopening the file */
for (reopen = FALSE; reopen <= TRUE; reopen++) {
nerrors += test_copy_committed_datatype_merge(fcpl_src, fcpl_dst, src_fapl, dst_fapl, reopen);
if (same_file)
nerrors += test_copy_committed_datatype_merge_same_file(fcpl_src, src_fapl, reopen);
nerrors += test_copy_committed_dt_merge_sugg(fcpl_src, fcpl_dst, src_fapl, dst_fapl, reopen);
nerrors += test_copy_committed_dt_merge_attr(fcpl_src, fcpl_dst, src_fapl, dst_fapl, reopen);
/* tests added for merging committed datatypes + suggestions + callback */
nerrors += test_copy_cdt_hier_merge(fcpl_src, fcpl_dst, src_fapl, dst_fapl, reopen);
nerrors += test_copy_cdt_merge_cdt(fcpl_src, fcpl_dst, src_fapl, dst_fapl, reopen);
nerrors += test_copy_cdt_merge_suggs(fcpl_src, fcpl_dst, src_fapl, dst_fapl, reopen);
nerrors += test_copy_cdt_merge_dset_suggs(fcpl_src, fcpl_dst, src_fapl, dst_fapl, reopen);
nerrors += test_copy_cdt_merge_all_suggs(fcpl_src, fcpl_dst, src_fapl, dst_fapl, reopen);
nerrors += test_copy_set_mcdt_search_cb(fcpl_src, fcpl_dst, src_fapl, dst_fapl, reopen);
nerrors += test_copy_set_get_mcdt_search_cb(fcpl_src, fcpl_dst, src_fapl, dst_fapl, reopen);
} /* end for */
nerrors += test_copy_dataset_external(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_named_dtype(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_named_dtype_hier(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_named_dtype_hier_outside(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_contig_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_chunked_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_compact_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_compressed_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_attribute_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_attribute_compound_vlstr(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_compact_named_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_contig_named_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
/* Test with dataset opened in the file or not */
nerrors += test_copy_dataset_chunked_named_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl, FALSE);
nerrors += test_copy_dataset_chunked_named_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl, TRUE);
nerrors += test_copy_dataset_compressed_named_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_compact_vl_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
/* Test with dataset opened in the file or not */
nerrors += test_copy_dataset_contig_vl_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl, FALSE);
nerrors += test_copy_dataset_contig_vl_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl, TRUE);
nerrors += test_copy_dataset_chunked_vl_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
/* Test with dataset opened in the file or not */
nerrors += test_copy_dataset_compressed_vl_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl, FALSE);
nerrors += test_copy_dataset_compressed_vl_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl, TRUE);
nerrors += test_copy_dataset_contig_cmpd_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_chunked_cmpd_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_dataset_compact_cmpd_vl(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_same_file_named_datatype(fcpl_src, src_fapl);
if (driver_is_default_compatible) {
/* Test with dataset opened in the file or not */
nerrors += test_copy_old_layout(fcpl_dst, dst_fapl, FALSE);
nerrors += test_copy_old_layout(fcpl_dst, dst_fapl, TRUE);
}
/* Test with dataset opened in the file or not */
nerrors += test_copy_null_ref(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_null_ref_open(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
nerrors += test_copy_cdt_v1_header_bug(fcpl_src, src_fapl);
nerrors += test_copy_iterate(fcpl_src, fcpl_dst, src_fapl, dst_fapl);
} /* end if */
/* TODO: not implemented
nerrors += test_copy_mount(src_fapl);
*/
} /* end for */
/* Reset file token checking info */
token_reset();
/* Verify symbol table messages are cached */
nerrors += (h5_verify_cached_stabs(FILENAME, fapl) < 0 ? 1 : 0);
/* Results */
if (nerrors) {
HDprintf("***** %d OBJECT COPY TEST%s FAILED! *****\n", nerrors, (1 == nerrors ? "" : "S"));
HDexit(EXIT_FAILURE);
} /* end if */
HDputs("All object copying tests passed.");
/* close property list.
* NOTE: if this property list is not closed and the test is
* run with the split or multi driver, an interesting
* problem is exposed in the property list shutdown code.
*
* Namely, since the split/multi driver copies property
* lists for internal use, there's a (high) chance that
* leaving the FAPL open and having the library's shutdown
* code close it will cause the underlying property lists
* to be cleaned up first, causing the actual property list
* close operation to fail (since it won't be able to close
* the already closed underlying property list).
*
* The could be addressed by converting the split/multi to
* use non-public API routines, or putting some way into the
* public H5I routines to indicate ordering at shutdown.
*
* For now, we just make certain to close the property list.
* (QAK - 2016/04/06)
*
*/
H5Pclose(fapl2);
h5_cleanup(FILENAME, fapl);
HDexit(EXIT_SUCCESS);
error:
HDexit(EXIT_FAILURE);
} /* main */