Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
c1731373
Commit
c1731373
authored
Aug 04, 2001
by
Tim Peters
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Derived from SF patch #446899 Permit import of .pyw under Windows, from
David Bolen.
parent
289898cd
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
68 additions
and
46 deletions
+68
-46
Lib/test/test_import.py
Lib/test/test_import.py
+46
-39
Misc/ACKS
Misc/ACKS
+1
-0
Misc/NEWS
Misc/NEWS
+7
-2
Python/import.c
Python/import.c
+14
-5
No files found.
Lib/test/test_import.py
View file @
c1731373
...
...
@@ -16,49 +16,56 @@ else:
# Another brief digression to test the accuracy of manifest float constants.
import
double_const
# don't blink -- that *was* the test
sys
.
path
.
insert
(
0
,
os
.
curdir
)
source
=
TESTFN
+
".py"
pyo
=
TESTFN
+
".pyo"
if
sys
.
platform
.
startswith
(
'java'
):
pyc
=
TESTFN
+
"$py.class"
else
:
pyc
=
TESTFN
+
".pyc"
def
test_with_extension
(
ext
):
# ext normally ".py"; perhaps ".pyw"
source
=
TESTFN
+
ext
pyo
=
TESTFN
+
".pyo"
if
sys
.
platform
.
startswith
(
'java'
):
pyc
=
TESTFN
+
"$py.class"
else
:
pyc
=
TESTFN
+
".pyc"
f
=
open
(
source
,
"w"
)
print
>>
f
,
"# This will test Python's ability to import a .py file
"
a
=
random
.
randrange
(
1000
)
b
=
random
.
randrange
(
1000
)
print
>>
f
,
"a ="
,
a
print
>>
f
,
"b ="
,
b
f
.
close
()
f
=
open
(
source
,
"w"
)
print
>>
f
,
"# This tests Python's ability to import a"
,
ext
,
"file.
"
a
=
random
.
randrange
(
1000
)
b
=
random
.
randrange
(
1000
)
print
>>
f
,
"a ="
,
a
print
>>
f
,
"b ="
,
b
f
.
close
()
try
:
try
:
mod
=
__import__
(
TESTFN
)
except
ImportError
,
err
:
raise
ValueError
,
"import from .py failed: %s"
%
err
try
:
mod
=
__import__
(
TESTFN
)
except
ImportError
,
err
:
raise
ValueError
(
"import from %s failed: %s"
%
(
ext
,
err
))
if
mod
.
a
!=
a
or
mod
.
b
!=
b
:
print
a
,
"!="
,
mod
.
a
print
b
,
"!="
,
mod
.
b
raise
ValueError
,
"module loaded (%s) but contents invalid"
%
mod
finally
:
os
.
unlink
(
source
)
if
mod
.
a
!=
a
or
mod
.
b
!=
b
:
print
a
,
"!="
,
mod
.
a
print
b
,
"!="
,
mod
.
b
raise
ValueError
(
"module loaded (%s) but contents invalid"
%
mod
)
finally
:
os
.
unlink
(
source
)
try
:
try
:
reload
(
mod
)
except
ImportError
,
err
:
raise
ValueError
,
"import from .pyc/.pyo failed: %s"
%
err
finally
:
try
:
os
.
unlink
(
pyc
)
except
os
.
error
:
pass
try
:
os
.
unlink
(
pyo
)
except
os
.
error
:
pass
try
:
reload
(
mod
)
except
ImportError
,
err
:
raise
ValueError
(
"import from .pyc/.pyo failed: %s"
%
err
)
finally
:
try
:
os
.
unlink
(
pyc
)
except
os
.
error
:
pass
try
:
os
.
unlink
(
pyo
)
except
os
.
error
:
pass
del
sys
.
modules
[
TESTFN
]
del
sys
.
path
[
0
]
sys
.
path
.
insert
(
0
,
os
.
curdir
)
try
:
test_with_extension
(
".py"
)
if
sys
.
platform
.
startswith
(
"win"
):
for
ext
in
".PY"
,
".Py"
,
".pY"
,
".pyw"
,
".PYW"
,
".pYw"
:
test_with_extension
(
ext
)
finally
:
del
sys
.
path
[
0
]
Misc/ACKS
View file @
c1731373
...
...
@@ -42,6 +42,7 @@ Roy Bixler
Pablo Bleyer
Finn Bock
Paul Boddie
David Bolen
Jurjen Bos
Peter Bosch
Eric Bouck
...
...
Misc/NEWS
View file @
c1731373
...
...
@@ -32,12 +32,17 @@ C API
against buffer overruns.
- Unicode APIs now use name mangling to assure that mixing interpreters
and extensions using different Unicode widths is rendered next to
impossible. Trying to import an incompatible Unicode-aware extension
and extensions using different Unicode widths is rendered next to
impossible. Trying to import an incompatible Unicode-aware extension
will result in an ImportError. Unicode extensions writers must make
sure to check the Unicode width compatibility in their extensions by
using at least one of the mangled Unicode APIs in the extension.
Windows
- "import module" now compiles module.pyw if it exists and nothing else
relevant is found.
What's New in Python 2.2a1?
===========================
...
...
Python/import.c
View file @
c1731373
...
...
@@ -70,6 +70,9 @@ static const struct filedescr _PyImport_StandardFiletab[] = {
#else
static
const
struct
filedescr
_PyImport_StandardFiletab
[]
=
{
{
".py"
,
"r"
,
PY_SOURCE
},
#ifdef MS_WIN32
{
".pyw"
,
"r"
,
PY_SOURCE
},
#endif
{
".pyc"
,
"rb"
,
PY_COMPILED
},
{
0
,
0
}
};
...
...
@@ -513,13 +516,19 @@ PyImport_ExecCodeModuleEx(char *name, PyObject *co, char *pathname)
static
char
*
make_compiled_pathname
(
char
*
pathname
,
char
*
buf
,
size_t
buflen
)
{
size_t
len
;
len
=
strlen
(
pathname
);
size_t
len
=
strlen
(
pathname
);
if
(
len
+
2
>
buflen
)
return
NULL
;
strcpy
(
buf
,
pathname
);
strcpy
(
buf
+
len
,
Py_OptimizeFlag
?
"o"
:
"c"
);
#ifdef MS_WIN32
/* Treat .pyw as if it were .py. The case of ".pyw" must match
that used in _PyImport_StandardFiletab. */
if
(
len
>=
4
&&
strcmp
(
&
pathname
[
len
-
4
],
".pyw"
)
==
0
)
--
len
;
/* pretend 'w' isn't there */
#endif
memcpy
(
buf
,
pathname
,
len
);
buf
[
len
]
=
Py_OptimizeFlag
?
'o'
:
'c'
;
buf
[
len
+
1
]
=
'\0'
;
return
buf
;
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment