1 karl 1.41 //%2006////////////////////////////////////////////////////////////////////////
|
2 mike 1.10 //
|
3 karl 1.35 // 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.34 // IBM Corp.; EMC Corporation, The Open Group.
|
7 karl 1.35 // 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.37 // Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.;
10 // EMC Corporation; VERITAS Software Corporation; The Open Group.
|
11 karl 1.41 // Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.;
12 // EMC Corporation; Symantec Corporation; The Open Group.
|
13 mike 1.10 //
14 // Permission is hereby granted, free of charge, to any person obtaining a copy
|
15 kumpf 1.26 // 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.10 // 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 karl 1.41 //
|
21 kumpf 1.26 // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN
|
22 mike 1.10 // 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.26 // 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.10 // 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.27 // Modified By: Carol Ann Krug Graves, Hewlett-Packard Company
|
35 david.dillard 1.36 // (carolann_graves@hp.com)
36 // David Dillard, VERITAS Software Corp.
37 // (david.dillard@veritas.com)
|
38 mike 1.10 //
39 //%/////////////////////////////////////////////////////////////////////////////
40
41 #include "CIMQualifier.h"
|
42 kumpf 1.19 #include "CIMQualifierRep.h"
|
43 mike 1.10 #include "Indentor.h"
44 #include "CIMName.h"
|
45 kumpf 1.32 #include "InternalException.h"
|
46 mike 1.10 #include "XmlWriter.h"
|
47 kumpf 1.24 #include "MofWriter.h"
|
48 mike 1.40 #include "StrLit.h"
|
49 mike 1.10
50 PEGASUS_NAMESPACE_BEGIN
|
51 karl 1.13 PEGASUS_USING_STD;
|
52 kumpf 1.19
|
53 mike 1.10 ////////////////////////////////////////////////////////////////////////////////
54 //
55 // CIMQualifierRep
56 //
57 ////////////////////////////////////////////////////////////////////////////////
58
|
59 chip 1.38 CIMQualifierRep::CIMQualifierRep()
60 {
61 }
62
63 CIMQualifierRep::CIMQualifierRep(const CIMQualifierRep& x) :
64 Sharable(),
65 _name(x._name),
66 _value(x._value),
67 _flavor(x._flavor),
68 _propagated(x._propagated)
69 {
70 }
71
|
72 mike 1.10 CIMQualifierRep::CIMQualifierRep(
|
73 chip 1.38 const CIMName& name,
74 const CIMValue& value,
|
75 kumpf 1.30 const CIMFlavor & flavor,
|
76 mike 1.10 Boolean propagated)
|
77 chip 1.38 :
78 _name(name),
79 _value(value),
|
80 mike 1.10 _flavor(flavor),
81 _propagated(propagated)
82 {
|
83 chip 1.38 // ensure name is not null
84 if(name.isNull())
85 {
86 throw UninitializedObjectException();
87 }
|
88 mike 1.10 }
89
90 CIMQualifierRep::~CIMQualifierRep()
91 {
92 }
93
|
94 chip 1.38 void CIMQualifierRep::setName(const CIMName& name)
|
95 mike 1.10 {
|
96 chip 1.38 // ensure name is not null
97 if(name.isNull())
98 {
99 throw UninitializedObjectException();
100 }
101
102 _name = name;
|
103 mike 1.10 }
104
|
105 kumpf 1.30 void CIMQualifierRep::resolveFlavor (
|
106 chip 1.38 const CIMFlavor & inheritedFlavor,
|
107 kumpf 1.30 Boolean inherited)
108 {
109 // ATTN: KS P3 Needs more tests and expansion so we treate first different
110 // from inheritance
|
111 karl 1.17
|
112 kumpf 1.30 // if the turnoff flags set, reset the flavor bits
|
113 chip 1.38 if (inheritedFlavor.hasFlavor (CIMFlavor::RESTRICTED))
|
114 kumpf 1.30 {
|
115 kumpf 1.31 _flavor.removeFlavor (CIMFlavor::TOSUBCLASS);
116 _flavor.removeFlavor (CIMFlavor::TOINSTANCE);
|
117 kumpf 1.30 }
|
118 chip 1.38 if (inheritedFlavor.hasFlavor (CIMFlavor::DISABLEOVERRIDE))
|
119 kumpf 1.30 {
120 _flavor.removeFlavor (CIMFlavor::ENABLEOVERRIDE);
121 }
122
123 _flavor.addFlavor (inheritedFlavor);
124 }
|
125 karl 1.17
|
126 mike 1.10 static const char* _toString(Boolean x)
127 {
128 return x ? "true" : "false";
129 }
130
|
131 mike 1.39 void CIMQualifierRep::toXml(Buffer& out) const
|
132 mike 1.10 {
|
133 mike 1.40 out << STRLIT("<QUALIFIER NAME=\"") << _name;
134 out.append('"');
135 out << STRLIT(" TYPE=\"") << cimTypeToString(_value.getType ());
136 out.append('"');
|
137 mike 1.10
138 if (_propagated != false)
|
139 mike 1.40 {
140 out << STRLIT(" PROPAGATED=\"") << _toString(_propagated);
141 out.append('"');
142 }
|
143 mike 1.10
|
144 kumpf 1.25 XmlWriter::appendQualifierFlavorEntity(out, _flavor);
|
145 mike 1.10
|
146 mike 1.40 out << STRLIT(">\n");
|
147 chip 1.38
|
148 kumpf 1.22 XmlWriter::appendValueElement(out, _value);
|
149 mike 1.10
|
150 mike 1.40 out << STRLIT("</QUALIFIER>\n");
|
151 mike 1.10 }
152
|
153 mike 1.11 /** toMof Generates MOF output for a qualifier.
154 The BNF for this is:
155 <pre>
156 qualifier = qualifierName [ qualifierParameter ] [ ":" 1*flavor]
157
158 qualifierParameter = "(" constantValue ")" | arrayInitializer
159
160 arrayInitializer = "{" constantValue*( "," constantValue)"}"
161 </pre>
162 */
|
163 mike 1.39 void CIMQualifierRep::toMof(Buffer& out) const
|
164 mike 1.11 {
165 // Output Qualifier name
166 out << _name;
167
168 /* If the qualifier is Boolean, we do not put out a value. This is
169 the way MOF is shown. Note that we should really be checking
|
170 karl 1.17 the qualifierdecl to compare with the default.
|
171 mike 1.11 Also if the value is Null, we do not put out a value because
172 no value has been set. Assumes that qualifiers are built
173 with NULL set if no value has been placed in the qualifier.
174 */
175 Boolean hasValueField = false;
|
176 karl 1.17 if (!_value.isNull())
|
177 mike 1.11 {
|
178 kumpf 1.27 if (_value.getType() == CIMTYPE_BOOLEAN)
|
179 karl 1.17 {
180 Boolean b;
181 _value.get(b);
182 if(!b)
|
183 mike 1.40 out << STRLIT(" (false)");
|
184 karl 1.17 }
185 else
186 {
|
187 mike 1.40 out << STRLIT(" (");
|
188 karl 1.17 hasValueField = true;
|
189 kumpf 1.24 MofWriter::appendValueElement(out, _value);
|
190 mike 1.40 out.append(')');
|
191 karl 1.17 }
|
192 mike 1.11 }
193
194 // output the flavors
195 String flavorString;
|
196 kumpf 1.25 flavorString = MofWriter::getQualifierFlavor(_flavor);
|
197 mike 1.11 if (flavorString.size())
198 {
|
199 mike 1.40 out << STRLIT(" : ");
|
200 karl 1.17 out << flavorString;
|
201 mike 1.11 }
|
202 karl 1.15 }
203
204
|
205 mike 1.10 Boolean CIMQualifierRep::identical(const CIMQualifierRep* x) const
206 {
207 return
208 this == x ||
|
209 chip 1.38 _name.equal(x->_name) &&
210 _value == x->_value &&
|
211 kumpf 1.30 (_flavor.equal (x->_flavor)) &&
|
212 mike 1.10 _propagated == x->_propagated;
213 }
214
|
215 chip 1.38 void CIMQualifierRep::setValue(const CIMValue& value)
|
216 mike 1.10 {
|
217 chip 1.38 _value = value;
|
218 mike 1.10 }
219
220 PEGASUS_NAMESPACE_END
|