Execute function for attributes attached to object


[status,idx_stop,cdata_out] = H5A.iterate(obj_id,idx_type,order,idx_start,iter_func,cdata_in)


[status,idx_stop,cdata_out] = H5A.iterate(obj_id,idx_type,order,idx_start,iter_func,cdata_in) executes the specified function iter_func for each attribute connected to an object. obj_id identifies the object to which attributes are attached. idx_type is the type of index and valid values include the following.

'H5_INDEX_NAME' An alpha-numeric index by attribute name
'H5_INDEX_CRT_ORDER' An index by creation order

order specifies the index traversal order. Valid values include the following.

'H5_ITER_INC' Iteration from beginning to end
'H5_ITER_DEC' Iteration from end to beginning
'H5_ITER_NATIVE' Iteration in the fastest available order

idx_start specifies the starting point of the iteration. idx_stop returns the point at which iteration was stopped. This allows an interrupted iteration to be resumed.

The callback function, iter_func, must have the following signature:

[status,cdata_out] = iter_func(obj_id,attr_name,info,cdata_in)

cdata_in is a user-defined value or structure and is passed to the first step of the iteration in the iter_func cdata_in parameter. The cdata_out of an iteration step forms the cdata_in for the next iteration step. Then, the final cdata_out at the end of the iteration is returned to the caller as cdata_out. This form of H5A.iterate corresponds to the H5Aiterate2 function in the HDF5 C API.

status value returned by iter_func is interpreted as follows.

zeroContinues with the iteration or returns zero status value to the caller if all members have been processed
positiveStops the iteration and returns the positive status value to the caller
negativeStops the iteration and throws an error indicating failure

H5A.iterate(loc_id,attr_idx,iterator_func) executes the specified function for each attribute of the group, dataset, or named datatype specified by loc_id. The attr_idx argument specifies where the iteration begins. iterator_func must be a function handle.

The iterator function must have the following signature:

status = iterator_func(loc_id,attr_name)

loc_id still specifies the group, dataset, or named data type passed into H5A.iterate, and attr_name specifies the current attribute. This form of H5A.iterate corresponds to H5Aiterate1 function in the HDF5 C API.