Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
setuptools_dso
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
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
setuptools_dso
Commits
150979d5
Commit
150979d5
authored
Jul 08, 2018
by
Michael Davidsaver
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
macos fixup
parent
1a61ea76
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
8 additions
and
7 deletions
+8
-7
example/setup.py
example/setup.py
+1
-0
src/setuptools_dso/dsocmd.py
src/setuptools_dso/dsocmd.py
+7
-7
No files found.
example/setup.py
View file @
150979d5
...
...
@@ -19,6 +19,7 @@ ext = Extension('dsodemo.ext.dtest', ['extension.cpp'],
setup
(
name
=
'dsodemo'
,
version
=
"0.1"
,
setup_requires
=
[
'setuptools_dso'
],
packages
=
[
'dsodemo'
,
'dsodemo.ext'
],
ext_modules
=
[
ext
],
x_dsos
=
[
dso
],
...
...
src/setuptools_dso/dsocmd.py
View file @
150979d5
...
...
@@ -58,6 +58,7 @@ class dso2libmixin:
mypath
=
os
.
path
.
join
(
*
ext
.
name
.
split
(
'.'
)[:
-
1
])
soargs
=
set
()
self
.
_osx_changes
=
[]
for
dso
in
getattr
(
ext
,
'dsos'
,
[]):
log
.
debug
(
"Will link against DSO %s"
%
dso
)
...
...
@@ -82,7 +83,6 @@ class dso2libmixin:
pass
found
=
False
self
.
_osx_changes
=
[]
for
candidate
in
dsosearch
:
C
=
os
.
path
.
join
(
candidate
,
libname
)
if
not
os
.
path
.
isfile
(
C
):
...
...
@@ -120,12 +120,11 @@ class dso2libmixin:
ext
.
extra_link_args
.
extend
(
list
(
soargs
))
def
dso2lib_post
(
self
,
ext
):
def
dso2lib_post
(
self
,
ext
_path
):
if
sys
.
platform
==
'darwin'
:
ext_path
=
self
.
get_ext_fullpath
(
ext
.
name
)
self
.
spawn
([
'otool'
,
'-L'
,
ext_path
])
for
old
,
new
in
osx_changes
:
for
old
,
new
in
self
.
_
osx_changes
:
self
.
spawn
([
'install_name_tool'
,
'-change'
,
old
,
new
,
ext_path
])
self
.
spawn
([
'otool'
,
'-L'
,
ext_path
])
...
...
@@ -195,9 +194,7 @@ class build_dso(dso2libmixin, Command):
self
.
compiler
.
linker_so
[
i
]
=
'-dynamiclib'
for
dso
in
self
.
dsos
:
self
.
dso2lib_pre
(
dso
)
self
.
build_dso
(
dso
)
self
.
dso2lib_post
(
dso
)
def
_name2file
(
self
,
dso
,
so
=
False
):
parts
=
dso
.
name
.
split
(
'.'
)
...
...
@@ -221,6 +218,7 @@ class build_dso(dso2libmixin, Command):
def
build_dso
(
self
,
dso
):
self
.
dso2lib_pre
(
dso
)
expand_sources
(
self
,
dso
.
sources
)
expand_sources
(
self
,
dso
.
depends
)
...
...
@@ -299,6 +297,8 @@ class build_dso(dso2libmixin, Command):
build_temp
=
self
.
build_temp
,
target_lang
=
language
)
self
.
dso2lib_post
(
outlib
)
if
baselib
!=
solib
:
self
.
copy_file
(
outlib
,
outbaselib
)
# link="sym" seem to get the target path wrong
...
...
@@ -335,7 +335,7 @@ class build_ext(dso2libmixin, _build_ext):
_build_ext
.
build_extension
(
self
,
ext
)
self
.
dso2lib_post
(
ext
)
self
.
dso2lib_post
(
self
.
get_ext_fullpath
(
ext
.
name
)
)
# Rant:
# Arranging for 'build_dso' to be run is seriously annoying!
...
...
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