mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-02-05 15:42:32 +08:00
168 lines
6.7 KiB
Java
168 lines
6.7 KiB
Java
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
|
* Copyright by The HDF Group. *
|
|
* Copyright by the Board of Trustees of the University of Illinois. *
|
|
* 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 files COPYING and Copyright.html. COPYING can be found at the root *
|
|
* of the source code distribution tree; Copyright.html can be found at the *
|
|
* root level of an installed copy of the electronic HDF5 document set and *
|
|
* is linked from the top-level documents page. It can also be found at *
|
|
* http://hdfgroup.org/HDF5/doc/Copyright.html. If you do not have *
|
|
* access to either file, you may request a copy from help@hdfgroup.org. *
|
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
|
|
|
/************************************************************
|
|
This example shows a way to recursively traverse the file
|
|
using H5Literate. The method shown here guarantees that
|
|
the recursion will not enter an infinite loop, but does
|
|
not prevent objects from being visited more than once.
|
|
The program prints the directory structure of the file
|
|
specified in FILE. The default file used by this example
|
|
implements the structure described in the User's Guide,
|
|
chapter 4, figure 26.
|
|
************************************************************/
|
|
package examples.groups;
|
|
|
|
import hdf.hdf5lib.H5;
|
|
import hdf.hdf5lib.HDF5Constants;
|
|
import hdf.hdf5lib.callbacks.H5L_iterate_cb;
|
|
import hdf.hdf5lib.callbacks.H5L_iterate_t;
|
|
import hdf.hdf5lib.structs.H5L_info_t;
|
|
import hdf.hdf5lib.structs.H5O_info_t;
|
|
import examples.groups.H5Ex_G_Iterate.H5O_type;
|
|
|
|
class opdata implements H5L_iterate_t {
|
|
int recurs;
|
|
opdata prev;
|
|
long addr;
|
|
}
|
|
|
|
public class H5Ex_G_Traverse {
|
|
|
|
private static String FILE = "h5ex_g_traverse.h5";
|
|
public static H5L_iterate_cb iter_cb = new H5L_iter_callbackT();
|
|
|
|
private static void OpenGroup() {
|
|
long file_id = -1;
|
|
H5O_info_t infobuf;
|
|
opdata od = new opdata();
|
|
|
|
// Open file and initialize the operator data structure.
|
|
try {
|
|
file_id = H5.H5Fopen(FILE, HDF5Constants.H5F_ACC_RDONLY, HDF5Constants.H5P_DEFAULT);
|
|
if (file_id >= 0) {
|
|
infobuf = H5.H5Oget_info(file_id);
|
|
od.recurs = 0;
|
|
od.prev = null;
|
|
od.addr = infobuf.addr;
|
|
}
|
|
}
|
|
catch (Exception e) {
|
|
e.printStackTrace();
|
|
}
|
|
|
|
// Print the root group and formatting, begin iteration.
|
|
try {
|
|
System.out.println("/ {");
|
|
// H5L_iterate_cb iter_cb = new H5L_iter_callbackT();
|
|
H5.H5Literate(file_id, HDF5Constants.H5_INDEX_NAME, HDF5Constants.H5_ITER_NATIVE, 0L, iter_cb, od);
|
|
System.out.println("}");
|
|
}
|
|
catch (Exception e) {
|
|
e.printStackTrace();
|
|
}
|
|
|
|
// Close and release resources.
|
|
try {
|
|
if (file_id >= 0)
|
|
H5.H5Fclose(file_id);
|
|
}
|
|
catch (Exception e) {
|
|
e.printStackTrace();
|
|
}
|
|
}
|
|
|
|
public static void main(String[] args) {
|
|
H5Ex_G_Traverse.OpenGroup();
|
|
}
|
|
}
|
|
|
|
class H5L_iter_callbackT implements H5L_iterate_cb {
|
|
public int callback(long group, String name, H5L_info_t info, H5L_iterate_t op_data) {
|
|
|
|
H5O_info_t infobuf;
|
|
int return_val = 0;
|
|
opdata od = (opdata) op_data; // Type conversion
|
|
int spaces = 2 * (od.recurs + 1); // Number of white spaces to prepend to output.
|
|
|
|
// Get type of the object and display its name and type.
|
|
// The name of the object is passed to this function by the Library.
|
|
try {
|
|
infobuf = H5.H5Oget_info_by_name(group, name, HDF5Constants.H5P_DEFAULT);
|
|
|
|
for (int i = 0; i < spaces; i++)
|
|
System.out.print(" "); // Format output.
|
|
switch (H5O_type.get(infobuf.type)) {
|
|
case H5O_TYPE_GROUP:
|
|
System.out.println("Group: " + name + " { ");
|
|
// Check group address against linked list of operator
|
|
// data structures. We will always run the check, as the
|
|
// reference count cannot be relied upon if there are
|
|
// symbolic links, and H5Oget_info_by_name always follows
|
|
// symbolic links. Alternatively we could use H5Lget_info
|
|
// and never recurse on groups discovered by symbolic
|
|
// links, however it could still fail if an object's
|
|
// reference count was manually manipulated with
|
|
// H5Odecr_refcount.
|
|
if (group_check(od, infobuf.addr)) {
|
|
for (int i = 0; i < spaces; i++)
|
|
System.out.print(" ");
|
|
System.out.println(" Warning: Loop detected!");
|
|
}
|
|
else {
|
|
// Initialize new object of type opdata and begin
|
|
// recursive iteration on the discovered
|
|
// group. The new opdata is given a pointer to the
|
|
// current one.
|
|
opdata nextod = new opdata();
|
|
nextod.recurs = od.recurs + 1;
|
|
nextod.prev = od;
|
|
nextod.addr = infobuf.addr;
|
|
H5L_iterate_cb iter_cb2 = new H5L_iter_callbackT();
|
|
return_val = H5.H5Literate_by_name(group, name, HDF5Constants.H5_INDEX_NAME,
|
|
HDF5Constants.H5_ITER_NATIVE, 0L, iter_cb2, nextod, HDF5Constants.H5P_DEFAULT);
|
|
}
|
|
for (int i = 0; i < spaces; i++)
|
|
System.out.print(" ");
|
|
System.out.println("}");
|
|
break;
|
|
case H5O_TYPE_DATASET:
|
|
System.out.println("Dataset: " + name);
|
|
break;
|
|
case H5O_TYPE_NAMED_DATATYPE:
|
|
System.out.println("Datatype: " + name);
|
|
break;
|
|
default:
|
|
System.out.println("Unknown: " + name);
|
|
}
|
|
}
|
|
catch (Exception e) {
|
|
e.printStackTrace();
|
|
}
|
|
|
|
return return_val;
|
|
}
|
|
|
|
public boolean group_check(opdata od, long target_addr) {
|
|
if (od.addr == target_addr)
|
|
return true; // Addresses match
|
|
else if (od.recurs == 0)
|
|
return false; // Root group reached with no matches
|
|
else
|
|
return group_check(od.prev, target_addr); // Recursively examine the next node
|
|
}
|
|
|
|
}
|