1 karl 1.8 //%2006////////////////////////////////////////////////////////////////////////
|
2 mike 1.2 //
|
3 karl 1.6 // Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development
4 // Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems.
5 // Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.;
|
6 karl 1.5 // IBM Corp.; EMC Corporation, The Open Group.
|
7 karl 1.6 // Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.;
8 // IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group.
|
9 karl 1.7 // Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.;
10 // EMC Corporation; VERITAS Software Corporation; The Open Group.
|
11 karl 1.8 // Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.;
12 // EMC Corporation; Symantec Corporation; The Open Group.
|
13 mike 1.2 //
14 // Permission is hereby granted, free of charge, to any person obtaining a copy
|
15 kumpf 1.3 // of this software and associated documentation files (the "Software"), to
16 // deal in the Software without restriction, including without limitation the
17 // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
18 mike 1.2 // sell copies of the Software, and to permit persons to whom the Software is
19 // furnished to do so, subject to the following conditions:
20 //
|
21 kumpf 1.3 // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN
|
22 mike 1.2 // ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED
23 // "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT
|
24 kumpf 1.3 // LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
25 // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
26 // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
|
27 mike 1.2 // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
28 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
29 //
30 //==============================================================================
31 //
32 // Author: Mike Brasher (mbrasher@bmc.com)
33 //
|
34 kumpf 1.4 // Modified By: Carol Ann Krug Graves, Hewlett-Packard Company
35 // (carolann_graves@hp.com)
|
36 mike 1.2 //
37 //%/////////////////////////////////////////////////////////////////////////////
38
39 #ifndef Pegasus_WQLSimplePropertySource_h
40 #define Pegasus_WQLSimplePropertySource_h
41
42 #include <Pegasus/Common/Config.h>
43 #include <Pegasus/WQL/WQLPropertySource.h>
44 #include <Pegasus/Common/HashTable.h>
45
46 PEGASUS_NAMESPACE_BEGIN
47
48 /** This class provides a simple property source implementation mainly for
49 testing purposes only.
50
51 It maintains a hash table which maps property names to values (represented
52 using WQLOperand objects).
53
54 This class implements getValue() by simply looking up the property name
55 in the map and fetching the corresponding value.
56
57 mike 1.2 The addValue() method is used to add property-name/value pairs to the
58 internal map.
59
60 Since this class is intended for testing purposes, all of the methods
61 are inline to avoid making the library any larger.
62 */
63 class WQLSimplePropertySource : public WQLPropertySource
64 {
65 public:
66
67 /** Default constructor.
68 */
69 WQLSimplePropertySource()
70 {
71 }
72
73 /** Virtual destructor.
74 */
75 virtual ~WQLSimplePropertySource()
76 {
77 }
78 mike 1.2
79 /** Get the value for the property with the given name. Simply looks up
80 the property name in the internal map to fetch the value.
81
82 @param propertyName name of property to be retrieved.
83 @param value value of property.
84 @return true is such a property exists and false otherwise.
85 */
86 virtual Boolean getValue(
|
87 kumpf 1.4 const CIMName& propertyName,
|
88 mike 1.2 WQLOperand& value) const
89 {
|
90 kumpf 1.4 return _map.lookup(propertyName.getString(), value);
|
91 mike 1.2 }
92
93 /** Add the given propert-name/value pair to the internal map.
94
95 @param propertyName name of property.
96 @param value value of property.
97 @return true if no such property already existed and false otherwise.
98 */
99 Boolean addValue(
|
100 kumpf 1.4 const CIMName& propertyName,
|
101 mike 1.2 const WQLOperand& value)
102 {
|
103 kumpf 1.4 return _map.insert(propertyName.getString(), value);
|
104 mike 1.2 }
105
106 private:
107
108 typedef HashTable<
109 String, WQLOperand, EqualFunc<String>, HashFunc<String> > Map;
110
111 Map _map;
112 };
113
114 PEGASUS_NAMESPACE_END
115
116 #endif /* Pegasus_WQLSimplePropertySource_h */
|