blob: aa1e4ff7940b16c54a3160053791191d2b2c07f6 [file] [log] [blame]
/*!
\file native.h
\brief Header file for the native encapsulated CMPI data type implementation.
This file defines all the data types and functions necessary to use
native encapsulated CMPI data objects. These are clones of the regular
CMPI data types like CMPIObjectPath, CMPIInstance etc., however, they
can be instantiated and manipulated without a full blown CIMOM. Instead,
they use an autononmous CIMOM clone that provides all the functions
to create these objects as defined by the CMPIBrokerEncFT.
(C) Copyright IBM Corp. 2003
THIS FILE IS PROVIDED UNDER THE TERMS OF THE ECLIPSE PUBLIC LICENSE
("AGREEMENT"). ANY USE, REPRODUCTION OR DISTRIBUTION OF THIS FILE
CONSTITUTES RECIPIENTS ACCEPTANCE OF THE AGREEMENT.
You can obtain a current copy of the Eclipse Public License from
http://www.opensource.org/licenses/eclipse-1.0.php
\author Frank Scheffler
$Revision: 1.2 $
*/
#ifndef _REMOTE_CMPI_NATIVE_DATA_H
#define _REMOTE_CMPI_NATIVE_DATA_H
#ifdef __cplusplus
extern "C" {
#endif
#define NATIVE_FT_VERSION 1
#include "cmcidt.h"
#include "cmcift.h"
#include "cmci.h"
// #include "cimXmlParser.h"
/* ************************************************** */
/* */
/* ************************************************** */
struct native_enum {
CMPIEnumeration enumeration;
CMPICount current;
CMPIArray * data;
};
//! Forward declaration for anonymous struct.
struct native_property;
struct native_qualifier;
struct native_method;
struct native_constClass {
CMPIConstClass ccls;
char * classname;
struct native_property * props;
struct native_qualifier *qualifiers;
struct native_method *methods;
};
struct native_instance {
CMPIInstance instance;
char * classname;
char * nameSpace;
int filtered;
char ** property_list;
char ** key_list;
struct native_property * props;
struct native_qualifier *qualifiers;
};
struct native_method {
char * name; //!< Method identifier.
CMPIType type; //!< Associated CMPIType.
CMPIValueState state; //!< Current value state.
CMPIValue value; //!< Current value.
struct native_parameter *parameters; //!< Methods have Parameters
struct native_qualifier *qualifiers; //!< Methods have Qualifiers.
struct native_method *next; //!< Pointer to next method.
};
struct native_parameter {
char * name; //!< Parameter identifier.
CMPIType type; //!< Associated CMPIType.
CMPIValueState state; //!< Current value state.
CMPIValue value; //!< Current value.
struct native_parameter *next; //!< Pointer to next parameter.
};
// TODO: add support for parameter qualifiers, references, reference arrays
struct native_property {
char * name; //!< Property identifier.
CMPIType type; //!< Associated CMPIType.
CMPIValueState state; //!< Current value state.
CMPIValue value; //!< Current value.
struct native_qualifier *qualifiers; //!< Qualifiers.
struct native_property * next; //!< Pointer to next property.
};
struct native_qualifier {
char * name; //!< Qualifier identifier.
CMPIType type; //!< Associated CMPIType.
CMPIValueState state; //!< Current value state.
CMPIValue value; //!< Current value.
struct native_qualifier * next; //!< Pointer to next qualifier.
};
//! Function table for native_property handling functions.
/*!
This structure holds all the function pointers necessary to handle
linked lists of native_property structs.
\sa propertyFT in native.h
*/
struct native_propertyFT
{
//! Function table version
int ftVersion;
//! Releases a complete list of native_property items.
void (* release) ( struct native_property * );
//! Clones a complete list of native_property items.
struct native_property * (* clone) ( struct native_property *,
CMPIStatus * );
//! Adds a new native_property to a list.
struct native_property* (* getProperty) ( struct native_property *,
const char *);
//! Adds a new native_property to a list.
int (* addProperty) ( struct native_property **,
const char *,
CMPIType,
CMPIValueState,
CMPIValue * );
//! Resets the values of an existing native_property, if existant.
int (* setProperty) ( struct native_property *,
const char *,
CMPIType,
CMPIValue * );
//! Looks up a specifix native_property in CMPIData format.
CMPIData (* getDataProperty) ( struct native_property *,
const char *,
CMPIStatus * );
//! Extract an indexed native_property in CMPIData format.
CMPIData (* getDataPropertyAt) ( struct native_property *,
unsigned int,
CMPIString **,
CMPIStatus * );
//! Yields the number of native_property items in a list.
CMPICount (* getPropertyCount) ( struct native_property *,
CMPIStatus * );
//! Looks up a specifix native_property and return qualifier chain.
struct native_qualifier *(*__getDataPropertyQualifiers ) ( struct native_property *,
const char *,
CMPIStatus * );
};
struct native_qualifierFT
{
//! Function table version
int ftVersion;
//! Releases a complete list of native_qualifier items.
void (* release) ( struct native_qualifier * );
//! Clones a complete list of native_qualifier items.
struct native_qualifier * (* clone) ( struct native_qualifier *,
CMPIStatus * );
//! Adds a new native_qualifier to a list.
int (* addQualifier) ( struct native_qualifier **,
const char *,
CMPIType,
CMPIValueState,
CMPIValue * );
//! Resets the values of an existing native_qualifier, if existant.
int (* setQualifier) ( struct native_qualifier *,
const char *,
CMPIType,
CMPIValue * );
//! Looks up a specifix native_qualifier in CMPIData format.
CMPIData (* getDataQualifier) ( struct native_qualifier *,
const char *,
CMPIStatus * );
//! Extract an indexed native_qualifier in CMPIData format.
CMPIData (* getDataQualifierAt) ( struct native_qualifier *,
unsigned int,
CMPIString **,
CMPIStatus * );
//! Yields the number of native_qualifier items in a list.
CMPICount (* getQualifierCount) ( struct native_qualifier *,
CMPIStatus * );
};
struct native_methodFT
{
//! Function table version
int ftVersion;
//! Releases a complete list of native_method items.
void (* release) ( struct native_method * );
//! Clones a complete list of native_method items.
struct native_method * (* clone) ( struct native_method *,
CMPIStatus * );
//! Gets a native_property by name
struct native_method* (* getMethod) ( struct native_method *,
const char *);
//! Adds a new native_method to a list.
int (* addMethod) ( struct native_method **,
const char *,
CMPIType,
CMPIValueState,
CMPIValue * );
//! Resets the values of an existing native_method, if existent.
int (* setMethod) ( struct native_method *,
const char *,
CMPIType,
CMPIValue * );
//! Looks up a specific native_method in CMPIData format.
CMPIData (* getDataMethod) ( struct native_method *,
const char *,
CMPIStatus * );
//! Extract an indexed native_method in CMPIData format.
CMPIData (* getDataMethodAt) ( struct native_method *,
unsigned int,
CMPIString **,
CMPIStatus * );
//! Yields the number of native_method items in a list.
CMPICount (* getMethodCount) ( struct native_method *,
CMPIStatus * );
};
struct native_parameterFT
{
//! Function table version
int ftVersion;
//! Releases a complete list of native_parameter items.
void (* release) ( struct native_parameter * );
//! Clones a complete list of native_parameter items.
struct native_parameter * (* clone) ( struct native_parameter *,
CMPIStatus * );
//! Gets a native_property by name
struct native_parameter* (* getParameter) ( struct native_parameter *,
const char *);
//! Adds a new native_parameter to a list.
int (* addParameter) ( struct native_parameter **,
const char *,
CMPIType );
//! Resets the values of an existing native_parameter, if existent.
int (* setParameter) ( struct native_parameter *,
const char *,
CMPIType );
//! Looks up a specific native_parameter in CMPIData format.
CMPIData (* getDataParameter) ( struct native_parameter *,
const char *,
CMPIStatus * );
//! Extract an indexed native_parameter in CMPIData format.
CMPIData (* getDataParameterAt) ( struct native_parameter *,
unsigned int,
CMPIString **,
CMPIStatus * );
//! Yields the number of native_parameter items in a list.
CMPICount (* getParameterCount) ( struct native_parameter *,
CMPIStatus * );
};
extern int addInstQualifier( CMPIInstance* ci, char * name,
CMPIValue * value,
CMPIType type);
/****************************************************************************/
void native_release_CMPIValue ( CMPIType, CMPIValue * val );
CMPIValue native_clone_CMPIValue ( CMPIType, CMPIValue * val, CMPIStatus * );
CMPIString * native_new_CMPIString ( const char *, CMPIStatus * );
CMPIArray * native_new_CMPIArray ( CMPICount size,
CMPIType type,
CMPIStatus * );
void native_array_increase_size ( CMPIArray *, CMPICount );
CMPIEnumeration * native_new_CMPIEnumeration ( CMPIArray *, CMPIStatus * );
CMPIInstance * native_new_CMPIInstance ( CMPIObjectPath *, CMPIStatus * );
CMPIObjectPath * native_new_CMPIObjectPath ( const char *,
const char *,
CMPIStatus * );
CMPIArgs * native_new_CMPIArgs ( CMPIStatus * );
CMPIDateTime * native_new_CMPIDateTime ( CMPIStatus * );
CMPIDateTime * native_new_CMPIDateTime_fromBinary ( CMPIUint64,
CMPIBoolean,
CMPIStatus * );
CMPIDateTime * native_new_CMPIDateTime_fromChars ( const char *,
CMPIStatus * );
struct xtokValueReference;
CMPIValue str2CMPIValue(CMPIType type, char *val, struct xtokValueReference *ref);
void setInstNsAndCn(CMPIInstance *ci, const char *ns, char *cn);
CMPIStatus simpleArrayAdd(CMPIArray * array, CMPIValue * val, CMPIType type);
const char *getNameSpaceChars(CMPIObjectPath * cop);
CMPIValue *getKeyValueTypePtr(char *type, char *value, struct xtokValueReference *ref,
CMPIValue * val, CMPIType * typ);
#define newCMPIString native_new_CMPIString
#define newCMPIObjectPath native_new_CMPIObjectPath
#define newCMPIInstance native_new_CMPIInstance
#define newCMPIArray native_new_CMPIArray
#define newCMPIEnumeration native_new_CMPIEnumeration
#define newCMPIArgs native_new_CMPIArgs
/****************************************************************************/
extern struct native_methodFT const methodFT;
extern struct native_parameterFT const parameterFT;
extern struct native_propertyFT const propertyFT;
extern struct native_qualifierFT const qualifierFT;
#ifdef __cplusplus
}
#endif
#endif
/*** Local Variables: ***/
/*** mode: C ***/
/*** c-basic-offset: 8 ***/
/*** End: ***/