|
|
@ -95,8 +95,19 @@ class CCompiler(): |
|
|
|
def split_shlib_to_parts(self, fname): |
|
|
|
def split_shlib_to_parts(self, fname): |
|
|
|
return (None, fname) |
|
|
|
return (None, fname) |
|
|
|
|
|
|
|
|
|
|
|
def build_rpath_args(self, build_dir, rpath_paths): |
|
|
|
# The default behaviour is this, override in |
|
|
|
|
|
|
|
# OSX and MSVC. |
|
|
|
|
|
|
|
def build_rpath_args(self, build_dir, rpath_paths, install_rpath): |
|
|
|
|
|
|
|
if len(rpath_paths) == 0 and len(install_rpath) == 0: |
|
|
|
return [] |
|
|
|
return [] |
|
|
|
|
|
|
|
paths = ':'.join([os.path.join(build_dir, p) for p in rpath_paths]) |
|
|
|
|
|
|
|
if len(paths) < len(install_rpath): |
|
|
|
|
|
|
|
padding = 'X'*(len(install_rpath) - len(paths)) |
|
|
|
|
|
|
|
if len(paths) == 0: |
|
|
|
|
|
|
|
paths = padding |
|
|
|
|
|
|
|
else: |
|
|
|
|
|
|
|
paths = paths + ':' + padding |
|
|
|
|
|
|
|
return ['-Wl,-rpath,' + paths] |
|
|
|
|
|
|
|
|
|
|
|
def get_id(self): |
|
|
|
def get_id(self): |
|
|
|
return self.id |
|
|
|
return self.id |
|
|
@ -457,7 +468,7 @@ class JavaCompiler(): |
|
|
|
def split_shlib_to_parts(self, fname): |
|
|
|
def split_shlib_to_parts(self, fname): |
|
|
|
return (None, fname) |
|
|
|
return (None, fname) |
|
|
|
|
|
|
|
|
|
|
|
def build_rpath_args(self, build_dir, rpath_paths): |
|
|
|
def build_rpath_args(self, build_dir, rpath_paths, install_rpath): |
|
|
|
return [] |
|
|
|
return [] |
|
|
|
|
|
|
|
|
|
|
|
def get_id(self): |
|
|
|
def get_id(self): |
|
|
@ -805,11 +816,6 @@ class GnuCCompiler(CCompiler): |
|
|
|
def split_shlib_to_parts(self, fname): |
|
|
|
def split_shlib_to_parts(self, fname): |
|
|
|
return (os.path.split(fname)[0], fname) |
|
|
|
return (os.path.split(fname)[0], fname) |
|
|
|
|
|
|
|
|
|
|
|
def build_rpath_args(self, build_dir, rpath_paths): |
|
|
|
|
|
|
|
if len(rpath_paths) == 0: |
|
|
|
|
|
|
|
return [] |
|
|
|
|
|
|
|
return ['-Wl,-rpath,' + ':'.join([os.path.join(build_dir, p) for p in rpath_paths])] |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def get_soname_args(self, shlib_name, path): |
|
|
|
def get_soname_args(self, shlib_name, path): |
|
|
|
return get_gcc_soname_args(self.gcc_type, shlib_name, path) |
|
|
|
return get_gcc_soname_args(self.gcc_type, shlib_name, path) |
|
|
|
|
|
|
|
|
|
|
@ -832,11 +838,6 @@ class GnuObjCCompiler(ObjCCompiler): |
|
|
|
def get_pch_suffix(self): |
|
|
|
def get_pch_suffix(self): |
|
|
|
return 'gch' |
|
|
|
return 'gch' |
|
|
|
|
|
|
|
|
|
|
|
def build_rpath_args(self, build_dir, rpath_paths): |
|
|
|
|
|
|
|
if len(rpath_paths) == 0: |
|
|
|
|
|
|
|
return [] |
|
|
|
|
|
|
|
return ['-Wl,-rpath,' + ':'.join([os.path.join(build_dir, p) for p in rpath_paths])] |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def get_soname_args(self, shlib_name, path): |
|
|
|
def get_soname_args(self, shlib_name, path): |
|
|
|
return get_gcc_soname_args(self.gcc_type, shlib_name, path) |
|
|
|
return get_gcc_soname_args(self.gcc_type, shlib_name, path) |
|
|
|
|
|
|
|
|
|
|
@ -860,11 +861,6 @@ class GnuObjCPPCompiler(ObjCPPCompiler): |
|
|
|
def get_pch_suffix(self): |
|
|
|
def get_pch_suffix(self): |
|
|
|
return 'gch' |
|
|
|
return 'gch' |
|
|
|
|
|
|
|
|
|
|
|
def build_rpath_args(self, build_dir, rpath_paths): |
|
|
|
|
|
|
|
if len(rpath_paths) == 0: |
|
|
|
|
|
|
|
return [] |
|
|
|
|
|
|
|
return ['-Wl,-rpath,' + ':'.join([os.path.join(build_dir, p) for p in rpath_paths])] |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def get_soname_args(self, shlib_name, path): |
|
|
|
def get_soname_args(self, shlib_name, path): |
|
|
|
return get_gcc_soname_args(self.gcc_type, shlib_name, path) |
|
|
|
return get_gcc_soname_args(self.gcc_type, shlib_name, path) |
|
|
|
|
|
|
|
|
|
|
@ -897,11 +893,6 @@ class ClangCCompiler(CCompiler): |
|
|
|
def get_pch_suffix(self): |
|
|
|
def get_pch_suffix(self): |
|
|
|
return 'pch' |
|
|
|
return 'pch' |
|
|
|
|
|
|
|
|
|
|
|
def build_rpath_args(self, build_dir, rpath_paths): |
|
|
|
|
|
|
|
if len(rpath_paths) == 0: |
|
|
|
|
|
|
|
return [] |
|
|
|
|
|
|
|
return ['-Wl,-rpath,' + ':'.join([os.path.join(build_dir, p) for p in rpath_paths])] |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class GnuCPPCompiler(CPPCompiler): |
|
|
|
class GnuCPPCompiler(CPPCompiler): |
|
|
|
std_warn_args = ['-Wall', '-Winvalid-pch'] |
|
|
|
std_warn_args = ['-Wall', '-Winvalid-pch'] |
|
|
|
# may need to separate the latter to extra_debug_args or something |
|
|
|
# may need to separate the latter to extra_debug_args or something |
|
|
@ -930,11 +921,6 @@ class GnuCPPCompiler(CPPCompiler): |
|
|
|
def get_pch_suffix(self): |
|
|
|
def get_pch_suffix(self): |
|
|
|
return 'gch' |
|
|
|
return 'gch' |
|
|
|
|
|
|
|
|
|
|
|
def build_rpath_args(self, build_dir, rpath_paths): |
|
|
|
|
|
|
|
if len(rpath_paths) == 0: |
|
|
|
|
|
|
|
return [] |
|
|
|
|
|
|
|
return ['-Wl,-rpath,' + ':'.join([os.path.join(build_dir, p) for p in rpath_paths])] |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def get_soname_args(self, shlib_name, path): |
|
|
|
def get_soname_args(self, shlib_name, path): |
|
|
|
return get_gcc_soname_args(self.gcc_type, shlib_name, path) |
|
|
|
return get_gcc_soname_args(self.gcc_type, shlib_name, path) |
|
|
|
|
|
|
|
|
|
|
@ -957,11 +943,6 @@ class ClangCPPCompiler(CPPCompiler): |
|
|
|
def get_pch_suffix(self): |
|
|
|
def get_pch_suffix(self): |
|
|
|
return 'pch' |
|
|
|
return 'pch' |
|
|
|
|
|
|
|
|
|
|
|
def build_rpath_args(self, build_dir, rpath_paths): |
|
|
|
|
|
|
|
if len(rpath_paths) == 0: |
|
|
|
|
|
|
|
return [] |
|
|
|
|
|
|
|
return ['-Wl,-rpath,' + ':'.join([os.path.join(build_dir, p) for p in rpath_paths])] |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class VisualStudioLinker(): |
|
|
|
class VisualStudioLinker(): |
|
|
|
always_args = ['/NOLOGO'] |
|
|
|
always_args = ['/NOLOGO'] |
|
|
|
def __init__(self, exelist): |
|
|
|
def __init__(self, exelist): |
|
|
@ -988,7 +969,7 @@ class VisualStudioLinker(): |
|
|
|
def get_linker_always_args(self): |
|
|
|
def get_linker_always_args(self): |
|
|
|
return VisualStudioLinker.always_args |
|
|
|
return VisualStudioLinker.always_args |
|
|
|
|
|
|
|
|
|
|
|
def build_rpath_args(self, build_dir, rpath_paths): |
|
|
|
def build_rpath_args(self, build_dir, rpath_paths, install_rpath): |
|
|
|
return [] |
|
|
|
return [] |
|
|
|
|
|
|
|
|
|
|
|
class ArLinker(): |
|
|
|
class ArLinker(): |
|
|
@ -997,7 +978,7 @@ class ArLinker(): |
|
|
|
def __init__(self, exelist): |
|
|
|
def __init__(self, exelist): |
|
|
|
self.exelist = exelist |
|
|
|
self.exelist = exelist |
|
|
|
|
|
|
|
|
|
|
|
def build_rpath_args(self, build_dir, rpath_paths): |
|
|
|
def build_rpath_args(self, build_dir, rpath_paths, install_rpath): |
|
|
|
return [] |
|
|
|
return [] |
|
|
|
|
|
|
|
|
|
|
|
def get_exelist(self): |
|
|
|
def get_exelist(self): |
|
|
|