RexxMain.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 AIX Support aixmain.c */
40 /* */
41 /* Main interface to the REXX interpreter */
42 /* */
43 /******************************************************************************/
44 #ifdef HAVE_CONFIG_H
45 # include "config.h"
46 #endif
47 
48 #include <stdlib.h>
49 #include <stdio.h>
50 #include <string.h>
51 #include <limits.h>
52 
53 #if defined( HAVE_SCHED_H )
54 # include <sched.h>
55 #endif
56 
57 #include "RexxCore.h" /* bring in global defines */
58 #include "StringClass.hpp"
59 #include "BufferClass.hpp"
60 #include "MethodClass.hpp"
61 #include "RexxCode.hpp"
62 #include "ArrayClass.hpp"
63 #include "RexxNativeActivation.hpp"
64 #include "RexxActivation.hpp"
65 #include "RexxActivity.hpp"
66 #include "SourceFile.hpp"
67 
68 #include "APIDefinitions.h"
69 #include "Interpreter.hpp"
70 
71 
72 /******************************************************************************/
73 /* Name: ApiRexxStart (like RexxStart) */
74 /* */
75 /* Arguments: argcount - Number of args in arglist */
76 /* arglist - Array of args (array of RXSTRINGs) */
77 /* programname - REXX program to run */
78 /* instore - Instore array (array of 2 RXSTRINGs) */
79 /* envname - Initial cmd environment */
80 /* calltype - How the program is called */
81 /* exits - Array of system exit names (array of RXSTRINGs) */
82 /* */
83 /* Returned: result - Result returned from program */
84 /* rc - Return code from program */
85 /* */
86 /* Notes: Primary path into Object REXX. Makes sure Object REXX is up */
87 /* and runs the requested program. */
88 /* */
89 /* Mainline path looks like this: */
90 /* RexxStart => server_RexxStart */
91 /******************************************************************************/
93  size_t argcount, /* Number of args in arglist */
94  PCONSTRXSTRING arglist, /* Array of args */
95  const char *programname, /* REXX program to run */
96  PRXSTRING instore, /* Instore array */
97  const char *envname, /* Initial cmd environment */
98  int calltype, /* How the program is called */
99  PRXSYSEXIT exits, /* Array of system exit names */
100  short * retcode, /* Integer form of result */
101  PRXSTRING result) /* Result returned from program */
102 
103 {
104  return RexxStart(argcount, arglist, programname, instore, envname, calltype, exits, retcode, result);
105 }
106 
107 
int REXXENTRY RexxStart(size_t argcount, PCONSTRXSTRING arglist, const char *programname, PRXSTRING instore, const char *envname, int calltype, PRXSYSEXIT exits, short *retcode, PRXSTRING result)
int ApiRexxStart(size_t argcount, PCONSTRXSTRING arglist, const char *programname, PRXSTRING instore, const char *envname, int calltype, PRXSYSEXIT exits, short *retcode, PRXSTRING result)
Definition: RexxMain.cpp:92
CONSTANT_RXSTRING * PCONSTRXSTRING
Definition: rexx.h:186