(file) Return to MessageQueue.cpp CVS log (file) (dir) Up to [Pegasus] / pegasus / src / Pegasus / Common

Diff for /pegasus/src/Pegasus/Common/MessageQueue.cpp between version 1.43 and 1.53

version 1.43, 2005/05/04 12:44:03 version 1.53, 2006/08/29 17:32:05
Line 1 
Line 1 
 //%2005////////////////////////////////////////////////////////////////////////  //%2006////////////////////////////////////////////////////////////////////////
 // //
 // Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development // Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development
 // Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems. // Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems.
Line 8 
Line 8 
 // IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group. // IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group.
 // Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.; // Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.;
 // EMC Corporation; VERITAS Software Corporation; The Open Group. // EMC Corporation; VERITAS Software Corporation; The Open Group.
   // Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.;
   // EMC Corporation; Symantec 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
Line 27 
Line 29 
 // //
 //============================================================================== //==============================================================================
 // //
 // Author: Mike Brasher (mbrasher@bmc.com)  
 //  
 // Modified By: Amit K Arora, IBM (amita@in.ibm.com) for Bug#1090  
 //              Josephine Eskaline Joyce, IBM (jojustin@in.ibm.com) for Bug#2076  
 //              David Dillard, VERITAS Software Corp.  
 //                  (david.dillard@veritas.com)  
 //  
 //%///////////////////////////////////////////////////////////////////////////// //%/////////////////////////////////////////////////////////////////////////////
  
 #include <Pegasus/Common/HashTable.h> #include <Pegasus/Common/HashTable.h>
 #include <Pegasus/Common/IPC.h>  
 #include <Pegasus/Common/Tracer.h> #include <Pegasus/Common/Tracer.h>
   #include <Pegasus/Common/CimomMessage.h>
 #include "MessageQueue.h" #include "MessageQueue.h"
 #include "MessageQueueService.h"  #include "IDFactory.h"
   
 PEGASUS_USING_STD; PEGASUS_USING_STD;
  
 PEGASUS_NAMESPACE_BEGIN PEGASUS_NAMESPACE_BEGIN
Line 51 
Line 47 
 static QueueTable _queueTable(256); static QueueTable _queueTable(256);
 static Mutex q_table_mut ; static Mutex q_table_mut ;
  
 void MessageQueue::remove_myself(Uint32 qid)  static IDFactory _qidFactory(CIMOM_Q_ID + 1);
 {  
     AutoMutex autoMut(q_table_mut);  
     _queueTable.remove(qid);  
 }  
   
  
 Uint32 MessageQueue::getNextQueueId() Uint32 MessageQueue::getNextQueueId()
 { {
     static Uint32 _nextQueueId = 2;      return _qidFactory.getID();
   
     //  
     // Lock mutex:  
     //  
     static Mutex _id_mut ;  
     AutoMutex autoMut(_id_mut);  
   
     Uint32 queueId;  
   
     // Assign the next queue ID that is not already in use  
     do  
     {  
         // Handle wrap around and never assign zero or one as a queue id:  
         if (_nextQueueId == 0)  
         {  
             _nextQueueId = 2;  
         }         }
  
         queueId = _nextQueueId++;  void MessageQueue::putQueueId(Uint32 queueId)
     } while (lookup(queueId) != 0);  {
       if (queueId != CIMOM_Q_ID)
     return queueId;          _qidFactory.putID(queueId);
 } }
  
   
   
 MessageQueue::MessageQueue( MessageQueue::MessageQueue(
     const char* name,     const char* name,
     Boolean async,     Boolean async,
     Uint32 queueId)     Uint32 queueId)
    : _queueId(queueId), _capabilities(0), _count(0), _front(0), _back(0), _async(async)     : _queueId(queueId), _capabilities(0), _async(async)
 { {
     //     //
     // Copy the name:     // Copy the name:
Line 134 
Line 107 
  
     delete [] _name;     delete [] _name;
  
     while(_front)      // Return the queue id.
     {  
        Message* tmp = _front;      putQueueId(_queueId);
        _front = _front->_next;  
        delete tmp;  
     }  
  
     PEG_METHOD_EXIT();     PEG_METHOD_EXIT();
 } }
Line 148 
Line 118 
 { {
     PEG_METHOD_ENTER(TRC_MESSAGEQUEUESERVICE,"MessageQueue::enqueue()");     PEG_METHOD_ENTER(TRC_MESSAGEQUEUESERVICE,"MessageQueue::enqueue()");
  
     if (!message)      PEGASUS_ASSERT(message != 0);
     {  
         Tracer::trace(TRC_MESSAGEQUEUESERVICE, Tracer::LEVEL3,  
                     "MessageQueue::enqueue failure");  
         PEG_METHOD_EXIT();  
         throw NullPointer();  
     }  
  
     PEG_TRACE_STRING( TRC_MESSAGEQUEUESERVICE, Tracer::LEVEL3,     PEG_TRACE_STRING( TRC_MESSAGEQUEUESERVICE, Tracer::LEVEL3,
                       String("Queue name: ") + getQueueName() ) ;                       String("Queue name: ") + getQueueName() ) ;
     Tracer::trace   ( TRC_MESSAGEQUEUESERVICE,     Tracer::trace   ( TRC_MESSAGEQUEUESERVICE,
                       Tracer::LEVEL3,                       Tracer::LEVEL3,
                       "Message: [%s, %d]",                        "Message: [%s]",
                       MessageTypeToString(message->getType()),                        MessageTypeToString(message->getType()));
                       message->getKey() );  
  
     {      _messageList.insert_back(message);
     AutoMutex autoMut(_mut);  
     if (_back)  
     {  
         _back->_next = message;  
         message->_prev = _back;  
         message->_next = 0;  
         _back = message;  
     }  
     else  
     {  
         _front = message;  
         _back = message;  
         message->_prev = 0;  
         message->_next = 0;  
     }  
     message->_owner = this;  
   
     _count++;  
     Tracer::trace(TRC_MESSAGEQUEUESERVICE, Tracer::LEVEL4,  
                   "MessageQueue::enqueue _queueId = %d, _count = %d", _queueId, _count);  
   
     } // mutex unlocks here  
  
     handleEnqueue();     handleEnqueue();
     PEG_METHOD_EXIT();     PEG_METHOD_EXIT();
Line 196 
Line 137 
 { {
     PEG_METHOD_ENTER(TRC_MESSAGEQUEUESERVICE,"MessageQueue::dequeue()");     PEG_METHOD_ENTER(TRC_MESSAGEQUEUESERVICE,"MessageQueue::dequeue()");
  
     AutoMutex autoMut(_mut);      Message* message = _messageList.remove_front();
     if (_front)  
     {  
         Message* message = _front;  
         _front = _front->_next;  
         if (_front)  
             _front->_prev = 0;  
   
         if (_back == message)  
             _back = 0;  
   
         _count--;  
         Tracer::trace(TRC_MESSAGEQUEUESERVICE, Tracer::LEVEL4,  
             "MessageQueue::dequeue _queueId = %d, _count = %d",  
             _queueId, _count);  
   
         message->_next = 0;  
         message->_prev = 0;  
         message->_owner = 0;  
  
         PEG_METHOD_EXIT();         PEG_METHOD_EXIT();
         return message;         return message;
     }     }
  
     PEG_METHOD_EXIT();  
     return 0;  
 }  
   
   
   
 void MessageQueue::remove(Message* message)  
 {  
     PEG_METHOD_ENTER(TRC_MESSAGEQUEUESERVICE,"MessageQueue::remove()");  
   
     if (!message)  
     {  
         PEG_METHOD_EXIT();  
         throw NullPointer();  
     }  
   
     if (message->_owner != this)  
     {  
         PEG_METHOD_EXIT();  
         throw NoSuchMessageOnQueue();  
     }  
   
     {  
     AutoMutex autoMut(_mut);  
   
     if (message->_next)  
         message->_next->_prev = message->_prev;  
     else  
         _back = message->_prev;  
   
     if (message->_prev)  
         message->_prev->_next = message->_next;  
     else  
         _front = message->_next;  
   
     _count--;  
     Tracer::trace(TRC_MESSAGEQUEUESERVICE, Tracer::LEVEL4,  
        "MessageQueue::remove _count = %d", _count);  
   
     } // mutex unlocks here  
   
     message->_prev = 0;  
     message->_next = 0;  
     message->_owner = 0;  
   
     PEG_METHOD_EXIT();  
 }  
   
 Message* MessageQueue::findByType(Uint32 type)  
 {  
     AutoMutex autoMut(_mut);  
   
     for (Message* m = front(); m; m = m->getNext())  
     {  
         if (m->getType() == type)  
         {  
             return m;  
         }  
     }  
   
     return 0;  
 }  
   
 Message* MessageQueue::findByKey(Uint32 key)  
 {  
     AutoMutex autoMut(_mut);  
   
     for (Message* m = front(); m; m = m->getNext())  
     {  
        if (m->getKey() == key)  
        {  
           return m;  
        }  
   
     }  
   
     return 0;  
 }  
   
 void MessageQueue::print(ostream& os) const  
 {  
     AutoMutex autoMut(const_cast<MessageQueue *>(this)->_mut);  
   
     for (const Message* m = front(); m; m = m->getNext())  
         m->print(os);  
 }  
   
 Message* MessageQueue::find(Uint32 type, Uint32 key)  
 {  
     AutoMutex autoMut(_mut);  
   
     for (Message* m = front(); m; m = m->getNext())  
     {  
         if (m->getType() == type && m->getKey() == key)  
         {  
             return m;  
         }  
     }  
   
     return 0;  
 }  
   
 void MessageQueue::lock()  
 {  
     _mut.lock(pegasus_thread_self());  
 }  
   
 void MessageQueue::unlock()  
 {  
     _mut.unlock();  
 }  
   
 const char* MessageQueue::getQueueName() const const char* MessageQueue::getQueueName() const
 { {
     return _name;     return _name;


Legend:
Removed from v.1.43  
changed lines
  Added in v.1.53

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2