ClassDirective.hpp
Go to the documentation of this file.
1 /*----------------------------------------------------------------------------*/
2 /* */
3 /* Copyright (c) 1995, 2004 IBM Corporation. All rights reserved. */
4 /* Copyright (c) 2005-2009 Rexx Language Association. All rights reserved. */
5 /* */
6 /* This program and the accompanying materials are made available under */
7 /* the terms of the Common Public License v1.0 which accompanies this */
8 /* distribution. A copy is also available at the following address: */
9 /* http://www.oorexx.org/license.html */
10 /* */
11 /* Redistribution and use in source and binary forms, with or */
12 /* without modification, are permitted provided that the following */
13 /* conditions are met: */
14 /* */
15 /* Redistributions of source code must retain the above copyright */
16 /* notice, this list of conditions and the following disclaimer. */
17 /* Redistributions in binary form must reproduce the above copyright */
18 /* notice, this list of conditions and the following disclaimer in */
19 /* the documentation and/or other materials provided with the distribution. */
20 /* */
21 /* Neither the name of Rexx Language Association nor the names */
22 /* of its contributors may be used to endorse or promote products */
23 /* derived from this software without specific prior written permission. */
24 /* */
25 /* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS */
26 /* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT */
27 /* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS */
28 /* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT */
29 /* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, */
30 /* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED */
31 /* TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, */
32 /* OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY */
33 /* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING */
34 /* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS */
35 /* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */
36 /* */
37 /*----------------------------------------------------------------------------*/
38 /******************************************************************************/
39 /* REXX Kernel ClassDirective.hpp */
40 /* */
41 /* Primitive Abstract Directive Class Definitions */
42 /* */
43 /******************************************************************************/
44 #ifndef Included_ClassDirective
45 #define Included_ClassDirective
46 
47 #include "RexxDirective.hpp"
48 
49 class RexxDirectory;
50 class RexxClass;
51 
53 {
54  friend class RexxSource;
55  public:
56  void *operator new(size_t);
57  inline void *operator new(size_t size, void *objectPtr) { return objectPtr; }
58  inline void operator delete(void *) { }
59  inline void operator delete(void *, void *) { }
60 
62  inline ClassDirective(RESTORETYPE restoreType) { ; };
63 
64  void live(size_t);
65  void liveGeneral(int reason);
66  void flatten(RexxEnvelope *);
67 
68  inline RexxString *getName() { return publicName; }
69  RexxClass *install(RexxSource *source, RexxActivation *activation);
70 
71  void addDependencies(RexxDirectory *class_directives);
72  void checkDependency(RexxString *name, RexxDirectory *class_directives);
73  bool dependenciesResolved();
74  void removeDependency(RexxString *name);
75 
76  inline RexxString *getMetaClass() { return metaclassName; }
77  inline void setMetaClass(RexxString *m) { OrefSet(this, this->metaclassName, m); }
78  inline RexxString *getSubClass() { return subclassName; }
79  inline void setSubClass(RexxString *m) { OrefSet(this, this->subclassName, m); }
80  inline void setMixinClass(RexxString *m) { OrefSet(this, this->subclassName, m); mixinClass = true; }
81  inline void setPublic() { publicClass = true; }
82  void addInherits(RexxString *name);
83  void addMethod(RexxString *name, RexxMethod *method, bool classMethod);
84  void addConstantMethod(RexxString *name, RexxMethod *method);
85  bool checkDuplicateMethod(RexxString *name, bool classMethod);
86 
87 
88 protected:
89 
92 
93 
94  RexxString *publicName; // the published name of the class
95  RexxString *idName; // the internal ID name
96  RexxString *metaclassName; // name of the class meta class
97  RexxString *subclassName; // the class used for the subclassing operation.
98  RexxList *inheritsClasses; // the names of inherited classes
99  RexxTable *instanceMethods; // the methods attached to this class
100  RexxTable *classMethods; // the set of class methods
101  bool publicClass; // this is a public class
102  bool mixinClass; // this is a mixin class
103  RexxDirectory *dependencies; // in-package dependencies
104 };
105 
106 #endif
107 
RESTORETYPE
Definition: ObjectClass.hpp:80
#define OrefSet(o, r, v)
Definition: RexxCore.h:94
RexxString * subclassName
RexxString * metaclassName
void setMetaClass(RexxString *m)
void live(size_t)
ClassDirective(RESTORETYPE restoreType)
void addInherits(RexxString *name)
ClassDirective(RexxString *, RexxString *, RexxClause *)
RexxString * getMetaClass()
RexxList * inheritsClasses
void removeDependency(RexxString *name)
bool checkDuplicateMethod(RexxString *name, bool classMethod)
RexxClass * install(RexxSource *source, RexxActivation *activation)
void setSubClass(RexxString *m)
void flatten(RexxEnvelope *)
RexxString * idName
RexxString * getSubClass()
void addConstantMethod(RexxString *name, RexxMethod *method)
RexxString * getName()
RexxTable * classMethods
RexxTable * getInstanceMethods()
void setMixinClass(RexxString *m)
void addMethod(RexxString *name, RexxMethod *method, bool classMethod)
bool dependenciesResolved()
RexxString * publicName
void checkDependency(RexxString *name, RexxDirectory *class_directives)
RexxTable * getClassMethods()
RexxDirectory * dependencies
void addDependencies(RexxDirectory *class_directives)
RexxTable * instanceMethods
void liveGeneral(int reason)