c2ddb1e2fc
register mca_base_var_enum_value_flag_t so they can be free'd upon finalize Signed-off-by: Gilles Gouaillardet <gilles@rist.or.jp>
251 строка
8.9 KiB
C
251 строка
8.9 KiB
C
/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */
|
|
/*
|
|
* Copyright (c) 2004-2007 The Trustees of Indiana University and Indiana
|
|
* University Research and Technology
|
|
* Corporation. All rights reserved.
|
|
* Copyright (c) 2004-2006 The University of Tennessee and The University
|
|
* of Tennessee Research Foundation. All rights
|
|
* reserved.
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
* University of Stuttgart. All rights reserved.
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
* All rights reserved.
|
|
* Copyright (c) 2008-2011 Cisco Systems, Inc. All rights reserved.
|
|
* Copyright (c) 2012-2016 Los Alamos National Security, LLC. All rights
|
|
* reserved.
|
|
* Copyright (c) 2017 Research Organization for Information Science
|
|
* and Technology (RIST). All rights reserved.
|
|
* $COPYRIGHT$
|
|
*
|
|
* Additional copyrights may follow
|
|
*
|
|
* $HEADER$
|
|
*/
|
|
|
|
#if !defined(MCA_BASE_VAR_ENUM_H)
|
|
#define MCA_BASE_VAR_ENUM_H
|
|
|
|
#include "opal_config.h"
|
|
|
|
#include "opal/class/opal_object.h"
|
|
#include "opal/constants.h"
|
|
|
|
typedef struct mca_base_var_enum_t mca_base_var_enum_t;
|
|
|
|
/**
|
|
* Get the number of values in the enumerator
|
|
*
|
|
* @param[in] self the enumerator
|
|
* @param[out] count the number of values in the enumerator
|
|
*/
|
|
typedef int (*mca_base_var_enum_get_count_fn_t)(mca_base_var_enum_t *self, int *count);
|
|
|
|
/**
|
|
* Get the value and its string representation for an index 0..get_count()
|
|
*
|
|
* @param[in] self the enumerator
|
|
* @param[in] index the index to get the value of
|
|
* @param[out] value integer value
|
|
* @param[out] string_value string value
|
|
*/
|
|
typedef int (*mca_base_var_enum_get_value_fn_t)(mca_base_var_enum_t *self, int index,
|
|
int *value, const char **string_value);
|
|
|
|
/**
|
|
* Look up the integer value of a string
|
|
*
|
|
* @param[in] self the enumerator
|
|
* @param[in] string_value string to lookup
|
|
* @param[out] value integer value for the string
|
|
*
|
|
* @retval OPAL_SUCCESS if found
|
|
* @retval OPAL_ERR_VALUE_OUT_OF_BOUNDS if not
|
|
*/
|
|
typedef int (*mca_base_var_enum_vfs_fn_t)(mca_base_var_enum_t *self, const char *string_value,
|
|
int *value);
|
|
|
|
/**
|
|
* Dump a textual representation of all the values in an enumerator
|
|
*
|
|
* @param[in] self the enumerator
|
|
* @param[out] out the string representation
|
|
*
|
|
* @retval OPAL_SUCCESS on success
|
|
* @retval opal error on error
|
|
*/
|
|
typedef int (*mca_base_var_enum_dump_fn_t)(mca_base_var_enum_t *self, char **out);
|
|
|
|
/**
|
|
* Get the string representation for an enumerator value
|
|
*
|
|
* @param[in] self the enumerator
|
|
* @param[in] value integer value
|
|
* @param[out] string_value string value for value
|
|
*
|
|
* @retval OPAL_SUCCESS on success
|
|
* @retval OPAL_ERR_VALUE_OUT_OF_BOUNDS if not found
|
|
*
|
|
* @long This function returns the string value for a given interger value in the
|
|
* {string_value} parameter. The {string_value} parameter may be NULL in which case
|
|
* no string is returned. If a string is returned in {string_value} the caller
|
|
* must free the string with free().
|
|
*/
|
|
typedef int (*mca_base_var_enum_sfv_fn_t)(mca_base_var_enum_t *self, const int value,
|
|
char **string_value);
|
|
|
|
/**
|
|
* The default enumerator class takes in a list of integer-string pairs. If a
|
|
* string is read from an environment variable or a file value the matching
|
|
* integer value is used for the MCA variable.
|
|
*/
|
|
struct mca_base_var_enum_value_t {
|
|
int value;
|
|
const char *string;
|
|
};
|
|
|
|
typedef struct mca_base_var_enum_value_t mca_base_var_enum_value_t;
|
|
|
|
/**
|
|
* enumerator base class
|
|
*/
|
|
struct mca_base_var_enum_t {
|
|
opal_object_t super;
|
|
|
|
/** Is the enumerator statically allocated */
|
|
bool enum_is_static;
|
|
|
|
/** Name of this enumerator. This value is duplicated from the argument provided to
|
|
mca_base_var_enum_create() */
|
|
char *enum_name;
|
|
|
|
/** Get the number of values this enumerator represents. Subclasses should override
|
|
the default function. */
|
|
mca_base_var_enum_get_count_fn_t get_count;
|
|
/** Get the value and string representation for a particular index. Subclasses should
|
|
override the default function */
|
|
mca_base_var_enum_get_value_fn_t get_value;
|
|
/** Given a string return corresponding integer value. If the string does not match a
|
|
valid value return OPAL_ERR_VALUE_OUT_OF_BOUNDS */
|
|
mca_base_var_enum_vfs_fn_t value_from_string;
|
|
/** Given an integer return the corresponding string value. If the integer does not
|
|
match a valid value return OPAL_ERR_VALUE_OUT_OF_BOUNDS */
|
|
mca_base_var_enum_sfv_fn_t string_from_value;
|
|
/** Dump a textual representation of the enumerator. The caller is responsible for
|
|
freeing the string */
|
|
mca_base_var_enum_dump_fn_t dump;
|
|
|
|
int enum_value_count;
|
|
/** Copy of the enumerators values (used by the default functions). This array and
|
|
and the strings it contains are freed by the destructor if not NULL. */
|
|
mca_base_var_enum_value_t *enum_values;
|
|
};
|
|
|
|
|
|
/**
|
|
* The default flag enumerator class takes in a list of integer-string pairs. If a
|
|
* string is read from an environment variable or a file value the matching
|
|
* flag value is used for the MCA variable. The conflicting_flag is used to
|
|
* indicate any flags that should conflict.
|
|
*/
|
|
struct mca_base_var_enum_value_flag_t {
|
|
/** flag value (must be power-of-two) */
|
|
int flag;
|
|
/** corresponding string name */
|
|
const char *string;
|
|
/** conflicting flag(s) if any */
|
|
int conflicting_flag;
|
|
};
|
|
|
|
typedef struct mca_base_var_enum_value_flag_t mca_base_var_enum_value_flag_t;
|
|
|
|
/**
|
|
* flag enumerator base class
|
|
*/
|
|
struct mca_base_var_enum_flag_t {
|
|
/** use the existing enumerator interface */
|
|
mca_base_var_enum_t super;
|
|
/** flag value(s) */
|
|
mca_base_var_enum_value_flag_t *enum_flags;
|
|
};
|
|
|
|
typedef struct mca_base_var_enum_flag_t mca_base_var_enum_flag_t;
|
|
|
|
/**
|
|
* Object declaration for mca_base_var_enum_t
|
|
*/
|
|
OPAL_DECLSPEC OBJ_CLASS_DECLARATION(mca_base_var_enum_t);
|
|
|
|
/**
|
|
* Create a new default enumerator
|
|
*
|
|
* @param[in] name Name for this enumerator
|
|
* @param[in] values List of values terminated with a NULL .string
|
|
* member.
|
|
* @param[out] enumerator Newly created enumerator.
|
|
*
|
|
* @retval OPAL_SUCCESS On success
|
|
* @retval opal error code On error
|
|
*
|
|
* This function creates a value enumerator for integer variables. The
|
|
* OUT enumerator value will be a newly OBJ_NEW'ed object that should
|
|
* be released by the caller via OBJ_RELEASE.
|
|
*
|
|
* Note that the output enumerator can be OBJ_RELEASE'd after it has
|
|
* been used in a cvar or pvar registration, because the variable
|
|
* registration functions will OBJ_RETAIN the enumberator.
|
|
*
|
|
* Note that all the strings in the values[] array are strdup'ed into
|
|
* internal storage, meaning that the caller can free all of the
|
|
* strings passed in values[] after mca_base_var_enum_create()
|
|
* returns.
|
|
*/
|
|
OPAL_DECLSPEC int mca_base_var_enum_create (const char *name, const mca_base_var_enum_value_t values[],
|
|
mca_base_var_enum_t **enumerator);
|
|
|
|
/**
|
|
* Create a new default flag enumerator
|
|
*
|
|
* @param[in] name Name for this enumerator
|
|
* @param[in] flags List of flags terminated with a NULL .string
|
|
* member.
|
|
* @param[out] enumerator Newly created enumerator.
|
|
*
|
|
* @retval OPAL_SUCCESS On success
|
|
* @retval opal error code On error
|
|
*
|
|
* This function creates a flag enumerator for integer variables. The
|
|
* OUT enumerator value will be a newly OBJ_NEW'ed object that should
|
|
* be released by the caller via OBJ_RELEASE.
|
|
*
|
|
* Note that the output enumerator can be OBJ_RELEASE'd after it has
|
|
* been used in a cvar or pvar registration, because the variable
|
|
* registration functions will OBJ_RETAIN the enumberator.
|
|
*
|
|
* Note that all the strings in the values[] array are strdup'ed into
|
|
* internal storage, meaning that the caller can free all of the
|
|
* strings passed in values[] after mca_base_var_enum_create()
|
|
* returns.
|
|
*/
|
|
OPAL_DECLSPEC int mca_base_var_enum_create_flag (const char *name, const mca_base_var_enum_value_flag_t flags[],
|
|
mca_base_var_enum_flag_t **enumerator);
|
|
|
|
OPAL_DECLSPEC int mca_base_var_enum_register(const char *project_name, const char *framework_name,
|
|
const char *component_name, const char *enum_name,
|
|
void *storage);
|
|
/* standard enumerators. it is invalid to call OBJ_RELEASE on any of these enumerators */
|
|
/**
|
|
* Boolean enumerator
|
|
*
|
|
* This enumerator maps:
|
|
* positive integer, true, yes, enabled, t -> 1
|
|
* 0, false, no, disabled, f -> 0
|
|
*/
|
|
extern mca_base_var_enum_t mca_base_var_enum_bool;
|
|
|
|
/**
|
|
* Verbosity level enumerator
|
|
*/
|
|
extern mca_base_var_enum_t mca_base_var_enum_verbose;
|
|
|
|
#endif /* !defined(MCA_BASE_VAR_ENUM_H) */
|