| // 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 javax.annotation.Nullable; |
| |
| /** |
| * The value of an option with additional metadata describing its origin. |
| * |
| * <p>This class represents an option as the parser received it, which is distinct from the final |
| * value of an option, as these values may be overridden or combined in some way. |
| * |
| * <p>The origin includes the form it had when parsed, its priority, a message about where it came |
| * from, and whether it was set explicitly or expanded/implied by other flags. |
| */ |
| public final class ParsedOptionDescription { |
| private final OptionDefinition optionDefinition; |
| private final String commandLineForm; |
| @Nullable private final String unconvertedValue; |
| private final OptionPriority priority; |
| @Nullable private final String source; |
| |
| // Whether this flag was explicitly given, as opposed to having been added by an expansion flag |
| // or an implicit dependency. Notice that this does NOT mean it was explicitly given by the |
| // user, for that to be true, it needs the right combination of explicit & priority. |
| private final boolean explicit; |
| |
| public ParsedOptionDescription( |
| OptionDefinition optionDefinition, |
| String commandLineForm, |
| @Nullable String unconvertedValue, |
| OptionPriority priority, |
| @Nullable String source, |
| boolean explicit) { |
| this.optionDefinition = optionDefinition; |
| this.commandLineForm = commandLineForm; |
| this.unconvertedValue = unconvertedValue; |
| this.priority = priority; |
| this.source = source; |
| this.explicit = explicit; |
| } |
| |
| public OptionDefinition getOptionDefinition() { |
| return optionDefinition; |
| } |
| |
| public String getCommandLineForm() { |
| return commandLineForm; |
| } |
| |
| public boolean isBooleanOption() { |
| return optionDefinition.getType().equals(boolean.class); |
| } |
| |
| private OptionDocumentationCategory documentationCategory() { |
| return optionDefinition.getDocumentationCategory(); |
| } |
| |
| private ImmutableList<OptionMetadataTag> metadataTags() { |
| return ImmutableList.copyOf(optionDefinition.getOptionMetadataTags()); |
| } |
| |
| public boolean isDocumented() { |
| return documentationCategory() != OptionDocumentationCategory.UNDOCUMENTED && !isHidden(); |
| } |
| |
| public boolean isHidden() { |
| ImmutableList<OptionMetadataTag> tags = metadataTags(); |
| return tags.contains(OptionMetadataTag.HIDDEN) || tags.contains(OptionMetadataTag.INTERNAL); |
| } |
| |
| public String getUnconvertedValue() { |
| return unconvertedValue; |
| } |
| |
| OptionPriority getPriority() { |
| return priority; |
| } |
| |
| public String getSource() { |
| return source; |
| } |
| |
| public boolean isExplicit() { |
| return explicit; |
| } |
| |
| public Object getConvertedValue() throws OptionsParsingException { |
| Converter<?> converter = optionDefinition.getConverter(); |
| try { |
| return converter.convert(unconvertedValue); |
| } catch (OptionsParsingException e) { |
| // The converter doesn't know the option name, so we supply it here by re-throwing: |
| throw new OptionsParsingException( |
| String.format("While parsing option %s: %s", commandLineForm, e.getMessage()), e); |
| } |
| } |
| |
| @Override |
| public String toString() { |
| StringBuilder result = new StringBuilder(); |
| result.append("option '").append(optionDefinition.getOptionName()).append("' "); |
| result.append("set to '").append(unconvertedValue).append("' "); |
| result.append("with priority ").append(priority); |
| if (source != null) { |
| result.append(" and source '").append(source).append("'"); |
| } |
| return result.toString(); |
| } |
| |
| } |