mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-03-31 17:10:47 +08:00
[svn-r13098] Description:
Checkpoint changes for bug fix, to shift coding to another machine. Tested on: Linux/64 2.6 (chicago2)
This commit is contained in:
parent
76ee1b2bda
commit
c1d6230290
@ -169,6 +169,19 @@ H5O_flush_msgs(H5F_t *f, H5O_t *oh)
|
||||
encode = H5O_MSG_SHARED->encode;
|
||||
else
|
||||
encode = curr_msg->type->encode;
|
||||
/* XXX: fix me */
|
||||
#ifdef NOT_YET
|
||||
if(!(curr_msg->flags & H5O_MSG_FLAG_SHARED)) {
|
||||
size_t msg_size;
|
||||
|
||||
HDfprintf(stderr, "%s: curr_msg->type->name = '%s'\n", FUNC, curr_msg->type->name);
|
||||
HDfprintf(stderr, "%s: curr_msg->raw_size = %Zu\n", FUNC, curr_msg->raw_size);
|
||||
msg_size = curr_msg->type->raw_size(f, curr_msg->native);
|
||||
HDfprintf(stderr, "%s: msg_size = %Zu\n", FUNC, msg_size);
|
||||
if(msg_size > curr_msg->raw_size)
|
||||
HDfprintf(stderr, "%s: YOW!\n", FUNC);
|
||||
} /* end if */
|
||||
#endif /* NOT_YET */
|
||||
if((encode)(f, curr_msg->raw, curr_msg->native) < 0)
|
||||
HGOTO_ERROR(H5E_OHDR, H5E_CANTENCODE, FAIL, "unable to encode object header message")
|
||||
} /* end if */
|
||||
@ -512,7 +525,7 @@ H5O_load(H5F_t *f, hid_t dxpl_id, haddr_t addr, const void UNUSED * _udata1,
|
||||
H5O_cont_t *cont;
|
||||
|
||||
/* Decode continuation message */
|
||||
cont = (H5O_MSG_CONT->decode)(f, dxpl_id, oh->mesg[curmesg].raw);
|
||||
cont = (H5O_cont_t *)(H5O_MSG_CONT->decode)(f, dxpl_id, oh->mesg[curmesg].raw);
|
||||
cont->chunkno = oh->nchunks; /*the next chunk to allocate */
|
||||
|
||||
/* Save 'native' form of continuation message */
|
||||
@ -749,7 +762,7 @@ H5O_dest(H5F_t UNUSED *f, H5O_t *oh)
|
||||
oh->chunk[u].image = H5FL_BLK_FREE(chunk_image, oh->chunk[u].image);
|
||||
} /* end for */
|
||||
if(oh->chunk)
|
||||
oh->chunk = H5FL_SEQ_FREE(H5O_chunk_t, oh->chunk);
|
||||
oh->chunk = (H5O_chunk_t *)H5FL_SEQ_FREE(H5O_chunk_t, oh->chunk);
|
||||
|
||||
/* destroy messages */
|
||||
for(u = 0; u < oh->nmesgs; u++) {
|
||||
@ -759,7 +772,7 @@ H5O_dest(H5F_t UNUSED *f, H5O_t *oh)
|
||||
H5O_msg_free_mesg(&oh->mesg[u]);
|
||||
} /* end for */
|
||||
if(oh->mesg)
|
||||
oh->mesg = H5FL_SEQ_FREE(H5O_mesg_t, oh->mesg);
|
||||
oh->mesg = (H5O_mesg_t *)H5FL_SEQ_FREE(H5O_mesg_t, oh->mesg);
|
||||
|
||||
/* destroy object header */
|
||||
H5FL_FREE(H5O_t,oh);
|
||||
|
191
test/tattr.c
191
test/tattr.c
@ -47,7 +47,7 @@
|
||||
#define NAME_BUF_SIZE 1024
|
||||
#define ATTR_NAME_LEN 16
|
||||
#define ATTR_MAX_DIMS 7
|
||||
#define ATTR_TMP_NAME "temp_name"
|
||||
#define ATTR_TMP_NAME "a really long temp_name"
|
||||
|
||||
/* 3-D dataset with fixed dimensions */
|
||||
#define SPACE1_NAME "Space1"
|
||||
@ -270,9 +270,11 @@ test_attr_basic_write(hid_t fapl)
|
||||
ret=H5Aclose(attr2);
|
||||
CHECK(ret, FAIL, "H5Aclose");
|
||||
|
||||
#ifndef OLD_WAY
|
||||
/* change first attribute back to the original name */
|
||||
ret=H5Arename(dataset, ATTR_TMP_NAME, ATTR1_NAME);
|
||||
CHECK(ret, FAIL, "H5Arename");
|
||||
#endif /* OLD_WAY */
|
||||
|
||||
ret = H5Sclose(sid1);
|
||||
CHECK(ret, FAIL, "H5Sclose");
|
||||
@ -360,8 +362,12 @@ test_attr_basic_read(hid_t fapl)
|
||||
ret=H5Aget_num_attrs(dataset);
|
||||
VERIFY(ret, 2, "H5Aget_num_attrs");
|
||||
|
||||
/* Open an attribute for the dataset */
|
||||
attr=H5Aopen_name(dataset,ATTR1_NAME);
|
||||
/* Open first attribute for the dataset */
|
||||
#ifndef OLD_WAY
|
||||
attr=H5Aopen_name(dataset, ATTR1_NAME);
|
||||
#else /* OLD_WAY */
|
||||
attr=H5Aopen_name(dataset, ATTR_TMP_NAME);
|
||||
#endif /* OLD_WAY */
|
||||
CHECK(attr, FAIL, "H5Aopen_name");
|
||||
|
||||
/* Read attribute information */
|
||||
@ -387,7 +393,7 @@ test_attr_basic_read(hid_t fapl)
|
||||
ret=H5Aget_num_attrs(group);
|
||||
VERIFY(ret, 1, "H5Aget_num_attrs");
|
||||
|
||||
/* Open an attribute for the dataset */
|
||||
/* Open the attribute for the group */
|
||||
attr=H5Aopen_name(group,ATTR2_NAME);
|
||||
CHECK(attr, FAIL, "H5Aopen_name");
|
||||
|
||||
@ -1768,6 +1774,8 @@ test_attr_dense_create(hid_t fcpl, hid_t fapl)
|
||||
unsigned min_dense; /* Minimum # of attributes to store "densely" */
|
||||
htri_t is_dense; /* Are attributes stored densely? */
|
||||
unsigned u; /* Local index variable */
|
||||
h5_stat_size_t empty_filesize; /* Size of empty file */
|
||||
h5_stat_size_t filesize; /* Size of file after modifications */
|
||||
herr_t ret; /* Generic return value */
|
||||
|
||||
/* Output message about test being performed */
|
||||
@ -1777,6 +1785,19 @@ test_attr_dense_create(hid_t fcpl, hid_t fapl)
|
||||
fid = H5Fcreate(FILENAME, H5F_ACC_TRUNC, fcpl, fapl);
|
||||
CHECK(fid, FAIL, "H5Fcreate");
|
||||
|
||||
/* Close file */
|
||||
ret = H5Fclose(fid);
|
||||
CHECK(ret, FAIL, "H5Fclose");
|
||||
|
||||
/* Get size of file */
|
||||
empty_filesize = h5_get_file_size(FILENAME);
|
||||
if(empty_filesize < 0)
|
||||
TestErrPrintf("Line %d: file size wrong!\n", __LINE__);
|
||||
|
||||
/* Re-open file */
|
||||
fid = H5Fopen(FILENAME, H5F_ACC_RDWR, fapl);
|
||||
CHECK(fid, FAIL, "H5Fopen");
|
||||
|
||||
/* Create dataspace for dataset */
|
||||
sid = H5Screate(H5S_SCALAR);
|
||||
CHECK(sid, FAIL, "H5Screate");
|
||||
@ -1850,9 +1871,22 @@ HDfprintf(stderr, "max_compact = %u, min_dense = %u\n", max_compact, min_dense);
|
||||
ret = H5Dclose(dataset);
|
||||
CHECK(ret, FAIL, "H5Dclose");
|
||||
|
||||
/* Unlink dataset with attributes */
|
||||
ret = H5Gunlink(fid, DSET1_NAME);
|
||||
CHECK(ret, FAIL, "H5Gunlink");
|
||||
|
||||
/* Close file */
|
||||
ret = H5Fclose(fid);
|
||||
CHECK(ret, FAIL, "H5Fclose");
|
||||
|
||||
/* Check size of file */
|
||||
filesize = h5_get_file_size(FILENAME);
|
||||
#ifdef LATER
|
||||
VERIFY(filesize, empty_filesize, "h5_get_file_size");
|
||||
#else /* LATER */
|
||||
/* XXX: Add similar check to other tests that use new storage */
|
||||
HDfprintf(stderr, "Check skipped - fix after ISOHM code deletes empty indices\n");
|
||||
#endif /* LATER */
|
||||
} /* test_attr_dense_create() */
|
||||
|
||||
/****************************************************************
|
||||
@ -2096,6 +2130,140 @@ HDfprintf(stderr, "max_compact = %u, min_dense = %u\n", max_compact, min_dense);
|
||||
ret = H5Fclose(fid);
|
||||
CHECK(ret, FAIL, "H5Fclose");
|
||||
} /* test_attr_dense_delete() */
|
||||
|
||||
/****************************************************************
|
||||
**
|
||||
** test_attr_dense_rename(): Test basic H5A (attribute) code.
|
||||
** Tests renaming attributes in "dense" storage
|
||||
**
|
||||
****************************************************************/
|
||||
static void
|
||||
test_attr_dense_rename(hid_t fcpl, hid_t fapl)
|
||||
{
|
||||
hid_t fid; /* HDF5 File ID */
|
||||
hid_t dataset; /* Dataset ID */
|
||||
hid_t sid; /* Dataspace ID */
|
||||
hid_t attr; /* Attribute ID */
|
||||
hid_t dcpl; /* Dataset creation property list ID */
|
||||
char attrname[NAME_BUF_SIZE]; /* Name of attribute */
|
||||
char new_attrname[NAME_BUF_SIZE]; /* New name of attribute */
|
||||
unsigned max_compact; /* Maximum # of attributes to store compactly */
|
||||
unsigned min_dense; /* Minimum # of attributes to store "densely" */
|
||||
htri_t is_dense; /* Are attributes stored densely? */
|
||||
unsigned u; /* Local index variable */
|
||||
int attr_count; /* # of attributes */
|
||||
herr_t ret; /* Generic return value */
|
||||
|
||||
/* Output message about test being performed */
|
||||
MESSAGE(5, ("Testing Renaming Attributes in Dense Storage\n"));
|
||||
|
||||
/* Create file */
|
||||
fid = H5Fcreate(FILENAME, H5F_ACC_TRUNC, fcpl, fapl);
|
||||
CHECK(fid, FAIL, "H5Fcreate");
|
||||
|
||||
/* Create dataspace for dataset */
|
||||
sid = H5Screate(H5S_SCALAR);
|
||||
CHECK(sid, FAIL, "H5Screate");
|
||||
|
||||
/* Query the group creation properties */
|
||||
dcpl = H5Pcreate(H5P_DATASET_CREATE);
|
||||
CHECK(dcpl, FAIL, "H5Pcreate");
|
||||
|
||||
/* Create a dataset */
|
||||
dataset = H5Dcreate(fid, DSET1_NAME, H5T_NATIVE_UCHAR, sid, dcpl);
|
||||
CHECK(dataset, FAIL, "H5Dcreate");
|
||||
|
||||
/* Retrieve limits for compact/dense attribute storage */
|
||||
ret = H5Pget_attr_phase_change(dcpl, &max_compact, &min_dense);
|
||||
CHECK(ret, FAIL, "H5Pget_attr_phase_change");
|
||||
#ifdef QAK
|
||||
HDfprintf(stderr, "max_compact = %u, min_dense = %u\n", max_compact, min_dense);
|
||||
#endif /* QAK */
|
||||
|
||||
/* Check on dataset's attribute storage status */
|
||||
is_dense = H5O_is_attr_dense_test(dataset);
|
||||
VERIFY(is_dense, FALSE, "H5O_is_attr_dense_test");
|
||||
|
||||
/* Add attributes, until well into dense storage */
|
||||
for(u = 0; u < (max_compact * 2); u++) {
|
||||
/* Create attribute */
|
||||
sprintf(attrname, "attr %02u", u);
|
||||
attr = H5Acreate(dataset, attrname, H5T_NATIVE_UINT, sid, H5P_DEFAULT);
|
||||
CHECK(attr, FAIL, "H5Acreate");
|
||||
|
||||
/* Write data into the attribute */
|
||||
ret = H5Awrite(attr, H5T_NATIVE_UINT, &u);
|
||||
CHECK(ret, FAIL, "H5Awrite");
|
||||
|
||||
/* Close attribute */
|
||||
ret = H5Aclose(attr);
|
||||
CHECK(ret, FAIL, "H5Aclose");
|
||||
|
||||
/* Rename attribute */
|
||||
sprintf(new_attrname, "new attr %02u", u);
|
||||
|
||||
/* Rename attribute */
|
||||
ret = H5Arename(dataset, attrname, new_attrname);
|
||||
CHECK(ret, FAIL, "H5Arename");
|
||||
|
||||
/* Check # of attributes */
|
||||
attr_count = H5Aget_num_attrs(dataset);
|
||||
CHECK(attr_count, FAIL, "H5Aget_num_attrs");
|
||||
VERIFY(attr_count, (int)(u + 1), "H5Aget_num_attrs");
|
||||
} /* end for */
|
||||
|
||||
/* Check on dataset's attribute storage status */
|
||||
is_dense = H5O_is_attr_dense_test(dataset);
|
||||
VERIFY(is_dense, TRUE, "H5O_is_attr_dense_test");
|
||||
|
||||
/* Close dataspace */
|
||||
ret = H5Sclose(sid);
|
||||
CHECK(ret, FAIL, "H5Sclose");
|
||||
|
||||
/* Close Dataset */
|
||||
ret = H5Dclose(dataset);
|
||||
CHECK(ret, FAIL, "H5Dclose");
|
||||
|
||||
/* Close file */
|
||||
ret = H5Fclose(fid);
|
||||
CHECK(ret, FAIL, "H5Fclose");
|
||||
|
||||
|
||||
/* Re-open file */
|
||||
fid = H5Fopen(FILENAME, H5F_ACC_RDWR, fapl);
|
||||
CHECK(fid, FAIL, "H5Fopen");
|
||||
|
||||
/* Open dataset */
|
||||
dataset = H5Dopen(fid, DSET1_NAME);
|
||||
CHECK(dataset, FAIL, "H5Dopen");
|
||||
|
||||
/* Verify renamed attributes */
|
||||
for(u = 0; u < (max_compact * 2); u++) {
|
||||
unsigned value; /* Attribute value */
|
||||
|
||||
/* Create attribute */
|
||||
sprintf(attrname, "new attr %02u", u);
|
||||
attr = H5Acreate(dataset, attrname, H5T_NATIVE_UINT, sid, H5P_DEFAULT);
|
||||
CHECK(attr, FAIL, "H5Acreate");
|
||||
|
||||
/* Read data from the attribute */
|
||||
ret = H5Aread(attr, H5T_NATIVE_UINT, &value);
|
||||
CHECK(ret, FAIL, "H5Aread");
|
||||
VERIFY(value, u, "H5Aread");
|
||||
|
||||
/* Close attribute */
|
||||
ret = H5Aclose(attr);
|
||||
CHECK(ret, FAIL, "H5Aclose");
|
||||
} /* end for */
|
||||
|
||||
/* Close Dataset */
|
||||
ret = H5Dclose(dataset);
|
||||
CHECK(ret, FAIL, "H5Dclose");
|
||||
|
||||
/* Close file */
|
||||
ret = H5Fclose(fid);
|
||||
CHECK(ret, FAIL, "H5Fclose");
|
||||
} /* test_attr_dense_rename() */
|
||||
#endif /* QAK */
|
||||
|
||||
/****************************************************************
|
||||
@ -2157,6 +2325,7 @@ HDfprintf(stderr, "max_compact = %u, min_dense = %u\n", max_compact, min_dense);
|
||||
VERIFY(is_dense, FALSE, "H5O_is_attr_dense_test");
|
||||
|
||||
/* Add attributes to each dataset, until after converting to dense storage */
|
||||
/* XXX: Test with shared & committed datatype/dataspace also */
|
||||
for(u = 0; u < max_compact * 2; u++) {
|
||||
/* Create attribute name */
|
||||
sprintf(attrname, "attr %02u", u);
|
||||
@ -2302,9 +2471,9 @@ test_attr(void)
|
||||
/* These next two tests use the same file information */
|
||||
test_attr_basic_write(my_fapl); /* Test basic H5A writing code */
|
||||
test_attr_basic_read(my_fapl); /* Test basic H5A reading code */
|
||||
test_attr_flush(my_fapl); /* Test H5A I/O in the presence of H5Fflush calls */
|
||||
|
||||
/* This next test uses the same file information */
|
||||
/* These next two tests use their own file information */
|
||||
test_attr_flush(my_fapl); /* Test H5A I/O in the presence of H5Fflush calls */
|
||||
test_attr_plist(my_fapl); /* Test attribute property lists */
|
||||
|
||||
/* These next two tests use the same file information */
|
||||
@ -2321,7 +2490,7 @@ test_attr(void)
|
||||
test_attr_iterate(my_fapl); /* Test H5A iterator code */
|
||||
test_attr_delete(my_fapl); /* Test H5A code for deleting attributes */
|
||||
|
||||
/* This next test use the same file information */
|
||||
/* This next test uses its own file information */
|
||||
test_attr_dtype_shared(my_fapl); /* Test using shared dataypes in attributes */
|
||||
} /* end for */
|
||||
|
||||
@ -2343,12 +2512,16 @@ test_attr(void)
|
||||
test_attr_dense_create(my_fcpl, fapl2); /* Test dense attribute storage creation */
|
||||
test_attr_dense_open(my_fcpl, fapl2); /* Test opening attributes in dense storage */
|
||||
test_attr_dense_delete(my_fcpl, fapl2); /* Test deleting attributes in dense storage */
|
||||
/* Rename attribute */
|
||||
/* Unlink object */
|
||||
/* XXX: Rename attribute */
|
||||
#ifdef NOT_YET
|
||||
test_attr_dense_rename(my_fcpl, fapl2); /* Test renaming attributes in dense storage */
|
||||
#endif /* NOT_YET */
|
||||
/* XXX: Unlink object */
|
||||
} /* end for */
|
||||
|
||||
/* Tests with both "new format" and "shared" attributes */
|
||||
test_attr_shared_write(fcpl2, fapl2); /* Test writing to shared attributes in compact & dense storage */
|
||||
/* XXX: Rename shared attributes */
|
||||
#else /* QAK */
|
||||
HDfprintf(stderr, "Uncomment tests!\n");
|
||||
#endif /* QAK */
|
||||
|
Loading…
x
Reference in New Issue
Block a user