summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>2001-10-18 18:49:37 (GMT)
committerGuido van Rossum <guido@python.org>2001-10-18 18:49:37 (GMT)
commit4114a4afecdf1753b1140059d71bb03b4cec3ef1 (patch)
tree0037455420bbddb0611fccc450b1a7f24e16838a
parent9ae09947f4c62bf1fffa9091b4ddc8833d5bcdfe (diff)
downloadcpython-4114a4afecdf1753b1140059d71bb03b4cec3ef1.zip
cpython-4114a4afecdf1753b1140059d71bb03b4cec3ef1.tar.gz
cpython-4114a4afecdf1753b1140059d71bb03b4cec3ef1.tar.bz2
Fix the frozen bytecode for __hello__ (betcha didn't know that existed
:-). Add a test that prevents the __hello__ bytecode from going stale unnoticed again. The test also tests the loophole noted in SF bug #404545. This test will fail right now; I'll check in the fix in a minute.
-rw-r--r--Lib/__phello__.foo.py1
-rw-r--r--Lib/test/output/test_frozen4
-rw-r--r--Lib/test/test_frozen.py26
-rw-r--r--Python/frozen.c17
4 files changed, 43 insertions, 5 deletions
diff --git a/Lib/__phello__.foo.py b/Lib/__phello__.foo.py
new file mode 100644
index 0000000..8e8623e
--- /dev/null
+++ b/Lib/__phello__.foo.py
@@ -0,0 +1 @@
+# This file exists as a helper for the test.test_frozen module.
diff --git a/Lib/test/output/test_frozen b/Lib/test/output/test_frozen
new file mode 100644
index 0000000..76f17db
--- /dev/null
+++ b/Lib/test/output/test_frozen
@@ -0,0 +1,4 @@
+test_frozen
+Hello world...
+Hello world...
+Hello world...
diff --git a/Lib/test/test_frozen.py b/Lib/test/test_frozen.py
new file mode 100644
index 0000000..3aa91ab
--- /dev/null
+++ b/Lib/test/test_frozen.py
@@ -0,0 +1,26 @@
+# Test the frozen module defined in frozen.c.
+
+from test_support import TestFailed
+import sys, os
+
+try:
+ import __hello__
+except ImportError, x:
+ raise TestFailed, "import __hello__ failed:", x
+
+try:
+ import __phello__
+except ImportError, x:
+ raise TestFailed, "import __phello__ failed:", x
+
+try:
+ import __phello__.spam
+except ImportError, x:
+ raise TestFailed, "import __phello__.spam failed:", x
+
+try:
+ import __phello__.foo
+except ImportError:
+ pass
+else:
+ raise TestFailed, "import __phello__.foo should have failed"
diff --git a/Python/frozen.c b/Python/frozen.c
index 21a0b52..e40d5d9 100644
--- a/Python/frozen.c
+++ b/Python/frozen.c
@@ -7,21 +7,28 @@
define a single frozen module, __hello__. Loading it will print
some famous words... */
+/* To regenerate this data after the bytecode or marshal format has changed,
+ go to ../Tools/freeze/ and freeze the hello.py file; then copy and paste
+ the appropriate bytes from M___main__.c. */
+
static unsigned char M___hello__[] = {
99,0,0,0,0,1,0,0,0,115,15,0,0,0,127,0,
0,127,1,0,100,0,0,71,72,100,1,0,83,40,2,0,
0,0,115,14,0,0,0,72,101,108,108,111,32,119,111,114,
108,100,46,46,46,78,40,0,0,0,0,40,0,0,0,0,
- 115,8,0,0,0,104,101,108,108,111,46,112,121,115,1,0,
- 0,0,63,1,0,115,0,0,0,0,
+ 40,0,0,0,0,40,0,0,0,0,115,8,0,0,0,104,
+ 101,108,108,111,46,112,121,115,1,0,0,0,63,1,0,115,
+ 0,0,0,0,
};
+#define SIZE sizeof(M___hello__)
+
static struct _frozen _PyImport_FrozenModules[] = {
/* Test module */
- {"__hello__", M___hello__, 90},
+ {"__hello__", M___hello__, SIZE},
/* Test package (negative size indicates package-ness) */
- {"__phello__", M___hello__, -90},
- {"__phello__.spam", M___hello__, 90},
+ {"__phello__", M___hello__, -SIZE},
+ {"__phello__.spam", M___hello__, SIZE},
{0, 0, 0} /* sentinel */
};