| // 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.packages; |
| |
| import com.google.common.collect.Interner; |
| import com.google.devtools.build.lib.concurrent.BlazeInterners; |
| import com.google.devtools.build.lib.syntax.StarlarkSemantics; |
| import com.google.devtools.common.options.Converters.CommaSeparatedOptionListConverter; |
| 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; |
| import com.google.devtools.common.options.OptionsBase; |
| import java.io.Serializable; |
| import java.util.List; |
| |
| /** |
| * Contains options that affect Starlark's semantics. |
| * |
| * <p>These are injected into Skyframe (as an instance of {@link StarlarkSemantics}) when a new |
| * build invocation occurs. Changing these options between builds will therefore trigger a |
| * reevaluation of everything that depends on the Starlark interpreter — in particular, |
| * evaluation of all BUILD and .bzl files. |
| * |
| * <p><em>To add a new option, update the following:</em> |
| * |
| * <ul> |
| * <li>Add a new abstract method (which is interpreted by {@code AutoValue} as a field) to {@link |
| * StarlarkSemantics} and {@link StarlarkSemantics.Builder}. Set its default value in {@link |
| * StarlarkSemantics#DEFAULT_SEMANTICS}. |
| * <li>Add a new {@code @Option}-annotated field to this class. The field name and default value |
| * should be the same as in {@link StarlarkSemantics}, and the option name in the annotation |
| * should be that name written in snake_case. Add a line to set the new field in {@link |
| * #toSkylarkSemantics}. |
| * <li>Add a line to set the new field in both {@link |
| * SkylarkSemanticsConsistencyTest#buildRandomOptions} and {@link |
| * SkylarkSemanticsConsistencyTest#buildRandomSemantics}. |
| * <li>Update manual documentation in site/docs/skylark/backward-compatibility.md. Also remember |
| * to update this when flipping a flag's default value. |
| * <li>Boolean semantic flags can toggle Skylark methods on or off. To do this, add a new entry to |
| * {@link StarlarkSemantics#FlagIdentifier}. Then, specify the identifier in {@code |
| * SkylarkCallable.enableOnlyWithFlag} or {@code SkylarkCallable.disableWithFlag}. |
| * </ul> |
| * |
| * For both readability and correctness, the relative order of the options in all of these locations |
| * must be kept consistent; to make it easy we use alphabetic order. The parts that need updating |
| * are marked with the comment "<== Add new options here in alphabetic order ==>". |
| */ |
| public class StarlarkSemanticsOptions extends OptionsBase implements Serializable { |
| |
| // <== Add new options here in alphabetic order ==> |
| |
| @Option( |
| name = "experimental_allow_incremental_repository_updates", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BAZEL_INTERNAL_CONFIGURATION}, |
| metadataTags = {OptionMetadataTag.EXPERIMENTAL}, |
| help = |
| "If used, it is possible to define a mapping between external repositories" |
| + " and some (mostly likely ignored by .bazelignore) directories." |
| + " The repository rule can read and update files in those directories," |
| + " and the changes will be visible in the same build." |
| + " Use attribute 'managed_directories' of the global workspace()" |
| + " function in WORKSPACE file to define the mapping.") |
| public boolean experimentalAllowIncrementalRepositoryUpdates; |
| |
| @Option( |
| name = "experimental_build_setting_api", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.UNDOCUMENTED, |
| effectTags = OptionEffectTag.BUILD_FILE_SEMANTICS, |
| help = |
| "If set to true, allows access to value of build setting rules via " |
| + "ctx.build_setting_value.") |
| public boolean experimentalBuildSettingApi; |
| |
| @Option( |
| name = "experimental_cc_skylark_api_enabled_packages", |
| converter = CommaSeparatedOptionListConverter.class, |
| defaultValue = "", |
| documentationCategory = OptionDocumentationCategory.UNDOCUMENTED, |
| effectTags = {OptionEffectTag.LOADING_AND_ANALYSIS}, |
| metadataTags = {OptionMetadataTag.EXPERIMENTAL}, |
| help = |
| "Passes list of packages that can use the C++ Starlark API. Don't enable this flag yet, " |
| + "we will be making breaking changes.") |
| public List<String> experimentalCcSkylarkApiEnabledPackages; |
| |
| @Option( |
| name = "experimental_enable_android_migration_apis", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = OptionEffectTag.BUILD_FILE_SEMANTICS, |
| help = "If set to true, enables the APIs required to support the Android Starlark migration.") |
| public boolean experimentalEnableAndroidMigrationApis; |
| |
| @Option( |
| name = "experimental_google_legacy_api", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.LOADING_AND_ANALYSIS}, |
| metadataTags = {OptionMetadataTag.EXPERIMENTAL}, |
| help = |
| "If set to true, exposes a number of experimental pieces of Starlark build API " |
| + "pertaining to Google legacy code.") |
| public boolean experimentalGoogleLegacyApi; |
| |
| // This flag is declared in StarlarkSemanticsOptions instead of JavaOptions because there is no |
| // way to retrieve the java configuration from the Java implementation of |
| // java_common.create_provider. |
| @Option( |
| name = "experimental_java_common_create_provider_enabled_packages", |
| converter = CommaSeparatedOptionListConverter.class, |
| defaultValue = "", |
| documentationCategory = OptionDocumentationCategory.UNDOCUMENTED, |
| effectTags = {OptionEffectTag.LOADING_AND_ANALYSIS}, |
| metadataTags = {OptionMetadataTag.EXPERIMENTAL}, |
| help = "Passes list of packages that can use the java_common.create_provider Starlark API.") |
| public List<String> experimentalJavaCommonCreateProviderEnabledPackages; |
| |
| @Option( |
| name = "experimental_platforms_api", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.LOADING_AND_ANALYSIS}, |
| metadataTags = {OptionMetadataTag.EXPERIMENTAL}, |
| help = |
| "If set to true, enables a number of platform-related Starlark APIs useful for " |
| + "debugging.") |
| public boolean experimentalPlatformsApi; |
| |
| @Option( |
| name = "experimental_starlark_config_transitions", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.LOADING_AND_ANALYSIS}, |
| metadataTags = {OptionMetadataTag.EXPERIMENTAL}, |
| help = |
| "If set to true, enables creation of configuration transition objects (the " |
| + "`transition()` function) in Starlark.") |
| public boolean experimentalStarlarkConfigTransitions; |
| |
| @Option( |
| name = "experimental_starlark_unused_inputs_list", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.CHANGES_INPUTS}, |
| metadataTags = {OptionMetadataTag.EXPERIMENTAL}, |
| help = "If set to true, enables use of 'unused_inputs_list' in starlark action.run().") |
| public boolean experimentalStarlarkUnusedInputsList; |
| |
| @Option( |
| name = "incompatible_bzl_disallow_load_after_statement", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "If set to true, all `load` must be called at the top of .bzl files, before any other " |
| + "statement.") |
| public boolean incompatibleBzlDisallowLoadAfterStatement; |
| |
| @Option( |
| name = "incompatible_depset_union", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "If set to true, depset union using `+`, `|` or `.union` are forbidden. " |
| + "Use the `depset` constructor instead.") |
| public boolean incompatibleDepsetUnion; |
| |
| @Option( |
| name = "incompatible_depset_is_not_iterable", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "If set to true, depset type is not iterable. For loops and functions expecting an " |
| + "iterable will reject depset objects. Use the `.to_list` method to explicitly " |
| + "convert to a list.") |
| public boolean incompatibleDepsetIsNotIterable; |
| |
| @Option( |
| name = "incompatible_disable_deprecated_attr_params", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "If set to true, disable the deprecated parameters 'single_file' and 'non_empty' on " |
| + "attribute definition methods, such as attr.label().") |
| public boolean incompatibleDisableDeprecatedAttrParams; |
| |
| @Option( |
| name = "incompatible_disable_objc_provider_resources", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = "Unused. Will be removed in future versions of Bazel.") |
| public boolean incompatibleDisableObjcProviderResources; |
| |
| // For Bazel, this flag is a no-op. Bazel doesn't support built-in third party license checking |
| // (see https://github.com/bazelbuild/bazel/issues/7444). |
| // |
| // For Blaze in Google, this flag is still needed to deprecate the logic that's already been |
| // removed from Bazel. That logic was introduced before Bazel existed, so Google's dependency on |
| // it is deeper. But we don't want that to add unnecessary baggage to Bazel or slow down Bazel's |
| // development. So this flag lets Blaze migrate on a slower timeline without blocking Bazel. This |
| // means you as a Bazel user are getting better code than Google has! (for a while, at least) |
| @Option( |
| name = "incompatible_disable_third_party_license_checking", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = OptionEffectTag.BUILD_FILE_SEMANTICS, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = "If true, disables all license checking logic") |
| public boolean incompatibleDisableThirdPartyLicenseChecking; |
| |
| @Option( |
| name = "incompatible_disallow_dict_lookup_unhashable_keys", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "If set to true, dict key lookups using `in` or `dict.get` will fail with unhashable" |
| + " types.") |
| public boolean incompatibleDisallowDictLookupUnhashableKeys; |
| |
| @Option( |
| name = "incompatible_disallow_dict_plus", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = "If set to true, the `+` becomes disabled for dicts.") |
| public boolean incompatibleDisallowDictPlus; |
| |
| @Option( |
| name = "incompatible_disallow_empty_glob", |
| defaultValue = "false", |
| category = "incompatible changes", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = "If set to true, the default value of the `allow_empty` argument of glob() is False.") |
| public boolean incompatibleDisallowEmptyGlob; |
| |
| @Option( |
| name = "incompatible_disallow_legacy_java_provider", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = "If set to true, usages of old .java provider are disallowed.") |
| public boolean incompatibleDisallowLegacyJavaProvider; |
| |
| @Option( |
| name = "incompatible_disallow_legacy_javainfo", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = "If set to true, old-style JavaInfo provider construction is disallowed.") |
| public boolean incompatibleDisallowLegacyJavaInfo; |
| |
| @Option( |
| name = "incompatible_disallow_rule_execution_platform_constraints_allowed", |
| defaultValue = "False", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "If set to true, disallow the use of the execution_platform_constraints_allowed " |
| + "attribute on rule().") |
| public boolean incompatibleDisallowRuleExecutionPlatformConstraintsAllowed; |
| |
| @Option( |
| name = "incompatible_disallow_split_empty_separator", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = "If set to true, `string.split` will fail if `sep` is the empty string.") |
| public boolean incompatibleDisallowSplitEmptySeparator; |
| |
| @Option( |
| name = "incompatible_string_join_requires_strings", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "If set to true, the argument of `string.join` must be an iterable whose elements are " |
| + "strings. If set to false, elements are first converted to string. " |
| + "See https://github.com/bazelbuild/bazel/issues/7802") |
| public boolean incompatibleStringJoinRequiresStrings; |
| |
| @Option( |
| name = "incompatible_disallow_struct_provider_syntax", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "If set to true, rule implementation functions may not return a struct. They must " |
| + "instead return a list of provider instances.") |
| public boolean incompatibleDisallowStructProviderSyntax; |
| |
| /** Controls legacy arguments to ctx.actions.Args#add. */ |
| @Option( |
| name = "incompatible_disallow_old_style_args_add", |
| defaultValue = "true", |
| category = "incompatible changes", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = "If set to true, vectorized calls to Args#add are disallowed.") |
| public boolean incompatibleDisallowOldStyleArgsAdd; |
| |
| @Option( |
| name = "incompatible_disallow_unverified_http_downloads", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.LOADING_AND_ANALYSIS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = "If set, disallow downloads via plain http if no checksum is given") |
| public boolean incompatibleDisallowUnverifiedHttpDownloads; |
| |
| @Option( |
| name = "incompatible_expand_directories", |
| defaultValue = "true", |
| category = "incompatible changes", |
| documentationCategory = OptionDocumentationCategory.UNCATEGORIZED, |
| effectTags = {OptionEffectTag.UNKNOWN}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "Controls whether directories are expanded to the list of files under that directory " |
| + "when added to Args, instead of replaced by the path of the directory.") |
| public boolean incompatibleExpandDirectories; |
| |
| @Option( |
| name = "incompatible_new_actions_api", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "If set to true, the API to create actions is only available on `ctx.actions`, " |
| + "not on `ctx`.") |
| public boolean incompatibleNewActionsApi; |
| |
| @Option( |
| name = "incompatible_no_attr_license", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = "If set to true, disables the function `attr.license`.") |
| public boolean incompatibleNoAttrLicense; |
| |
| @Option( |
| name = "incompatible_no_output_attr_default", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "If set to true, disables the `default` parameter of the `attr.output` and " |
| + "`attr.output_list` attribute definition functions.") |
| public boolean incompatibleNoOutputAttrDefault; |
| |
| @Option( |
| name = "incompatible_no_rule_outputs_param", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = "If set to true, disables the `outputs` parameter of the `rule()` Starlark function.") |
| public boolean incompatibleNoRuleOutputsParam; |
| |
| @Option( |
| name = "incompatible_no_support_tools_in_action_inputs", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "If set to true, tools should be passed to `ctx.actions.run()` and " |
| + "`ctx.actions.run_shell()` using the `tools` parameter instead of the `inputs` " |
| + "parameter. Furthermore, if this flag is set and a `tools` parameter is not " |
| + "passed to the action, it is an error for any tools to appear in the `inputs`.") |
| public boolean incompatibleNoSupportToolsInActionInputs; |
| |
| @Option( |
| name = "incompatible_no_target_output_group", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = "If set to true, disables the output_group field of the 'Target' Starlark type.") |
| public boolean incompatibleNoTargetOutputGroup; |
| |
| @Option( |
| name = "incompatible_no_transitive_loads", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "If set to true, only symbols explicitly defined in the file can be loaded; " |
| + "symbols introduced by load are not implicitly re-exported.") |
| public boolean incompatibleNoTransitiveLoads; |
| |
| @Option( |
| name = "incompatible_remap_main_repo", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = OptionEffectTag.LOADING_AND_ANALYSIS, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| oldName = "experimental_remap_main_repo", |
| help = "If set to true, will treat references to '@<main repo name>' the same as '@'.") |
| public boolean incompatibleRemapMainRepo; |
| |
| @Option( |
| name = "incompatible_remove_native_maven_jar", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "If set to true, the native maven_jar rule is disabled; only the Starlark version " |
| + "will be available") |
| public boolean incompatibleRemoveNativeMavenJar; |
| |
| @Option( |
| name = "incompatible_run_shell_command_string", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = "If set to true, the command parameter of actions.run_shell will only accept string") |
| public boolean incompatibleRunShellCommandString; |
| |
| /** Used in an integration test to confirm that flags are visible to the interpreter. */ |
| @Option( |
| name = "internal_skylark_flag_test_canary", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.UNDOCUMENTED, |
| effectTags = {OptionEffectTag.UNKNOWN}) |
| public boolean internalSkylarkFlagTestCanary; |
| |
| @Option( |
| name = "incompatible_do_not_split_linking_cmdline", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.BUILD_TIME_OPTIMIZATION, |
| effectTags = {OptionEffectTag.LOADING_AND_ANALYSIS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "When true, Bazel no longer modifies command line flags used for linking, and also " |
| + "doesn't selectively decide which flags go to the param file and which don't. " |
| + "See https://github.com/bazelbuild/bazel/issues/7670 for details.") |
| public boolean incompatibleDoNotSplitLinkingCmdline; |
| |
| @Option( |
| name = "incompatible_objc_framework_cleanup", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "If enabled, use the post-cleanup mode for prebuilt frameworks. The cleanup changes " |
| + "the objc provider API pertaining to frameworks. This change is expected to be " |
| + "transparent to most users unless they write their own Starlark rules to handle " |
| + "frameworks. See https://github.com/bazelbuild/bazel/issues/7944 for details.") |
| public boolean incompatibleObjcFrameworkCleanup; |
| |
| @Option( |
| name = "incompatible_restrict_named_params", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.LOADING_AND_ANALYSIS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "If set to true, restricts a number of Starlark built-in function parameters to be " |
| + "only specifiable positionally (and not by keyword).") |
| public boolean incompatibleRestrictNamedParams; |
| |
| @Option( |
| name = "incompatible_restrict_attribute_names", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.LOADING_AND_ANALYSIS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = "If set to true, restrict rule attribute names to valid identifiers") |
| public boolean incompatibleRestrictAttributeNames; |
| |
| @Option( |
| name = "incompatible_depset_for_libraries_to_link_getter", |
| defaultValue = "true", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.LOADING_AND_ANALYSIS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = |
| "When true, Bazel no longer returns a list from linking_context.libraries_to_link but " |
| + "returns a depset instead.") |
| public boolean incompatibleDepsetForLibrariesToLinkGetter; |
| |
| @Option( |
| name = "incompatible_restrict_string_escapes", |
| defaultValue = "false", |
| documentationCategory = OptionDocumentationCategory.STARLARK_SEMANTICS, |
| effectTags = {OptionEffectTag.BUILD_FILE_SEMANTICS}, |
| metadataTags = { |
| OptionMetadataTag.INCOMPATIBLE_CHANGE, |
| OptionMetadataTag.TRIGGERED_BY_ALL_INCOMPATIBLE_CHANGES |
| }, |
| help = "If set to true, unknown string escapes like `\\a` become rejected.") |
| public boolean incompatibleRestrictStringEscapes; |
| |
| /** |
| * An interner to reduce the number of StarlarkSemantics instances. A single Blaze instance should |
| * never accumulate a large number of these and being able to shortcut on object identity makes a |
| * comparison later much faster. In particular, the semantics become part of the |
| * MethodDescriptorKey in FuncallExpression and are thus compared for every function call. |
| */ |
| private static final Interner<StarlarkSemantics> INTERNER = BlazeInterners.newWeakInterner(); |
| |
| /** Constructs a {@link StarlarkSemantics} object corresponding to this set of option values. */ |
| public StarlarkSemantics toSkylarkSemantics() { |
| StarlarkSemantics semantics = |
| StarlarkSemantics.builder() |
| // <== Add new options here in alphabetic order ==> |
| .experimentalAllowIncrementalRepositoryUpdates( |
| experimentalAllowIncrementalRepositoryUpdates) |
| .experimentalBuildSettingApi(experimentalBuildSettingApi) |
| .experimentalCcSkylarkApiEnabledPackages(experimentalCcSkylarkApiEnabledPackages) |
| .experimentalEnableAndroidMigrationApis(experimentalEnableAndroidMigrationApis) |
| .experimentalGoogleLegacyApi(experimentalGoogleLegacyApi) |
| .experimentalJavaCommonCreateProviderEnabledPackages( |
| experimentalJavaCommonCreateProviderEnabledPackages) |
| .experimentalPlatformsApi(experimentalPlatformsApi) |
| .experimentalStarlarkConfigTransitions(experimentalStarlarkConfigTransitions) |
| .experimentalStarlarkUnusedInputsList(experimentalStarlarkUnusedInputsList) |
| .incompatibleBzlDisallowLoadAfterStatement(incompatibleBzlDisallowLoadAfterStatement) |
| .incompatibleDepsetIsNotIterable(incompatibleDepsetIsNotIterable) |
| .incompatibleDepsetUnion(incompatibleDepsetUnion) |
| .incompatibleDisableThirdPartyLicenseChecking( |
| incompatibleDisableThirdPartyLicenseChecking) |
| .incompatibleDisableDeprecatedAttrParams(incompatibleDisableDeprecatedAttrParams) |
| .incompatibleDisableObjcProviderResources(incompatibleDisableObjcProviderResources) |
| .incompatibleDisallowDictPlus(incompatibleDisallowDictPlus) |
| .incompatibleDisallowEmptyGlob(incompatibleDisallowEmptyGlob) |
| .incompatibleDisallowLegacyJavaInfo(incompatibleDisallowLegacyJavaInfo) |
| .incompatibleDisallowLegacyJavaProvider(incompatibleDisallowLegacyJavaProvider) |
| .incompatibleDisallowOldStyleArgsAdd(incompatibleDisallowOldStyleArgsAdd) |
| .incompatibleDisallowStructProviderSyntax(incompatibleDisallowStructProviderSyntax) |
| .incompatibleDisallowRuleExecutionPlatformConstraintsAllowed( |
| incompatibleDisallowRuleExecutionPlatformConstraintsAllowed) |
| .incompatibleDisallowUnverifiedHttpDownloads( |
| incompatibleDisallowUnverifiedHttpDownloads) |
| .incompatibleExpandDirectories(incompatibleExpandDirectories) |
| .incompatibleNewActionsApi(incompatibleNewActionsApi) |
| .incompatibleNoAttrLicense(incompatibleNoAttrLicense) |
| .incompatibleNoOutputAttrDefault(incompatibleNoOutputAttrDefault) |
| .incompatibleNoRuleOutputsParam(incompatibleNoRuleOutputsParam) |
| .incompatibleNoSupportToolsInActionInputs(incompatibleNoSupportToolsInActionInputs) |
| .incompatibleNoTargetOutputGroup(incompatibleNoTargetOutputGroup) |
| .incompatibleNoTransitiveLoads(incompatibleNoTransitiveLoads) |
| .incompatibleObjcFrameworkCleanup(incompatibleObjcFrameworkCleanup) |
| .incompatibleRemapMainRepo(incompatibleRemapMainRepo) |
| .incompatibleRemoveNativeMavenJar(incompatibleRemoveNativeMavenJar) |
| .incompatibleRestrictAttributeNames(incompatibleRestrictAttributeNames) |
| .incompatibleRestrictNamedParams(incompatibleRestrictNamedParams) |
| .incompatibleRunShellCommandString(incompatibleRunShellCommandString) |
| .incompatibleStringJoinRequiresStrings(incompatibleStringJoinRequiresStrings) |
| .internalSkylarkFlagTestCanary(internalSkylarkFlagTestCanary) |
| .incompatibleDoNotSplitLinkingCmdline(incompatibleDoNotSplitLinkingCmdline) |
| .incompatibleDepsetForLibrariesToLinkGetter(incompatibleDepsetForLibrariesToLinkGetter) |
| .incompatibleRestrictStringEscapes(incompatibleRestrictStringEscapes) |
| .incompatibleDisallowSplitEmptySeparator(incompatibleDisallowSplitEmptySeparator) |
| .incompatibleDisallowDictLookupUnhashableKeys( |
| incompatibleDisallowDictLookupUnhashableKeys) |
| .build(); |
| return INTERNER.intern(semantics); |
| } |
| } |