LibraryDirective.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 LibraryDirective.cpp */
40 /* */
41 /* Primitive Translator Abstract Directive Code */
42 /* */
43 /******************************************************************************/
44 #include <stdlib.h>
45 #include "RexxCore.h"
46 #include "LibraryDirective.hpp"
47 #include "Clause.hpp"
48 #include "RexxActivation.hpp"
49 
50 
51 /**
52  * Construct a LibraryDirective.
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 LibraryDirective::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);
97 
99 }
100 
101 
102 /**
103  * Allocate a new requires directive.
104  *
105  * @param size The size of the object.
106  *
107  * @return The memory for the new object.
108  */
109 void *LibraryDirective::operator new(size_t size)
110 {
111  return new_object(size, T_LibraryDirective); /* Get new object */
112 }
113 
114 
115 /**
116  * Do install-time processing of the ::requires directive. This
117  * will resolve the directive and merge all of the public information
118  * from the resolved file into this program context.
119  *
120  * @param activation The activation we're running under for the install.
121  */
123 {
124  context->loadLibrary(name, this);
125 }
126 
@ T_LibraryDirective
#define memory_mark(oref)
Definition: RexxMemory.hpp:450
RexxObject * new_object(size_t s)
Definition: RexxMemory.hpp:436
#define flatten_reference(oref, envel)
Definition: RexxMemory.hpp:498
#define memory_mark_general(oref)
Definition: RexxMemory.hpp:451
#define cleanUpFlatten
Definition: RexxMemory.hpp:484
#define setUpFlatten(type)
Definition: RexxMemory.hpp:478
#define KEYWORD_LIBRARY
Definition: Token.hpp:200
LibraryDirective(RexxString *, RexxClause *)
void flatten(RexxEnvelope *)
void install(RexxActivation *context)
void liveGeneral(int reason)
void loadLibrary(RexxString *target, RexxInstruction *instruction)
RexxInstruction * nextInstruction