1 karl 1.44 //%2006////////////////////////////////////////////////////////////////////////
|
2 mike 1.16 //
|
3 karl 1.40 // 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.35 // IBM Corp.; EMC Corporation, The Open Group.
|
7 karl 1.40 // 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.42 // Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.;
10 // EMC Corporation; VERITAS Software Corporation; The Open Group.
|
11 karl 1.44 // Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.;
12 // EMC Corporation; Symantec Corporation; The Open Group.
|
13 mike 1.16 //
14 // Permission is hereby granted, free of charge, to any person obtaining a copy
|
15 chip 1.20 // 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.16 // 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 kumpf 1.28 //
|
21 chip 1.20 // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN
|
22 mike 1.16 // 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 chip 1.20 // 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.16 // 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 //%/////////////////////////////////////////////////////////////////////////////
33
34 #ifndef Pegasus_CIMClassRep_h
35 #define Pegasus_CIMClassRep_h
36
37 #include <Pegasus/Common/Config.h>
|
38 kumpf 1.33 #include <Pegasus/Common/InternalException.h>
|
39 kumpf 1.31 #include <Pegasus/Common/CIMName.h>
|
40 mike 1.18 #include <Pegasus/Common/CIMObjectRep.h>
|
41 mike 1.16 #include <Pegasus/Common/CIMMethod.h>
|
42 karl 1.38 #include <Pegasus/Common/CIMInstance.h>
|
43 karl 1.37 #include <Pegasus/Common/CIMPropertyList.h>
|
44 kumpf 1.30 #include <Pegasus/Common/Linkage.h>
|
45 mike 1.16
46 PEGASUS_NAMESPACE_BEGIN
47
48 class DeclContext;
49 class CIMClass;
50 class CIMConstClass;
51 class CIMInstanceRep;
52
|
53 karl 1.21 // ATTN: KS P3 -document the CIMClass and CIMObjectRep classes.
|
54 mike 1.19
|
55 mike 1.45 class CIMClassRep : public CIMObjectRep
|
56 mike 1.16 {
57 public:
58
59 CIMClassRep(
|
60 kumpf 1.46 const CIMName& className,
61 const CIMName& superClassName);
|
62 mike 1.16
|
63 mike 1.18 virtual ~CIMClassRep();
|
64 mike 1.16
65 Boolean isAssociation() const;
66
67 Boolean isAbstract() const;
|
68 karl 1.21
|
69 kumpf 1.31 const CIMName& getSuperClassName() const { return _superClassName; }
|
70 mike 1.16
|
71 kumpf 1.31 void setSuperClassName(const CIMName& superClassName);
|
72 mike 1.16
|
73 mike 1.18 virtual void addProperty(const CIMProperty& x);
|
74 mike 1.16
75 void addMethod(const CIMMethod& x);
76
|
77 kumpf 1.31 Uint32 findMethod(const CIMName& name) const;
|
78 mike 1.16
|
79 kumpf 1.34 CIMMethod getMethod(Uint32 index);
|
80 mike 1.16
|
81 kumpf 1.34 CIMConstMethod getMethod(Uint32 index) const
|
82 mike 1.16 {
|
83 kumpf 1.46 return ((CIMClassRep*)this)->getMethod(index);
|
84 mike 1.16 }
85
|
86 kumpf 1.34 void removeMethod(Uint32 index);
|
87 mike 1.16
88 Uint32 getMethodCount() const;
89
90 void resolve(
|
91 kumpf 1.46 DeclContext* context,
92 const CIMNamespaceName& nameSpace);
|
93 mike 1.16
|
94 kumpf 1.23 virtual Boolean identical(const CIMObjectRep* x) const;
|
95 mike 1.18
96 virtual CIMObjectRep* clone() const
|
97 mike 1.16 {
|
98 kumpf 1.46 return new CIMClassRep(*this);
|
99 mike 1.16 }
100
|
101 kumpf 1.31 void getKeyNames(Array<CIMName>& keyNames) const;
|
102 mike 1.16
103 Boolean hasKeys() const;
104
|
105 karl 1.39 CIMInstance buildInstance(Boolean includeQualifiers,
|
106 karl 1.37 Boolean includeClassOrigin,
107 const CIMPropertyList & propertyList) const;
108
|
109 mike 1.16 private:
110
111 CIMClassRep(const CIMClassRep& x);
112
|
113 kumpf 1.47 CIMClassRep(); // Unimplemented
114 CIMClassRep& operator=(const CIMClassRep& x); // Unimplemented
|
115 mike 1.16
|
116 kumpf 1.31 CIMName _superClassName;
|
117 marek 1.48 typedef OrderedSet<CIMMethod,
118 CIMMethodRep,
119 PEGASUS_METHOD_ORDEREDSET_HASHSIZE> MethodSet;
120 MethodSet _methods;
|
121 mike 1.16
122 friend class CIMClass;
123 friend class CIMInstanceRep;
|
124 schuur 1.36 friend class BinaryStreamer;
|
125 mike 1.16 };
126
127 PEGASUS_NAMESPACE_END
128
129 #endif /* Pegasus_CIMClassRep_h */
|