blob: da45a892b91bd7061f6d855495ec6196e8ed6639 [file] [log] [blame]
// Copyright 2018 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.query2.aquery;
import com.google.devtools.build.lib.query2.common.CommonQueryOptions;
import com.google.devtools.common.options.Option;
import com.google.devtools.common.options.OptionDocumentationCategory;
import com.google.devtools.common.options.OptionEffectTag;
import com.google.devtools.common.options.OptionMetadataTag;
/** Options class for aquery specific query options. */
public class AqueryOptions extends CommonQueryOptions {
@Option(
name = "output",
defaultValue = "text",
documentationCategory = OptionDocumentationCategory.QUERY,
effectTags = {OptionEffectTag.TERMINAL_OUTPUT},
help =
"The format in which the aquery results should be printed. Allowed values for aquery "
+ "are: text, textproto, proto.")
public String outputFormat;
@Option(
name = "include_commandline",
defaultValue = "true",
documentationCategory = OptionDocumentationCategory.QUERY,
effectTags = {OptionEffectTag.TERMINAL_OUTPUT},
help = "Includes the content of the action command lines in the output (potentially large).")
public boolean includeCommandline;
@Option(
name = "include_artifacts",
defaultValue = "true",
documentationCategory = OptionDocumentationCategory.QUERY,
effectTags = {OptionEffectTag.TERMINAL_OUTPUT},
help =
"Includes names of the action inputs and outputs in the output " + "(potentially large).")
public boolean includeArtifacts;
@Option(
name = "include_aspects",
defaultValue = "false",
documentationCategory = OptionDocumentationCategory.QUERY,
effectTags = {OptionEffectTag.TERMINAL_OUTPUT},
help = "Whether to include aspect generated actions in the output.")
public boolean useAspects;
@Option(
name = "include_param_files",
defaultValue = "false",
documentationCategory = OptionDocumentationCategory.QUERY,
effectTags = {OptionEffectTag.TERMINAL_OUTPUT},
help =
"Include the content of the param files used in the command (potentially large). "
+ "Note: Enabling this flag will automatically enable the "
+ "--include_commandline flag.")
public boolean includeParamFiles;
@Option(
name = "skyframe_state",
defaultValue = "false",
documentationCategory = OptionDocumentationCategory.QUERY,
effectTags = {OptionEffectTag.TERMINAL_OUTPUT},
help =
"Without performing extra analysis, dump the current Action Graph from Skyframe. "
+ "Note: Specifying a target with --skyframe_state is currently not supported. "
+ "This flag is only available with --output=proto or --output=textproto.")
public boolean queryCurrentSkyframeState;
@Option(
name = "incompatible_proto_output_v2",
defaultValue = "false",
documentationCategory = OptionDocumentationCategory.QUERY,
effectTags = {OptionEffectTag.TERMINAL_OUTPUT},
metadataTags = {
OptionMetadataTag.INCOMPATIBLE_CHANGE,
OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES
},
help =
"Whether aquery should print proto/textproto results with proto v2 "
+ "(with ids in uint64 instead of string).")
public boolean protoV2;
}