diff options
-rw-r--r-- | Python/import.c | 11 | ||||
-rw-r--r-- | Python/pythonrun.c | 48 |
2 files changed, 58 insertions, 1 deletions
diff --git a/Python/import.c b/Python/import.c index 1a13fcf..f655041 100644 --- a/Python/import.c +++ b/Python/import.c @@ -176,6 +176,14 @@ static object *modules; /* Forward */ static int init_builtin PROTO((char *)); +/* Helper for reading .pyc files */ + +long +get_pyc_magic() +{ + return MAGIC; +} + /* Initialization */ void @@ -482,6 +490,9 @@ get_module(m, name, m_ret) /* Now write the code object to the ".pyc" file */ strcpy(namebuf + len, "c"); fpc = fopen(namebuf, "wb"); +#ifdef macintosh + setfiletype(namebuf, 'PYTH', 'PYC '); +#endif if (fpc == NULL) { if (verbose) fprintf(stderr, diff --git a/Python/pythonrun.c b/Python/pythonrun.c index 8387eed..e547f92 100644 --- a/Python/pythonrun.c +++ b/Python/pythonrun.c @@ -37,6 +37,7 @@ OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. #include "ceval.h" #include "pythonrun.h" #include "import.h" +#include "marshal.h" #ifdef HAVE_SIGNAL_H #include <signal.h> @@ -192,11 +193,24 @@ run_script(fp, filename) char *filename; { object *m, *d, *v; + char *ext; + m = add_module("__main__"); if (m == NULL) return -1; d = getmoduledict(m); - v = run_file(fp, filename, file_input, d, d); + ext = filename + strlen(filename) - 4; + if ( strcmp(ext, ".pyc") == 0 ) { + /* Try to run a pyc file. First, re-open in binary */ + fclose(fp); + if( (fp = fopen(filename, "rb")) == NULL ) { + fprintf(stderr, "python: Can't reopen .pyc file\n"); + return -1; + } + v = run_pyc_file(fp, filename, d, d); + } else { + v = run_file(fp, filename, file_input, d, d); + } flushline(); if (v == NULL) { print_error(); @@ -357,6 +371,38 @@ run_node(n, filename, globals, locals) } object * +run_pyc_file(fp, filename, globals, locals) + FILE *fp; + char *filename; + object *globals, *locals; +{ + codeobject *co; + object *v; + long magic; + long get_pyc_magic(); + + magic = rd_long(fp); + if (magic != get_pyc_magic()) { + err_setstr(RuntimeError, + "Bad magic number in .pyc file"); + return NULL; + } + (void) rd_long(fp); + v = rd_object(fp); + fclose(fp); + if (v == NULL || !is_codeobject(v)) { + XDECREF(v); + err_setstr(RuntimeError, + "Bad code object in .pyc file"); + return NULL; + } + co = (codeobject *)v; + v = eval_code(co, globals, locals, (object *)NULL, (object *)NULL); + DECREF(co); + return v; +} + +object * compile_string(str, filename, start) char *str; char *filename; |