Commit 2579549e authored by Sang Ik Lee's avatar Sang Ik Lee Committed by Scott Cyphers

Add license files and cleanup compiler/linker options. (#2138)

* Add license files and cleanup compiler/linker options.

* Update comment on c++ standard option flag
parent ca4437bb
...@@ -126,16 +126,13 @@ def has_flag(compiler, flagname): ...@@ -126,16 +126,13 @@ def has_flag(compiler, flagname):
def cpp_flag(compiler): def cpp_flag(compiler):
"""Return the -std=c++[11/14] compiler flag. """Check and return the -std=c++11 compiler flag.
The c++14 is prefered over c++11 (when it is available).
""" """
if has_flag(compiler, '-std=c++14'): if has_flag(compiler, '-std=c++11'):
return '-std=c++14'
elif has_flag(compiler, '-std=c++11'):
return '-std=c++11' return '-std=c++11'
else: else:
raise RuntimeError('Unsupported compiler -- at least C++11 support is needed!') raise RuntimeError('Unsupported compiler -- C++11 support is needed!')
sources = [ sources = [
...@@ -273,6 +270,17 @@ data_files = [ ...@@ -273,6 +270,17 @@ data_files = [
NGRAPH_CPP_LIBRARY_DIR + "/" + library NGRAPH_CPP_LIBRARY_DIR + "/" + library
for library in os.listdir(NGRAPH_CPP_LIBRARY_DIR) for library in os.listdir(NGRAPH_CPP_LIBRARY_DIR)
], ],
),
(
'licenses',
[
PYNGRAPH_SOURCE_DIR + "/../licenses/" + license
for license in os.listdir(PYNGRAPH_SOURCE_DIR + "/../licenses")
],
),
(
'',
[PYNGRAPH_SOURCE_DIR + "/../LICENSE"],
) )
] ]
...@@ -321,29 +329,33 @@ class BuildExt(build_ext): ...@@ -321,29 +329,33 @@ class BuildExt(build_ext):
""" """
def build_extensions(self): def build_extensions(self):
if sys.platform == 'win32':
raise RuntimeError('Unsupported platform: win32!')
"""-Wstrict-prototypes is not a valid option for c++"""
try:
self.compiler.compiler_so.remove("-Wstrict-prototypes")
except (AttributeError, ValueError):
pass
for ext in self.extensions: for ext in self.extensions:
ext.extra_compile_args += [cpp_flag(self.compiler)] ext.extra_compile_args += [cpp_flag(self.compiler)]
if has_flag(self.compiler, '-fstack-protector-strong'): if has_flag(self.compiler, '-fstack-protector-strong'):
ext.extra_compile_args += ['-fstack-protector-strong'] ext.extra_compile_args += ['-fstack-protector-strong']
else: elif has_flag(self.compiler, '-fstack-protector'):
ext.extra_compile_args += ['-fstack-protector'] ext.extra_compile_args += ['-fstack-protector']
if has_flag(self.compiler, '-frtti'): if has_flag(self.compiler, '-fvisibility=hidden'):
ext.extra_compile_args += ['-frtti'] ext.extra_compile_args += ['-fvisibility=hidden']
if sys.platform == 'darwin': if has_flag(self.compiler, '-flto'):
ext.extra_compile_args += [ ext.extra_compile_args += ['-flto']
'-stdlib=libc++', if has_flag(self.compiler, '-fPIC'):
'-mmacosx-version-min=10.7', ext.extra_compile_args += ['-fPIC']
] if sys.platform.startswith('linux'):
ext.extra_link_args += ["-Wl,-rpath,@loader_path/../.."]
else:
if has_flag(self.compiler, '-fvisibility=hidden'):
ext.extra_compile_args += ['-fvisibility=hidden']
ext.extra_link_args += ['-Wl,-rpath,$ORIGIN/../..'] ext.extra_link_args += ['-Wl,-rpath,$ORIGIN/../..']
if sys.platform != 'darwin':
ext.extra_link_args += ['-z', 'noexecstack'] ext.extra_link_args += ['-z', 'noexecstack']
ext.extra_link_args += ['-z', 'relro'] ext.extra_link_args += ['-z', 'relro']
ext.extra_link_args += ['-z', 'now'] ext.extra_link_args += ['-z', 'now']
ext.extra_compile_args += ['-Wformat', '-Wformat-security', '-Wno-comment'] elif sys.platform == 'darwin':
ext.extra_link_args += ["-Wl,-rpath,@loader_path/../.."]
ext.extra_compile_args += ['-Wformat', '-Wformat-security']
ext.extra_compile_args += ['-O2', '-D_FORTIFY_SOURCE=2'] ext.extra_compile_args += ['-O2', '-D_FORTIFY_SOURCE=2']
build_ext.build_extensions(self) build_ext.build_extensions(self)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment