1 sage 1.1 //%////////////-*-c++-*-///////////////////////////////////////////////////////////
2 //
3 // Copyright (c) 2000, 2001 The Open group, BMC Software, Tivoli Systems, IBM
4 //
5 // Permission is hereby granted, free of charge, to any person obtaining a copy
6 // of this software and associated documentation files (the "Software"), to
7 // deal in the Software without restriction, including without limitation the
8 // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
9 // sell copies of the Software, and to permit persons to whom the Software is
10 // furnished to do so, subject to the following conditions:
11 //
12 // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN
13 // ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED
14 // "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT
15 // LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
16 // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
17 // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
18 // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
19 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
20 //
21 //==============================================================================
22 sage 1.1 //
23 // Author: Arthur Pichlkostner
24 // (checked in: Markus Mueller sedgewick_de@yahoo.de)
25 //
26 //%/////////////////////////////////////////////////////////////////////////////
27
28 #include "StatisticalData.h"
29
30 PEGASUS_NAMESPACE_BEGIN
31
32 String StatisticalData::requestName[] = {
33 "GET_CLASS",
34 "GET_INSTANCE",
35 "DELETE_CLASS",
36 "DELETE_INSTANCE",
37 "CREATE_CLASS",
38 "CREATE_INSTANCE",
39 "MODIFY_CLASS",
40 "MODIFY_INSTANCE",
41 "ENUMERATE_CLASSES",
42 "ENUMERATE_CLASS_NAMES",
43 sage 1.1 "ENUMERATE_INSTANCES",
44 "ENUMERATE_INSTANCE_NAMES",
45 "EXEC_QUERY",
46 "ASSOCIATORS",
47 "ASSOCIATOR_NAMES",
48 "REFERENCES",
49 "REFERENCE_NAMES",
50 "GET_PROPERTY",
51 "SET_PROPERTY",
52 "GET_QUALIFIER",
53 "SET_QUALIFIER",
54 "DELETE_QUALIFIER",
55 "ENUMERATE_QUALIFIERS"
56 };
57
58 const Uint32 StatisticalData::length = NUMBER_OF_TYPES;
59
60 StatisticalData* StatisticalData::cur = NULL;
61
62 StatisticalData* StatisticalData::current(){
63 if (cur == NULL){
64 sage 1.1 cur = new StatisticalData();
65 }
66 return cur;
67 }
68
69 StatisticalData::StatisticalData(){
70 for (unsigned int i=0; i<StatisticalData::length; i++){
71 numCalls[i] = 0;
72 cimomTime[i] = 0; providerTime[i] = 0;
73 responseSize[i] = 0;
74 requestSize[i] = 0;
75 }
76 }
77
78 void StatisticalData::addToValue(Uint64 value, Uint16 type, Uint32 t){
79 _mutex.lock( pegasus_thread_self() );
80 switch(t){
81 case SERVER: numCalls[type] += 1;
82 cimomTime[type] += value;
83 break;
84 case PROVIDER: providerTime[type] += value;
85 sage 1.1 break;
86 case BYTES_SENT: responseSize[type] += value;
87 break;
88 case BYTES_READ: requestSize[type] += value;
89 break;
90 }
91 _mutex.unlock();
92 }
93
94 PEGASUS_NAMESPACE_END
|