version 1.6, 2003/08/21 19:36:25
|
version 1.20, 2003/11/04 03:51:27
|
|
|
//%///////////////////////////////////////////////////////////////////////////// |
//%2003//////////////////////////////////////////////////////////////////////// |
// | // |
// Copyright (c) 2000 - 2003 BMC Software, Hewlett-Packard Company, IBM, |
// Copyright (c) 2000, 2001, 2002 BMC Software, Hewlett-Packard Development |
// The Open Group, Tivoli Systems |
// Company, L. P., IBM Corp., The Open Group, Tivoli Systems. |
|
// Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L. P.; |
|
// IBM Corp.; EMC Corporation, The Open Group. |
// | // |
// Permission is hereby granted, free of charge, to any person obtaining a copy | // Permission is hereby granted, free of charge, to any person obtaining a copy |
// of this software and associated documentation files (the "Software"), to | // of this software and associated documentation files (the "Software"), to |
|
|
// Mike Day, IBM (mdday@us.ibm.com) | // Mike Day, IBM (mdday@us.ibm.com) |
// Karl Schopmeyer(k.schopmeyer@opengroup.org) - Fix associators. | // Karl Schopmeyer(k.schopmeyer@opengroup.org) - Fix associators. |
// Yi Zhou, Hewlett-Packard Company (yi_zhou@hp.com) | // Yi Zhou, Hewlett-Packard Company (yi_zhou@hp.com) |
|
// Adrian Schuur, IBM (schuur@de.ibm.com) |
// | // |
//%///////////////////////////////////////////////////////////////////////////// | //%///////////////////////////////////////////////////////////////////////////// |
| |
|
|
| |
#include <Pegasus/Config/ConfigManager.h> | #include <Pegasus/Config/ConfigManager.h> |
| |
PEGASUS_NAMESPACE_BEGIN |
#include <Pegasus/ProviderManager2/ProviderManagerModule.h> |
|
#include <Pegasus/ProviderManager2/ProviderManager.h> |
| |
// ATTN: this section is a temporary solution to populate the list of enabled |
PEGASUS_NAMESPACE_BEGIN |
// provider managers for a given distribution. it includes another temporary |
|
// solution for converting a generic file name into a file name useable by |
|
// each platform. |
|
| |
// BEGIN TEMP SECTION | // BEGIN TEMP SECTION |
String _resolveFileName(const String & fileName) |
class ProviderManagerContainer |
{ | { |
String temp; |
public: |
|
ProviderManagerContainer(void) : _manager(0) |
|
{ |
|
} |
| |
|
ProviderManagerContainer(const ProviderManagerContainer & container) : _manager(0) |
|
{ |
|
*this = container; |
|
} |
|
|
|
ProviderManagerContainer(const String & physicalName, const String & logicalName, const String & interfaceName) : _manager(0) |
|
{ |
#if defined(PEGASUS_OS_TYPE_WINDOWS) | #if defined(PEGASUS_OS_TYPE_WINDOWS) |
temp = fileName + String(".dll"); |
_physicalName = physicalName + String(".dll"); |
#elif defined(PEGASUS_OS_HPUX) && defined(PEGASUS_PLATFORM_HPUX_PARISC_ACC) | #elif defined(PEGASUS_OS_HPUX) && defined(PEGASUS_PLATFORM_HPUX_PARISC_ACC) |
temp = ConfigManager::getHomedPath(ConfigManager::getInstance()->getCurrentValue("providerDir")); |
_physicalName = ConfigManager::getHomedPath(ConfigManager::getInstance()->getCurrentValue("providerDir")); |
temp.append(String("/lib") + fileName + String(".sl")); |
_physicalName.append(String("/lib") + physicalName + String(".sl")); |
#elif defined(PEGASUS_OS_HPUX) && !defined(PEGASUS_PLATFORM_HPUX_PARISC_ACC) | #elif defined(PEGASUS_OS_HPUX) && !defined(PEGASUS_PLATFORM_HPUX_PARISC_ACC) |
temp = ConfigManager::getHomedPath(ConfigManager::getInstance()->getCurrentValue("providerDir")); |
_physicalName = ConfigManager::getHomedPath(ConfigManager::getInstance()->getCurrentValue("providerDir")); |
temp.append(String("/lib") + fileName + String(".so")); |
_physicalName.append(String("/lib") + physicalName + String(".so")); |
#elif defined(PEGASUS_OS_OS400) | #elif defined(PEGASUS_OS_OS400) |
temp = fileName; |
_physicalName = physicalName; |
#else | #else |
temp = ConfigManager::getHomedPath(ConfigManager::getInstance()->getCurrentValue("providerDir")); |
_physicalName = ConfigManager::getHomedPath(ConfigManager::getInstance()->getCurrentValue("providerDir")); |
temp.append(String("/lib") + fileName + String(".so")); |
_physicalName.append(String("/lib") + physicalName + String(".so")); |
#endif | #endif |
| |
return(temp); |
_logicalName = logicalName; |
} |
|
| |
Array<Pair<String, String> > _initializeFileNames(void) |
_interfaceName = interfaceName; |
{ |
|
Array<Pair<String, String> > temp; |
|
| |
#if defined(ENABLE_DEFAULT_PROVIDER_MANAGER) |
_module = ProviderManagerModule(_physicalName); |
temp.append(Pair<String, String>(_resolveFileName("DefaultProviderManager"), String("DEFAULT"))); |
|
#endif |
|
| |
#if defined(ENABLE_CMPI_PROVIDER_MANAGER) |
_module.load(); |
temp.append(Pair<String, String>(_resolveFileName("CMPIProviderManager"), String("CMPI"))); |
|
#endif |
|
| |
return(temp); |
_manager = _module.getProviderManager(_logicalName); |
} |
|
| |
static const Array<Pair<String,String> > _fileNames = _initializeFileNames(); |
PEGASUS_ASSERT(_manager != 0); |
// END TEMP SECTION |
} |
| |
inline Boolean _isSupportedRequestType(const Message * message) |
~ProviderManagerContainer(void) |
{ | { |
Boolean rc = false; |
_module.unload(); |
|
} |
| |
if(message == 0) |
ProviderManagerContainer & operator=(const ProviderManagerContainer & container) |
|
{ |
|
if(this == &container) |
{ | { |
return(rc); |
return(*this); |
} | } |
| |
/* |
_logicalName = container._logicalName; |
// ATTN : need to determine valid request message types |
_physicalName = container._physicalName; |
// before enabling. |
_interfaceName = container._interfaceName; |
|
|
switch(message->getType()) |
|
{ |
|
case CIM_GET_INSTANCE_REQUEST_MESSAGE: |
|
case CIM_ENUMERATE_INSTANCES_REQUEST_MESSAGE: |
|
case CIM_ENUMERATE_INSTANCE_NAMES_REQUEST_MESSAGE: |
|
case CIM_CREATE_INSTANCE_REQUEST_MESSAGE: |
|
case CIM_MODIFY_INSTANCE_REQUEST_MESSAGE: |
|
case CIM_DELETE_INSTANCE_REQUEST_MESSAGE: |
|
case CIM_EXEC_QUERY_REQUEST_MESSAGE: |
|
case CIM_ASSOCIATORS_REQUEST_MESSAGE: |
|
case CIM_ASSOCIATOR_NAMES_REQUEST_MESSAGE: |
|
case CIM_REFERENCES_REQUEST_MESSAGE: |
|
case CIM_REFERENCE_NAMES_REQUEST_MESSAGE: |
|
case CIM_GET_PROPERTY_REQUEST_MESSAGE: |
|
case CIM_SET_PROPERTY_REQUEST_MESSAGE: |
|
case CIM_INVOKE_METHOD_REQUEST_MESSAGE: |
|
case CIM_CREATE_SUBSCRIPTION_REQUEST_MESSAGE: |
|
case CIM_MODIFY_SUBSCRIPTION_REQUEST_MESSAGE: |
|
case CIM_DELETE_SUBSCRIPTION_REQUEST_MESSAGE: |
|
case CIM_ENABLE_INDICATIONS_REQUEST_MESSAGE: |
|
case CIM_DISABLE_INDICATIONS_REQUEST_MESSAGE: |
|
case CIM_DISABLE_MODULE_REQUEST_MESSAGE: |
|
case CIM_ENABLE_MODULE_REQUEST_MESSAGE: |
|
case CIM_STOP_ALL_PROVIDERS_REQUEST_MESSAGE: |
|
case CIM_CONSUME_INDICATION_REQUEST_MESSAGE: |
|
rc = true; |
|
| |
break; |
_module = container._module; |
default: |
_manager = container._manager; |
rc = false; |
|
| |
break; |
return(*this); |
} | } |
*/ |
|
| |
rc = true; |
ProviderManager *getProviderManager(void) |
|
{ |
return(rc); |
return _manager; |
} | } |
| |
inline Boolean _isSupportedResponseType(const Message * message) |
const String & getPhysicalName(void) const |
{ | { |
Boolean rc = false; |
return(_physicalName); |
|
|
return(rc); |
|
} | } |
| |
ProviderManagerService::ProviderManagerService(void) |
const String & getLogicalName(void) const |
: MessageQueueService(PEGASUS_QUEUENAME_PROVIDERMANAGER_CPP) |
|
{ | { |
|
return(_logicalName); |
} | } |
| |
ProviderManagerService::ProviderManagerService(ProviderRegistrationManager * providerRegistrationManager) |
const String & getInterfaceName(void) const |
: MessageQueueService(PEGASUS_QUEUENAME_PROVIDERMANAGER_CPP) |
|
{ |
|
for(Uint32 i = 0, n = _fileNames.size(); i < n; i++) |
|
{ | { |
String message; |
return(_interfaceName); |
|
} |
| |
message = "ProviderManagerService::ProviderManagerService() loading " + |
private: |
_fileNames[i].first + "(" + _fileNames[i].second + ")"; |
String _physicalName; |
|
String _logicalName; |
|
String _interfaceName; |
| |
PEG_TRACE_STRING(TRC_PROVIDERMANAGER, Tracer::LEVEL4, message); |
ProviderManagerModule _module; |
|
ProviderManager * _manager; |
| |
try |
}; |
{ |
|
ProviderManagerModule module(_fileNames[i].first); |
static Array<ProviderManagerContainer*> _providerManagers; |
|
// END TEMP SECTION |
| |
if(module.load() == false) |
inline Boolean _isSupportedRequestType(const Message * message) |
{ | { |
throw 0; // ATTN: inefficient |
// ATTN: needs implementation |
} |
|
| |
ProviderManager * manager = module.getProviderManager(_fileNames[i].second); |
// for now, assume all requests are valid |
| |
if(manager == 0) |
return(true); |
{ |
|
throw 0; // ATTN: inefficient |
|
} | } |
| |
// ATTN: only set the hacked/cached provider registration manager pointer after the |
inline Boolean _isSupportedResponseType(const Message * message) |
// DEFAULT provider manager is loaded. |
|
if(String::equalNoCase(_fileNames[i].second, "DEFAULT")) |
|
{ | { |
manager->setProviderRegistrationManager(providerRegistrationManager); |
// ATTN: needs implementation |
|
|
|
// for now, assume all responses are invalid |
|
|
|
return(false); |
} | } |
| |
_providerManagers.append(Pair<ProviderManager *, ProviderManagerModule>(manager, module)); |
ProviderManagerService* ProviderManagerService::providerManagerService=NULL; |
|
|
|
ProviderManagerService::ProviderManagerService(void) |
|
: MessageQueueService(PEGASUS_QUEUENAME_PROVIDERMANAGER_CPP) |
|
{ |
|
providerManagerService=this; |
} | } |
catch(...) |
|
|
ProviderManagerService::ProviderManagerService(ProviderRegistrationManager * providerRegistrationManager) |
|
: MessageQueueService(PEGASUS_QUEUENAME_PROVIDERMANAGER_CPP) |
{ | { |
message = "ProviderManagerService::ProviderManagerService() exception loading " + |
providerManagerService=this; |
_fileNames[i].first + "(" + _fileNames[i].second + ")"; |
SetProviderRegistrationManager(providerRegistrationManager); |
| |
PEG_TRACE_STRING(TRC_PROVIDERMANAGER, Tracer::LEVEL4, message); |
// ATTN: this section is a temporary solution to populate the list of enabled |
} |
// provider managers for a given distribution. it includes another temporary |
} |
// solution for converting a generic file name into a file name useable by |
|
// each platform. |
|
|
|
// BEGIN TEMP SECTION |
|
//#if defined(PEGASUS_OS_OS400) |
|
//_providerManagers.append(ProviderManagerContainer("QSYS/??????????", "INTERNAL", "INTERNAL")); |
|
//#else |
|
//_providerManager.append(ProviderManagerContainer("InternalProviderManager", "DEFAULT", "INTERNAL")); |
|
//#endif |
|
|
|
#if defined(ENABLE_DEFAULT_PROVIDER_MANAGER) |
|
#if defined(PEGASUS_OS_OS400) |
|
_providerManagers.append( |
|
new ProviderManagerContainer("QSYS/QYCMDFTPVM", "DEFAULT", "C++Default")); |
|
#else |
|
_providerManagers.append( |
|
new ProviderManagerContainer("DefaultProviderManager", "DEFAULT", "C++Default")); |
|
#endif |
|
#endif |
|
|
|
#if defined(ENABLE_CMPI_PROVIDER_MANAGER) |
|
#if defined(PEGASUS_OS_OS400) |
|
_providerManagers.append( |
|
new ProviderManagerContainer("QSYS/QYCMCMPIPM", "CMPI", "CMPI")); |
|
#else |
|
_providerManagers.append( |
|
new ProviderManagerContainer("CMPIProviderManager", "CMPI", "CMPI")); |
|
#endif |
|
#endif |
|
// END TEMP SECTION |
} | } |
| |
ProviderManagerService::~ProviderManagerService(void) | ProviderManagerService::~ProviderManagerService(void) |
{ | { |
|
providerManagerService=NULL; |
} | } |
| |
Boolean ProviderManagerService::messageOK(const Message * message) | Boolean ProviderManagerService::messageOK(const Message * message) |
|
|
{ | { |
PEG_METHOD_ENTER(TRC_PROVIDERMANAGER, "ProviderManagerService::handleCimOperation"); | PEG_METHOD_ENTER(TRC_PROVIDERMANAGER, "ProviderManagerService::handleCimOperation"); |
| |
|
if(arg == 0) |
|
{ |
|
// thread started with invalid argument. |
|
return(PEGASUS_THREAD_RETURN(1)); |
|
} |
|
|
// get the service from argument | // get the service from argument |
ProviderManagerService * service = reinterpret_cast<ProviderManagerService *>(arg); | ProviderManagerService * service = reinterpret_cast<ProviderManagerService *>(arg); |
| |
PEGASUS_ASSERT(service != 0); |
|
|
|
if(service->_incomingQueue.size() == 0) | if(service->_incomingQueue.size() == 0) |
{ | { |
PEG_TRACE_STRING(TRC_PROVIDERMANAGER, Tracer::LEVEL4, | PEG_TRACE_STRING(TRC_PROVIDERMANAGER, Tracer::LEVEL4, |
|
|
| |
AsyncOpNode * op = service->_incomingQueue.dequeue(); | AsyncOpNode * op = service->_incomingQueue.dequeue(); |
| |
PEGASUS_ASSERT(op != 0 ); |
if((op == 0) || (op->_request.count() == 0)) |
|
|
if(op->_request.count() == 0) |
|
{ | { |
MessageQueue * queue = MessageQueue::lookup(op->_source_queue); | MessageQueue * queue = MessageQueue::lookup(op->_source_queue); |
| |
|
|
| |
AsyncRequest * request = static_cast<AsyncRequest *>(op->_request.next(0)); | AsyncRequest * request = static_cast<AsyncRequest *>(op->_request.next(0)); |
| |
PEGASUS_ASSERT(request != 0); |
if((request == 0) || (request->getType() != async_messages::ASYNC_LEGACY_OP_START)) |
|
|
if(request->getType() != async_messages::ASYNC_LEGACY_OP_START) |
|
{ | { |
// reply with NAK | // reply with NAK |
| |
|
|
return(PEGASUS_THREAD_RETURN(0)); | return(PEGASUS_THREAD_RETURN(0)); |
} | } |
| |
|
try |
|
{ |
Message * legacy = static_cast<AsyncLegacyOperationStart *>(request)->get_action(); | Message * legacy = static_cast<AsyncLegacyOperationStart *>(request)->get_action(); |
| |
if(_isSupportedRequestType(legacy)) | if(_isSupportedRequestType(legacy)) |
|
|
Thread::clearLanguages(); | Thread::clearLanguages(); |
} | } |
| |
try |
|
{ |
|
service->handleCimRequest(op, legacy); | service->handleCimRequest(op, legacy); |
} | } |
|
} |
catch(...) | catch(...) |
{ | { |
// ATTN: log error | // ATTN: log error |
} | } |
} |
|
| |
PEG_METHOD_EXIT(); | PEG_METHOD_EXIT(); |
| |
return(PEGASUS_THREAD_RETURN(0)); | return(PEGASUS_THREAD_RETURN(0)); |
} | } |
| |
void ProviderManagerService::handleCimRequest(AsyncOpNode * op, const Message * message) throw() |
void ProviderManagerService::handleCimRequest(AsyncOpNode * op, const Message * message) |
{ | { |
PEG_METHOD_ENTER(TRC_PROVIDERMANAGER, "ProviderManagerService::handleCimRequest"); | PEG_METHOD_ENTER(TRC_PROVIDERMANAGER, "ProviderManagerService::handleCimRequest"); |
| |
|
|
| |
Message * response = 0; | Message * response = 0; |
| |
// find provider manager |
// get the responsible provider Manager |
// ATTN: implement efficient lookup |
ProviderManager *pm=locateProviderManager(message); |
ProviderManager * manager = _providerManagers[0].first; |
if (pm) { |
|
response = pm->processMessage(request); |
try |
|
{ |
|
PEG_TRACE_STRING(TRC_PROVIDERMANAGER, Tracer::LEVEL4, |
|
"ProviderManagerService::handleCimRequest() passing control to provider manager."); |
|
|
|
// forward request |
|
response = manager->processMessage(request); |
|
} | } |
catch(...) |
else { |
{ |
// no provider manager found ... |
// ATTN: create response with error message |
|
} | } |
| |
// preserve message key | // preserve message key |
|
|
PEG_METHOD_EXIT(); | PEG_METHOD_EXIT(); |
} | } |
| |
|
ProviderManager* ProviderManagerService::locateProviderManager(const Message *message) |
|
{ |
|
String nameSpace; |
|
String className; |
|
Uint32 type=ProviderType::INSTANCE; |
|
|
|
switch(message->getType()) |
|
{ |
|
case CIM_GET_INSTANCE_REQUEST_MESSAGE: |
|
{ |
|
const CIMGetInstanceRequestMessage * p = dynamic_cast<const CIMGetInstanceRequestMessage *>(message); |
|
|
|
PEGASUS_ASSERT(p != 0); |
|
|
|
nameSpace = p->nameSpace.getString(); |
|
className = p->instanceName.getClassName().getString(); |
|
} |
|
|
|
break; |
|
case CIM_ENUMERATE_INSTANCES_REQUEST_MESSAGE: |
|
{ |
|
const CIMEnumerateInstancesRequestMessage * p = dynamic_cast<const CIMEnumerateInstancesRequestMessage *>(message); |
|
|
|
PEGASUS_ASSERT(p != 0); |
|
|
|
nameSpace = p->nameSpace.getString(); |
|
className = p->className.getString(); |
|
} |
|
|
|
break; |
|
case CIM_ENUMERATE_INSTANCE_NAMES_REQUEST_MESSAGE: |
|
{ |
|
const CIMEnumerateInstanceNamesRequestMessage * p = dynamic_cast<const CIMEnumerateInstanceNamesRequestMessage *>(message); |
|
|
|
PEGASUS_ASSERT(p != 0); |
|
|
|
nameSpace = p->nameSpace.getString(); |
|
className = p->className.getString(); |
|
} |
|
|
|
break; |
|
case CIM_CREATE_INSTANCE_REQUEST_MESSAGE: |
|
{ |
|
const CIMCreateInstanceRequestMessage * p = dynamic_cast<const CIMCreateInstanceRequestMessage *>(message); |
|
|
|
PEGASUS_ASSERT(p != 0); |
|
|
|
nameSpace = p->nameSpace.getString(); |
|
className = p->newInstance.getClassName().getString(); |
|
} |
|
|
|
break; |
|
case CIM_MODIFY_INSTANCE_REQUEST_MESSAGE: |
|
{ |
|
const CIMModifyInstanceRequestMessage * p = dynamic_cast<const CIMModifyInstanceRequestMessage *>(message); |
|
|
|
PEGASUS_ASSERT(p != 0); |
|
|
|
nameSpace = p->nameSpace.getString(); |
|
className = p->modifiedInstance.getClassName().getString(); |
|
} |
|
|
|
break; |
|
case CIM_DELETE_INSTANCE_REQUEST_MESSAGE: |
|
{ |
|
const CIMDeleteInstanceRequestMessage * p = dynamic_cast<const CIMDeleteInstanceRequestMessage *>(message); |
|
|
|
PEGASUS_ASSERT(p != 0); |
|
|
|
nameSpace = p->nameSpace.getString(); |
|
className = p->instanceName.getClassName().getString(); |
|
} |
|
|
|
break; |
|
case CIM_EXEC_QUERY_REQUEST_MESSAGE: |
|
break; |
|
case CIM_ASSOCIATORS_REQUEST_MESSAGE: |
|
{ |
|
const CIMAssociatorsRequestMessage * p = dynamic_cast<const CIMAssociatorsRequestMessage *>(message); |
|
|
|
PEGASUS_ASSERT(p != 0); |
|
|
|
nameSpace = p->nameSpace.getString(); |
|
className = p->assocClass.getString(); |
|
type=ProviderType::ASSOCIATION; |
|
} |
|
|
|
break; |
|
case CIM_ASSOCIATOR_NAMES_REQUEST_MESSAGE: |
|
{ |
|
const CIMAssociatorNamesRequestMessage * p = dynamic_cast<const CIMAssociatorNamesRequestMessage *>(message); |
|
|
|
PEGASUS_ASSERT(p != 0); |
|
|
|
nameSpace = p->nameSpace.getString(); |
|
className = p->assocClass.getString(); |
|
std::cout<<"--- className: "<<className<<std::endl; |
|
type=ProviderType::ASSOCIATION; |
|
} |
|
|
|
break; |
|
case CIM_REFERENCES_REQUEST_MESSAGE: |
|
{ |
|
const CIMReferencesRequestMessage * p = dynamic_cast<const CIMReferencesRequestMessage *>(message); |
|
|
|
PEGASUS_ASSERT(p != 0); |
|
|
|
nameSpace = p->nameSpace.getString(); |
|
className = p->resultClass.getString(); |
|
type=ProviderType::ASSOCIATION; |
|
} |
|
|
|
break; |
|
case CIM_REFERENCE_NAMES_REQUEST_MESSAGE: |
|
{ |
|
const CIMReferenceNamesRequestMessage * p = dynamic_cast<const CIMReferenceNamesRequestMessage *>(message); |
|
|
|
PEGASUS_ASSERT(p != 0); |
|
|
|
nameSpace = p->nameSpace.getString(); |
|
className = p->resultClass.getString(); |
|
type=ProviderType::ASSOCIATION; |
|
} |
|
|
|
break; |
|
case CIM_INVOKE_METHOD_REQUEST_MESSAGE: |
|
{ |
|
const CIMInvokeMethodRequestMessage * p = dynamic_cast<const CIMInvokeMethodRequestMessage *>(message); |
|
|
|
PEGASUS_ASSERT(p != 0); |
|
|
|
nameSpace = p->nameSpace.getString(); |
|
type=ProviderType::METHOD; |
|
} |
|
|
|
break; |
|
|
|
case CIM_CREATE_SUBSCRIPTION_REQUEST_MESSAGE: |
|
{ |
|
const CIMCreateSubscriptionRequestMessage * p = dynamic_cast<const CIMCreateSubscriptionRequestMessage *>(message); |
|
|
|
PEGASUS_ASSERT(p != 0); |
|
nameSpace = p->nameSpace.getString(); |
|
std::cout<<"--- nameSpace: "<<nameSpace<<std::endl; |
|
className = p->classNames[0].getString(); |
|
std::cout<<"--- className: "<<className<<std::endl; |
|
type=ProviderType::INDICATION; |
|
} |
|
|
|
break; |
|
default: |
|
//asm("int $3"); |
|
break; |
|
} |
|
|
|
ProviderName name( |
|
CIMObjectPath(String::EMPTY, nameSpace, className).toString(), |
|
String::EMPTY, |
|
String::EMPTY, |
|
String::EMPTY, |
|
type); |
|
|
|
std::cout<<"--- name: "<<name.toString()<<std::endl; |
|
|
|
// find provider manager |
|
name = ProviderRegistrar().findProvider(name); |
|
|
|
std::cout<<"--- name.getInterfaceName(): "<<name.getInterfaceName()<<std::endl; |
|
|
|
// find provider manager for provider interface |
|
for(Uint32 i = 0, n = _providerManagers.size(); i < n; i++) |
|
{ |
|
if (String::equalNoCase(name.getInterfaceName(), _providerManagers[i]->getInterfaceName())) { |
|
ProviderManagerContainer *pmc=_providerManagers[i]; |
|
return pmc->getProviderManager(); |
|
} |
|
} |
|
return NULL; |
|
} |
|
|
void ProviderManagerService::unload_idle_providers(void) | void ProviderManagerService::unload_idle_providers(void) |
{ | { |
} | } |
| |
PEGASUS_NAMESPACE_END | PEGASUS_NAMESPACE_END |
|
|