diff options
Diffstat (limited to 'c++/examples/h5group.cpp')
-rw-r--r-- | c++/examples/h5group.cpp | 130 |
1 files changed, 73 insertions, 57 deletions
diff --git a/c++/examples/h5group.cpp b/c++/examples/h5group.cpp index 95161da..d7f3c66 100644 --- a/c++/examples/h5group.cpp +++ b/c++/examples/h5group.cpp @@ -12,14 +12,14 @@ * access to either file, you may request a copy from hdfhelp@ncsa.uiuc.edu. * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ -// -// This example creates a group in the file and dataset in the group. -// Hard link to the group object is created and the dataset is accessed -// under different names. -// Iterator function is used to find the object names in the root group. -// Note that the C++ API iterator function is not completed yet, thus -// the C version is used in this example. -// +/* + * This example creates a group in the file and dataset in the group. + * Hard link to the group object is created and the dataset is accessed + * under different names. + * Iterator function is used to find the object names in the root group. + * Note that the C++ API iterator function is not completed yet, thus + * the C version is used in this example. + */ #include <string> #ifdef OLD_HEADER_FILENAME @@ -48,19 +48,29 @@ int main(void) // Try block to detect exceptions raised by any of the calls inside it try { - // Create the named file, truncating the existing one if any, - // using default create and access property lists. + /* + * Turn off the auto-printing when failure occurs so that we can + * handle the errors appropriately + */ + Exception::dontPrint(); + + /* + * Create the named file, truncating the existing one if any, + * using default create and access property lists. + */ H5File *file = new H5File( FILE_NAME, H5F_ACC_TRUNC ); - // Create a group in the file + /* + * Create a group in the file + */ Group* group = new Group( file->createGroup( "/Data" )); - // - // Create dataset "Compressed Data" in the group using absolute - // name. Dataset creation property list is modified to use - // GZIP compression with the compression effort set to 6. - // Note that compression can be used only when dataset is chunked. - // + /* + * Create dataset "Compressed Data" in the group using absolute + * name. Dataset creation property list is modified to use + * GZIP compression with the compression effort set to 6. + * Note that compression can be used only when dataset is chunked. + */ dims[0] = 1000; dims[1] = 20; cdims[0] = 20; @@ -74,22 +84,22 @@ int main(void) DataSet* dataset = new DataSet( file->createDataSet( "/Data/Compressed_Data", PredType::NATIVE_INT, dataspace, ds_creatplist )); - // - // Close the dataset and the file. - // + /* + * Close the dataset and the file. + */ delete dataset; delete group; delete file; - // - // Now reopen the file and group in the file. - // + /* + * Now reopen the file and group in the file. + */ file = new H5File( FILE_NAME, H5F_ACC_RDWR ); group = new Group( file->openGroup( "Data" )); - // - // Access "Compressed_Data" dataset in the group. - // + /* + * Access "Compressed_Data" dataset in the group. + */ try { // to determine if the dataset exists in the group dataset = new DataSet( group->openDataSet( "Compressed_Data" )); } @@ -99,20 +109,20 @@ int main(void) } cout << "dataset \"/Data/Compressed_Data\" is open" << endl; - // - // Close the dataset. - // + /* + * Close the dataset. + */ delete dataset; - // - // Create hard link to the Data group. - // + /* + * Create hard link to the Data group. + */ file->link( H5G_LINK_HARD, "Data", "Data_new" ); - // - // We can access "Compressed_Data" dataset using created - // hard link "Data_new". - // + /* + * We can access "Compressed_Data" dataset using created + * hard link "Data_new". + */ try { // to determine if the dataset exists in the file dataset = new DataSet( file->openDataSet( "/Data_new/Compressed_Data" )); } @@ -122,23 +132,23 @@ int main(void) } cout << "dataset \"/Data_new/Compressed_Data\" is open" << endl; - // - // Close the dataset. - // + /* + * Close the dataset. + */ delete dataset; - // - // Use iterator to see the names of the objects in the file - // root directory. - // + /* + * Use iterator to see the names of the objects in the file + * root directory. + */ cout << endl << "Iterating over elements in the file" << endl; herr_t idx = H5Giterate(file->getId(), "/", NULL, file_info, NULL); cout << endl; - // - // Unlink name "Data" and use iterator to see the names - // of the objects in the file root direvtory. - // + /* + * Unlink name "Data" and use iterator to see the names + * of the objects in the file root direvtory. + */ cout << "Unlinking..." << endl; try { // attempt to unlink the dataset file->unlink( "Data" ); @@ -153,7 +163,9 @@ int main(void) idx = H5Giterate(file->getId(), "/", NULL, file_info, NULL); cout << endl; - // Close the file. + /* + * Close the file. + */ delete file; } // end of try block @@ -162,43 +174,47 @@ int main(void) catch( FileIException error ) { error.printError(); + return -1; } // catch failure caused by the DataSet operations catch( DataSetIException error ) { error.printError(); + return -1; } // catch failure caused by the DataSpace operations catch( DataSpaceIException error ) { error.printError(); + return -1; } // catch failure caused by the Attribute operations catch( AttributeIException error ) { error.printError(); + return -1; } return 0; } -// -// Operator function. -// +/* + * Operator function. + */ herr_t file_info(hid_t loc_id, const char *name, void *opdata) { hid_t group; - // - // Open the group using its name. - // + /* + * Open the group using its name. + */ group = H5Gopen(loc_id, name); - // - // Display group name. - // + /* + * Display group name. + */ cout << "Name : " << name << endl; H5Gclose(group); |