summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Python/import.c11
-rw-r--r--Python/pythonrun.c48
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;