Next attempt of adding build type to executable and library names.
This commit is contained in:
29
SConscript
29
SConscript
@@ -464,7 +464,10 @@ def _build_target(target: _Target):
|
||||
_build_target(lib)
|
||||
target.kwargs['LIBS'].remove(lib)
|
||||
target.kwargs['LIBS'].append(lib.target)
|
||||
target.target = target.builder(*target.args, **target.kwargs)
|
||||
new_kwargs = target.kwargs.copy()
|
||||
if 'target' in new_kwargs: # there should always be a target, right?
|
||||
new_kwargs['target'] = f"{new_kwargs['target']}-{build_type}"
|
||||
target.target = target.builder(*target.args, **new_kwargs)
|
||||
|
||||
def _version_to_string(version) -> str:
|
||||
return '.'.join([str(v) for v in version])
|
||||
@@ -570,11 +573,13 @@ def _generate_project(project_type: str) -> None:
|
||||
for target in env['SPP_TARGETS']:
|
||||
if target.target_type == TargetType.PROGRAM:
|
||||
trgt = _target_entry(target.kwargs['target'])
|
||||
exe_path = pathlib.Path(trgt.abspath).relative_to(root_path)
|
||||
exe_path = exe_path.parent / f'{env["PROGPREFIX"]}{exe_path.name}{env["PROGSUFFIX"]}'
|
||||
def _exe_path(build_type) -> str:
|
||||
exe_path = pathlib.Path(trgt.abspath).relative_to(root_path)
|
||||
exe_path = exe_path.parent / f'{env.subst("$PROGPREFIX")}{exe_path.name}-{build_type}{env.subst("$PROGSUFFIX")}'
|
||||
return str(exe_path)
|
||||
result.append({
|
||||
'name': target.name,
|
||||
'filename': str(exe_path)
|
||||
'filename': _exe_path
|
||||
})
|
||||
return result
|
||||
def _get_libraries() -> list:
|
||||
@@ -582,19 +587,23 @@ def _generate_project(project_type: str) -> None:
|
||||
for target in env['SPP_TARGETS']:
|
||||
if target.target_type == TargetType.STATIC_LIBRARY:
|
||||
trgt = _target_entry(target.kwargs['target'])
|
||||
lib_path = pathlib.Path(trgt.abspath).relative_to(root_path)
|
||||
lib_path = lib_path.parent / f'{env.subst("$LIBPREFIX")}{lib_path.name}{env.subst("$LIBSUFFIX")}'
|
||||
def _lib_path(build_type) -> str:
|
||||
lib_path = pathlib.Path(trgt.abspath).relative_to(root_path)
|
||||
lib_path = lib_path.parent / f'{env.subst("$LIBPREFIX")}{lib_path.name}-{build_type}{env.subst("$LIBSUFFIX")}'
|
||||
return str(lib_path)
|
||||
result.append({
|
||||
'name': target.name,
|
||||
'filename': str(lib_path)
|
||||
'filename': _lib_path
|
||||
})
|
||||
elif target.target_type == TargetType.SHARED_LIBRARY:
|
||||
trgt = _target_entry(target.kwargs['target'])
|
||||
lib_path = pathlib.Path(trgt.abspath).relative_to(root_path)
|
||||
lib_path = lib_path.parent / f'{env.subst("$SHLIBPREFIX")}{lib_path.name}{env.subst("$SHLIBSUFFIX")}'
|
||||
def _lib_path(build_type) -> str:
|
||||
lib_path = pathlib.Path(trgt.abspath).relative_to(root_path)
|
||||
lib_path = lib_path.parent / f'{env.subst("$SHLIBPREFIX")}{lib_path.name}-{build_type}{env.subst("$SHLIBSUFFIX")}'
|
||||
return str(lib_path)
|
||||
result.append({
|
||||
'name': target.name,
|
||||
'filename': str(lib_path)
|
||||
'filename': _lib_path
|
||||
})
|
||||
return result
|
||||
def _escape_path(input: str) -> str:
|
||||
|
||||
Reference in New Issue
Block a user