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
a024034b
Commit
a024034b
authored
Oct 14, 2004
by
Anthony Baxter
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Patch 1046644 - improved distutils support for SWIG.
parent
78f58abe
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
35 additions
and
5 deletions
+35
-5
Lib/distutils/command/build_ext.py
Lib/distutils/command/build_ext.py
+23
-4
Lib/distutils/core.py
Lib/distutils/core.py
+1
-1
Lib/distutils/extension.py
Lib/distutils/extension.py
+5
-0
Misc/ACKS
Misc/ACKS
+1
-0
Misc/NEWS
Misc/NEWS
+5
-0
No files found.
Lib/distutils/command/build_ext.py
View file @
a024034b
...
...
@@ -81,6 +81,10 @@ class build_ext (Command):
"specify the compiler type"
),
(
'swig-cpp'
,
None
,
"make SWIG create C++ files (default is C)"
),
(
'swig-opts='
,
None
,
"list of SWIG command line options"
),
(
'swig='
,
None
,
"path to the SWIG executable"
),
]
boolean_options
=
[
'inplace'
,
'debug'
,
'force'
,
'swig-cpp'
]
...
...
@@ -107,8 +111,9 @@ class build_ext (Command):
self
.
debug
=
None
self
.
force
=
None
self
.
compiler
=
None
self
.
swig
=
None
self
.
swig_cpp
=
None
self
.
swig_opts
=
None
def
finalize_options
(
self
):
from
distutils
import
sysconfig
...
...
@@ -205,6 +210,11 @@ class build_ext (Command):
if
self
.
undef
:
self
.
undef
=
string
.
split
(
self
.
undef
,
','
)
if
self
.
swig_opts
is
None
:
self
.
swig_opts
=
[]
else
:
self
.
swig_opts
=
self
.
swig_opts
.
split
(
' '
)
# finalize_options ()
...
...
@@ -429,7 +439,7 @@ class build_ext (Command):
# First, scan the sources for SWIG definition files (.i), run
# SWIG on 'em to create .c files, and modify the sources list
# accordingly.
sources
=
self
.
swig_sources
(
sources
)
sources
=
self
.
swig_sources
(
sources
,
ext
)
# Next, compile the source code to object files.
...
...
@@ -492,7 +502,7 @@ class build_ext (Command):
target_lang
=
language
)
def
swig_sources
(
self
,
sources
):
def
swig_sources
(
self
,
sources
,
extension
):
"""Walk the list of source files in 'sources', looking for SWIG
interface (.i) files. Run SWIG on all that are found, and
...
...
@@ -510,6 +520,9 @@ class build_ext (Command):
# the temp dir.
if
self
.
swig_cpp
:
log
.
warn
(
"--swig-cpp is deprecated - use --swig-opts=-c++"
)
if
self
.
swig_cpp
or
(
'-c++'
in
self
.
swig_opts
):
target_ext
=
'.cpp'
else
:
target_ext
=
'.c'
...
...
@@ -526,11 +539,17 @@ class build_ext (Command):
if
not
swig_sources
:
return
new_sources
swig
=
self
.
find_swig
()
swig
=
self
.
swig
or
self
.
find_swig
()
swig_cmd
=
[
swig
,
"-python"
]
swig_cmd
.
extend
(
self
.
swig_opts
)
if
self
.
swig_cpp
:
swig_cmd
.
append
(
"-c++"
)
# Do not override commandline arguments
if
not
self
.
swig_opts
:
for
o
in
extension
.
swig_opts
:
swig_cmd
.
append
(
o
)
for
source
in
swig_sources
:
target
=
swig_targets
[
source
]
log
.
info
(
"swigging %s to %s"
,
source
,
target
)
...
...
Lib/distutils/core.py
View file @
a024034b
...
...
@@ -54,7 +54,7 @@ extension_keywords = ('name', 'sources', 'include_dirs',
'define_macros'
,
'undef_macros'
,
'library_dirs'
,
'libraries'
,
'runtime_library_dirs'
,
'extra_objects'
,
'extra_compile_args'
,
'extra_link_args'
,
'export_symbols'
,
'depends'
,
'language'
)
'
swig_opts'
,
'
export_symbols'
,
'depends'
,
'language'
)
def
setup
(
**
attrs
):
"""The gateway to the Distutils: do everything your setup script needs
...
...
Lib/distutils/extension.py
View file @
a024034b
...
...
@@ -75,6 +75,9 @@ class Extension:
used on all platforms, and not generally necessary for Python
extensions, which typically export exactly one symbol: "init" +
extension_name.
swig_opts : [string]
any extra options to pass to SWIG if a source file has the .i
extension.
depends : [string]
list of files that the extension depends on
language : string
...
...
@@ -95,6 +98,7 @@ class Extension:
extra_compile_args
=
None
,
extra_link_args
=
None
,
export_symbols
=
None
,
swig_opts
=
None
,
depends
=
None
,
language
=
None
,
**
kw
# To catch unknown keywords
...
...
@@ -116,6 +120,7 @@ class Extension:
self
.
extra_compile_args
=
extra_compile_args
or
[]
self
.
extra_link_args
=
extra_link_args
or
[]
self
.
export_symbols
=
export_symbols
or
[]
self
.
swig_opts
=
swig_opts
or
[]
self
.
depends
=
depends
or
[]
self
.
language
=
language
...
...
Misc/ACKS
View file @
a024034b
...
...
@@ -284,6 +284,7 @@ Eric Huss
Jeremy Hylton
Mihai Ibanescu
Juan David Ibez Palomar
Lars Immisch
Tony Ingraldi
John Interrante
Bob Ippolito
...
...
Misc/NEWS
View file @
a024034b
...
...
@@ -47,6 +47,11 @@ Extension modules
Library
-------
-
Patch
1046644
:
distutils
build_ext
grew
two
new
options
-
--
swig
for
specifying
the
swig
executable
to
use
,
and
--
swig
-
opts
to
specify
options
to
pass
to
swig
.
--
swig
-
opts
=
"-c++"
is
the
new
way
to
spell
--
swig
-
cpp
.
-
Patch
983206
:
distutils
now
obeys
environment
variable
LDSHARED
,
if
it
is
set
.
...
...
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