blob: fc3b9613d1fe712c283145f3edc9bf0403168c50 [file] [log] [blame]
// Copyright 2017 The Bazel Authors. All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package com.google.devtools.build.lib.analysis.config.transitions;
import com.google.devtools.build.lib.analysis.config.BuildOptions;
import com.google.devtools.build.lib.events.EventHandler;
import java.util.Map;
/**
* A configuration transition.
*/
public interface ConfigurationTransition {
/**
* A designated key string for patch transitions. See {@link ConfigurationTransition#apply} for
* its usage.
*/
String PATCH_TRANSITION_KEY = "";
/**
* Returns the map of {@code BuildOptions} after applying this transition. The returned map keys
* are only used for dealing with split transitions. Patch transitions, including internal, native
* Patch transitions, should return a single entry map with key {@code PATCH_TRANSITION_KEY}.
*
* <p>Returning an empty or null map triggers a {@link RuntimeException}.
*/
Map<String, BuildOptions> apply(BuildOptions buildOptions, EventHandler eventHandler);
/**
* We want to keep the number of transition interfaces no larger than what's necessary to maintain
* a clear configuration API.
*
* <p>This method provides a speed bump against creating new interfaces too casually. While we
* could provide stronger enforcement by making {@link ConfigurationTransition} an abstract class
* with a limited access constructor, keeping it as an interface supports defining transitions
* with lambdas.
*
* <p>If you're considering adding a new override, contact bazel-dev@googlegroups.com to discuss.
*/
@SuppressWarnings("unused")
String reasonForOverride();
/**
* Does this transition switch to a "host" configuration?
*/
default boolean isHostTransition() {
return false;
}
default String getName() {
return this.getClass().getSimpleName();
}
/** Allows the given {@link Visitor} to inspect this transition. */
default <E extends Exception> void visit(Visitor<E> visitor) throws E {
visitor.accept(this);
}
/** Helper object that can be used to inspect {@link ConfigurationTransition} instances. */
@FunctionalInterface
interface Visitor<E extends Exception> {
void accept(ConfigurationTransition transition) throws E;
}
}