More fixes.
[mpsl.git] / mpsl_m.c
blob79bfc6606d349cf62e1410148b96fd31c8ba75fe
1 /*
3 MPSL - Minimum Profit Scripting Language
4 Copyright (C) 2003/2010 Angel Ortega <angel@triptico.com>
6 mpsl_m.c - Minimum Profit Scripting Language main()
8 This program is free software; you can redistribute it and/or
9 modify it under the terms of the GNU General Public License
10 as published by the Free Software Foundation; either version 2
11 of the License, or (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
22 http://www.triptico.com
26 #include "config.h"
28 #include <stdio.h>
29 #include <string.h>
30 #include <wchar.h>
31 #include "mpdm.h"
32 #include "mpsl.h"
35 /** code **/
37 mpdm_t trap_func(mpdm_t args, mpdm_t ctxt)
39 mpdm_t c = mpdm_aget(args, 0);
40 mpdm_t r = mpdm_aget(args, 2);
42 printf("-- Code ---------------\n");
43 mpdm_dump(c);
44 printf("-- Ret ---------------\n");
45 mpdm_dump(r);
47 printf("Press ENTER\n");
48 getchar();
50 return NULL;
54 int mpsl_main(int argc, char *argv[])
56 mpdm_t v = NULL;
57 mpdm_t w = NULL;
58 char *immscript = NULL;
59 FILE *script = stdin;
60 int ret = 0;
61 int dump_only = 0;
62 int install_trap = 0;
64 /* skip the executable */
65 argv++;
66 argc--;
68 while (argc > 0) {
69 if (strcmp(argv[0], "-v") == 0 || strcmp(argv[0], "--help") == 0) {
70 printf("MPSL %s - Minimum Profit Scripting Language\n",
71 VERSION);
72 printf("Copyright (C) 2003-2010 Angel Ortega <angel@triptico.com>\n");
73 printf("This software is covered by the GPL license. NO WARRANTY.\n\n");
75 printf("Usage: mpsl [-d | -s] [-e 'script' | script.mpsl ]\n\n");
77 return 0;
79 else
80 if (strcmp(argv[0], "-d") == 0)
81 dump_only = 1;
82 else
83 if (strcmp(argv[0], "-s") == 0)
84 install_trap = 1;
85 else
86 if (strcmp(argv[0], "-e") == 0) {
87 argv++;
88 argc--;
89 immscript = argv[0];
91 else {
92 /* next argument is a script name; open it */
93 if ((script = fopen(argv[0], "r")) == NULL) {
94 fprintf(stderr, "Can't open '%s'\n", argv[0]);
95 return 1;
99 argv++;
100 argc--;
103 mpsl_startup();
105 /* set arguments */
106 mpsl_argv(argc, argv);
108 if (install_trap)
109 mpsl_trap(MPDM_X(trap_func));
111 /* compile */
112 if (immscript != NULL) {
113 w = mpdm_ref(MPDM_MBS(immscript));
114 v = mpsl_compile(w);
115 mpdm_unref(w);
117 else {
118 int c;
120 /* if line starts with #!, discard it */
121 if ((c = getc(script)) == '#' && (c = getc(script)) == '!')
122 while ((c = getc(script)) != EOF && c != '\n');
123 else
124 ungetc(c, script);
126 if (c != EOF) {
127 w = mpdm_ref(MPDM_F(script));
128 v = mpsl_compile_file(w, NULL);
129 mpdm_close(w);
130 mpdm_unref(w);
134 if (v != NULL) {
135 mpdm_ref(v);
137 if (dump_only)
138 mpdm_dump(v);
139 else
140 mpdm_void(mpdm_exec(v, NULL, NULL));
142 mpdm_unref(v);
145 /* prints the error, if any */
146 if ((w = mpdm_hget_s(mpdm_root(), L"ERROR")) != NULL) {
147 mpdm_write_wcs(stderr, mpdm_string(w));
148 fprintf(stderr, "\n");
150 ret = 1;
153 mpsl_shutdown();
155 return ret;
159 int main(int argc, char *argv[])
161 return mpsl_main(argc, argv);