mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-01-24 15:25:00 +08:00
85449cbd18
Name change in th5d.c
305 lines
9.6 KiB
C
305 lines
9.6 KiB
C
/****************************************************************************
|
|
* NCSA HDF *
|
|
* Software Development Group *
|
|
* National Center for Supercomputing Applications *
|
|
* University of Illinois at Urbana-Champaign *
|
|
* 605 E. Springfield, Champaign IL 61820 *
|
|
* *
|
|
* For conditions of distribution and use, see the accompanying *
|
|
* hdf/COPYING file. *
|
|
* *
|
|
****************************************************************************/
|
|
|
|
#ifdef RCSID
|
|
static char RcsId[] = "$Revision$";
|
|
#endif
|
|
|
|
/* $Id$ */
|
|
|
|
/***********************************************************
|
|
*
|
|
* Test program: tfile
|
|
*
|
|
* Test the low-level file I/O features.
|
|
*
|
|
*************************************************************/
|
|
|
|
#include <testhdf5.h>
|
|
|
|
#include <H5private.h>
|
|
#include <H5Bprivate.h>
|
|
#include <H5Cprivate.h>
|
|
#include <H5Mprivate.h>
|
|
|
|
#define F1_USERBLOCK_SIZE H5C_USERBLOCK_DEFAULT
|
|
#define F1_OFFSET_SIZE H5C_OFFSETSIZE_DEFAULT
|
|
#define F1_LENGTH_SIZE H5C_LENGTHSIZE_DEFAULT
|
|
#define F1_SYM_LEAF_K H5C_SYM_LEAF_K_DEFAULT
|
|
#define F1_SYM_INTERN_K (btree_k_default_g[H5B_SNODE_ID])
|
|
#define FILE1 "tfile1.h5"
|
|
|
|
#define F2_USERBLOCK_SIZE 512
|
|
#define F2_OFFSET_SIZE 8
|
|
#define F2_LENGTH_SIZE 8
|
|
#define F2_SYM_LEAF_K 8
|
|
#define F2_SYM_INTERN_K 32
|
|
#define FILE2 "tfile2.h5"
|
|
|
|
#define F3_USERBLOCK_SIZE H5C_USERBLOCK_DEFAULT
|
|
#define F3_OFFSET_SIZE F2_OFFSET_SIZE
|
|
#define F3_LENGTH_SIZE F2_LENGTH_SIZE
|
|
#define F3_SYM_LEAF_K F2_SYM_LEAF_K
|
|
#define F3_SYM_INTERN_K F2_SYM_INTERN_K
|
|
#define FILE3 "tfile3.h5"
|
|
|
|
static const uintn btree_k_default_g[] = H5C_BTREE_K_DEFAULT;
|
|
|
|
/****************************************************************
|
|
**
|
|
** test_file_create(): Low-level file creation I/O test routine.
|
|
**
|
|
****************************************************************/
|
|
static void test_file_create(void)
|
|
{
|
|
hatom_t fid1,fid2,fid3; /* HDF5 File IDs */
|
|
hatom_t tmpl1,tmpl2; /* File creation templates */
|
|
uintn parm; /* File-creation parameters */
|
|
uint8 parm2; /* File-creation parameters */
|
|
herr_t ret; /* Generic return value */
|
|
|
|
/* Output message about test being performed */
|
|
MESSAGE(5, ("Testing Low-Level File Creation I/O\n"));
|
|
|
|
/* Create first file */
|
|
fid1=H5Fcreate(FILE1,H5ACC_OVERWRITE,0,0);
|
|
CHECK(fid1,FAIL,"H5Fcreate");
|
|
|
|
/* Try to create first file again (should fail) */
|
|
fid2=H5Fcreate(FILE1,H5ACC_OVERWRITE,0,0);
|
|
VERIFY(fid2,FAIL,"H5Fcreate");
|
|
|
|
/* Get the file-creation template */
|
|
tmpl1=H5Fget_create_template(fid1);
|
|
CHECK(tmpl1,FAIL,"H5Fget_create_template");
|
|
|
|
/* Get the file-creation parameters */
|
|
ret=H5Cgetparm(tmpl1,H5_USERBLOCK_SIZE,&parm);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm,F1_USERBLOCK_SIZE,"H5Cgetparm");
|
|
|
|
ret=H5Cgetparm(tmpl1,H5_OFFSET_SIZE,&parm2);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm2,F1_OFFSET_SIZE,"H5Cgetparm");
|
|
|
|
ret=H5Cgetparm(tmpl1,H5_LENGTH_SIZE,&parm2);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm2,F1_LENGTH_SIZE,"H5Cgetparm");
|
|
|
|
ret=H5Cgetparm(tmpl1,H5_SYM_LEAF_K,&parm);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm,F1_SYM_LEAF_K,"H5Cgetparm");
|
|
|
|
ret=H5Cgetparm(tmpl1,H5_SYM_INTERN_K,&parm);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm,F1_SYM_INTERN_K,"H5Cgetparm");
|
|
|
|
/* Release file-creation template */
|
|
ret=H5Mrelease(tmpl1);
|
|
CHECK(ret,FAIL,"H5Mrelease");
|
|
|
|
/* Double-check that the atom has been vaporized */
|
|
ret=H5Mrelease(tmpl1);
|
|
VERIFY(ret,FAIL,"H5Mrelease");
|
|
|
|
/* Create a new file with a non-standard file-creation template */
|
|
tmpl1=H5Mcreate(fid1,H5_TEMPLATE,NULL);
|
|
CHECK(tmpl1,FAIL,"H5Mcreate");
|
|
|
|
/* Set the new file-creation parameters */
|
|
parm=F2_USERBLOCK_SIZE;
|
|
ret=H5Csetparm(tmpl1,H5_USERBLOCK_SIZE,&parm);
|
|
CHECK(ret,FAIL,"H5Csetparm");
|
|
|
|
parm2=F2_OFFSET_SIZE;
|
|
ret=H5Csetparm(tmpl1,H5_OFFSET_SIZE,&parm2);
|
|
CHECK(ret,FAIL,"H5Csetparm");
|
|
|
|
parm2=F2_LENGTH_SIZE;
|
|
ret=H5Csetparm(tmpl1,H5_LENGTH_SIZE,&parm2);
|
|
CHECK(ret,FAIL,"H5Csetparm");
|
|
|
|
parm=F2_SYM_LEAF_K;
|
|
ret=H5Csetparm(tmpl1,H5_SYM_LEAF_K,&parm);
|
|
CHECK(ret,FAIL,"H5Csetparm");
|
|
|
|
parm=F2_SYM_INTERN_K;
|
|
ret=H5Csetparm(tmpl1,H5_SYM_INTERN_K,&parm);
|
|
CHECK(ret,FAIL,"H5Csetparm");
|
|
|
|
/* Try to create second file, with non-standard file-creation template params */
|
|
fid2=H5Fcreate(FILE2,H5ACC_OVERWRITE,tmpl1,0);
|
|
CHECK(fid2,FAIL,"H5Fcreate");
|
|
|
|
/* Release file-creation template */
|
|
ret=H5Mrelease(tmpl1);
|
|
CHECK(ret,FAIL,"H5Mrelease");
|
|
|
|
/* Get the file-creation template */
|
|
tmpl1=H5Fget_create_template(fid2);
|
|
CHECK(tmpl1,FAIL,"H5Fget_create_template");
|
|
|
|
/* Get the file-creation parameters */
|
|
ret=H5Cgetparm(tmpl1,H5_USERBLOCK_SIZE,&parm);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm,F2_USERBLOCK_SIZE,"H5Cgetparm");
|
|
|
|
ret=H5Cgetparm(tmpl1,H5_OFFSET_SIZE,&parm2);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm2,F2_LENGTH_SIZE,"H5Cgetparm");
|
|
|
|
ret=H5Cgetparm(tmpl1,H5_LENGTH_SIZE,&parm2);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm2,F2_OFFSET_SIZE,"H5Cgetparm");
|
|
|
|
ret=H5Cgetparm(tmpl1,H5_SYM_LEAF_K,&parm);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm,F2_SYM_LEAF_K,"H5Cgetparm");
|
|
|
|
ret=H5Cgetparm(tmpl1,H5_SYM_INTERN_K,&parm);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm,F2_SYM_INTERN_K,"H5Cgetparm");
|
|
|
|
/* Clone the file-creation template */
|
|
tmpl2=H5Mcopy(tmpl1);
|
|
CHECK(tmpl2,FAIL,"H5Mcopy");
|
|
|
|
/* Release file-creation template */
|
|
ret=H5Mrelease(tmpl1);
|
|
CHECK(ret,FAIL,"H5Mrelease");
|
|
|
|
/* Set the new file-creation parameter */
|
|
parm=F3_USERBLOCK_SIZE;
|
|
ret=H5Csetparm(tmpl2,H5_USERBLOCK_SIZE,&parm);
|
|
CHECK(ret,FAIL,"H5Csetparm");
|
|
|
|
/* Try to create second file, with non-standard file-creation template params */
|
|
fid3=H5Fcreate(FILE3,H5ACC_OVERWRITE,tmpl2,0);
|
|
CHECK(fid3,FAIL,"H5Fcreate");
|
|
|
|
/* Release file-creation template */
|
|
ret=H5Mrelease(tmpl2);
|
|
CHECK(ret,FAIL,"H5Mrelease");
|
|
|
|
/* Get the file-creation template */
|
|
tmpl1=H5Fget_create_template(fid3);
|
|
CHECK(tmpl1,FAIL,"H5Fget_create_template");
|
|
|
|
/* Get the file-creation parameters */
|
|
ret=H5Cgetparm(tmpl1,H5_USERBLOCK_SIZE,&parm);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm,F3_USERBLOCK_SIZE,"H5Cgetparm");
|
|
|
|
ret=H5Cgetparm(tmpl1,H5_OFFSET_SIZE,&parm2);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm2,F3_LENGTH_SIZE,"H5Cgetparm");
|
|
|
|
ret=H5Cgetparm(tmpl1,H5_LENGTH_SIZE,&parm2);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm2,F3_OFFSET_SIZE,"H5Cgetparm");
|
|
|
|
ret=H5Cgetparm(tmpl1,H5_SYM_LEAF_K,&parm);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm,F3_SYM_LEAF_K,"H5Cgetparm");
|
|
|
|
ret=H5Cgetparm(tmpl1,H5_SYM_INTERN_K,&parm);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm,F3_SYM_INTERN_K,"H5Cgetparm");
|
|
|
|
/* Release file-creation template */
|
|
ret=H5Mrelease(tmpl1);
|
|
CHECK(ret,FAIL,"H5Mrelease");
|
|
|
|
/* Close first file */
|
|
ret=H5Fclose(fid1);
|
|
CHECK(ret,FAIL,"H5Fclose");
|
|
|
|
/* Close second file */
|
|
ret=H5Fclose(fid2);
|
|
CHECK(ret,FAIL,"H5Fclose");
|
|
|
|
/* Close third file */
|
|
ret=H5Fclose(fid3);
|
|
CHECK(ret,FAIL,"H5Fclose");
|
|
} /* test_file_create() */
|
|
|
|
|
|
/****************************************************************
|
|
**
|
|
** test_file_open(): Low-level file open I/O test routine.
|
|
**
|
|
****************************************************************/
|
|
static void test_file_open(void)
|
|
{
|
|
hatom_t fid1; /* HDF5 File IDs */
|
|
hatom_t tmpl1; /* File creation templates */
|
|
uintn parm; /* File-creation parameters */
|
|
uint8 parm2; /* File-creation parameters */
|
|
herr_t ret; /* Generic return value */
|
|
|
|
/* Output message about test being performed */
|
|
MESSAGE(5, ("Testing Low-Level File Opening I/O\n"));
|
|
|
|
/* Open second file */
|
|
fid1=H5Fopen(FILE2,H5ACC_WRITE,0);
|
|
CHECK(fid1,FAIL,"H5Fooen");
|
|
|
|
/* Get the file-creation template */
|
|
tmpl1=H5Fget_create_template(fid1);
|
|
CHECK(tmpl1,FAIL,"H5Fget_create_template");
|
|
|
|
/* Get the file-creation parameters */
|
|
ret=H5Cgetparm(tmpl1,H5_USERBLOCK_SIZE,&parm);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm,F2_USERBLOCK_SIZE,"H5Cgetparm");
|
|
|
|
ret=H5Cgetparm(tmpl1,H5_OFFSET_SIZE,&parm2);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm2,F2_OFFSET_SIZE,"H5Cgetparm");
|
|
|
|
ret=H5Cgetparm(tmpl1,H5_LENGTH_SIZE,&parm2);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm2,F2_LENGTH_SIZE,"H5Cgetparm");
|
|
|
|
ret=H5Cgetparm(tmpl1,H5_SYM_LEAF_K,&parm);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm,F2_SYM_LEAF_K,"H5Cgetparm");
|
|
|
|
ret=H5Cgetparm(tmpl1,H5_SYM_INTERN_K,&parm);
|
|
CHECK(ret,FAIL,"H5Cgetparm");
|
|
VERIFY(parm,F2_SYM_INTERN_K,"H5Cgetparm");
|
|
|
|
/* Release file-creation template */
|
|
ret=H5Mrelease(tmpl1);
|
|
CHECK(ret,FAIL,"H5Mrelease");
|
|
|
|
/* Close first file */
|
|
ret=H5Fclose(fid1);
|
|
CHECK(ret,FAIL,"H5Fclose");
|
|
} /* test_file_open() */
|
|
|
|
|
|
/****************************************************************
|
|
**
|
|
** test_file(): Main low-level file I/O test routine.
|
|
**
|
|
****************************************************************/
|
|
void test_file(void)
|
|
{
|
|
/* Output message about test being performed */
|
|
MESSAGE(5, ("Testing Low-Level File I/O\n"));
|
|
|
|
test_file_create(); /* Test file creation (also creation templates) */
|
|
test_file_open(); /* Test file opening */
|
|
} /* test_file() */
|
|
|