ActivationApiContexts.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.ibm.com/developerworks/oss/CPLv1.0.htm */
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 */
40 /* */
41 /* Definition of contexts used for API call vector states. */
42 /* */
43 /******************************************************************************/
44 #ifndef ActivationApiContexts_Included
45 #define ActivationApiContexts_Included
46 
47 #include "RexxCore.h"
48 
49 class RexxActivity;
52 
53 // structure used to hand out a thread context structure for this
54 // activity. This stucture contains a RexxThreadContext structure
55 // followed by a self-referential pointer back to the containing
56 // activity. This gives us a quick mapping back to the activity
57 // associated with the thread context.
58 
59 typedef struct
60 {
61  RexxInstance instanceContext; // externalized instance context
62  InterpreterInstance *instance; // the instance this represents
64 
65 typedef struct
66 {
67  RexxThreadContext threadContext; // the thread context structure used for the API
68  RexxActivity *owningActivity; // a pointer back to the owning activity
70 
71 // and similar structures for other API context structures
72 typedef struct
73 {
74  RexxMethodContext threadContext; // the thread context structure used for the API
75  RexxNativeActivation *context; // a pointer back to the owning activation
77 
78 typedef struct
79 {
80  RexxCallContext threadContext; // the thread context structure used for the API
81  RexxNativeActivation *context; // a pointer back to the owning activation
82 } CallContext;
83 
84 typedef struct
85 {
86  RexxExitContext threadContext; // the thread context structure used for the API
87  RexxNativeActivation *context; // a pointer back to the owning activation
88 } ExitContext;
89 
90 
91 /**
92  * Convert a context into the activity the context is associated with.
93  *
94  * @param c The calling thread context.
95  *
96  * @return The activity object the context is associated with.
97  */
99 {
100  return ((ActivityContext *)c)->owningActivity;
101 }
102 
103 
104 /**
105  * Convert a context into the activity the context is associated with.
106  *
107  * @param c The calling thread context.
108  *
109  * @return The activity object the context is associated with.
110  */
112 {
113  return ((ActivityContext *)(c->threadContext))->owningActivity;
114 }
115 
116 
117 /**
118  * Convert a context into the activity the context is associated with.
119  *
120  * @param c The calling thread context.
121  *
122  * @return The activity object the context is associated with.
123  */
125 {
126  return ((ActivityContext *)(c->threadContext))->owningActivity;
127 }
128 
129 
130 /**
131  * Convert a context into the activity the context is associated with.
132  *
133  * @param c The calling thread context.
134  *
135  * @return The activity object the context is associated with.
136  */
138 {
139  return ((ActivityContext *)(c->threadContext))->owningActivity;
140 }
141 
142 #endif
143 
RexxActivity * contextToActivity(RexxThreadContext *c)
RexxActivity * owningActivity
RexxThreadContext threadContext
RexxNativeActivation * context
RexxCallContext threadContext
RexxNativeActivation * context
RexxExitContext threadContext
InterpreterInstance * instance
RexxInstance instanceContext
RexxNativeActivation * context
RexxMethodContext threadContext
RexxThreadContext * threadContext
Definition: oorexxapi.h:2200
RexxThreadContext * threadContext
Definition: oorexxapi.h:2972
RexxThreadContext * threadContext
Definition: oorexxapi.h:1430