RequiresDirective.cpp
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 RequiresDirective.cpp */
40 /* */
41 /* Primitive Translator Abstract Directive Code */
42 /* */
43 /******************************************************************************/
44 #include <stdlib.h>
45 #include "RexxCore.h"
46 #include "RequiresDirective.hpp"
47 #include "Clause.hpp"
48 #include "RexxActivation.hpp"
49 
50 
51 /**
52  * Construct a RequiresDirective.
53  *
54  * @param n The name of the requires target.
55  * @param clause The source file clause containing the directive.
56  */
58 {
59  name = n;
60 }
61 
62 /**
63  * Normal garbage collecting live mark.
64  *
65  * @param liveMark The current live object mark.
66  */
67 void RequiresDirective::live(size_t liveMark)
68 {
69  memory_mark(this->nextInstruction); // must be first one marked (though normally null)
70  memory_mark(this->name);
71 }
72 
73 
74 /**
75  * The generalized object marking routine.
76  *
77  * @param reason The processing faze we're running the mark on.
78  */
80 {
81  memory_mark_general(this->nextInstruction); // must be first one marked (though normally null)
83 }
84 
85 
86 /**
87  * Flatten the directive instance.
88  *
89  * @param envelope The envelope we're flattening into.
90  */
92 {
94 
95  flatten_reference(newThis->nextInstruction, envelope);
96  flatten_reference(newThis->name, envelope);
98 }
99 
100 
101 /**
102  * Allocate a new requires directive.
103  *
104  * @param size The size of the object.
105  *
106  * @return The memory for the new object.
107  */
108 void *RequiresDirective::operator new(size_t size)
109 {
110  return new_object(size, T_RequiresDirective); /* Get new object */
111 }
112 
113 
114 /**
115  * Do install-time processing of the ::requires directive. This
116  * will resolve the directive and merge all of the public information
117  * from the resolved file into this program context.
118  *
119  * @param activation The activation we're running under for the install.
120  */
122 {
123  context->loadRequires(name, this);
124 }
@ T_RequiresDirective
#define memory_mark(oref)
Definition: RexxMemory.hpp:445
RexxObject * new_object(size_t s)
Definition: RexxMemory.hpp:431
#define flatten_reference(oref, envel)
Definition: RexxMemory.hpp:493
#define memory_mark_general(oref)
Definition: RexxMemory.hpp:446
#define cleanUpFlatten
Definition: RexxMemory.hpp:479
#define setUpFlatten(type)
Definition: RexxMemory.hpp:473
#define KEYWORD_REQUIRES
Definition: Token.hpp:195
void install(RexxActivation *context)
void liveGeneral(int reason)
RequiresDirective(RexxString *, RexxClause *)
void flatten(RexxEnvelope *)
PackageClass * loadRequires(RexxString *, RexxInstruction *)
RexxInstruction * nextInstruction