| 
									
										
										
										
											1991-02-19 12:39:46 +00:00
										 |  |  | /***********************************************************
 | 
					
						
							|  |  |  | Copyright 1991 by Stichting Mathematisch Centrum, Amsterdam, The | 
					
						
							|  |  |  | Netherlands. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         All Rights Reserved | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Permission to use, copy, modify, and distribute this software and its  | 
					
						
							|  |  |  | documentation for any purpose and without fee is hereby granted,  | 
					
						
							|  |  |  | provided that the above copyright notice appear in all copies and that | 
					
						
							|  |  |  | both that copyright notice and this permission notice appear in  | 
					
						
							|  |  |  | supporting documentation, and that the names of Stichting Mathematisch | 
					
						
							|  |  |  | Centrum or CWI not be used in advertising or publicity pertaining to | 
					
						
							|  |  |  | distribution of the software without specific, written prior permission. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | STICHTING MATHEMATISCH CENTRUM DISCLAIMS ALL WARRANTIES WITH REGARD TO | 
					
						
							|  |  |  | THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND | 
					
						
							|  |  |  | FITNESS, IN NO EVENT SHALL STICHTING MATHEMATISCH CENTRUM BE LIABLE | 
					
						
							|  |  |  | FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | 
					
						
							|  |  |  | WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | 
					
						
							|  |  |  | ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT | 
					
						
							|  |  |  | OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ******************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | /* System module */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  | Various bits of information used by the interpreter are collected in | 
					
						
							|  |  |  | module 'sys'. | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | Function member: | 
					
						
							|  |  |  | - exit(sts): call (C, POSIX) exit(sts) | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | Data members: | 
					
						
							|  |  |  | - stdin, stdout, stderr: standard file objects | 
					
						
							|  |  |  | - modules: the table of modules (dictionary) | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | - path: module search path (list of strings) | 
					
						
							|  |  |  | - argv: script arguments (list of strings) | 
					
						
							|  |  |  | - ps1, ps2: optional primary and secondary prompts (strings) | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | #include "allobjects.h"
 | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "sysmodule.h"
 | 
					
						
							|  |  |  | #include "import.h"
 | 
					
						
							|  |  |  | #include "modsupport.h"
 | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* Define delimiter used in $PYTHONPATH */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef THINK_C
 | 
					
						
							|  |  |  | #define DELIM ' '
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef DELIM
 | 
					
						
							|  |  |  | #define DELIM ':'
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static object *sysdict; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | object * | 
					
						
							|  |  |  | sysget(name) | 
					
						
							|  |  |  | 	char *name; | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return dictlookup(sysdict, name); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | FILE * | 
					
						
							|  |  |  | sysgetfile(name, def) | 
					
						
							|  |  |  | 	char *name; | 
					
						
							|  |  |  | 	FILE *def; | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	FILE *fp = NULL; | 
					
						
							|  |  |  | 	object *v = sysget(name); | 
					
						
							|  |  |  | 	if (v != NULL) | 
					
						
							|  |  |  | 		fp = getfilefile(v); | 
					
						
							|  |  |  | 	if (fp == NULL) | 
					
						
							|  |  |  | 		fp = def; | 
					
						
							|  |  |  | 	return fp; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int | 
					
						
							|  |  |  | sysset(name, v) | 
					
						
							|  |  |  | 	char *name; | 
					
						
							|  |  |  | 	object *v; | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (v == NULL) | 
					
						
							|  |  |  | 		return dictremove(sysdict, name); | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		return dictinsert(sysdict, name, v); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static object * | 
					
						
							|  |  |  | sys_exit(self, args) | 
					
						
							|  |  |  | 	object *self; | 
					
						
							|  |  |  | 	object *args; | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int sts; | 
					
						
							|  |  |  | 	if (!getintarg(args, &sts)) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	goaway(sts); | 
					
						
							|  |  |  | 	exit(sts); /* Just in case */ | 
					
						
							|  |  |  | 	/* NOTREACHED */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | static struct methodlist sys_methods[] = { | 
					
						
							|  |  |  | 	{"exit",	sys_exit}, | 
					
						
							|  |  |  | 	{NULL,		NULL}		/* sentinel */ | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | static object *sysin, *sysout, *syserr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | initsys() | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | 	object *m = initmodule("sys", sys_methods); | 
					
						
							|  |  |  | 	sysdict = getmoduledict(m); | 
					
						
							|  |  |  | 	INCREF(sysdict); | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | 	/* NB keep an extra ref to the std files to avoid closing them
 | 
					
						
							|  |  |  | 	   when the user deletes them */ | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | 	/* XXX File objects should have a "don't close" flag instead */ | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | 	sysin = newopenfileobject(stdin, "<stdin>", "r"); | 
					
						
							|  |  |  | 	sysout = newopenfileobject(stdout, "<stdout>", "w"); | 
					
						
							|  |  |  | 	syserr = newopenfileobject(stderr, "<stderr>", "w"); | 
					
						
							|  |  |  | 	if (err_occurred()) | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | 		fatal("can't create sys.std* file objects"); | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | 	dictinsert(sysdict, "stdin", sysin); | 
					
						
							|  |  |  | 	dictinsert(sysdict, "stdout", sysout); | 
					
						
							|  |  |  | 	dictinsert(sysdict, "stderr", syserr); | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | 	dictinsert(sysdict, "modules", get_modules()); | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | 	if (err_occurred()) | 
					
						
							|  |  |  | 		fatal("can't insert sys.* objects in sys dict"); | 
					
						
							| 
									
										
										
										
											1990-11-18 17:41:40 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | static object * | 
					
						
							|  |  |  | makepathobject(path, delim) | 
					
						
							|  |  |  | 	char *path; | 
					
						
							|  |  |  | 	int delim; | 
					
						
							| 
									
										
										
										
											1990-11-18 17:41:40 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | 	int i, n; | 
					
						
							|  |  |  | 	char *p; | 
					
						
							|  |  |  | 	object *v, *w; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	n = 1; | 
					
						
							|  |  |  | 	p = path; | 
					
						
							|  |  |  | 	while ((p = strchr(p, delim)) != NULL) { | 
					
						
							|  |  |  | 		n++; | 
					
						
							|  |  |  | 		p++; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	v = newlistobject(n); | 
					
						
							|  |  |  | 	if (v == NULL) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	for (i = 0; ; i++) { | 
					
						
							|  |  |  | 		p = strchr(path, delim); | 
					
						
							|  |  |  | 		if (p == NULL) | 
					
						
							|  |  |  | 			p = strchr(path, '\0'); /* End of string */ | 
					
						
							|  |  |  | 		w = newsizedstringobject(path, (int) (p - path)); | 
					
						
							|  |  |  | 		if (w == NULL) { | 
					
						
							|  |  |  | 			DECREF(v); | 
					
						
							|  |  |  | 			return NULL; | 
					
						
							| 
									
										
										
										
											1990-11-18 17:41:40 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | 		setlistitem(v, i, w); | 
					
						
							|  |  |  | 		if (*p == '\0') | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		path = p+1; | 
					
						
							| 
									
										
										
										
											1990-11-18 17:41:40 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | 	return v; | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | setpythonpath(path) | 
					
						
							|  |  |  | 	char *path; | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | 	object *v; | 
					
						
							|  |  |  | 	if ((v = makepathobject(path, DELIM)) == NULL) | 
					
						
							|  |  |  | 		fatal("can't create sys.path"); | 
					
						
							|  |  |  | 	if (sysset("path", v) != 0) | 
					
						
							|  |  |  | 		fatal("can't assign sys.path"); | 
					
						
							|  |  |  | 	DECREF(v); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static object * | 
					
						
							|  |  |  | makeargvobject(argc, argv) | 
					
						
							|  |  |  | 	int argc; | 
					
						
							|  |  |  | 	char **argv; | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	object *av; | 
					
						
							|  |  |  | 	if (argc < 0 || argv == NULL) | 
					
						
							|  |  |  | 		argc = 0; | 
					
						
							|  |  |  | 	av = newlistobject(argc); | 
					
						
							|  |  |  | 	if (av != NULL) { | 
					
						
							| 
									
										
										
										
											1990-11-18 17:41:40 +00:00
										 |  |  | 		int i; | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | 		for (i = 0; i < argc; i++) { | 
					
						
							|  |  |  | 			object *v = newstringobject(argv[i]); | 
					
						
							|  |  |  | 			if (v == NULL) { | 
					
						
							|  |  |  | 				DECREF(av); | 
					
						
							|  |  |  | 				av = NULL; | 
					
						
							|  |  |  | 				break; | 
					
						
							| 
									
										
										
										
											1990-11-18 17:41:40 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | 			setlistitem(av, i, v); | 
					
						
							| 
									
										
										
										
											1990-11-18 17:41:40 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | 	return av; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void | 
					
						
							|  |  |  | setpythonargv(argc, argv) | 
					
						
							|  |  |  | 	int argc; | 
					
						
							|  |  |  | 	char **argv; | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	object *av = makeargvobject(argc, argv); | 
					
						
							|  |  |  | 	if (av == NULL) | 
					
						
							|  |  |  | 		fatal("no mem for sys.argv"); | 
					
						
							|  |  |  | 	if (sysset("argv", av) != 0) | 
					
						
							|  |  |  | 		fatal("can't assign sys.argv"); | 
					
						
							|  |  |  | 	DECREF(av); | 
					
						
							| 
									
										
										
										
											1990-10-14 12:07:46 +00:00
										 |  |  | } |