version 1.6, 2003/08/21 19:36:25
|
version 1.9, 2003/10/08 16:31:16
|
|
|
Array<Pair<String, String> > temp; | Array<Pair<String, String> > temp; |
| |
#if defined(ENABLE_DEFAULT_PROVIDER_MANAGER) | #if defined(ENABLE_DEFAULT_PROVIDER_MANAGER) |
|
#if defined(PEGASUS_OS_OS400) |
|
temp.append(Pair<String, String>(_resolveFileName("QSYS/QYCMDFTPVM"), String("DEFAULT"))); |
|
#else |
temp.append(Pair<String, String>(_resolveFileName("DefaultProviderManager"), String("DEFAULT"))); | temp.append(Pair<String, String>(_resolveFileName("DefaultProviderManager"), String("DEFAULT"))); |
#endif | #endif |
|
#endif |
| |
#if defined(ENABLE_CMPI_PROVIDER_MANAGER) | #if defined(ENABLE_CMPI_PROVIDER_MANAGER) |
|
#if defined(PEGASUS_OS_OS400) |
|
temp.append(Pair<String, String>(_resolveFileName("QSYS/QYCMCMPIPM"), String("CMPI"))); |
|
#else |
temp.append(Pair<String, String>(_resolveFileName("CMPIProviderManager"), String("CMPI"))); | temp.append(Pair<String, String>(_resolveFileName("CMPIProviderManager"), String("CMPI"))); |
#endif | #endif |
|
#endif |
| |
return(temp); | return(temp); |
} | } |
|
|
throw 0; // ATTN: inefficient | throw 0; // ATTN: inefficient |
} | } |
| |
// ATTN: only set the hacked/cached provider registration manager pointer after the |
|
// DEFAULT provider manager is loaded. |
|
if(String::equalNoCase(_fileNames[i].second, "DEFAULT")) |
|
{ |
|
manager->setProviderRegistrationManager(providerRegistrationManager); |
|
} |
|
|
|
_providerManagers.append(Pair<ProviderManager *, ProviderManagerModule>(manager, module)); | _providerManagers.append(Pair<ProviderManager *, ProviderManagerModule>(manager, module)); |
} | } |
catch(...) | catch(...) |
|
|
{ | { |
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"); |
| |
|
|
} | } |
| |
PEGASUS_NAMESPACE_END | PEGASUS_NAMESPACE_END |
|
|