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

Diff for /pegasus/src/Pegasus/Common/StatisticalData.cpp between version 1.22.8.5 and 1.24

version 1.22.8.5, 2013/10/13 21:31:59 version 1.24, 2014/08/27 23:10:08
Line 48 
Line 48 
                                     // Pegasus        CIM_StatisticalData                                     // Pegasus        CIM_StatisticalData
                                     // message type                                     // message type
                                     // -------------- -------------------                                     // -------------- -------------------
   "Unknown",                        //                 0   default  //"Unknown",                        //                 0   default
   "Other",                          //                 1   mapped  //"Other",                          //                 1   mapped
   "Batched",                        //                 2   not used  //"Batched",                        //                 2   not used
   "GetClass",                       //     1           3   "GetClass",                       //     1           3
   "GetInstance",                    //     2           4   "GetInstance",                    //     2           4
   "IndicationDelivery",             //     3          26   "IndicationDelivery",             //     3          26
Line 68 
Line 68 
   "Associators",                    //    16          16   "Associators",                    //    16          16
   "AssociatorNames",                //    17          17   "AssociatorNames",                //    17          17
   "References",                     //    18          18   "References",                     //    18          18
   "ReferenceNames",                 //    19          20    "ReferenceNames",                 //    19          19
   "SetProperty",                    //    20          21    "GetProperty",                    //    20          20
   "GetQualifier",                   //    21          22    "SetProperty",                    //    21          21
   "SetQualifier",                   //    22          23    "GetQualifier",                   //    22          22
   "DeleteQualifier",                //    23          24    "SetQualifier",                   //    23          23
   "EnumerateQualifiers",            //    24          25    "DeleteQualifier",                //    24          24
     "EnumerateQualifiers",            //    25          25
 // Entries below this point are not part of the CIM Class and are treated // Entries below this point are not part of the CIM Class and are treated
 // as OtherOperationTypes in the instance.  // as OtherOperationTypes in the CIM_CIMOMStatisticalData instance.
   "InvokeMethod"                    //     25          Not Present index = 26    "InvokeMethod",                    //    26          Not Present index = 26
 //EXP_PULL_BEGIN //EXP_PULL_BEGIN
 //// TODO these are not defined in CIM_StatisticalData class and are  //// These are not defined in CIM_StatisticalData class and are
 ///  represented by the Other groping with supplementary property ///  represented by the Other groping with supplementary property
   "OpenEnumerateInstances",         //    71          27   "OpenEnumerateInstances",         //    71          27
   "OpenEnumerateInstancePaths",     //    72   "OpenEnumerateInstancePaths",     //    72
   "OpenReferences",                 //    73    "OpenAssociators",                //    73
   "OpenReferenceNames",             //    74    "OpenAssociatorPaths",           //     74
   "OpenAssociators",                //    75    "OpenReferences",                 //    75
   "OpenAssociatorPaths",            //    76    "OpenReferenceNames",             //    76
   "PullInstancesWithPath",          //    77    "OpenQueryInstances",             //    77
   "PullInstancePaths",              //    77    "PullInstancesWithPath",          //    78
   "CloseEnumeration" ,              //    79    "PullInstancePaths",              //    79
     "CloseEnumeration" ,              //    80
 //EXP_PULL_END //EXP_PULL_END
   
 }; };
  
 const Uint32 StatisticalData::length = NUMBER_OF_TYPES; const Uint32 StatisticalData::length = NUMBER_OF_TYPES;
  
 StatisticalData* StatisticalData::cur = NULL;  // Pointer to StatisticalData table if it exists.
   StatisticalData* StatisticalData::table = NULL;
  
 // If first call, create the statistical data array // If first call, create the statistical data array
 StatisticalData* StatisticalData::current() StatisticalData* StatisticalData::current()
 { {
     if (cur == NULL)      if (table == NULL)
     {     {
         cur = new StatisticalData();          table = new StatisticalData();
     }     }
     return cur;      return table;
 } }
  
 // Clear the statisticalData Array  // Constructor clears the statisticalData Array and sets the gatherint
   // flag to zero
 StatisticalData::StatisticalData() StatisticalData::StatisticalData()
 { {
     copyGSD = 0;     copyGSD = 0;
       clear();
   }
  
   void StatisticalData::clear()
   {
       AutoMutex autoMut(_mutex);
     for (unsigned int i=0; i<StatisticalData::length; i++)     for (unsigned int i=0; i<StatisticalData::length; i++)
     {     {
         numCalls[i] = 0;         numCalls[i] = 0;
Line 122 
Line 130 
     }     }
 } }
  
   String StatisticalData::getRequestName(Uint16 i)
   {
       return requestName[i];
   }
   
 void StatisticalData::addToValue(Sint64 value, void StatisticalData::addToValue(Sint64 value,
     MessageType msgType,     MessageType msgType,
     StatDataType t)     StatDataType t)
 { {
     // Map MessageType to statistic type      // Map MessageType to statistic type. Requires multiple tests because
       // mapping request and responses to the request types.
     Uint16 type;     Uint16 type;
     if ((msgType) >= CIM_OPEN_ENUMERATE_INSTANCES_RESPONSE_MESSAGE)  
     {      if ((msgType) >= CIM_OPEN_ENUMERATE_INSTANCES_REQUEST_MESSAGE)
         type = msgType - CIM_SET_QUALIFIER_RESPONSE_MESSAGE;  
     }  
     else if (msgType >= CIM_ENUMERATE_CLASSES_RESPONSE_MESSAGE)  
     {     {
        type = msgType - CIM_OPEN_ENUMERATE_INSTANCES_REQUEST_MESSAGE;          type = msgType - CIM_DELETE_QUALIFIER_RESPONSE_MESSAGE;
     }     }
     else if (msgType >= CIM_GET_CLASS_RESPONSE_MESSAGE)     else if (msgType >= CIM_GET_CLASS_RESPONSE_MESSAGE)
     {     {
Line 142 
Line 153 
     }     }
     else     else
     {     {
         type = msgType;          type = msgType - 1;
     }     }
  
     //// KS_TODO diagnostic to confirm that the above if statements are correct  
     //// KS_DELETE when we get bug 9786 completely integrated.  
     PEG_TRACE((TRC_STATISTICAL_DATA, Tracer::LEVEL4,  
      "StatisticalData::addToValue msgType %s %u. stat type %u",  
                MessageTypeToString(msgType),  
                msgType, type ));  
   
     // Test if valid statistic type     // Test if valid statistic type
     if (type >= NUMBER_OF_TYPES)     if (type >= NUMBER_OF_TYPES)
     {     {
Line 160 
Line 164 
                  "Invalid Request Type =  %u", type));                  "Invalid Request Type =  %u", type));
          return;          return;
     }     }
       //// Diagnostic to confirm message type conversion. Normally commented
       //// out
   //  PEG_TRACE((TRC_STATISTICAL_DATA, Tracer::LEVEL4,
   //   "StatisticalData::addToValue msgType %s %u. stat type %u %s",
   //             MessageTypeToString(msgType),
   //             msgType, type, (const char*)requestName[type].getCString() ));
  
     if (copyGSD)     if (copyGSD)
     {     {


Legend:
Removed from v.1.22.8.5  
changed lines
  Added in v.1.24

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2