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 #include "FlagSet.hpp"
49 
50 class RexxDirectory;
51 class RexxClass;
52 
54 {
55  friend class RexxSource;
56  public:
57  void *operator new(size_t);
58  inline void *operator new(size_t size, void *objectPtr) { return objectPtr; }
59  inline void operator delete(void *) { }
60  inline void operator delete(void *, void *) { }
61 
63  inline ClassDirective(RESTORETYPE restoreType) { ; };
64 
65  void live(size_t);
66  void liveGeneral(int reason);
67  void flatten(RexxEnvelope *);
68 
69  typedef enum
70  {
71  PUBLIC, // class has public scope
72  MIXIN, // this is a mixin class
73  ABSTRACT, // this is an abstract class
75 
76 
77  inline RexxString *getName() { return publicName; }
78  RexxClass *install(RexxSource *source, RexxActivation *activation);
79 
80  void addDependencies(RexxDirectory *class_directives);
81  void checkDependency(RexxString *name, RexxDirectory *class_directives);
82  bool dependenciesResolved();
83  void removeDependency(RexxString *name);
84 
85  inline RexxString *getMetaClass() { return metaclassName; }
86  inline void setMetaClass(RexxString *m) { OrefSet(this, this->metaclassName, m); }
87  inline RexxString *getSubClass() { return subclassName; }
88  inline void setSubClass(RexxString *m) { OrefSet(this, this->subclassName, m); }
89  inline void setMixinClass(RexxString *m) { OrefSet(this, this->subclassName, m); classFlags[MIXIN] = true; }
90  inline bool isMixinClass() { return classFlags[MIXIN]; }
91  inline void setPublic() { classFlags[PUBLIC] = true; }
92  inline bool isPublic() { return classFlags[PUBLIC]; }
93  inline void setAbstract() { classFlags[ABSTRACT] = true; }
94  inline bool isAbstract() { return classFlags[ABSTRACT]; }
95  void addInherits(RexxString *name);
96  void addMethod(RexxString *name, RexxMethod *method, bool classMethod);
97  void addConstantMethod(RexxString *name, RexxMethod *method);
98  bool checkDuplicateMethod(RexxString *name, bool classMethod);
99 
100 
101 protected:
102 
105 
106 
107  RexxString *publicName; // the published name of the class
108  RexxString *idName; // the internal ID name
109  RexxString *metaclassName; // name of the class meta class
110  RexxString *subclassName; // the class used for the subclassing operation.
111  RexxList *inheritsClasses; // the names of inherited classes
112  RexxTable *instanceMethods; // the methods attached to this class
113  RexxTable *classMethods; // the set of class methods
114  RexxDirectory *dependencies; // in-package dependencies
116 };
117 
118 #endif
119 
RESTORETYPE
Definition: ObjectClass.hpp:82
#define OrefSet(o, r, v)
Definition: RexxCore.h:101
RexxString * subclassName
RexxString * metaclassName
void setMetaClass(RexxString *m)
void live(size_t)
ClassDirective(RESTORETYPE restoreType)
FlagSet< ClassProperties, 32 > classFlags
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)