Represents a configuration transition across a dependency edge. For example, if //package:foo depends on //package:bar with a configuration transition, then the configuration of these two targets will differ: //package:bar's transition will be determined by that of //package:foo, as subject to the function defined by a transition object.
Members
transition
transition transition(implementation, inputs, outputs)
Example:
def _transition_impl(settings, attr):
    # This transition just reads the current CPU value as a demonstration.
    # A real transition could incorporate this into its followup logic.
    current_cpu = settings["//command_line_option:cpu"]
    return {"//command_line_option:compilation_mode": "dbg"}
build_in_debug_mode = transition(
    implementation = _transition_impl,
    inputs = ["//command_line_option:cpu"],
    outputs = ["//command_line_option:compilation_mode"],
)For more details see here.
Parameters
| Parameter | Description | 
|---|---|
| implementation | required The function implementing this transition. This function always has two parameters: settingsandattr. Thesettingsparam is a dictionary whose set of keys is defined by the inputs parameter. So, for each build setting--//foo=bar, ifinputscontains//foo,settingswill have an entrysettings['//foo']='bar'.The  This function must return a  | 
| inputs | sequence of strings;
                                     requiredList of build settings that can be read by this transition. This becomes the key set of the settings parameter of the implementation function parameter. | 
| outputs | sequence of strings;
                                     requiredList of build settings that can be written by this transition. This must be a superset of the key set of the dictionary returned by this transition. |