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
f6a3f4c6
Commit
f6a3f4c6
authored
Jun 04, 2008
by
Stefan Behnel
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
merged (and partially rewrote) dependency tracking and package resolution changes from Pyrex 0.9.8
parent
23814b66
Changes
7
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
235 additions
and
64 deletions
+235
-64
Cython/Compiler/CmdLine.py
Cython/Compiler/CmdLine.py
+10
-0
Cython/Compiler/Main.py
Cython/Compiler/Main.py
+192
-55
Cython/Compiler/ModuleNode.py
Cython/Compiler/ModuleNode.py
+15
-0
Cython/Compiler/Parsing.py
Cython/Compiler/Parsing.py
+3
-1
Cython/Compiler/Scanning.py
Cython/Compiler/Scanning.py
+5
-3
Cython/Compiler/Symtab.py
Cython/Compiler/Symtab.py
+2
-4
Cython/Utils.py
Cython/Utils.py
+8
-1
No files found.
Cython/Compiler/CmdLine.py
View file @
f6a3f4c6
...
@@ -18,6 +18,10 @@ Options:
...
@@ -18,6 +18,10 @@ Options:
-I, --include-dir <directory> Search for include files in named directory
-I, --include-dir <directory> Search for include files in named directory
(multiply include directories are allowed).
(multiply include directories are allowed).
-o, --output-file <filename> Specify name of generated C file
-o, --output-file <filename> Specify name of generated C file
-r, --recursive Recursively find and compile dependencies
-t, --timestamps Only compile newer source files (implied with -r)
-f, --force Compile all source files (overrides implied -t)
-q, --quiet Don't print module names in recursive mode
-p, --embed-positions If specified, the positions in Cython files of each
-p, --embed-positions If specified, the positions in Cython files of each
function definition is embedded in its docstring.
function definition is embedded in its docstring.
-z, --pre-import <module> If specified, assume undeclared names in this
-z, --pre-import <module> If specified, assume undeclared names in this
...
@@ -111,6 +115,12 @@ def parse_command_line(args):
...
@@ -111,6 +115,12 @@ def parse_command_line(args):
options
.
working_path
=
pop_arg
()
options
.
working_path
=
pop_arg
()
elif
option
in
(
"-o"
,
"--output-file"
):
elif
option
in
(
"-o"
,
"--output-file"
):
options
.
output_file
=
pop_arg
()
options
.
output_file
=
pop_arg
()
elif
option
in
(
"-r"
,
"--recursive"
):
options
.
recursive
=
1
elif
option
in
(
"-t"
,
"--timestamps"
):
options
.
timestamps
=
1
elif
option
in
(
"-f"
,
"--force"
):
options
.
timestamps
=
0
elif
option
in
(
"-p"
,
"--embed-positions"
):
elif
option
in
(
"-p"
,
"--embed-positions"
):
Options
.
embed_pos_in_docstring
=
1
Options
.
embed_pos_in_docstring
=
1
elif
option
in
(
"-z"
,
"--pre-import"
):
elif
option
in
(
"-z"
,
"--pre-import"
):
...
...
Cython/Compiler/Main.py
View file @
f6a3f4c6
This diff is collapsed.
Click to expand it.
Cython/Compiler/ModuleNode.py
View file @
f6a3f4c6
...
@@ -54,6 +54,7 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
...
@@ -54,6 +54,7 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
if
self
.
has_imported_c_functions
():
if
self
.
has_imported_c_functions
():
self
.
module_temp_cname
=
env
.
allocate_temp_pyobject
()
self
.
module_temp_cname
=
env
.
allocate_temp_pyobject
()
env
.
release_temp
(
self
.
module_temp_cname
)
env
.
release_temp
(
self
.
module_temp_cname
)
self
.
generate_dep_file
(
env
,
result
)
self
.
generate_c_code
(
env
,
options
,
result
)
self
.
generate_c_code
(
env
,
options
,
result
)
self
.
generate_h_code
(
env
,
options
,
result
)
self
.
generate_h_code
(
env
,
options
,
result
)
self
.
generate_api_code
(
env
,
result
)
self
.
generate_api_code
(
env
,
result
)
...
@@ -65,6 +66,20 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
...
@@ -65,6 +66,20 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode):
return
1
return
1
return
0
return
0
def
generate_dep_file
(
self
,
env
,
result
):
modules
=
self
.
referenced_modules
if
len
(
modules
)
>
1
or
env
.
included_files
:
dep_file
=
replace_suffix
(
result
.
c_file
,
".dep"
)
f
=
open
(
dep_file
,
"w"
)
try
:
for
module
in
modules
:
if
module
is
not
env
:
f
.
write
(
"cimport %s
\
n
"
%
module
.
qualified_name
)
for
path
in
module
.
included_files
:
f
.
write
(
"include %s
\
n
"
%
path
)
finally
:
f
.
close
()
def
generate_h_code
(
self
,
env
,
options
,
result
):
def
generate_h_code
(
self
,
env
,
options
,
result
):
def
h_entries
(
entries
,
pxd
=
0
):
def
h_entries
(
entries
,
pxd
=
0
):
return
[
entry
for
entry
in
entries
return
[
entry
for
entry
in
entries
...
...
Cython/Compiler/Parsing.py
View file @
f6a3f4c6
...
@@ -1203,8 +1203,10 @@ def p_include_statement(s, level):
...
@@ -1203,8 +1203,10 @@ def p_include_statement(s, level):
if
s
.
compile_time_eval
:
if
s
.
compile_time_eval
:
include_file_path
=
s
.
context
.
find_include_file
(
include_file_name
,
pos
)
include_file_path
=
s
.
context
.
find_include_file
(
include_file_name
,
pos
)
if
include_file_path
:
if
include_file_path
:
s
.
included_files
.
append
(
include_file_name
)
f
=
Utils
.
open_source_file
(
include_file_path
,
mode
=
"rU"
)
f
=
Utils
.
open_source_file
(
include_file_path
,
mode
=
"rU"
)
s2
=
PyrexScanner
(
f
,
include_file_path
,
s
,
source_encoding
=
f
.
encoding
)
s2
=
PyrexScanner
(
f
,
include_file_path
,
parent_scanner
=
s
,
source_encoding
=
f
.
encoding
)
try
:
try
:
tree
=
p_statement_list
(
s2
,
level
)
tree
=
p_statement_list
(
s2
,
level
)
finally
:
finally
:
...
...
Cython/Compiler/Scanning.py
View file @
f6a3f4c6
...
@@ -206,24 +206,26 @@ def initial_compile_time_env():
...
@@ -206,24 +206,26 @@ def initial_compile_time_env():
class
PyrexScanner
(
Scanner
):
class
PyrexScanner
(
Scanner
):
# context Context Compilation context
# context Context Compilation context
# type_names set Identifiers to be treated as type names
# type_names set Identifiers to be treated as type names
# included_files [string] Files included with 'include' statement
# compile_time_env dict Environment for conditional compilation
# compile_time_env dict Environment for conditional compilation
# compile_time_eval boolean In a true conditional compilation context
# compile_time_eval boolean In a true conditional compilation context
# compile_time_expr boolean In a compile-time expression context
# compile_time_expr boolean In a compile-time expression context
resword_dict
=
build_resword_dict
()
resword_dict
=
build_resword_dict
()
def
__init__
(
self
,
file
,
filename
,
parent_scanner
=
None
,
def
__init__
(
self
,
file
,
filename
,
parent_scanner
=
None
,
type_names
=
None
,
context
=
None
,
source_encoding
=
None
):
scope
=
None
,
context
=
None
,
source_encoding
=
None
):
Scanner
.
__init__
(
self
,
get_lexicon
(),
file
,
filename
)
Scanner
.
__init__
(
self
,
get_lexicon
(),
file
,
filename
)
if
parent_scanner
:
if
parent_scanner
:
self
.
context
=
parent_scanner
.
context
self
.
context
=
parent_scanner
.
context
self
.
type_names
=
parent_scanner
.
type_names
self
.
type_names
=
parent_scanner
.
type_names
self
.
included_files
=
parent_scanner
.
included_files
self
.
compile_time_env
=
parent_scanner
.
compile_time_env
self
.
compile_time_env
=
parent_scanner
.
compile_time_env
self
.
compile_time_eval
=
parent_scanner
.
compile_time_eval
self
.
compile_time_eval
=
parent_scanner
.
compile_time_eval
self
.
compile_time_expr
=
parent_scanner
.
compile_time_expr
self
.
compile_time_expr
=
parent_scanner
.
compile_time_expr
else
:
else
:
self
.
context
=
context
self
.
context
=
context
self
.
type_names
=
type_names
self
.
type_names
=
scope
.
type_names
self
.
included_files
=
scope
.
included_files
self
.
compile_time_env
=
initial_compile_time_env
()
self
.
compile_time_env
=
initial_compile_time_env
()
self
.
compile_time_eval
=
1
self
.
compile_time_eval
=
1
self
.
compile_time_expr
=
0
self
.
compile_time_expr
=
0
...
...
Cython/Compiler/Symtab.py
View file @
f6a3f4c6
...
@@ -554,10 +554,6 @@ class Scope:
...
@@ -554,10 +554,6 @@ class Scope:
return [entry for entry in self.temp_entries
return [entry for entry in self.temp_entries
if entry not in self.free_temp_entries]
if entry not in self.free_temp_entries]
#def recycle_pending_temps(self):
# # Obsolete
# pass
def use_utility_code(self, new_code):
def use_utility_code(self, new_code):
self.global_scope().use_utility_code(new_code)
self.global_scope().use_utility_code(new_code)
...
@@ -687,6 +683,7 @@ class ModuleScope(Scope):
...
@@ -687,6 +683,7 @@ class ModuleScope(Scope):
# parent_module Scope Parent in the import namespace
# parent_module Scope Parent in the import namespace
# module_entries {string : Entry} For cimport statements
# module_entries {string : Entry} For cimport statements
# type_names {string : 1} Set of type names (used during parsing)
# type_names {string : 1} Set of type names (used during parsing)
# included_files [string] Cython sources included with 'include'
# pxd_file_loaded boolean Corresponding .pxd file has been processed
# pxd_file_loaded boolean Corresponding .pxd file has been processed
# cimported_modules [ModuleScope] Modules imported with cimport
# cimported_modules [ModuleScope] Modules imported with cimport
# new_interned_string_entries [Entry] New interned strings waiting to be declared
# new_interned_string_entries [Entry] New interned strings waiting to be declared
...
@@ -723,6 +720,7 @@ class ModuleScope(Scope):
...
@@ -723,6 +720,7 @@ class ModuleScope(Scope):
self.interned_objs = []
self.interned_objs = []
self.all_pystring_entries = []
self.all_pystring_entries = []
self.types_imported = {}
self.types_imported = {}
self.included_files = []
self.pynum_entries = []
self.pynum_entries = []
self.has_extern_class = 0
self.has_extern_class = 0
self.cached_builtins = []
self.cached_builtins = []
...
...
Cython/Utils.py
View file @
f6a3f4c6
...
@@ -24,7 +24,6 @@ def castrate_file(path, st):
...
@@ -24,7 +24,6 @@ def castrate_file(path, st):
except
EnvironmentError
:
except
EnvironmentError
:
pass
pass
else
:
else
:
#st = os.stat(path)
f
.
seek
(
0
,
0
)
f
.
seek
(
0
,
0
)
f
.
truncate
()
f
.
truncate
()
f
.
write
(
f
.
write
(
...
@@ -33,6 +32,14 @@ def castrate_file(path, st):
...
@@ -33,6 +32,14 @@ def castrate_file(path, st):
if
st
:
if
st
:
os
.
utime
(
path
,
(
st
.
st_atime
,
st
.
st_mtime
))
os
.
utime
(
path
,
(
st
.
st_atime
,
st
.
st_mtime
))
def
modification_time
(
path
):
st
=
os
.
stat
(
path
)
return
st
.
st_mtime
def
file_newer_than
(
path
,
time
):
ftime
=
modification_time
(
path
)
return
ftime
>
time
# support for source file encoding detection and unicode decoding
# support for source file encoding detection and unicode decoding
def
encode_filename
(
filename
):
def
encode_filename
(
filename
):
...
...
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