Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Labels
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Commits
Open sidebar
nexedi
cython
Commits
0a7503ed
Commit
0a7503ed
authored
Nov 12, 2011
by
Stefan Behnel
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
support for compiling __init__.py in pyximport, plus some minor cleanups
parent
116dbc81
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
39 additions
and
14 deletions
+39
-14
pyximport/pyximport.py
pyximport/pyximport.py
+39
-14
No files found.
pyximport/pyximport.py
View file @
0a7503ed
...
@@ -62,6 +62,18 @@ PYXBLD_EXT = ".pyxbld"
...
@@ -62,6 +62,18 @@ PYXBLD_EXT = ".pyxbld"
DEBUG_IMPORT
=
False
DEBUG_IMPORT
=
False
def
_print
(
message
,
args
):
if
args
:
message
=
message
%
args
print
(
message
)
def
_debug
(
message
,
*
args
):
if
DEBUG_IMPORT
:
_print
(
message
,
args
)
def
_info
(
message
,
*
args
):
_print
(
message
,
args
)
# Performance problem: for every PYX file that is imported, we will
# Performance problem: for every PYX file that is imported, we will
# invoke the whole distutils infrastructure even if the module is
# invoke the whole distutils infrastructure even if the module is
# already built. It might be more efficient to only do it when the
# already built. It might be more efficient to only do it when the
...
@@ -142,7 +154,7 @@ def handle_dependencies(pyxfilename):
...
@@ -142,7 +154,7 @@ def handle_dependencies(pyxfilename):
for
file
in
files
:
for
file
in
files
:
from
distutils.dep_util
import
newer
from
distutils.dep_util
import
newer
if
newer
(
file
,
pyxfilename
):
if
newer
(
file
,
pyxfilename
):
print
(
"Rebuilding because of "
,
file
)
_debug
(
"Rebuilding %s because of %s"
,
pyxfilename
,
file
)
filetime
=
os
.
path
.
getmtime
(
file
)
filetime
=
os
.
path
.
getmtime
(
file
)
os
.
utime
(
pyxfilename
,
(
filetime
,
filetime
))
os
.
utime
(
pyxfilename
,
(
filetime
,
filetime
))
if
testing
:
if
testing
:
...
@@ -174,13 +186,17 @@ def build_module(name, pyxfilename, pyxbuild_dir=None):
...
@@ -174,13 +186,17 @@ def build_module(name, pyxfilename, pyxbuild_dir=None):
try
:
try
:
os
.
remove
(
path
)
os
.
remove
(
path
)
except
IOError
:
except
IOError
:
print
(
"Couldn't remove
"
,
path
)
_info
(
"Couldn't remove %s
"
,
path
)
return
so_path
return
so_path
def
load_module
(
name
,
pyxfilename
,
pyxbuild_dir
=
None
):
def
load_module
(
name
,
pyxfilename
,
pyxbuild_dir
=
None
,
is_package
=
False
):
try
:
try
:
so_path
=
build_module
(
name
,
pyxfilename
,
pyxbuild_dir
)
if
is_package
:
module_name
=
name
+
'.__init__'
else
:
module_name
=
name
so_path
=
build_module
(
module_name
,
pyxfilename
,
pyxbuild_dir
)
mod
=
imp
.
load_dynamic
(
name
,
so_path
)
mod
=
imp
.
load_dynamic
(
name
,
so_path
)
assert
mod
.
__file__
==
so_path
,
(
mod
.
__file__
,
so_path
)
assert
mod
.
__file__
==
so_path
,
(
mod
.
__file__
,
so_path
)
except
Exception
:
except
Exception
:
...
@@ -190,8 +206,9 @@ def load_module(name, pyxfilename, pyxbuild_dir=None):
...
@@ -190,8 +206,9 @@ def load_module(name, pyxfilename, pyxbuild_dir=None):
assert
mod
.
__file__
in
(
pyxfilename
,
pyxfilename
+
'c'
,
pyxfilename
+
'o'
),
(
mod
.
__file__
,
pyxfilename
)
assert
mod
.
__file__
in
(
pyxfilename
,
pyxfilename
+
'c'
,
pyxfilename
+
'o'
),
(
mod
.
__file__
,
pyxfilename
)
else
:
else
:
import
traceback
import
traceback
raise
ImportError
(
"Building module failed: %s"
%
raise
ImportError
(
"Building module %s failed: %s"
%
traceback
.
format_exception_only
(
*
sys
.
exc_info
()[:
2
])),
None
,
sys
.
exc_info
()[
2
]
(
name
,
traceback
.
format_exception_only
(
*
sys
.
exc_info
()[:
2
]))),
None
,
sys
.
exc_info
()[
2
]
return
mod
return
mod
...
@@ -210,6 +227,12 @@ class PyxImporter(object):
...
@@ -210,6 +227,12 @@ class PyxImporter(object):
try
:
try
:
fp
,
pathname
,
(
ext
,
mode
,
ty
)
=
imp
.
find_module
(
fullname
,
package_path
)
fp
,
pathname
,
(
ext
,
mode
,
ty
)
=
imp
.
find_module
(
fullname
,
package_path
)
if
fp
:
fp
.
close
()
# Python should offer a Default-Loader to avoid this double find/open!
if
fp
:
fp
.
close
()
# Python should offer a Default-Loader to avoid this double find/open!
if
pathname
and
ty
==
imp
.
PKG_DIRECTORY
:
pkg_file
=
os
.
path
.
join
(
pathname
,
'__init__'
+
self
.
extension
)
if
os
.
path
.
isfile
(
pkg_file
):
return
PyxLoader
(
fullname
,
pathname
,
init_path
=
pkg_file
,
pyxbuild_dir
=
self
.
pyxbuild_dir
)
if
pathname
and
pathname
.
endswith
(
self
.
extension
):
if
pathname
and
pathname
.
endswith
(
self
.
extension
):
return
PyxLoader
(
fullname
,
pathname
,
return
PyxLoader
(
fullname
,
pathname
,
pyxbuild_dir
=
self
.
pyxbuild_dir
)
pyxbuild_dir
=
self
.
pyxbuild_dir
)
...
@@ -224,12 +247,12 @@ class PyxImporter(object):
...
@@ -224,12 +247,12 @@ class PyxImporter(object):
# .so/.pyd's on PATH should not be remote from .pyx's
# .so/.pyd's on PATH should not be remote from .pyx's
# think no need to implement PyxArgs.importer_search_remote here?
# think no need to implement PyxArgs.importer_search_remote here?
except
ImportError
:
except
ImportError
:
pass
pass
# searching sys.path ...
# searching sys.path ...
#if DEBUG_IMPORT: print "SEARCHING", fullname, package_path
#if DEBUG_IMPORT: print "SEARCHING", fullname, package_path
if
'.'
in
fullname
:
# only when package_path anyway?
if
'.'
in
fullname
:
# only when package_path anyway?
mod_parts
=
fullname
.
split
(
'.'
)
mod_parts
=
fullname
.
split
(
'.'
)
...
@@ -257,6 +280,7 @@ class PyxImporter(object):
...
@@ -257,6 +280,7 @@ class PyxImporter(object):
pyxbuild_dir
=
self
.
pyxbuild_dir
)
pyxbuild_dir
=
self
.
pyxbuild_dir
)
# not found, normal package, not a .pyx file, none of our business
# not found, normal package, not a .pyx file, none of our business
_debug
(
"%s not found"
%
fullname
)
return
None
return
None
class
PyImporter
(
PyxImporter
):
class
PyImporter
(
PyxImporter
):
...
@@ -277,8 +301,7 @@ class PyImporter(PyxImporter):
...
@@ -277,8 +301,7 @@ class PyImporter(PyxImporter):
if
fullname
in
self
.
blocked_modules
:
if
fullname
in
self
.
blocked_modules
:
# prevent infinite recursion
# prevent infinite recursion
return
None
return
None
if
DEBUG_IMPORT
:
_debug
(
"trying import of module '%s'"
,
fullname
)
print
(
"trying import of module '%s'"
%
fullname
)
if
fullname
in
self
.
uncompilable_modules
:
if
fullname
in
self
.
uncompilable_modules
:
path
,
last_modified
=
self
.
uncompilable_modules
[
fullname
]
path
,
last_modified
=
self
.
uncompilable_modules
[
fullname
]
try
:
try
:
...
@@ -297,11 +320,12 @@ class PyImporter(PyxImporter):
...
@@ -297,11 +320,12 @@ class PyImporter(PyxImporter):
try
:
try
:
if
importer
.
init_path
:
if
importer
.
init_path
:
path
=
importer
.
init_path
path
=
importer
.
init_path
real_name
=
fullname
+
'.__init__'
else
:
else
:
path
=
importer
.
path
path
=
importer
.
path
if
DEBUG_IMPORT
:
real_name
=
fullname
print
(
"importer found path %s"
%
path
)
_debug
(
"importer found path %s for module %s"
,
path
,
real_name
)
build_module
(
full
name
,
path
,
build_module
(
real_
name
,
path
,
pyxbuild_dir
=
self
.
pyxbuild_dir
)
pyxbuild_dir
=
self
.
pyxbuild_dir
)
except
Exception
,
e
:
except
Exception
,
e
:
if
DEBUG_IMPORT
:
if
DEBUG_IMPORT
:
...
@@ -320,6 +344,7 @@ class PyImporter(PyxImporter):
...
@@ -320,6 +344,7 @@ class PyImporter(PyxImporter):
class
PyxLoader
(
object
):
class
PyxLoader
(
object
):
def
__init__
(
self
,
fullname
,
path
,
init_path
=
None
,
pyxbuild_dir
=
None
):
def
__init__
(
self
,
fullname
,
path
,
init_path
=
None
,
pyxbuild_dir
=
None
):
_debug
(
"PyxLoader created for loading %s from %s (init path: %s)"
,
fullname
,
path
,
init_path
)
self
.
fullname
=
fullname
self
.
fullname
=
fullname
self
.
path
,
self
.
init_path
=
path
,
init_path
self
.
path
,
self
.
init_path
=
path
,
init_path
self
.
pyxbuild_dir
=
pyxbuild_dir
self
.
pyxbuild_dir
=
pyxbuild_dir
...
@@ -332,7 +357,7 @@ class PyxLoader(object):
...
@@ -332,7 +357,7 @@ class PyxLoader(object):
# package
# package
#print "PACKAGE", fullname
#print "PACKAGE", fullname
module
=
load_module
(
fullname
,
self
.
init_path
,
module
=
load_module
(
fullname
,
self
.
init_path
,
self
.
pyxbuild_dir
)
self
.
pyxbuild_dir
,
is_package
=
True
)
module
.
__path__
=
[
self
.
path
]
module
.
__path__
=
[
self
.
path
]
else
:
else
:
#print "MODULE", fullname
#print "MODULE", fullname
...
...
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