123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137 |
- /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
- * Copyright by The HDF Group. *
- * *
- * 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 COPYING file, which can be found at the root of the source code *
- * distribution tree, or in https://www.hdfgroup.org/licenses. *
- * If you do not have access to either file, you may request a copy from *
- * help@hdfgroup.org. *
- * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
- /*
- * Programmer: Jacob Smith
- * 2018-04-23
- *
- * Purpose: The public header file for the hdfs driver.
- */
- #ifndef H5FDhdfs_H
- #define H5FDhdfs_H
- #ifdef H5_HAVE_LIBHDFS
- #define H5FD_HDFS (H5FDperform_init(H5FD_hdfs_init))
- #define H5FD_HDFS_VALUE H5_VFD_HDFS
- #else /* H5_HAVE_LIBHDFS */
- #define H5FD_HDFS (H5I_INVALID_HID)
- #define H5FD_HDFS_VALUE H5_VFD_INVALID
- #endif /* H5_HAVE_LIBHDFS */
- #ifdef H5_HAVE_LIBHDFS
- #ifdef __cplusplus
- extern "C" {
- #endif
- /****************************************************************************
- *
- * Structure: H5FD_hdfs_fapl_t
- *
- * Purpose:
- *
- * H5FD_hdfs_fapl_t is a public structure that is used to pass
- * configuration information to the appropriate HDFS VFD via the FAPL.
- * A pointer to an instance of this structure is a parameter to
- * H5Pset_fapl_hdfs() and H5Pget_fapl_hdfs().
- *
- *
- *
- * `version` (int32_t)
- *
- * Version number of the `H5FD_hdfs_fapl_t` structure. Any instance passed
- * to the above calls must have a recognized version number, or an error
- * will be flagged.
- *
- * This field should be set to `H5FD__CURR_HDFS_FAPL_T_VERSION`.
- *
- * `namenode_name` (const char[])
- *
- * Name of "Name Node" to access as the HDFS server.
- *
- * Must not be longer than `H5FD__HDFS_NODE_NAME_SPACE`.
- *
- * TBD: Can be NULL.
- *
- * `namenode_port` (int32_t) TBD
- *
- * Port number to use to connect with Name Node.
- *
- * TBD: If 0, uses a default port.
- *
- * `kerberos_ticket_cache` (const char[])
- *
- * Path to the location of the Kerberos authentication cache.
- *
- * Must not be longer than `H5FD__HDFS_KERB_CACHE_PATH_SPACE`.
- *
- * TBD: Can be NULL.
- *
- * `user_name` (const char[])
- *
- * Username to use when accessing file.
- *
- * Must not be longer than `H5FD__HDFS_USER_NAME_SPACE`.
- *
- * TBD: Can be NULL.
- *
- * `stream_buffer_size` (int32_t)
- *
- * Size (in bytes) of the file read stream buffer.
- *
- * TBD: If -1, relies on a default value.
- *
- *
- *
- * Programmer: Jacob Smith
- * 2018-04-23
- *
- ****************************************************************************/
- #define H5FD__CURR_HDFS_FAPL_T_VERSION 1
- #define H5FD__HDFS_NODE_NAME_SPACE 128
- #define H5FD__HDFS_USER_NAME_SPACE 128
- #define H5FD__HDFS_KERB_CACHE_PATH_SPACE 128
- typedef struct H5FD_hdfs_fapl_t {
- int32_t version;
- char namenode_name[H5FD__HDFS_NODE_NAME_SPACE + 1];
- int32_t namenode_port;
- char user_name[H5FD__HDFS_USER_NAME_SPACE + 1];
- char kerberos_ticket_cache[H5FD__HDFS_KERB_CACHE_PATH_SPACE + 1];
- int32_t stream_buffer_size;
- } H5FD_hdfs_fapl_t;
- H5_DLL hid_t H5FD_hdfs_init(void);
- /**
- * \ingroup FAPL
- *
- * \todo Add missing documentation
- */
- H5_DLL herr_t H5Pget_fapl_hdfs(hid_t fapl_id, H5FD_hdfs_fapl_t *fa_out);
- /**
- * \ingroup FAPL
- *
- * \todo Add missing documentation
- */
- H5_DLL herr_t H5Pset_fapl_hdfs(hid_t fapl_id, H5FD_hdfs_fapl_t *fa);
- #ifdef __cplusplus
- }
- #endif
- #endif /* H5_HAVE_LIBHDFS */
- #endif /* ifndef H5FDhdfs_H */
|