blob: 3268cbdcc4dd2beb47e95a08001df8b58665cee2 [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.common.options;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap;
import java.util.Collection;
import java.util.Map;
import javax.annotation.concurrent.Immutable;
/**
* This extends IsolatedOptionsData with information that can only be determined once all the {@link
* OptionsBase} subclasses for a parser are known. In particular, this includes expansion
* information.
*/
@Immutable
final class OptionsData extends IsolatedOptionsData {
/** Mapping from each option to the (unparsed) options it expands to, if any. */
private final ImmutableMap<OptionDefinition, ImmutableList<String>> evaluatedExpansions;
/**
* Whether this options data has been created with duplicate options definitions allowed as long
* as those options are parsed (but not necessarily evaluated) equivalently.
*/
private final boolean allowDuplicatesParsingEquivalently;
/** Construct {@link OptionsData} by extending an {@link IsolatedOptionsData} with new info. */
private OptionsData(
IsolatedOptionsData base,
Map<OptionDefinition, ImmutableList<String>> evaluatedExpansions,
boolean allowDuplicatesParsingEquivalently) {
super(base);
this.evaluatedExpansions = ImmutableMap.copyOf(evaluatedExpansions);
this.allowDuplicatesParsingEquivalently = allowDuplicatesParsingEquivalently;
}
private static final ImmutableList<String> EMPTY_EXPANSION = ImmutableList.<String>of();
/**
* Returns the expansion of an options field. If the field is not an expansion option returns an
* empty array.
*/
public ImmutableList<String> getEvaluatedExpansion(OptionDefinition optionDefinition) {
ImmutableList<String> result = evaluatedExpansions.get(optionDefinition);
return result != null ? result : EMPTY_EXPANSION;
}
/**
* Returns whether this options data has been created with duplicate options definitions allowed
* as long as those options are parsed (but not necessarily evaluated) equivalently.
*/
public boolean createdWithAllowDuplicatesParsingEquivalently() {
return allowDuplicatesParsingEquivalently;
}
/**
* Constructs an {@link OptionsData} object for a parser that knows about the given {@link
* OptionsBase} classes. In addition to the work done to construct the {@link
* IsolatedOptionsData}, this also computes expansion information. If an option has an expansion,
* try to precalculate its here.
*/
static OptionsData from(
Collection<Class<? extends OptionsBase>> classes,
boolean allowDuplicatesParsingEquivalently) {
IsolatedOptionsData isolatedData =
IsolatedOptionsData.from(classes, allowDuplicatesParsingEquivalently);
// All that's left is to compute expansions.
ImmutableMap.Builder<OptionDefinition, ImmutableList<String>> evaluatedExpansionsBuilder =
ImmutableMap.builder();
for (Map.Entry<String, OptionDefinition> entry : isolatedData.getAllOptionDefinitions()) {
OptionDefinition optionDefinition = entry.getValue();
String[] constExpansion = optionDefinition.getOptionExpansion();
if (constExpansion.length > 0) {
evaluatedExpansionsBuilder.put(optionDefinition, ImmutableList.copyOf(constExpansion));
}
}
return new OptionsData(
isolatedData,
evaluatedExpansionsBuilder.buildOrThrow(),
allowDuplicatesParsingEquivalently);
}
}