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

  1 karl  1.28 //%2006////////////////////////////////////////////////////////////////////////
  2 mike  1.9  //
  3 karl  1.26 // 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.25 // IBM Corp.; EMC Corporation, The Open Group.
  7 karl  1.26 // 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.27 // Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.;
 10            // EMC Corporation; VERITAS Software Corporation; The Open Group.
 11 karl  1.28 // Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.;
 12            // EMC Corporation; Symantec Corporation; The Open Group.
 13 mike  1.9  //
 14            // Permission is hereby granted, free of charge, to any person obtaining a copy
 15 kumpf 1.15 // 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.9  // 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.15 // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN
 22 mike  1.9  // 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.15 // 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.9  // 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.10 // Modified By: Roger Kumpf, Hewlett-Packard Company (roger_kumpf@hp.com)
 35 kumpf 1.16 //              Carol Ann Krug Graves, Hewlett-Packard Company
 36            //                (carolann_graves@hp.com)
 37 mike  1.9  //
 38            //%/////////////////////////////////////////////////////////////////////////////
 39            
 40            #include "CIMQualifier.h"
 41 kumpf 1.10 #include "CIMQualifierRep.h"
 42 mike  1.9  
 43            PEGASUS_NAMESPACE_BEGIN
 44            
 45            #define PEGASUS_ARRAY_T CIMQualifier
 46            # include "ArrayImpl.h"
 47            #undef PEGASUS_ARRAY_T
 48            
 49 kumpf 1.10 ////////////////////////////////////////////////////////////////////////////////
 50            //
 51            // CIMQualifier
 52            //
 53            ////////////////////////////////////////////////////////////////////////////////
 54            
 55            CIMQualifier::CIMQualifier()
 56                : _rep(0)
 57            {
 58            }
 59            
 60            CIMQualifier::CIMQualifier(const CIMQualifier& x)
 61            {
 62                Inc(_rep = x._rep);
 63            }
 64            
 65            CIMQualifier::CIMQualifier(
 66 kumpf 1.17     const CIMName& name,
 67 kumpf 1.10     const CIMValue& value,
 68 kumpf 1.19     const CIMFlavor & flavor,
 69 kumpf 1.10     Boolean propagated)
 70            {
 71                _rep = new CIMQualifierRep(name, value, flavor, propagated);
 72            }
 73            
 74            CIMQualifier::CIMQualifier(CIMQualifierRep* rep)
 75                : _rep(rep)
 76            {
 77            }
 78            
 79            CIMQualifier::~CIMQualifier()
 80            {
 81                Dec(_rep);
 82            }
 83            
 84            CIMQualifier& CIMQualifier::operator=(const CIMQualifier& x)
 85            {
 86                if (x._rep != _rep)
 87                {
 88                    Dec(_rep);
 89                    Inc(_rep = x._rep);
 90 kumpf 1.10     }
 91            
 92                return *this;
 93            }
 94            
 95 kumpf 1.17 const CIMName& CIMQualifier::getName() const
 96 kumpf 1.10 {
 97                _checkRep();
 98                return _rep->getName();
 99            }
100            
101 kumpf 1.17 void CIMQualifier::setName(const CIMName& name)
102 kumpf 1.10 {
103                _checkRep();
104                _rep->setName(name);
105            }
106            
107            CIMType CIMQualifier::getType() const
108            {
109                _checkRep();
110                return _rep->getType();
111            }
112            
113            Boolean CIMQualifier::isArray() const
114            {
115                _checkRep();
116                return _rep->isArray();
117            }
118            
119            const CIMValue& CIMQualifier::getValue() const
120            {
121                _checkRep();
122                return _rep->getValue();
123 kumpf 1.10 }
124            
125            void CIMQualifier::setValue(const CIMValue& value)
126            {
127                _checkRep();
128                _rep->setValue(value);
129            }
130            
131 kumpf 1.19 void CIMQualifier::setFlavor(const CIMFlavor & flavor)
132 kumpf 1.10 {
133                _checkRep();
134                _rep->setFlavor(flavor);
135            }
136            
137 kumpf 1.20 void CIMQualifier::unsetFlavor(const CIMFlavor & flavor)
138 kumpf 1.10 {
139                _checkRep();
140                _rep->unsetFlavor(flavor);
141            }
142            
143 kumpf 1.19 const CIMFlavor & CIMQualifier::getFlavor() const
144 kumpf 1.10 {
145                _checkRep();
146                return _rep->getFlavor();
147            }
148            
149 kumpf 1.24 const Uint32 CIMQualifier::getPropagated() const
150 kumpf 1.10 {
151                _checkRep();
152 kumpf 1.24     return (_rep->getPropagated()) ? 1 : 0;
153 kumpf 1.10 }
154            
155            void CIMQualifier::setPropagated(Boolean propagated)
156            {
157                _checkRep();
158                _rep->setPropagated(propagated);
159            }
160            
161 kumpf 1.18 Boolean CIMQualifier::isUninitialized() const
162 kumpf 1.10 {
163 kumpf 1.12     return (_rep == 0)? true : false;
164 kumpf 1.10 }
165            
166 mike  1.9  Boolean CIMQualifier::identical(const CIMConstQualifier& x) const
167            {
168                x._checkRep();
169                _checkRep();
170                return _rep->identical(x._rep);
171 kumpf 1.10 }
172            
173            CIMQualifier CIMQualifier::clone() const
174            {
175                return CIMQualifier(_rep->clone());
176            }
177            
178            void CIMQualifier::_checkRep() const
179            {
180                if (!_rep)
181 kumpf 1.22         throw UninitializedObjectException();
182 kumpf 1.10 }
183            
184            
185            ////////////////////////////////////////////////////////////////////////////////
186            //
187            // CIMConstQualifier
188            //
189            ////////////////////////////////////////////////////////////////////////////////
190            
191            CIMConstQualifier::CIMConstQualifier()
192                : _rep(0)
193            {
194            }
195            
196            CIMConstQualifier::CIMConstQualifier(const CIMConstQualifier& x)
197            {
198                Inc(_rep = x._rep);
199            }
200            
201            CIMConstQualifier::CIMConstQualifier(const CIMQualifier& x)
202            {
203 kumpf 1.10     Inc(_rep = x._rep);
204            }
205            
206            CIMConstQualifier::CIMConstQualifier(
207 kumpf 1.17     const CIMName& name,
208 kumpf 1.10     const CIMValue& value,
209 kumpf 1.19     const CIMFlavor & flavor,
210 kumpf 1.10     Boolean propagated)
211            {
212                _rep = new CIMQualifierRep(name, value, flavor, propagated);
213            }
214            
215            CIMConstQualifier::~CIMConstQualifier()
216            {
217                Dec(_rep);
218            }
219            
220            CIMConstQualifier& CIMConstQualifier::operator=(const CIMConstQualifier& x)
221            {
222                if (x._rep != _rep)
223                {
224                    Dec(_rep);
225                    Inc(_rep = x._rep);
226                }
227            
228                return *this;
229            }
230            
231 kumpf 1.10 CIMConstQualifier& CIMConstQualifier::operator=(const CIMQualifier& x)
232            {
233                if (x._rep != _rep)
234                {
235                    Dec(_rep);
236                    Inc(_rep = x._rep);
237                }
238            
239                return *this;
240            }
241            
242 kumpf 1.17 const CIMName& CIMConstQualifier::getName() const
243 kumpf 1.10 {
244                _checkRep();
245                return _rep->getName();
246            }
247            
248            CIMType CIMConstQualifier::getType() const
249            {
250                _checkRep();
251                return _rep->getType();
252            }
253            
254            Boolean CIMConstQualifier::isArray() const
255            {
256                _checkRep();
257                return _rep->isArray();
258            }
259            
260            const CIMValue& CIMConstQualifier::getValue() const
261            {
262                _checkRep();
263                return _rep->getValue();
264 kumpf 1.10 }
265            
266 kumpf 1.19 const CIMFlavor & CIMConstQualifier::getFlavor() const
267 kumpf 1.10 {
268                _checkRep();
269                return _rep->getFlavor();
270            }
271            
272 kumpf 1.24 const Uint32 CIMConstQualifier::getPropagated() const
273 kumpf 1.10 {
274                _checkRep();
275 kumpf 1.24     return (_rep->getPropagated()) ? 1 : 0;
276 kumpf 1.10 }
277            
278 kumpf 1.18 Boolean CIMConstQualifier::isUninitialized() const
279 kumpf 1.10 {
280 kumpf 1.12     return (_rep == 0)? true : false;
281 kumpf 1.10 }
282            
283            Boolean CIMConstQualifier::identical(const CIMConstQualifier& x) const
284            {
285                x._checkRep();
286                _checkRep();
287                return _rep->identical(x._rep);
288            }
289            
290            CIMQualifier CIMConstQualifier::clone() const
291            {
292                return CIMQualifier(_rep->clone());
293            }
294            
295            void CIMConstQualifier::_checkRep() const
296            {
297                if (!_rep)
298 kumpf 1.22         throw UninitializedObjectException();
299 mike  1.9  }
300            
301            PEGASUS_NAMESPACE_END

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2