Implementation¶
Writer¶
/**
* @brief write NPY header
* @param[in] ndim : number of dimensions of the data set, e.g. 2
* @param[in] shape : number of points of the data set in each dimension, e.g. [3, 4]
* @param[in] dtype : data type, e.g. "'<f8'"
* @param[in] is_fortran_order : row-major order (false) or column-major order (true)
* @param[in] fp : file stream to which the header is written
* @param[out] header_size : written header size (in bytes)
* @return : success: 0, failure: otherwise
*/
extern int snpyio_w_header(
const size_t ndim,
const size_t * shape,
const char dtype[],
const bool is_fortran_order,
FILE * fp,
size_t * header_size
);
Warning
The shape
parameter must contain exactly ndim
elements.
Users are responsible for correctly allocating memory to prevent undefined behavior.
Note
The user must open the file in writable mode (e.g., "w"
) before calling this function.
Note
The last argument header_size
denotes the size of the header written to the file stream fp.
This can be used to know the offset from the top of the file pointer after which the main dataset is stored.
The procedure for writing a NPY
header is managed by the main function snpyio_w_header
, which includes the following steps:
Reader¶
/**
* @brief read NPY header
* @param[out] ndim : number of dimensions of the data set, e.g. 2
* @param[out] shape : number of points of the data set in each dimension, e.g. [3, 4]
* @param[out] dtype : data type, e.g. "'<f8'"
* @param[out] is_fortran_order : row-major order (false) or column-major order (true)
* @param[in] fp : file stream to which the header is loaded
* @param[out] header_size : loaded header size (in bytes)
* @return : success: 0, failure: otherwise
*/
extern int snpyio_r_header(
size_t * ndim,
size_t ** shape,
char ** dtype,
bool * is_fortran_order,
FILE * fp,
size_t * header_size
);
Warning
The shape
and dtype
parameters are allocated within this library and returned to the user.
Users are responsible for managing (deallocating) their memory properly to prevent memory leaks.
Note
The user must open the file in readable mode (e.g., "r"
) before calling this function.
Note
The last argument header_size
denotes the size of the header loaded from the file stream fp.
This can be used to know the offset from the top of the file pointer after which the main dataset is stored.
The procedure for reading a NPY
header is managed by the main function snpyio_r_header
, which includes the following steps:
Error handling¶
File-IO operations can fail due to external factors.
This library gracefully handles such errors without terminating the program by avoiding calls to the exit()
function, except the occurrence of fatal errors such as memory allocation failure.
In both normal and error exit scenarios, the writer and reader functions free all internally allocated memory before returning an error code to the user, ensuring no memory leaks occur.
There are two exceptions: the reader function returns the data type (e.g., '"<f8"'
) and the shape of the data (e.g., [123, 456]
) to the user.
It is crucial for users to deallocate these resources properly after use to prevent memory leaks.