# Copyright 2003, 2004, 2006 Vladimir Prus # Distributed under the Boost Software License, Version 1.0. # (See accompanying file LICENSE_1_0.txt or http://www.boost.org/LICENSE_1_0.txt) # Status: ported (danielw) # Base revision: 56043 # This module defines the 'alias' rule and associated class. # # Alias is just a main target which returns its source targets without any # processing. For example:: # # alias bin : hello test_hello ; # alias lib : helpers xml_parser ; # # Another important use of 'alias' is to conveniently group source files:: # # alias platform-src : win.cpp : NT ; # alias platform-src : linux.cpp : LINUX ; # exe main : main.cpp platform-src ; # # Lastly, it's possible to create local alias for some target, with different # properties:: # # alias big_lib : : @/external_project/big_lib/static ; # import targets import property_set from b2.manager import get_manager from b2.util import metatarget, is_iterable_typed class AliasTarget(targets.BasicTarget): def __init__(self, *args): targets.BasicTarget.__init__(self, *args) def construct(self, name, source_targets, properties): if __debug__: from .virtual_target import VirtualTarget assert isinstance(name, basestring) assert is_iterable_typed(source_targets, VirtualTarget) assert isinstance(properties, property_set.PropertySet) return [property_set.empty(), source_targets] def compute_usage_requirements(self, subvariant): if __debug__: from .virtual_target import Subvariant assert isinstance(subvariant, Subvariant) base = targets.BasicTarget.compute_usage_requirements(self, subvariant) # Add source's usage requirement. If we don't do this, "alias" does not # look like 100% alias. return base.add(subvariant.sources_usage_requirements()) @metatarget def alias(name, sources=[], requirements=[], default_build=[], usage_requirements=[]): assert isinstance(name, basestring) assert is_iterable_typed(sources, basestring) assert is_iterable_typed(requirements, basestring) assert is_iterable_typed(default_build, basestring) assert is_iterable_typed(usage_requirements, basestring) project = get_manager().projects().current() targets = get_manager().targets() targets.main_target_alternative(AliasTarget( name, project, targets.main_target_sources(sources, name, no_renaming=True), targets.main_target_requirements(requirements or [], project), targets.main_target_default_build(default_build, project), targets.main_target_usage_requirements(usage_requirements or [], project))) # Declares the 'alias' target. It will build sources, and return them unaltered. get_manager().projects().add_rule("alias", alias)