指令列參考資料

bazel [<startup options>] <command> [<args>]
bazel [<startup options>] <command> [<args>] -- [<target patterns>]
如要瞭解目標模式語法,請參閱使用者指南

選項語法

您可以透過不同方式將選項傳遞至 Bazel。需要值的選項可以透過等號或空格傳遞:

--<option>=<value>
--<option> <value>
部分選項有單一字元的簡寫形式;在這種情況下,您必須使用單一破折號和空格來傳遞簡寫形式。
-<short_form> <value>

您可以透過下列方式啟用布林值選項:

--<option>
--<option>=[true|yes|1]
並停用以下項目:
--no<option>
--<option>=[false|no|0]

三態選項通常預設為自動,可透過下列方式強制啟用:

--<option>=[true|yes|1]
或強制停用,如下所示:
--no<option>
--<option>=[false|no|0]

指令

analyze-profile 分析建構設定檔資料。
aquery 分析指定的目標,並查詢動作圖表。
build 建構指定的目標。
canonicalize-flags 將 Bazel 選項清單標準化。
clean 移除輸出檔案,並視需要停止伺服器。
coverage 為指定的測試目標產生程式碼涵蓋率報表。
cquery 載入、分析及查詢指定的目標和設定。
dump 轉儲 Bazel 伺服器程序的內部狀態。
fetch 擷取目標的必要條件外部存放區。
help 列印指令或索引的說明。
info 顯示 Bazel 伺服器的執行階段資訊。
license 列印此軟體的授權。
mobile-install 在行動裝置上安裝目標。
mod 查詢 Bzlmod 外部依附元件圖
print_action 列印編譯檔案的指令列引數。
query 執行依附元件圖表查詢。
run 執行指定的目標。
shutdown 停止 Bazel 伺服器。
sync 同步處理工作區檔案中指定的所有存放區
test 建構並執行指定的測試目標。
vendor 將外部存放區擷取至由標記 --vendor_dir 指定的資料夾。
version 列印 Bazel 的版本資訊。

開機選項

顯示在指令前方且由用戶端剖析的選項:
--[no]autodetect_server_javabase 預設值:「true」
傳遞 --noautodetect_server_javabase 時,Bazel 不會改用本機 JDK 來執行 bazel 伺服器,而是會結束。
標記: affects_outputsloses_incremental_state
--[no]batch 預設值:「false」
如果設定此值,Bazel 就會以沒有伺服器的用戶端程序執行,而不是以標準用戶端/伺服器模式執行。這項功能已淘汰,並將移除。如果您想避免伺服器閒置,請改為明確關閉伺服器。
標記: loses_incremental_statebazel_internal_configurationdeprecated
--[no]batch_cpu_scheduling 預設值:「false」
僅適用於 Linux;請為 Blaze 使用「批次」CPU 排程。這項政策適用於非互動的工作負載,但不想降低其優先順序值。請參閱「man 2 sched_setscheduler」。如果為 false,則 Bazel 不會執行系統呼叫。
標記: host_machine_resource_optimizations
--bazelrc=<path> 預設值:請參閱說明
包含 Bazel 選項預設值的使用者 .bazelrc 檔案位置。/dev/null 表示系統會忽略所有後續的 `--bazelrc`,這可用於停用搜尋使用者 RC 檔案的功能,例如在發布版本中。您也可以多次指定這個選項。例如,使用 `--bazelrc=x.rc --bazelrc=y.rc --bazelrc=/dev/null --bazelrc=z.rc` 時,系統會讀取 1) x.rc 和 y.rc。2) 由於先前的 /dev/null,因此系統會忽略 z.rc。如果未指定,Bazel 會使用在以下兩個位置找到的第一個 .bazelrc 檔案:工作區目錄,然後是使用者的家目錄。注意:指令列選項一律會取代 bazelrc 中的任何選項。
標記: changes_inputs
--[no]block_for_lock 預設值:「true」
傳遞 --noblock_for_lock 時,Bazel 不會等待執行中的指令完成,而是立即結束。
標記: eagerness_to_exit
--[no]client_debug 預設值:「false」
如果設為 true,系統會將來自用戶端的偵錯資訊記錄到 stderr。變更這個選項不會導致伺服器重新啟動。
標記: affects_outputsbazel_monitoring
--connect_timeout_secs=<an integer> 預設值:「30」
用戶端每次嘗試連線至伺服器時的等待時間
標記: bazel_internal_configuration
--digest_function=<hash function> 預設值:請參閱說明
計算檔案摘要時要使用的雜湊函式。
標記: loses_incremental_statebazel_internal_configuration
--experimental_cgroup_parent=<path> 預設值:請參閱說明
以絕對路徑形式指定啟動 Bazel 伺服器的 cgroup。伺服器程序會在每個支援控制器的指定 cgroup 中啟動。舉例來說,如果這個旗標的值是 /build/bazel,且 CPU 和記憶體控制器分別掛載在 /sys/fs/cgroup/cpu 和 /sys/fs/cgroup/memory,則伺服器會在 /sys/fs/cgroup/cpu/build/bazel 和 /sys/fs/cgroup/memory/build/bazel 群組中啟動。如果指定的群組無法供一或多個控制器寫入,也不會發生錯誤。這個選項不會對不支援 cgroup 的平台造成任何影響。
標記: bazel_monitoringexecution
--failure_detail_out=<path> 預設值:請參閱說明
如果已設定,則會在伺服器發生失敗且無法正常透過 gRPC 回報時,指定寫入 failure_detail protobuf 訊息的位置。否則位置會是 ${OUTPUT_BASE}/failure_detail.rawproto。
標記: affects_outputsloses_incremental_state
--[no]home_rc 預設值:「true」
是否在 $HOME/.bazelrc 中尋找主目錄 bazelrc 檔案
標記: changes_inputs
--[no]idle_server_tasks 預設值:「true」
在伺服器閒置時執行 System.gc()
代碼: loses_incremental_statehost_machine_resource_optimizations
--[no]ignore_all_rc_files 預設值:「false」
無論其他 rc 修飾旗標的值為何,都會停用所有 rc 檔案,即使這些旗標在啟動選項清單中出現在後面也一樣。
標記: changes_inputs
--io_nice_level={-1,0,1,2,3,4,5,6,7} 預設值:「-1」
僅限 Linux;使用 sys_ioprio_set 系統呼叫,將等級設為 0 到 7,以便盡力安排 I/O 排程。0 為最高優先順序,7 為最低優先順序。預測排程器最多只會執行優先順序 4 的工作。如果設為負值,Bazel 就不會執行系統呼叫。
標記: host_machine_resource_optimizations
--local_startup_timeout_secs=<an integer> 預設值:「120」
用戶端等待連線至伺服器的時間上限
標記: bazel_internal_configuration
--macos_qos_class=<a string> 預設值:"default"
在 macOS 上執行時,設定 bazel 伺服器的 QoS 服務類別。這個標記對所有其他平台都沒有影響,但系統支援這項標記,可確保 rc 檔案可在這些平台之間共用,而不會發生變化。可能的值包括:使用者互動、使用者啟動、預設、公用程式和背景。
標記: host_machine_resource_optimizations
--max_idle_secs=<integer> 預設值:「10800」
建構伺服器在關閉前等待閒置的秒數。零表示伺服器永遠不會關閉。這個值只會在伺服器啟動時讀取,變更這個選項不會導致伺服器重新啟動。
標記: eagerness_to_exitloses_incremental_state
--output_base=<path> 預設值:請參閱說明
如果設為此值,系統會指定所有建構輸出內容的輸出位置。否則,位置會是 ${OUTPUT_ROOT}/_blaze_${USER}/${MD5_OF_WORKSPACE_ROOT}。注意:如果您為這個值指定不同的選項,從一個 Bazel 叫用到下一個 Bazel 叫用,很可能會啟動新的額外 Bazel 伺服器。Bazel 會為每個指定的輸出基底啟動一項伺服器。通常每個工作區只有一個輸出基礎,但如果您選取這個選項,每個工作區可能會有多個輸出基礎,因此可在同一台機器上同時執行多個相同用戶端的建構作業。請參閱「bazel help shutdown」瞭解如何關閉 Bazel 伺服器。
標記: affects_outputsloses_incremental_state
--output_user_root=<path> 預設值:請參閱說明
使用者專屬目錄,所有建構輸出內容都會寫入此目錄;根據預設,這是 $USER 的函式,但如果指定常數,建構輸出內容就能在協作使用者之間共用。
標記: affects_outputsloses_incremental_state
--[no]preemptible 預設值:「false」
如果為 true,在啟動其他指令時,系統可以搶先執行此指令。
標記: eagerness_to_exit
--[no]quiet 預設值:「false」
如果設為 True,主控台就不會顯示資訊訊息,只會顯示錯誤訊息。變更這個選項不會導致伺服器重新啟動。
標記: affects_outputsbazel_monitoring
--server_jvm_out=<path> 預設值:請參閱說明
寫入伺服器 JVM 輸出內容的位置。如未設定,則預設為 output_base 中的某個位置。
標記: affects_outputsloses_incremental_state
--[no]shutdown_on_low_sys_mem 預設值:「false」
如果已設定 max_idle_secs,且建構伺服器閒置一段時間,請在系統可用 RAM 不足時關閉伺服器。僅適用於 Linux。
標記: eagerness_to_exitloses_incremental_state
--[no]system_rc 預設值:「true」
是否要尋找系統層級的 bazelrc。
標記: changes_inputs
--[no]unlimit_coredumps 預設值:「false」
將軟性核心轉儲限制提高至硬性限制,以便在一般情況下,為伺服器 (包括 JVM) 和用戶端建立核心轉儲。將這個標記貼在 bazelrc 中一次,然後就忘了它,這樣當您實際遇到觸發條件時,就能取得核心轉儲檔。
標記: bazel_internal_configuration
如果設為 true,Windows 上會建立實際的符號連結,而非複製檔案。必須啟用 Windows 開發人員模式,並使用 Windows 10 1703 以上版本。
標記: bazel_internal_configuration
--[no]workspace_rc 預設值:「true」
是否在 $workspace/.bazelrc 中尋找工作區的 bazelrc 檔案
標記: changes_inputs
其他選項,未歸類:
--host_jvm_args=<jvm_arg> 累積多次使用
要傳遞至執行 Blaze 的 JVM 的標記。
--host_jvm_debug
便利選項可新增一些額外的 JVM 啟動標記,讓 JVM 在啟動期間等待,直到您從符合 JDWP 標準的偵錯工具 (例如 Eclipse) 連線至 5005 埠為止。
展開為:
  --host_jvm_args=-Xdebug
  --host_jvm_args=-Xrunjdwp:transport=dt_socket,server=y,address=5005
--server_javabase=<jvm path> 預設值:""
用來執行 Bazel 本身的 JVM 路徑。

所有指令的通用選項

顯示在指令前方且由用戶端剖析的選項:
--distdir=<a path> 累積多次使用
在存取網路下載檔案之前,可搜尋檔案的其他位置。
標記: bazel_internal_configuration
如果已設定,存放區快取會在快取命中時建立檔案的硬連結,而不是複製檔案。這麼做是為了節省磁碟空間。
標記: bazel_internal_configuration
--experimental_repository_downloader_retries=<an integer> 預設值:「5」
重試下載錯誤的次數上限。如果設為 0,則會停用重試。
標記: experimental
--experimental_scale_timeouts=<a double> 預設值:「1.0」
以這個係數縮放 Starlark 存放區規則中的所有逾時時間。如此一來,外部存放區就能在速度比規則作者預期慢的電腦上運作,而不需要變更原始碼
標記: bazel_internal_configurationexperimental
--http_connector_attempts=<an integer> 預設值:「8」
HTTP 下載嘗試次數上限。
標記: bazel_internal_configuration
--http_connector_retry_max_timeout=<An immutable length of time.> 預設值:「0 秒」
HTTP 下載重試的逾時上限。如果值為 0,則不會定義逾時上限。
標記: bazel_internal_configuration
--http_max_parallel_downloads=<an integer> 預設值:「8」
並行 HTTP 下載次數上限。
標記: bazel_internal_configuration
--http_timeout_scaling=<a double> 預設值:「1.0」
以指定係數縮放與 HTTP 下載相關的所有逾時時間
代碼: bazel_internal_configuration
--[no]incompatible_disable_native_repo_rules 預設值:「false」
如果設為 false,則可在 WORKSPACE 中使用原生存放區規則;否則,必須改用 Starlark 存放區規則。原生存放區規則包括 local_repository、new_local_repository、local_config_platform 和 android_sdk_repository。
標記: bazel_internal_configuration
--repository_cache=<a path> 預設值:請參閱說明
指定在擷取外部存放區時取得的下載值的快取位置。空字串做為引數時,系統會要求停用快取,否則會使用預設的「<output_user_root>/cache/repos/v1」
bazel_internal_configuration
--[no]repository_disable_download 預設值:「false」
如果已設為啟用,則在擷取存放區時,系統將不允許使用 ctx.download{,_and_extract} 下載。請注意,系統並未完全停用網路存取權;ctx.execute 仍可執行任意可存取網際網路的可執行檔。
代碼: bazel_internal_configuration
控制建構執行作業的選項:
--experimental_ui_max_stdouterr_bytes=<an integer in (-1)-1073741819 range> 預設值:「1048576」
要輸出至控制台的 stdout / stderr 檔案大小上限。-1 表示沒有限制。
標記: execution
--gc_thrashing_threshold=<an integer in 0-100 range> 預設值:「100」
佔用已登記空間的百分比 (0-100),超過此值後,GcThrashingDetector 會根據限制 (--gc_thrashing_limits) 判斷記憶體壓力事件。如果設為 100,系統就會停用 GcThrashingDetector。
代碼: host_machine_resource_optimizations
設定用於執行動作的工具鍊的選項:
--[no]incompatible_enable_proto_toolchain_resolution 預設值:「false」
如果為 true,proto 語言規則會定義 protobuf 存放區的工具鍊。
標記: loading_and_analysisincompatible_change
讓使用者設定預期輸出內容的選項,影響其值,而非其存在:
--bep_maximum_open_remote_upload_files=<an integer> 預設值:「-1」
BEP 構件上傳期間允許開啟的檔案數量上限。
標記: affects_outputs
--remote_download_all
將所有遠端輸出內容下載至本機。這個標記是 --remote_download_outputs=all 的別名。
展開為:
  --remote_download_outputs=all

標記: affects_outputs
--remote_download_minimal
不會將任何遠端建構輸出內容下載到本機。這個旗標是 --remote_download_outputs=minimal 的別名。
展開為:
  --remote_download_outputs=minimal

標記: affects_outputs
--remote_download_outputs=<all, minimal or toplevel> 預設值:「toplevel」
如果設為「最小」,則不會將任何遠端建構輸出內容下載到本機電腦,但本機動作所需的輸出內容除外。如果設為「toplevel」,則會像「minimal」一樣運作,但會將頂層目標的輸出內容下載到本機。如果網路頻寬是瓶頸,這兩種做法都能大幅縮短建構時間。
標記: affects_outputs
請勿將遠端建構輸出內容下載到本機電腦,而是建立符號連結。符號連結的目標可以使用範本字串的形式指定。這個範本字串可能包含 {hash} 和 {size_bytes},分別會展開為物件的雜湊和以位元組為單位的大小。例如,這些符號連結可能會指向 FUSE 檔案系統,該系統會視需要從 CAS 載入物件。
標記: affects_outputs
--remote_download_toplevel
只會將頂層目標的遠端輸出內容下載到本機。這個旗標是 --remote_download_outputs=toplevel 的別名。
展開為:
  --remote_download_outputs=toplevel

標記: affects_outputs
--repo_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定僅供存放區規則使用的其他環境變數。請注意,存放區規則會查看完整環境,但透過這種方式,設定資訊可透過選項傳遞至存放區,而不會使動作圖表失效。
標記: action_command_lines
影響 Bazel 如何嚴格執行有效建構輸入內容 (規則定義、標記組合等) 的選項:
--[no]check_bzl_visibility 預設值:「true」
如果停用,.bzl 載入可見度錯誤會降級為警告。
標記: build_file_semantics
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]enable_bzlmod 預設值:「true」
如果設為 true,系統會啟用 Bzlmod 依附元件管理系統,優先於 WORKSPACE。詳情請參閱 https://bazel.build/docs/bzlmod。
標記: loading_and_analysis
--[no]enable_workspace 預設值:「false」
如果設為 true,系統會為外部依附元件啟用舊版 WORKSPACE 系統。詳情請參閱 https://bazel.build/external/overview。
標記: loading_and_analysis
--[no]experimental_action_resource_set 預設值:「true」
如果設為 true,ctx.actions.run() 和 ctx.actions.run_shell() 就會接受 resource_set 參數,用於本機執行。否則,系統會將記憶體和 CPU 的預設值設為 250 MB 和 1。
標記: executionbuild_file_semanticsexperimental
--[no]experimental_bzl_visibility 預設值:「true」
如果啟用,就會新增 `visibility()` 函式,.bzl 檔案可在頂層評估期間呼叫此函式,以便針對 load() 陳述式的目的設定其可見度。
標記: loading_and_analysisexperimental
--[no]experimental_cc_shared_library 預設值:「false」
如果設為 true,系統就會提供規則 cc_shared_library 所需的規則屬性和 Starlark API 方法
標記: build_file_semanticsloading_and_analysisexperimental
--[no]experimental_cc_static_library 預設值:「false」
如果設為 true,就會提供 cc_static_library 規則所需的規則屬性和 Starlark API 方法
標記: build_file_semanticsloading_and_analysisexperimental
--[no]experimental_disable_external_package 預設值:「false」
如果設為 true,系統就不會再提供自動產生的 //external 套件。Bazel 仍無法剖析檔案「external/BUILD」,但從未命名套件進入 external/ 的 glob 會正常運作。
標記: loading_and_analysisloses_incremental_stateexperimental
--[no]experimental_dormant_deps 預設值:「false」
如果設為 true,系統會允許使用 attr.label(materializer=)、attr(for_dependency_resolution=)、attr.dormant_label()、attr.dormant_label_list() 和 rule(for_dependency_resolution=)。
標記: build_file_semanticsexperimental
--[no]experimental_enable_android_migration_apis 預設值:「false」
如果設為 true,系統就會啟用支援 Android Starlark 遷移作業所需的 API。
標記: build_file_semantics
--[no]experimental_enable_first_class_macros 預設值:「true」
如果設為 true,系統就會啟用 `macro()` 結構定義符號巨集。
標記: build_file_semantics
--[no]experimental_enable_macro_inherit_attrs 預設值:「false」
如果設為 true,會在符號巨集中啟用屬性繼承功能,並在 macro() 內建
標記中啟用 inherit_attrs 參數: build_file_semantics
--[no]experimental_enable_scl_dialect 預設值:「true」
如果設為 true,load() 陳述式可能會使用 .scl 檔案。
標記: build_file_semantics
--[no]experimental_enable_starlark_set 預設值:「false」
如果設為 true,就會在 Starlark 中啟用 set 資料類型和 set() 建構函式。
標記: build_file_semanticsexperimental
--[no]experimental_google_legacy_api 預設值:「false」
如果設為 true,就會公開與 Google 舊版程式碼相關的 Starlark 建構 API 實驗功能。
標記: loading_and_analysisexperimental
--[no]experimental_isolated_extension_usages 預設值:「false」
如果為 true,則會在 <a href="https://bazel.build/rules/lib/globals/module#use_extension"><code>use_extension</code></a> 函式中啟用<code>isolate</code> 參數。
標記: loading_and_analysis
--[no]experimental_java_library_export 預設值:「false」
如果啟用,即可使用 experimental_java_library_export_do_not_use 模組。
標記: loading_and_analysisincompatible_change
--[no]experimental_platforms_api 預設值:「false」
如果設為 true,系統會啟用許多與平台相關的 Starlark API,這些 API 可用於偵錯。
標記: loading_and_analysisexperimental
--[no]experimental_repo_remote_exec 預設值:「false」
如果設為 true,repository_rule 就會獲得部分遠端執行功能。
標記: build_file_semanticsloading_and_analysisexperimental
--[no]experimental_sibling_repository_layout 預設值:「false」
如果設為 true,非主要存放區會在執行根目錄中,以符號連結方式連結至主要存放區。也就是說,所有存放區都是 $output_base/execution_root 目錄的直接子項。這會產生副作用,為真正的頂層「external」目錄釋出 $output_base/execution_root/__main__/external。
標記: action_command_linesbazel_internal_configurationloading_and_analysisloses_incremental_stateexperimental
--[no]experimental_single_package_toolchain_binding 預設值:「false」
如果啟用,register_toolchain 函式可能不會包含可能參照多個套件的目標模式。
標記: loading_and_analysisincompatible_change
--[no]incompatible_allow_tags_propagation 預設值:「true」
如果設為 true,標記會從目標傳播至動作的執行需求;否則標記不會傳播。詳情請參閱 https://github.com/bazelbuild/bazel/issues/8830。
標記: build_file_semanticsexperimental
--[no]incompatible_always_check_depset_elements 預設值:「true」
在所有建構函式中,檢查新增至 depset 的元素是否有效。元素必須是不可變動的,但過去 depset(direct=...) 建構函式忘記檢查。在 depset 元素中使用元組,而非清單。詳情請參閱 https://github.com/bazelbuild/bazel/issues/10313。
標記: build_file_semanticsincompatible_change
--incompatible_autoload_externally=<comma-separated set of options> 預設值:"+@rules_python,+JavaInfo,+JavaPluginInfo,ProguardSpecProvider,java_binary,java_import,java_library,java_plugin,java_test,+java_runtime,+java_toolchain,+java_package_configuration,@protobuf,@rules_shell,+@rules_android"
以逗號分隔的規則 (或其他符號) 清單,這些規則先前是 Bazel 的一部分,現在則會從各自的外部存放區擷取。這個標記可用於協助將規則從 Bazel 遷移。另請參閱 https://github.com/bazelbuild/bazel/issues/23043。在檔案中自動載入的符號,其行為就像是內建在 Bazel 中的定義,已由外部存放區中的新標準定義取代。對於 BUILD 檔案,這基本上表示隱含新增 load() 陳述式。對於 .bzl 檔案,這可能是 load() 陳述式,也可能是對 `native` 物件欄位的變更,這取決於自動載入的符號是否為規則。Bazel 會維護一個硬式編碼清單,其中列出所有可能自動載入的符號;只有這些符號會顯示在這個標記中。對於每個符號,Bazel 都會知道外部存放區中新定義的位置,以及一組特殊情況的存放區,這些存放區不得自動載入,以免產生循環。這個標記中的「+foo」清單項目會導致符號 foo 自動載入,但在 foo 的豁免存放區中除外,因為在該存放區中,Bazel 定義的 foo 版本仍可使用。清單項目「foo」會觸發上述自動載入功能,但 Bazel 定義的 foo 版本不會提供給已排除的存放區。這可確保 foo 的外部存放區不依賴 foo 的舊 Bazel 實作。清單項目「-foo」不會觸發任何自動載入作業,但會使整個工作區無法存取 Bazel 定義的 foo 版本。這可用於驗證工作區是否已準備好從 Bazel 中刪除 foo 的定義。如果這個標記中沒有指定符號,則會繼續正常運作,不會執行自動載入,也不會抑制 Bazel 定義的版本。如需設定資訊,請參閱 https://github.com/bazelbuild/bazel/blob/master/src/main/java/com/google/devtools/build/lib/packages/AutoloadSymbols.java。您也可以使用整個存放區做為捷徑,例如 +@rules_python 會自動載入所有 Python 規則。
標記: loses_incremental_statebuild_file_semanticsincompatible_change
如果為 true,Bazel 就不會再從 linking_context.libraries_to_link 傳回清單,而是傳回 depset。
標記: loading_and_analysisincompatible_change
--[no]incompatible_disable_objc_library_transition 預設值:「true」
停用 objc_library 的自訂轉換,改為從頂層目標繼承 (在 Bazel 中為無操作)
標記: build_file_semanticsincompatible_change
--[no]incompatible_disable_starlark_host_transitions 預設值:「false」
如果設為 true,規則屬性就無法設定「cfg = "host"」。規則應改為設定「cfg = "exec"」。
標記: loading_and_analysisincompatible_change
--[no]incompatible_disable_target_default_provider_fields 預設值:「false」
如果設為 true,則會停用透過欄位語法存取「target」物件上的供應器的功能。請改用供應者鍵語法。舉例來說,請改用 `ctx.attr.dep[MyInfo]`,而非 `ctx.attr.dep.my_info`,以便從規則實作函式中存取 `my_info`。詳情請參閱 https://github.com/bazelbuild/bazel/issues/9014。
標記: build_file_semanticsincompatible_change
--[no]incompatible_disable_target_provider_fields 預設值:「false」
如果設為 true,則會停用透過欄位語法使用預設提供者的功能。請改用供應者鍵語法。舉例來說,請使用 `ctx.attr.dep[DefaultInfo].files` 取代 `ctx.attr.dep.files` 來存取 `files`。詳情請參閱 https://github.com/bazelbuild/bazel/issues/9014。
標記: build_file_semanticsincompatible_change
--[no]incompatible_disallow_ctx_resolve_tools 預設值:「true」
如果設為 true,呼叫已淘汰的 ctx.resolve_tools API 一律會失敗。請將這個 API 的用途替換為可執行檔或工具引數,並將其傳遞至 ctx.actions.run 或 ctx.actions.run_shell。
標記: loading_and_analysisincompatible_change
--[no]incompatible_disallow_empty_glob 預設值:「true」
如果設為 true,glob() 的 `allow_empty` 引數預設值為 False。
標記: build_file_semanticsincompatible_change
--[no]incompatible_disallow_struct_provider_syntax 預設值:「true」
如果設為 true,規則實作函式可能不會傳回結構體。而是必須傳回提供者執行個體清單。
標記: build_file_semanticsincompatible_change
--[no]incompatible_enable_deprecated_label_apis 預設值:「true」
如果啟用,您就能使用特定的已淘汰 API (native.repository_name、Label.workspace_name、Label.relative)。
標記: loading_and_analysis
--[no]incompatible_fail_on_unknown_attributes 預設值:「true」
如果啟用,則未知屬性設為「None」的目標會失敗。
標記: loading_and_analysisincompatible_change
--[no]incompatible_fix_package_group_reporoot_syntax 預設值:「true」
在 package_group 的 `packages` 屬性中,變更「//...」值的含義,以便參照目前存放區中的所有套件,而非任何存放區中的所有套件。您可以使用特殊值「public」取代「//...」,以取得舊版行為。這個旗標需要同時啟用 --incompatible_package_group_has_public_syntax。
標記: build_file_semanticsincompatible_change
--[no]incompatible_java_common_parameters 預設值:「true」
如果設為 true,系統會移除編譯時 pack_sources 中的 output_jar 和 host_javabase 參數,以及 host_javabase。
標記: build_file_semanticsincompatible_change
--[no]incompatible_merge_fixed_and_default_shell_env 預設值:「true」
如果啟用此選項,則使用 ctx.actions.run 和 ctx.actions.run_shell 註冊的動作,並同時指定「env」和「use_default_shell_env = True」時,系統會使用從預設殼層環境取得的環境,方法是覆寫傳入「env」的值。如果停用,系統會完全忽略「env」的值。
標記: loading_and_analysisincompatible_change
--[no]incompatible_no_attr_license 預設值:「true」
如果設為 true,就會停用 `attr.license` 函式。
標記: build_file_semanticsincompatible_change
--[no]incompatible_no_implicit_file_export 預設值:「false」
如果已設定,除非明確匯出,否則 (已使用) 來源檔案會是套件私有。請參閱 https://github.com/bazelbuild/proposals/blob/master/designs/2019-10-24-file-visibility.md
標記: build_file_semanticsincompatible_change
--[no]incompatible_no_implicit_watch_label 預設值:「true」
如果為 true,則傳遞標籤的 <code>repository_ctx</code> 方法將不再自動監控該標籤底下的檔案是否有變更,即使 <code>watch = "no"</code>,且 <code>repository_ctx.path</code> 不再導致傳回路徑遭到監控也一樣。請改用 <code>repository_ctx.watch</code>。
標記: loading_and_analysisincompatible_change
--[no]incompatible_no_rule_outputs_param 預設值:「false」
如果設為 true,則會停用 `rule()` Starlark 函式的 `outputs` 參數。
標記: build_file_semanticsincompatible_change
--[no]incompatible_package_group_has_public_syntax 預設值:「true」
在 package_group 的 `packages` 屬性中,允許寫入「public」或「private」,分別參照所有套件或不參照任何套件。
標記: build_file_semanticsincompatible_change
--[no]incompatible_require_linker_input_cc_api 預設值:「true」
如果設為 true,則規則 create_linking_context 會要求 linker_inputs,而不是 libraries_to_link。舊的 linking_context getter 也會遭到停用,只會提供 linker_inputs。
標記: build_file_semanticsloading_and_analysisincompatible_change
--[no]incompatible_run_shell_command_string 預設值:「true」
如果設為 true,actions.run_shell 的 command 參數只會接受字串
標記:build_file_semanticsincompatible_change
--[no]incompatible_simplify_unconditional_selects_in_rule_attrs 預設值:「true」
如果為「是」,則會簡化只包含無條件選取項目的可設定規則屬性;舉例來說,如果將 ["a"] + select("//conditions:default", ["b"]) 指派給規則屬性,系統會將其儲存為 ["a", "b"]。這個選項不會影響符號巨集的屬性或屬性預設值。
標記: build_file_semanticsincompatible_change
--[no]incompatible_stop_exporting_build_file_path 預設值:「false」
如果設為 true,就無法使用已淘汰的 ctx.build_file_path。您可以改用 ctx.label.package + '/BUILD'。
標記: loading_and_analysisincompatible_change
--[no]incompatible_stop_exporting_language_modules 預設值:「false」
如果啟用,使用者 .bzl 檔案就無法使用特定語言專屬模組 (例如 `cc_common`),只能從各自的規則存放區呼叫。
標記: loading_and_analysisincompatible_change
--[no]incompatible_top_level_aspects_require_providers 預設值:「true」
如果設為 true,頂層層面會遵循其必要供應器,並只在規則的廣告供應器滿足層面必要供應器的情況下,在頂層目標上執行。
標記: loading_and_analysisincompatible_change
--[no]incompatible_unambiguous_label_stringification 預設值:「true」
如果為 true,Bazel 會將標籤 @//foo:bar 轉為字串 @//foo:bar,而不是 //foo:bar。這只會影響 str()、% 運算子等的行為;repr() 的行為不會改變。詳情請參閱 https://github.com/bazelbuild/bazel/issues/15916。
標記: loading_and_analysisincompatible_change
--[no]incompatible_use_cc_configure_from_rules_cc 預設值:「false」
設為 true 時,Bazel 將不再允許使用 @bazel_tools 中的 cc_configure。如需詳細資訊和遷移操作說明,請參閱 https://github.com/bazelbuild/bazel/issues/10134。
標記: loading_and_analysisincompatible_change
--max_computation_steps=<a long integer> 預設值:「0」
BUILD 檔案可執行的 Starlark 運算步驟數量上限 (零表示沒有限制)。
標記: build_file_semantics
--nested_set_depth_limit=<an integer> 預設值:「3500」
depset (也稱為 NestedSet) 內部圖表的深度上限,超過此上限,depset() 建構函式就會失敗。
標記: loading_and_analysis
--repositories_without_autoloads=<comma-separated set of options> 預設值:""
清單中列出其他儲存庫 (除了 Bazel 知道的硬式編碼儲存庫),不應在其中新增自動載入功能。這通常應包含可能會自動載入的存放區所間接依附的存放區 (因此可能會產生循環)。
標記: loses_incremental_statebuild_file_semanticsincompatible_change
與 Bzlmod 輸出內容和語義相關的選項:
--allow_yanked_versions=<a string> 累積多次使用
以 `<module1>@<version1>,<module2>@<version2>` 的格式指定模組版本,即使這些版本在原始來源的登錄資料庫中已宣告為已撤銷 (如果這些版本不是來自 NonRegistryOverride),也能在解析的依附元件圖表中使用。否則,撤銷版本會導致解析失敗。您也可以使用 `BZLMOD_ALLOW_YANKED_VERSIONS` 環境變數,定義允許的撤銷版本。您可以使用「all」關鍵字停用這項檢查 (不建議)。
標記: loading_and_analysis
--check_bazel_compatibility=<error, warning or off> 預設值:「error」
檢查 Bazel 模組的 Bazel 版本相容性。有效值為 `error` (將其升級為解析失敗)、`off` (停用檢查) 或 `warning` (在偵測到不相符時顯示警告)。
標記: loading_and_analysis
--check_direct_dependencies=<off, warning or error> 預設值:「warning」
請檢查根模組中宣告的直接 `bazel_dep` 依附元件,是否與解析依附元件圖表中的版本相同。有效值為 `off` (停用檢查)、`warning` (在偵測到不相符時顯示警告) 或 `error` (將其升級為解析失敗)。
標記: loading_and_analysis
--[no]ignore_dev_dependency 預設值:「false」
如果為 True,Bazel 會忽略根模組的 MODULE.bazel 中宣告為 `dev_dependency` 的 `bazel_dep` 和 `use_extension`。請注意,如果不是根模組,系統一律會忽略 MODULE.bazel 中的這些開發依附元件,無論此旗標的值為何。
標記: loading_and_analysis
--lockfile_mode=<off, update, refresh or error> 預設值:「update」
指定是否要使用鎖定檔案,以及使用方式。有效值包括 `update` (使用鎖定檔案,並在有變更時更新)、`refresh` (不時從遠端登錄重新整理可變更資訊 (已撤銷的版本和先前遺漏的模組))、`error` (使用鎖定檔案,但如果檔案未更新就會擲回錯誤) 或 `off` (既不讀取也不寫入鎖定檔案)。
標記: loading_and_analysis
--override_module=<an equals-separated mapping of module name to path> 累積多次使用
以 <模組名稱>=<路徑> 的格式,覆寫含有本機路徑的模組。如果指定的路徑為絕對路徑,系統會直接使用該路徑。如果指定的路徑為相對路徑,則會以目前的作業目錄為基準。如果指定的路徑以「%workspace%」開頭,則會相對於工作區根目錄,也就是 `bazel info workspace` 的輸出內容。如果指定的路徑為空白,請移除先前的覆寫值。
--registry=<a string> 累積多次使用
指定用於尋找 Bazel 模組依附元件的註冊中心。順序很重要:模組會先在較早的註冊表中查詢,只有在較早的註冊表中找不到時,才會改為使用較晚的註冊表。
標記: changes_inputs
--vendor_dir=<a path> 預設值:請參閱說明
指定應在供應商模式中保留外部存放區的目錄,無論是為了擷取存放區,或是在建構時使用存放區,皆可使用此目錄。路徑可以是絕對路徑,也可以是相對於工作區目錄的路徑。
標記: loading_and_analysis
觸發建構時間最佳化功能的選項:
--gc_thrashing_limits=<comma separated pairs of <period>:<count>> 預設值:「1s:2,20s:3,1m:5」
如果達到此限制,就會導致 GcThrashingDetector 因 OOM 而導致 Bazel 當機。每個限制都會以 <period>:<count> 的格式指定,其中 period 是時間長度,count 是正整數。如果在 <period> 內連續執行 <count> 次全 GC 後,仍有超過 --gc_thrashing_threshold 百分比的保留空間 (舊世代堆積) 仍在使用中,系統就會觸發 OOM。您可以指定多個限制,並以半形逗號分隔。
標記: host_machine_resource_optimizations
--[no]heuristically_drop_nodes 預設值:「false」
如果設為 true,Blaze 會在相關的 File 和 DirectoryListing 節點完成後移除 FileState 和 DirectoryListingState 節點,以節省記憶體。我們認為這些節點不太可能再次需要。若是,系統會重新評估這些項目。
標記: loses_incremental_state
--[no]incompatible_do_not_split_linking_cmdline 預設值:「true」
如果為 true,Bazel 就不會再修改用於連結的指令列標記,也不會選擇性決定哪些標記會傳送至參數檔案,哪些標記不會傳送。詳情請參閱 https://github.com/bazelbuild/bazel/issues/7670。
標記: loading_and_analysisincompatible_change
--[no]keep_state_after_build 預設值:「true」
如果為 false,Blaze 會在建構作業完成時,捨棄這個建構作業的記憶體內狀態。後續版本不會對這個版本進行任何增量處理。
標記: loses_incremental_state
--skyframe_high_water_mark_full_gc_drops_per_invocation=<an integer, >= 0> 預設值:「10」
標記用於 Bazel 內部 Skyframe 引擎的進階設定。如果 Bazel 偵測到保留堆積使用率超過 --skyframe_high_water_mark_threshold 所設門檻,當完整 GC 事件發生時,它會捨棄不必要的暫時性 Skyframe 狀態,每次呼叫最多可捨棄這麼多次。預設值為 10。零表示完整 GC 事件永遠不會觸發掉落。如果達到限制,當完整 GC 事件發生且保留堆積百分比超出閾值時,Skyframe 狀態就不會再遭到捨棄。
標記: host_machine_resource_optimizations
--skyframe_high_water_mark_minor_gc_drops_per_invocation=<an integer, >= 0> 預設值:「10」
標記用於 Bazel 內部 Skyframe 引擎的進階設定。如果 Bazel 偵測到保留堆積使用率超過 --skyframe_high_water_mark_threshold 所設門檻,當次要 GC 事件發生時,就會捨棄不必要的暫時性 Skyframe 狀態,每次呼叫最多可捨棄這麼多次。預設值為 10。若為零,表示次要 GC 事件永遠不會觸發釋放作業。如果達到限制,當次要 GC 事件發生且保留堆積百分比超出閾值時,Skyframe 狀態就不會再捨棄。
標記: host_machine_resource_optimizations
--skyframe_high_water_mark_threshold=<an integer> 預設值:「85」
標記用於 Bazel 內部 Skyframe 引擎的進階設定。如果 Bazel 偵測到保留堆積使用率至少達到此門檻,就會捨棄不必要的暫時性 Skyframe 狀態。調整這個值,或許能減輕 GC 耗損的實際時間影響,前提是 GC 耗損 (i) 是由此暫時狀態的記憶體用量所造成,且 (ii) 比在必要時重建狀態的成本還要高。
標記: host_machine_resource_optimizations
--[no]track_incremental_state 預設值:「true」
如果為 false,Blaze 就不會保留可在增量版本中無效化及重新評估的資料,以便節省這個版本的記憶體。後續版本不會對此版本有任何增量。通常,如果要將這個值設為 false,您需要指定 --batch。
標記: loses_incremental_state
影響記錄詳細程度、格式或位置的選項:
--[no]announce_rc 預設值:「false」
是否要宣告 rc 選項。
標記: affects_outputs
--[no]attempt_to_print_relative_paths 預設值:「false」
當您要列印訊息的位置部分時,請嘗試使用相對於工作區目錄或 --package_path 指定的目錄之一的路徑。
標記: terminal_output
--bes_backend=<a string> 預設值:""
以 [SCHEME://]HOST[:PORT] 的格式指定 Build Event Service (BES) 後端端點。預設會停用 BES 上傳功能。支援的配置為 grpc 和 grpcs (已啟用 TLS 的 grpc)。如果未提供配置,Bazel 會假設使用 grpcs。
標記: affects_outputs
--[no]bes_check_preceding_lifecycle_events 預設值:「false」
在 PublishBuildToolEventStreamRequest 上設定 check_preceding_lifecycle_events_present 欄位,指示 BES 檢查先前是否收到與目前工具事件相符的 InvocationAttemptStarted 和 BuildEnqueued 事件。
標記: affects_outputs
--bes_header=<a 'name=value' assignment> 累積多次使用
以名稱=值的格式指定標頭,以便納入 BES 要求中。您可以多次指定標記,藉此傳遞多個標頭。同一個名稱的多個值會轉換為以半形逗號分隔的清單。
標記: affects_outputs
--bes_instance_name=<a string> 預設值:請參閱說明
指定 BES 會在哪個執行個體下保存上傳的 BEP。預設值為 null。
標記: affects_outputs
--bes_keywords=<comma-separated list of options> 累積多次使用
指定要新增至 BES 的預設關鍵字清單 (「command_name=<command_name>」", "protocol_name=BEP")。預設值為無。
標記: affects_outputs
--[no]bes_lifecycle_events 預設值:「true」
指定是否要發布 BES 生命週期事件。(預設為「true」)。
標記: affects_outputs
--bes_oom_finish_upload_timeout=<An immutable length of time.> 預設值:「10m」
指定 Bazel 在 OOM 時,應等待 BES/BEP 上傳作業完成的時間長度。這個標記可確保在 JVM 發生嚴重 GC 衝突且無法在任何使用者執行緒上取得進展時終止。
標記: bazel_monitoring
--bes_outerr_buffer_size=<an integer> 預設值:「10240」
指定在 BEP 中要緩衝的 stdout 或 stderr 最大大小,以便在做為進度事件回報前進行緩衝。即使個別寫入作業的大小超過指定值 (--bes_outerr_chunk_size),系統仍會在單一事件中回報這些作業。
標記: affects_outputs
--bes_outerr_chunk_size=<an integer> 預設值:「1048576」
指定在單一郵件中,要傳送至 BEP 的 stdout 或 stderr 大小上限。
標記: affects_outputs
--bes_proxy=<a string> 預設值:請參閱說明
透過 Proxy 連線至 Build Event Service。目前這個旗標只能用於設定 Unix 網域 Socket (unix:/path/to/socket)。
--bes_results_url=<a string> 預設值:""
指定使用者可查看串流至 BES 後端的資訊的基礎網址。Bazel 會將叫用 ID 附加的網址輸出到終端機。
標記: terminal_output
--bes_system_keywords=<comma-separated list of options> 累積多次使用
指定要直接納入的通知關鍵字清單,不含透過 --bes_keywords 提供的關鍵字前置字串「user_keyword="。適用於設定 --bes_lifecycle_events=false 且在呼叫 PublishLifecycleEvent 時加入關鍵字的 Build 服務運算子。使用此旗標的建構服務運算子應可防止使用者覆寫旗標值。
標記: affects_outputs
--bes_timeout=<An immutable length of time.> 預設值:「0 秒」
指定 Bazel 在建構和測試完成後,應等待多久才能完成 BES/BEP 上傳作業。有效的逾時時間應為自然數後接單位:天數 (d)、小時 (h)、分鐘 (m)、秒數 (s) 和毫秒 (ms)。預設值為「0」,表示沒有逾時限制。
標記: affects_outputs
--bes_upload_mode=<wait_for_upload_complete, nowait_for_upload_complete or fully_async> 預設值:「wait_for_upload_complete」
指定建構事件服務上傳作業是否應阻斷建構作業的完成,或是應立即結束叫用作業,並在背景中完成上傳作業。可選的值為「wait_for_upload_complete」(預設)、「nowait_for_upload_complete」或「fully_async」。
標記: eagerness_to_exit
--build_event_binary_file=<a string> 預設值:""
如果不為空白,請將建構事件通訊協定以 varint 分隔的二進位表示法寫入該檔案。這個選項會暗示 --bes_upload_mode=wait_for_upload_complete。
標記: affects_outputs
--[no]build_event_binary_file_path_conversion 預設值:「true」
盡可能將建構事件通訊協定的二進位檔案表示法路徑轉換為更具全球效力的 URI;如果停用,系統一律會使用 file:// uri 配置
affects_outputs
--build_event_binary_file_upload_mode=<wait_for_upload_complete, nowait_for_upload_complete or fully_async> 預設值:「wait_for_upload_complete」
指定 --build_event_binary_file 的 Build Event Service 上傳作業應否阻斷建構作業完成,或是應立即結束叫用作業,並在背景完成上傳作業。可選的值為「wait_for_upload_complete」(預設)、「nowait_for_upload_complete」或「fully_async」。
標記: eagerness_to_exit
--build_event_json_file=<a string> 預設值:""
如果不為空白,請將建構事件通訊協定的 JSON 序列化寫入該檔案。這個選項會暗示 --bes_upload_mode=wait_for_upload_complete。
標記: affects_outputs
--[no]build_event_json_file_path_conversion 預設值:「true」
盡可能將建構事件通訊協定的 JSON 檔案表示法中的路徑轉換為更具全球效力的 URI;如果停用,系統一律會使用 file:// uri 配置項
標記: affects_outputs
--build_event_json_file_upload_mode=<wait_for_upload_complete, nowait_for_upload_complete or fully_async> 預設值:「wait_for_upload_complete」
指定 --build_event_json_file 的 Build Event Service 上傳作業應否阻斷建構作業的完成,或是應立即結束叫用作業,並在背景完成上傳作業。可選的值為「wait_for_upload_complete」(預設)、「nowait_for_upload_complete」或「fully_async」。
標記: eagerness_to_exit
--build_event_max_named_set_of_file_entries=<an integer> 預設值:「5000」
單一 named_set_of_files 事件的項目數量上限;系統會忽略小於 2 的值,且不會執行事件分割作業。這項設定旨在限制建構事件通訊協定中的事件大小上限,但不會直接控制事件大小。事件總大小取決於集合結構、檔案和 URI 長度,而這些項目又可能取決於雜湊函式。
標記: affects_outputs
--[no]build_event_publish_all_actions 預設值:「false」
是否應發布所有動作。
標記: affects_outputs
--build_event_text_file=<a string> 預設值:""
如果不為空白,請將建構事件通訊協定的文字表示法寫入該檔案
標記: affects_outputs
--[no]build_event_text_file_path_conversion 預設值:「true」
盡可能將建構事件通訊協定的文字檔案表示法路徑轉換為更具全球效力的 URI;如果停用,系統一律會使用 file:// uri 配置
affects_outputs
--build_event_text_file_upload_mode=<wait_for_upload_complete, nowait_for_upload_complete or fully_async> 預設值:「wait_for_upload_complete」
指定 --build_event_text_file 的建構事件服務上傳作業應否阻斷建構作業完成,或是應立即結束叫用作業,並在背景完成上傳作業。可選的值為「wait_for_upload_complete」(預設)、「nowait_for_upload_complete」或「fully_async」。
標記: eagerness_to_exit
--build_event_upload_max_retries=<an integer> 預設值:「4」
Bazel 重試上傳建構事件的次數上限。
標記: bazel_internal_configuration
--[no]experimental_bep_target_summary 預設值:「false」
是否要發布 TargetSummary 事件。
--[no]experimental_build_event_expand_filesets 預設值:「false」
如果為 true,則在呈現輸出檔案時,會在 BEP 中展開 Fileset。
標記: affects_outputs
如果設為 true,在呈現輸出檔案時,BEP 會完全解析相對檔案集符號連結。需要使用 --experimental_build_event_expand_filesets。
標記: affects_outputs
--experimental_build_event_output_group_mode=<an output group name followed by an OutputGroupFileMode, e.g. default=both> 累積多次使用
指定輸出群組的檔案在 TargetComplete/AspectComplete BEP 事件中如何顯示。值是將輸出群組名稱指派給「NAMED_SET_OF_FILES_ONLY」、「INLINE_ONLY」或「BOTH」其中一個。預設值為「NAMED_SET_OF_FILES_ONLY」。如果重複輸出群組,系統會使用最後顯示的值。預設值會將涵蓋率構件模式設為「BOTH」:--experimental_build_event_output_group_mode=baseline.lcov=both
標記: affects_outputs
--experimental_build_event_upload_retry_minimum_delay=<An immutable length of time.> 預設值:「1 秒」
BEP 上傳失敗時,指數輪詢重試的初始最小延遲時間。(指數:1.6)
標記: bazel_internal_configuration
--experimental_build_event_upload_strategy=<a string> 預設值:請參閱說明
選取如何上傳在建構事件通訊協定中參照的構件。在 Bazel 中,有效的選項包括「local」和「remote」。預設值為「local」。
標記: affects_outputs
--[no]experimental_collect_load_average_in_profiler 預設值:「true」
如果啟用,剖析器會收集系統的整體平均負載。
標記: bazel_monitoring
--[no]experimental_collect_pressure_stall_indicators 預設值:「false」
如果啟用,剖析器會收集 Linux PSI 資料。
標記: bazel_monitoring
--[no]experimental_collect_resource_estimation 預設值:「false」
如果啟用,剖析器會收集本機動作的 CPU 和記憶體用量預估值。
標記: bazel_monitoring
--[no]experimental_collect_skyframe_counts_in_profiler 預設值:「false」
如果啟用,剖析器會在 Skyframe 圖表中,針對主要函式類型 (例如已設定的目標和動作執行作業) 收集 SkyFunction 計數。由於這項作業會在每個分析時間單位中造訪整個 Skyframe 圖表,因此可能會影響效能。請勿在與效能相關的評估功能中使用這個標記。
標記: bazel_monitoring
--[no]experimental_collect_system_network_usage 預設值:「true」
如果啟用,剖析器會收集系統的網路用量。
標記: bazel_monitoring
--[no]experimental_collect_worker_data_in_profiler 預設值:「false」
如果啟用,剖析器會收集 worker 的匯總資源資料。
標記: bazel_monitoring
--experimental_command_profile=<cpu, wall, alloc or lock> 預設值:請參閱說明
在指令執行期間記錄 Java Flight Recorder 設定檔。必須提供一個支援的剖析事件類型 (cpu、wall、alloc 或 lock) 做為引數。設定檔會寫入輸出基礎目錄下以事件類型命名的檔案。這個旗標的語法和語意可能會在日後變更,以支援其他設定檔類型或輸出格式;請自行承擔使用風險。
--experimental_profile_additional_tasks=<phase, action, discover_inputs, action_check, action_lock, action_update, action_complete, action_rewinding, bzlmod, info, create_package, remote_execution, local_execution, scanner, local_parse, upload_time, remote_process_time, remote_queue, remote_setup, fetch, local_process_time, vfs_stat, vfs_dir, vfs_readlink, vfs_md5, vfs_xattr, vfs_delete, vfs_open, vfs_read, vfs_write, vfs_glob, vfs_vmfs_stat, vfs_vmfs_dir, vfs_vmfs_read, wait, thread_name, thread_sort_index, skyframe_eval, skyfunction, critical_path, critical_path_component, handle_gc_notification, local_action_counts, starlark_parser, starlark_user_fn, starlark_builtin_fn, starlark_user_compiled_fn, starlark_repository_fn, action_fs_staging, remote_cache_check, remote_download, remote_network, filesystem_traversal, worker_execution, worker_setup, worker_borrow, worker_working, worker_copying_outputs, credential_helper, conflict_check, dynamic_lock, repository_fetch, repository_vendor or unknown> 累積多次使用
指定要納入設定檔的其他設定檔工作。
標記: bazel_monitoring
--[no]experimental_profile_include_primary_output 預設值:「false」
在動作事件中加入額外的「out」屬性,其中包含動作主要輸出的執行路徑。
標記: bazel_monitoring
--[no]experimental_profile_include_target_configuration 預設值:「false」
在動作事件的 JSON 設定檔資料中加入目標設定雜湊。
標記: bazel_monitoring
--[no]experimental_profile_include_target_label 預設值:「false」
在動作事件的 JSON 設定檔資料中加入目標標籤。
標記: bazel_monitoring
--[no]experimental_record_metrics_for_all_mnemonics 預設值:「false」
控制 BEP ActionSummary 和 BuildGraphMetrics 的輸出內容,限制 ActionData 中的助憶符號數量,以及 BuildGraphMetrics.AspectCount/RuleClassCount 中回報的項目數量。根據預設,類型數量會限制在前 20 個,依據 ActionData 執行的動作數量,以及 RuleClass 和 Asepcts 的例項。設定這個選項後,系統會為所有助憶法、規則類別和層面寫入統計資料。
--[no]experimental_record_skyframe_metrics 預設值:「false」
控制 BEP BuildGraphMetrics 的輸出內容,包括關於 Skykey、RuleClass 和 Aspect 的昂貴 Skyframe 指標。如果此標記設為 false,BuildGraphMetrics.rule_count 和 aspectfields 就不會在 BEP 中填入。
--[no]experimental_run_bep_event_include_residue 預設值:「false」
是否要在可能包含殘留內容的執行建構事件中加入指令列殘留內容。根據預設,執行指令的建構事件不會包含殘留物。
標記: affects_outputs
--[no]experimental_stream_log_file_uploads 預設值:「false」
直接將記錄檔案串流上傳至遠端儲存空間,而非寫入磁碟。
標記: affects_outputs
--experimental_workspace_rules_log_file=<a path> 預設值:請參閱說明
將特定 Workspace 規則事件記錄到這個檔案中,做為以分隔符分隔的 WorkspaceEvent 原型。
--[no]generate_json_trace_profile 預設值:「auto」
如果啟用,Bazel 會分析建構作業,並將 JSON 格式的設定檔寫入輸出基礎的檔案中。將設定檔載入至 chrome://tracing 即可查看設定檔。根據預設,Bazel 會為所有類似建構的指令和查詢寫入設定檔。
標記: bazel_monitoring
--[no]heap_dump_on_oom 預設值:「false」
如果擲回 OOM (包括因達到 --gc_thrashing_limits 而產生的手動 OOM),是否要手動輸出堆積轉儲記錄。轉儲內容會寫入 <output_base>/<invocation_id>.heapdump.hprof。這個選項可有效取代 -XX:+HeapDumpOnOutOfMemoryError,後者對手動 OOM 沒有任何影響。
標記: bazel_monitoring
--jvm_heap_histogram_internal_object_pattern=<a valid Java regular expression> 預設值:"jdk\.internal\.vm\.Filler.+"
用於覆寫 JDK21+ JVM 堆積記憶體收集的規則運算式。我們會依據不穩定的內部 G1 GC 實作詳細資料,取得清晰的記憶體指標,這個選項可讓我們因應內部實作的變更,無須等待二進位檔版本。傳遞至 JDK Matcher.find()
--[no]legacy_important_outputs 預設值:「false」
使用此選項可在 TargetComplete 事件中抑制產生舊版 important_outputs 欄位。如果要將 Bazel 與 ResultStore/BTX 整合,就必須使用 important_outputs。
標記: affects_outputs
--logging=<0 <= an integer <= 6> 預設值:「3」
記錄層級。
標記: affects_outputs
--memory_profile=<a path> 預設值:請參閱說明
如果已設為此值,系統就會在階段結束時將記憶體用量資料寫入指定檔案,並在建構結束時將穩定堆積寫入主記錄。
標記: bazel_monitoring
--memory_profile_stable_heap_parameters=<integers, separated by a comma expected in pairs> 預設值:"1,0"
在建構結束時,調整記憶體設定檔對穩定堆積的計算。應為以半形逗號分隔的偶數整數。在每個組中,第一個整數是執行 GC 的次數。每個組合的第二個整數是 GC 之間的等待秒數。例如:2,4,4,0 會執行 2 次 GC,並暫停 4 秒,接著執行 4 次 GC,並暫停 0 秒
標記: bazel_monitoring
--profile=<a path> 預設值:請參閱說明
如果已設定,系統會分析 Bazel 並將資料寫入指定檔案。使用 bazel analyze-profile 分析設定檔。
標記: bazel_monitoring
--profiles_to_retain=<an integer> 預設值:「5」
在輸出基礎中保留的設定檔數量。如果輸出資料庫中的設定檔超過這個數量,系統會刪除最舊的設定檔,直到總數低於限制為止。
標記: bazel_monitoring
--[no]record_full_profiler_data 預設值:「false」
根據預設,Bazel 分析工具只會針對快速且大量的事件 (例如檢查檔案狀態) 記錄匯總資料。如果啟用這個選項,剖析器會記錄每個事件,因此產生的剖析資料會更精確,但會對效能造成巨大影響。只有在使用 --profile 時,這個選項才會生效。
標記: bazel_monitoring
--[no]redirect_local_instrumentation_output_writes 預設值:「false」
如果為 true 且受支援,檢測輸出內容就會重新導向至本機,並在不同的機器上寫入,而非在 Bazel 執行所在的機器上寫入。
標記: bazel_monitoring
--remote_print_execution_messages=<failure, success or all> 預設值:「failure」
選擇要何時列印遠端執行訊息。有效值為 `failure` (只在失敗時列印)、`success` (只在成功時列印) 和 `all` (一律列印)。
標記: terminal_output
--[no]slim_profile 預設值:「true」
如果設定檔過大,則會合併事件,以縮減 JSON 設定檔的大小。
標記: bazel_monitoring
--starlark_cpu_profile=<a string> 預設值:""
將所有 Starlark 執行緒的 CPU 用量 pprof 設定檔寫入指定檔案。
標記: bazel_monitoring
--tool_tag=<a string> 預設值:""
要將此 Bazel 叫用歸屬至的工具名稱。
標記: affects_outputsbazel_monitoring
--ui_event_filters=<Convert list of comma separated event kind to list of filters> 累積多次使用
指定要在 UI 中顯示哪些事件。您可以使用前置的 +/- 新增或移除事件,也可以直接指派來完全覆寫預設組合。支援的事件類型組合包括 INFO、DEBUG、ERROR 等。
標記: terminal_output
選項可指定或變更 Bazel 指令的一般輸入內容,而該輸入內容不屬於其他類別:
--experimental_resolved_file_instead_of_workspace=<a string> 預設值:""
如果非空白,則讀取指定的已解析檔案,而非 WORKSPACE 檔案
標記: changes_inputs
遠端快取和執行選項:
--experimental_circuit_breaker_strategy=<failure> 預設值:請參閱說明
指定斷路器要使用的策略。可用的策略為「failure」。選項的無效值會與未設定選項的行為相同。
標記: execution
--experimental_downloader_config=<a string> 預設值:請參閱說明
指定要用來設定遠端下載器的檔案。這個檔案包含多行,每行開頭都是指令 (allow、block 或 rewrite),後面接著主機名稱 (適用於 allow 和 block) 或兩個模式,一個用於比對,另一個用於做為替代網址,其中的回溯參照會從 `$1` 開始。同一個網址可以有多個 `rewrite` 指令,在這種情況下,系統會傳回多個網址。
--[no]experimental_guard_against_concurrent_changes 預設值:「false」
將此選項設為關閉,即可停用檢查動作輸入檔案 ctime 的功能,然後上傳至遠端快取。在某些情況下,Linux 核心可能會延遲寫入檔案,導致誤判。
--experimental_remote_cache_compression_threshold=<an integer> 預設值:「100」
使用 zstd 壓縮/解壓縮時所需的 Blob 大小下限。除非設定 --remote_cache_compression,否則無效。
--[no]experimental_remote_cache_lease_extension 預設值:「false」
如果設為 true,Bazel 會在建構期間定期將 `FindMissingBlobs` 呼叫傳送至遠端快取,藉此延長遠端動作輸出的租約。頻率取決於 `--experimental_remote_cache_ttl` 的值。
--experimental_remote_cache_ttl=<An immutable length of time.> 預設值:「3h」
在最近參照 Blob 摘要 (例如透過 ActionResult 或 FindMissingBlobs) 後,保證遠端快取中 Blob 的最短 TTL。Bazel 會根據 Blob 的 TTL 執行多項最佳化作業,例如在漸進式建構作業中不重複呼叫 GetActionResult。這個值應設為略低於實際的 TTL,因為伺服器傳回摘要與 Bazel 收到摘要之間存在時間差。
標記: execution
--experimental_remote_capture_corrupted_outputs=<a path> 預設值:請參閱說明
要擷取損毀輸出內容的目錄路徑。
--[no]experimental_remote_discard_merkle_trees 預設值:「true」
如果設為 true,系統會在呼叫 GetActionResult() 和 Execute() 時,捨棄輸入根目錄的 Merkle 樹狀結構和相關輸入對應項目的記憶體副本。這麼做可大幅減少記憶體使用量,但需要在遠端快取遺漏和重試時,由 Bazel 重新計算這些項目。
--experimental_remote_downloader=<a string> 預設值:請參閱說明
Remote Asset API 端點 URI,用於做為遠端下載 Proxy。支援的結構定義為 grpc、grpcs (已啟用 TLS 的 grpc) 和 unix (本機 UNIX 通訊端)。如果未提供結構定義,Bazel 會預設為使用 grpcs。請參閱:https://github.com/bazelbuild/remote-apis/blob/master/build/bazel/remote/asset/v1/remote_asset.proto
--[no]experimental_remote_downloader_local_fallback 預設值:「false」
如果遠端下載器失敗,是否要改用本機下載器。
--[no]experimental_remote_downloader_propagate_credentials 預設值:「false」
是否要從 netrc 和憑證輔助程式,將憑證傳播至遠端下載器伺服器。伺服器實作項目必須支援新的 `http_header_url:<url-index>:<header-key>` 限定詞,其中 `<url-index>` 是 FetchBlobRequest 的 `uris` 欄位中網址的 0 為起點位置。網址專屬標頭應優先於全域標頭。
--[no]experimental_remote_execution_keepalive 預設值:「false」
是否要為遠端執行呼叫使用保留機制。
--experimental_remote_failure_rate_threshold=<an integer in 0-100 range> 預設值:「10」
設定特定時間區間內允許的失敗率百分比,超過此百分比後,系統就會停止呼叫遠端快取/執行緒。預設值為 10。將這個值設為 0 表示沒有限制。
標記: execution
--experimental_remote_failure_window_interval=<An immutable length of time.> 預設值:「60 秒」
計算遠端要求失敗率的間隔。如果值為零或負值,系統會將執行作業的整個期間計算為失敗時間。您可以使用以下單位:天 (d)、小時 (h)、分鐘 (m)、秒 (s) 和毫秒 (ms)。如果省略單位,系統會將值解讀為秒。
標記: execution
--[no]experimental_remote_mark_tool_inputs 預設值:「false」
如果設為 True,Bazel 就會將輸入內容標示為遠端執行工具的輸入內容。這可用於實作遠端持續性工作者。
--[no]experimental_remote_merkle_tree_cache 預設值:「false」
如果設為 true,系統會記錄 Merkle 樹狀圖計算結果,以改善遠端快取命中檢查速度。快取的記憶體足跡會由 --experimental_remote_merkle_tree_cache_size 控制。
--experimental_remote_merkle_tree_cache_size=<a long integer> 預設值:「1000」
要快取的 Merkle 樹狀圖數量,以改善遠端快取命中檢查速度。雖然快取會根據 Java 處理軟性參照的方式自動裁剪,但如果設定過高,就可能發生記憶體不足錯誤。如果設為 0,快取大小就沒有限制。最佳值會因專案大小而異。預設為 1000。
--experimental_remote_output_service=<a string> 預設值:請參閱說明
遠端輸出服務端點的 HOST 或 HOST:PORT。支援的結構定義為 grpc、grpcs (已啟用 TLS 的 grpc) 和 unix (本機 UNIX 通訊端)。如果未提供結構定義,Bazel 會預設為使用 grpcs。指定 grpc:// 或 unix: 結構定義,以停用 TLS。
--experimental_remote_output_service_output_path_prefix=<a string> 預設值:""
--experimental_remote_output_service 管理的輸出目錄內容會放在這個路徑下。實際上,建構作業所使用的輸出目錄會是這個路徑的子項,並由輸出服務決定。
--[no]experimental_remote_require_cached 預設值:「false」
如果設為 true,系統會強制將所有可在遠端執行的動作儲存為快取,否則建構作業會失敗。這有助於排解非決定論問題,因為您可以檢查應快取的動作是否確實已快取,而不會將新結果誤植入快取。
--experimental_remote_scrubbing_config=<Converts to a Scrubber> 預設值:請參閱說明
透過提供的設定檔啟用遠端快取索引鍵清除功能,該設定檔必須是文字格式的通訊協定緩衝區 (請參閱 src/main/protobuf/remote_scrubbing.proto)。 這項功能旨在協助在不同平台上執行但指定相同平台的動作之間共用遠端/磁碟快取。請務必謹慎使用,因為設定不當可能會導致意外共用快取項目,進而導致不正確的建構作業。清除作業不會影響動作的執行方式,只會影響系統如何計算遠端/磁碟快取金鑰,以便擷取或儲存動作結果。經過修飾的動作與遠端執行作業不相容,因此一律會改為在本機執行。修改清除設定不會使本機檔案系統或內部快取中的輸出內容失效;您必須執行清除建構作業,才能重新執行受影響的動作。為了成功使用這項功能,您可能會想設定自訂的 --host_platform,並搭配 --experimental_platform_in_output_dir (用於標準化輸出前置字串) 和 --incompatible_strict_action_env (用於標準化環境變數)。
--experimental_worker_for_repo_fetching=<off, platform, virtual or auto> 預設值:「auto」
用於擷取存放區的執行緒模式。如果設為「off」,系統就不會使用 worker 執行緒,且 repo 擷取作業會在重新啟動時執行。否則,請使用虛擬工作者執行緒。
--[no]remote_accept_cached 預設值:「true」
是否接受遠端快取的動作結果。
--remote_build_event_upload=<all or minimal> 預設值:「minimal」
如果設為「all」,BEP 參照的所有本機輸出內容都會上傳至遠端快取。如果設為「minimal」,BEP 參照的本機輸出內容就不會上傳至遠端快取,但對 BEP 使用者而言重要的檔案 (例如測試記錄和時間設定檔) 除外。即使檔案未出現在遠端快取中,檔案的 URI 一律會使用 bytestream:// 配置。預設為「minimal」。
--remote_bytestream_uri_prefix=<a string> 預設值:請參閱說明
在寫入建構事件串流的 bytestream:// URI 中,要使用的主機名稱和執行個體名稱。您可以在使用 Proxy 執行建構作業時設定這個選項,這會導致 --remote_executor 和 --remote_instance_name 的值不再對應至遠端執行服務的標準名稱。如未設定,則預設為「${hostname}/${instance_name}」。
--remote_cache=<a string> 預設值:請參閱說明
快取端點的 URI。支援的結構定義為 http、https、grpc、grpcs (已啟用 TLS 的 grpc) 和 unix (本機 UNIX 通訊端)。如果未提供結構定義,Bazel 會預設為使用 grpcs。指定 grpc://、http:// 或 unix: 結構定義,即可停用 TLS。請參閱 https://bazel.build/remote/caching
--[no]remote_cache_async 預設值:「true」
如果設為 true,系統會在背景上傳動作結果至磁碟或遠端快取,而不會阻斷動作的完成。某些動作與背景上傳功能不相容,即使設定了這個標記,也可能仍會遭到封鎖。
--[no]remote_cache_compression 預設值:「false」
如果啟用,當快取 blob 的大小至少達到 --experimental_remote_cache_compression_threshold 時,系統就會使用 zstd 進行壓縮/解壓縮。
--remote_cache_header=<a 'name=value' assignment> 累積多次使用
指定要納入快取要求的標頭:--remote_cache_header=Name=Value。您可以多次指定標記,藉此傳遞多個標頭。同一個名稱的多個值會轉換為以半形逗號分隔的清單。
--remote_default_exec_properties=<a 'name=value' assignment> 累積多次使用
如果執行平台尚未設定 exec_properties,請設定要用於遠端執行平台的預設執行屬性。
標記: affects_outputs
--remote_default_platform_properties=<a string> 預設值:""
如果執行平台尚未設定 remote_execution_properties,請設定要為遠端執行 API 設定的預設平台屬性。如果主機平台已選為遠端執行的執行平台,系統也會使用這個值。
--remote_download_regex=<a valid Java regular expression> 累積多次使用
強制下載路徑符合此模式的遠端建構輸出內容,不受 --remote_download_outputs 影響。您可以重複使用這個旗標來指定多個模式。
標記: affects_outputs
--remote_downloader_header=<a 'name=value' assignment> 累積多次使用
指定要納入遠端下載器要求的標頭:--remote_downloader_header=名稱=值。您可以多次指定標記,藉此傳遞多個標頭。同一個名稱的多個值會轉換為以半形逗號分隔的清單。
--remote_exec_header=<a 'name=value' assignment> 累積多次使用
指定執行要求中要納入的標頭:--remote_exec_header=Name=Value。您可以多次指定標記,藉此傳遞多個標頭。同一個名稱的多個值會轉換為以半形逗號分隔的清單。
--remote_execution_priority=<an integer> 預設值:「0」
要遠端執行的動作相對優先順序。特定優先值的語意取決於伺服器。
--remote_executor=<a string> 預設值:請參閱說明
遠端執行端點的 HOST 或 HOST:PORT。支援的結構定義為 grpc、grpcs (已啟用 TLS 的 grpc) 和 unix (本機 UNIX 通訊端)。如果未提供結構定義,Bazel 會預設為使用 grpcs。指定 grpc:// 或 unix: 結構定義,以停用 TLS。
--remote_grpc_log=<a path> 預設值:請參閱說明
如果指定,則為記錄 gRPC 呼叫相關詳細資料的檔案路徑。此記錄包含序列化的 com.google.devtools.build.lib.remote.logging.RemoteExecutionLog.LogEntry protobuf,每則訊息的前置字串為 varint,表示下一個序列化 protobuf 訊息的大小,如 LogEntry.writeDelimitedTo(OutputStream) 方法所執行。
--remote_header=<a 'name=value' assignment> 累積多次使用
指定要納入要求的標頭:--remote_header=名稱=值。您可以多次指定標記,藉此傳遞多個標頭。同一個名稱的多個值會轉換為以半形逗號分隔的清單。
--remote_instance_name=<a string> 預設值:""
在遠端執行 API 中,要做為 instance_name 傳遞的值。
--[no]remote_local_fallback 預設值:「false」
如果遠端執行作業失敗,是否要改用獨立的本機執行策略。
--remote_local_fallback_strategy=<a string> 預設值:「local」
已淘汰。詳情請參閱 https://github.com/bazelbuild/bazel/issues/7480。
--remote_max_connections=<an integer> 預設值:「100」
限制遠端快取/執行工具的並行連線數上限。預設值為 100。將這個值設為 0 表示沒有限制。對於 HTTP 遠端快取,一個 TCP 連線可同時處理一個要求,因此 Bazel 最多可提出 --remote_max_connections 個並行要求。對於 gRPC 遠端快取/執行緒,一個 gRPC 管道通常可處理 100 個以上的並發要求,因此 Bazel 可以發出約 `--remote_max_connections * 100` 個並發要求。
標記: host_machine_resource_optimizations
--remote_proxy=<a string> 預設值:請參閱說明
透過 Proxy 連線至遠端快取。目前這個旗標只能用於設定 Unix 網域 Socket (unix:/path/to/socket)。
--remote_result_cache_priority=<an integer> 預設值:「0」
要儲存在遠端快取中的遠端動作相對優先順序。特定優先值的語意取決於伺服器。
--remote_retries=<an integer> 預設值:「5」
重試暫時性錯誤的最大次數。如果設為 0,則會停用重試。
--remote_retry_max_delay=<An immutable length of time.> 預設值:「5 秒」
遠端重試之間的最大輪詢延遲時間。可使用的單位包括:天數 (d)、小時 (h)、分鐘 (m)、秒數 (s) 和毫秒 (ms)。如果省略單位,系統會將值解讀為秒。
--remote_timeout=<An immutable length of time.> 預設值:「60 秒」
等待遠端執行作業和快取呼叫的時間上限。對於 REST 快取,這同時是連線和讀取逾時時間。可使用的單位包括:天數 (d)、小時 (h)、分鐘 (m)、秒數 (s) 和毫秒 (ms)。如果省略單位,系統會將值解讀為秒。
--[no]remote_upload_local_results 預設值:「true」
如果遠端快取支援上傳,且使用者已獲授權,則是否將本機執行的動作結果上傳至遠端快取。
--[no]remote_verify_downloads 預設值:「true」
如果設為 true,Bazel 會計算所有遠端下載的雜湊總和,並在遠端快取的值不符合預期值時丟棄。
其他選項,未歸類於其他類別:
--build_metadata=<a 'name=value' assignment> 累積多次使用
在建構事件中提供的自訂鍵/值字串組合。
標記: terminal_output
--color=<yes, no or auto> 預設值:「auto」
使用終端機控制項為輸出內容著色。
--config=<a string> 累積多次使用
會從 rc 檔案中選取其他設定區段。對於每個 <command>,如果有此區段,它也會從 <command>:<config> 提取選項;如果任何 .rc 檔案中都沒有這個區段,Blaze 就會失敗並顯示錯誤訊息。等同於設定區段和標記組合的設定區段位於 tools/*.blazerc 設定檔中。
--credential_helper=<Path to a credential helper. It may be absolute, relative to the PATH environment variable, or %workspace%-relative. The path be optionally prefixed by a scope followed by an '='. The scope is a domain name, optionally with a single leading '*' wildcard component. A helper applies to URIs matching its scope, with more specific scopes preferred. If a helper has no scope, it applies to every URI.> 累積多次使用
設定符合 <a href="https://github.com/EngFlow/credential-helper-spec">憑證輔助程式規格</a>的憑證輔助程式,用於擷取存放區擷取、遠端快取和執行作業,以及建構事件服務的授權憑證。輔助程式提供的憑證優先於 `--google_default_credentials`、`--google_credentials`、`.netrc` 檔案或 `repository_ctx.download()` 和 `repository_ctx.download_and_extract()` 的授權參數。 可多次指定,以設定多個輔助程式。 如需操作說明,請參閱 https://blog.engflow.com/2023/10/09/configuring-bazels-credential-helper/。
--credential_helper_cache_duration=<An immutable length of time.> 預設值:「30m」
如果憑證輔助程式未在憑證到期時提供憑證,則系統會將憑證輔助程式提供的憑證快取一段預設時間。
--credential_helper_timeout=<An immutable length of time.> 預設值:「10 秒」
設定憑證輔助程式的逾時時間。如果憑證輔助程式未在逾時期間內回應,叫用作業就會失敗。
--curses=<yes, no or auto> 預設值:「auto」
使用終端機游標控制項,盡量減少捲動輸出內容。
--disk_cache=<a path> 預設值:請參閱說明
Bazel 可讀取及寫入動作和動作輸出的目錄路徑。如果目錄不存在,系統會建立該目錄。
--[no]enable_platform_specific_config 預設值:「false」
如果為 true,Bazel 會從 bazelrc 檔案中挑選主機作業系統專屬的設定行。舉例來說,如果主機作業系統是 Linux,且您執行 bazel build,Bazel 會挑選開頭為 build:linux 的程式碼行。支援的 OS ID 包括 linux、macos、windows、freebsd 和 openbsd。啟用這個標記,就等同於在 Linux 上使用 --config=linux,在 Windows 上使用 --config=windows 等。
--experimental_disk_cache_gc_idle_delay=<An immutable length of time.> 預設值:「5m」
在磁碟快取進行垃圾收集前,伺服器必須閒置多久。如要指定垃圾收集政策,請設定 --experimental_disk_cache_gc_max_size 和/或 --experimental_disk_cache_gc_max_age。
--experimental_disk_cache_gc_max_age=<An immutable length of time.> 預設值:「0」
如果設為正值,系統會定期執行垃圾收集作業,移除超過此年齡的項目。如果與 --experimental_disk_cache_gc_max_size 搭配使用,系統會套用兩項條件。伺服器閒置後,系統會根據 --experimental_disk_cache_gc_idle_delay 標記,在背景執行垃圾收集作業。
--experimental_disk_cache_gc_max_size=<a size in bytes, optionally followed by a K, M, G or T multiplier> 預設值:「0」
如果設為正值,系統會定期執行垃圾收集作業,確保磁碟快取大小不超過這個值。如果與 --experimental_disk_cache_gc_max_age 搭配使用,系統會套用這兩項條件。伺服器閒置後,系統會根據 --experimental_disk_cache_gc_idle_delay 標記,在背景執行垃圾收集作業。
--[no]experimental_rule_extension_api 預設值:「true」
啟用實驗性規則擴充 API 和子規則 API
標記: loading_and_analysisexperimental
--[no]experimental_windows_watchfs 預設值:「false」
如果為 true,系統就會啟用實驗性 Windows 支援 --watchfs。否則,--watchfs 在 Windows 上為非作業。請務必也啟用 --watchfs。
--google_auth_scopes=<comma-separated list of options> 預設值:「https://www.googleapis.com/auth/cloud-platform」
以半形逗號分隔的 Google Cloud 驗證權限範圍清單。
--google_credentials=<a string> 預設值:請參閱說明
指定要從哪個檔案取得驗證憑證。詳情請參閱 https://cloud.google.com/docs/authentication。
--[no]google_default_credentials 預設值:「false」
是否使用「Google 應用程式預設憑證」進行驗證。詳情請參閱 https://cloud.google.com/docs/authentication。預設為停用。
--grpc_keepalive_time=<An immutable length of time.> 預設值:請參閱說明
設定傳出 gRPC 連線的保持連線 ping。如果設定了這個值,則 Bazel 會在連線上沒有讀取作業的時間達到這個值後傳送 ping,但前提是至少有一個待處理的 gRPC 呼叫。時間會以秒為單位計算;如果設定的值小於一秒,系統會傳回錯誤。根據預設,系統會停用保活 ping。請先與服務擁有者協調,再啟用這項設定。舉例來說,如要將這個旗標設為 30 秒,應使用以下格式:--grpc_keepalive_time=30s
--grpc_keepalive_timeout=<An immutable length of time.> 預設值:「20 秒」
設定傳出 gRPC 連線的保持運作逾時時間。如果使用 --grpc_keepalive_time 啟用保活 ping,如果在指定時間內未收到 ping 回覆,Bazel 就會讓連線逾時。時間會以秒為單位計算;如果設定的值小於一秒,系統會傳回錯誤。如果已停用保活 ping,系統會忽略這項設定。
--[no]incompatible_disable_non_executable_java_binary 預設值:「false」
如果為 true,java_binary 一律可執行。create_executable 屬性會遭到移除。
標記: loading_and_analysisincompatible_change
--inject_repository=<an equals-separated mapping of repository name to path> 累積多次使用
新增存放區,並使用本機路徑,格式為 <repository name>=<path>。此選項只會在使用 --enable_bzlmod 時生效,且等同於透過 `use_repo_rule` 將對應的 `local_repository` 新增至根模組的 MODULE.bazel 檔案。如果指定的路徑為絕對路徑,系統會直接使用該路徑。如果指定的路徑為相對路徑,則會相對於目前的工作目錄。如果指定的路徑開頭為「%workspace%」,則該路徑相對於工作區根目錄,也就是 `bazel info workspace` 的輸出內容。如果指定的路徑為空白,請移除先前的所有注入內容。
--invocation_id=<a UUID> 預設值:""
執行的指令專屬 ID,格式為 UUID。如果明確指定不重複性,則呼叫端必須確保不重複性。UUID 會輸出至 stderr、BEP 和遠端執行通訊協定。
標記: bazel_monitoringbazel_internal_configuration
--override_repository=<an equals-separated mapping of repository name to path> 累積多次使用
使用本機路徑覆寫存放區,格式為 <repository name>=<path>。如果指定的路徑是絕對路徑,系統會直接使用該路徑。如果指定的路徑是相對路徑,則會以目前的作業目錄為基準。如果指定的路徑以「%workspace%」開頭,則會相對於工作區根目錄,也就是 `bazel info workspace` 的輸出內容。如果指定的路徑為空白,請移除先前的覆寫值。
--[no]progress_in_terminal_title 預設值:「false」
在終端機標題中顯示指令進度。在有多個終端機分頁時,可用來查看 Bazel 正在執行的作業。
--[no]show_progress 預設值:「true」
在建構期間顯示進度訊息。
--show_progress_rate_limit=<a double> 預設值:「0.2」
輸出內容中進度訊息之間的最短秒數。
--[no]show_timestamps 預設值:「false」
在訊息中加入時間戳記
--tls_certificate=<a string> 預設值:請參閱說明
指定 TLS 憑證的路徑,該憑證可信任簽署伺服器憑證。
--tls_client_certificate=<a string> 預設值:請參閱說明
指定要使用的 TLS 用戶端憑證;您也需要提供用戶端金鑰,才能啟用用戶端驗證。
--tls_client_key=<a string> 預設值:請參閱說明
指定要使用的 TLS 用戶端金鑰;您也必須提供用戶端憑證,才能啟用用戶端驗證。
--ui_actions_shown=<an integer> 預設值:「8」
詳細進度列中顯示的並行動作數量;每個動作會顯示在個別的列中。進度列一律會顯示至少一個 1,所有小於 1 的數字都會對應至 1。
標記: terminal_output
--[no]watchfs 預設值:「false」
在 Linux/macOS 上:如果為 true,bazel 會嘗試使用作業系統的檔案監控服務來監控本機變更,而非掃描每個檔案以尋找變更。在 Windows 上:這個標記目前是無操作,但可與 --experimental_windows_watchfs 搭配使用。在任何作業系統上:如果工作區位於網路檔案系統中,且檔案是在遠端電腦上編輯,則行為未定義。

Analyze-profile 選項

這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
代碼: loading_and_analysis
影響記錄詳細程度、格式或位置的選項:
--dump=<text or raw> [-d] 預設值:請參閱說明
以人類可讀的「文字」格式或易於腳本使用的「原始」格式輸出完整設定檔資料傾印。
標記: bazel_monitoring

Aquery 選項

繼承「build」的所有選項。

這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
標記: loading_and_analysis
與查詢輸出和語義相關的選項:
--aspect_deps=<off, conservative or precise> 預設值:「conservative」
如何在輸出格式為 {xml,proto,record} 的情況下解析面向依附元件。「off」表示不會解析任何面向依賴項、「conservative」(預設值) 表示會新增所有已宣告的面向依賴項,無論其是否已指定直接依賴項的規則類別;「precise」表示只會新增那些在直接依賴項的規則類別中可能處於作用中的面向。請注意,精確模式需要載入其他套件才能評估單一目標,因此速度會比其他模式慢。另請注意,即使是精確模式也不完全精確:決定是否要計算某個面向的決定是在分析階段做出,而這並不會在「bazel 查詢」期間執行。
標記: build_file_semantics
--[no]consistent_labels 預設值:「false」
如果啟用,每個查詢指令都會像是將 Starlark <code>str</code> 函式套用至 <code>Label</code> 例項時一樣,發出標籤。這項功能對於需要比對不同查詢指令和/或規則產生標籤的工具來說非常實用。如果未啟用,輸出格式化器可以自由發出明顯的存放區名稱 (相對於主要存放區),以便讓輸出內容更易讀。
標記: terminal_output
--[no]experimental_explicit_aspects 預設值:「false」
aquery、cquery:是否要在輸出內容中加入由子集產生的動作。query:無操作 (一律會遵循子集)。
標記: terminal_output
--[no]graph:factored 預設值:「true」
如果設為 true,系統會「分解」圖表,也就是將拓樸上等價的節點合併,並連結其標籤。這個選項僅適用於 --output=graph。
標記: terminal_output
--graph:node_limit=<an integer> 預設值:「512」
輸出內容中圖形節點標籤字串的長度上限。較長的標籤會遭到截斷;-1 表示不截斷。這個選項僅適用於 --output=graph。
標記: terminal_output
--[no]implicit_deps 預設值:「true」
如果啟用,系統會在查詢運作的依附元件圖表中加入隱含依附元件。隱含依附元件是指未在 BUILD 檔案中明確指定,但由 Bazel 新增的依附元件。針對 cquery,這個選項會控制篩選已解析的工具鍊。
標記: build_file_semantics
--[no]include_artifacts 預設值:「true」
輸出內容中包含動作輸入和輸出項目的名稱 (可能很大)。
標記: terminal_output
--[no]include_aspects 預設值:「true」
aquery、cquery:是否要在輸出內容中加入由子集產生的動作。query:無操作 (一律會遵循子集)。
標記: terminal_output
--[no]include_commandline 預設值:「true」
輸出內容包含動作指令列 (可能很大)。
標記: terminal_output
--[no]include_file_write_contents 預設值:「false」
加入 FileWrite、SourceSymlinkManifest 和 RepoMappingManifest 動作的檔案內容 (可能很大)。
標記: terminal_output
--[no]include_param_files 預設值:「false」
請附上指令中使用的參數檔案內容 (可能很大)。注意:啟用這個標記會自動啟用 --include_commandline 標記。
標記: terminal_output
--[no]include_pruned_inputs 預設值:「true」
包含在執行動作時遭到裁剪的動作輸入項目。只會影響發現輸入內容且已在先前叫用中執行的動作。只有在同時設定 --include_artifacts 時才會生效。
標記: terminal_output
--[no]incompatible_package_group_includes_double_slash 預設值:「true」
如果啟用此選項,在輸出 package_group 的 `packages` 屬性時,系統就不會省略開頭的 `//`。
標記: terminal_outputincompatible_change
--[no]infer_universe_scope 預設值:「false」
如果已設定且未設定 --universe_scope,系統會將 --universe_scope 的值推斷為查詢運算式中的不重複目標模式清單。請注意,如果查詢運算式使用全域範圍函式 (例如 `allrdeps`),系統推斷的 --universe_scope 值可能不是您想要的,因此請務必確實瞭解這個選項的用途後再使用。如需詳細資訊和範例,請參閱 https://bazel.build/reference/query#sky-query。如果已設定 --universe_scope,系統會忽略這個選項的值。注意:這個選項僅適用於 `query` (即非 `cquery`)。
代碼: loading_and_analysis
--[no]line_terminator_null 預設值:「false」
是否以 \0 而非換行符號結束每個格式。
標記: terminal_output
--[no]nodep_deps 預設值:「true」
如果啟用,系統會在查詢運作的依附元件圖中納入「nodep」屬性的依附元件。「nodep」屬性的常見例子為「visibility」。執行並剖析 `info build-language` 的輸出內容,瞭解建構語言中的所有「nodep」屬性。
標記: build_file_semantics
--output=<a string> 預設值:「text」
aquery 結果的輸出格式。aquery 的有效值為:text、textproto、proto、streamed_proto、jsonproto。
標記: terminal_output
--[no]proto:default_values 預設值:「true」
如果為 true,則會納入 BUILD 檔案中未明確指定值的屬性;否則會略過這些屬性。這個選項適用於 --output=proto
標記: terminal_output
--[no]proto:definition_stack 預設值:「false」
為 definition_stack proto 欄位填入資料,為每個規則例項記錄規則類別定義時的 Starlark 呼叫堆疊。
標記: terminal_output
--[no]proto:flatten_selects 預設值:「true」
如果啟用,則由 select() 建立的可設定屬性會扁平化。對於清單類型,平坦化表示法是清單,其中只包含所選對應項目的每個值一次。純量型別會扁平化為空值。
標記: build_file_semantics
--[no]proto:include_attribute_source_aspects 預設值:「false」
將屬性來源的來源層面填入每個屬性的 source_aspect_name 原型欄位 (如果沒有,則為空字串)。
標記: terminal_output
--[no]proto:include_synthetic_attribute_hash 預設值:「false」
是否要計算並填入 $internal_attr_hash 屬性。
標記: terminal_output
--[no]proto:instantiation_stack 預設值:「false」
填入每項規則的例項化呼叫堆疊。請注意,這需要堆疊存在
標記: terminal_output
--[no]proto:locations 預設值:「true」
是否在 Proto 輸出內容中輸出位置資訊。
標記: terminal_output
--proto:output_rule_attrs=<comma-separated list of options> 預設值:「all」
以半形逗號分隔的屬性清單,用於納入輸出內容。預設為所有屬性。如要不輸出任何屬性,請將其設為空字串。這個選項適用於 --output=proto。
標記: terminal_output
--[no]proto:rule_classes 預設值:「false」
為每項規則填入 rule_class_key 欄位;如果第一個規則具有指定的 rule_class_key,請為其填入 rule_class_info 原型欄位。rule_class_key 欄位可唯一識別規則類別,而 rule_class_info 欄位則是 Stardoc 格式的規則類別 API 定義。
標記: terminal_output
--[no]proto:rule_inputs_and_outputs 預設值:「true」
是否要填入 rule_input 和 rule_output 欄位。
標記: terminal_output
--query_file=<a string> 預設值:""
如果設定此值,查詢會從此處指定的檔案讀取查詢,而不是從指令列讀取。在此處指定檔案和指令列查詢是錯誤的做法。
標記: changes_inputs
--[no]relative_locations 預設值:「false」
如果設為 true,XML 和 Proto 輸出內容中的 BUILD 檔案位置會是相對位置。根據預設,位置輸出內容為絕對路徑,且在不同機器上不會一致。您可以將這個選項設為 true,讓各機器的結果保持一致。
標記: terminal_output
--[no]skyframe_state 預設值:「false」
不執行額外分析,從 Skyframe 轉儲目前的動作圖表。注意:目前不支援使用 --skyframe_state 指定目標。這個標記只能與 --output=proto 或 --output=textproto 搭配使用。
標記: terminal_output
--[no]tool_deps 預設值:「true」
查詢:如果停用,系統就不會在查詢運作的依附元件圖中納入「執行設定」的依附元件。「執行設定」依附元件邊緣 (例如從任何「proto_library」規則到 Protocol Compiler 的邊緣),通常會指向建構期間執行的工具,而非同一個「target」程式的一部分。Cquery:如果停用,系統會篩除所有從發現此已設定目標的頂層目標跨越執行轉換的已設定目標。也就是說,如果頂層目標位於目標設定中,則系統只會傳回目標設定中已設定的目標。如果頂層目標位於執行設定中,系統只會傳回執行設定的目標。這個選項不會排除已解析的工具鍊。
標記: build_file_semantics
--universe_scope=<comma-separated list of options> 預設值:""
以逗號分隔的目標模式組合 (加法和減法)。查詢可能會在指定目標的傳遞閉包所定義的宇宙中執行。這個選項可用於查詢和 cquery 指令。對於 cquery,這個選項的輸入內容是所有答案的目標,因此這個選項可能會影響設定和轉換。如果未指定這個選項,系統會假設頂層目標是從查詢運算式解析的目標。注意:如果從查詢運算式解析的目標無法使用頂層選項進行建構,則針對 cquery 未指定此選項可能會導致建構作業中斷。
代碼: loading_and_analysis
控制建構執行作業的選項:
是否要直接呼叫檔案系統以建立符號連結樹狀結構,而非委派給輔助程序。
標記: loading_and_analysisexecutionexperimental
--[no]experimental_persistent_aar_extractor 預設值:「false」
使用 worker 啟用持續性 AAR Extractor。
標記: executionexperimental
--[no]experimental_remotable_source_manifests 預設值:「false」
是否要讓來源資訊清單動作可遠端執行
標記: loading_and_analysisexecutionexperimental
--[no]experimental_split_coverage_postprocessing 預設值:「false」
如果為 true,Bazel 就會在新的產生事件中執行測試的涵蓋率後置處理程序。
標記: executionexperimental
--[no]experimental_strict_fileset_output 預設值:「false」
如果啟用這個選項,檔案集會將所有輸出構件視為一般檔案。不會遍歷目錄,也不會對符號連結敏感。
標記: executionexperimental
--[no]incompatible_modify_execution_info_additive 預設值:「false」
啟用後,傳遞多個 --modify_execution_info 標記會相加。停用時,系統只會考量最後一個標記。
標記: executionaffects_outputsloading_and_analysisincompatible_change
--modify_execution_info=<regex=[+-]key,regex=[+-]key,...> 累積多次使用
根據動作助憶法,新增或移除動作執行資訊中的鍵。僅適用於支援執行資訊的動作。許多常見動作都支援執行資訊,例如 Genrule、CppCompile、Javac、StarlarkAction、TestRunner。指定多個值時,順序很重要,因為許多規則運算式可能會套用相同的助憶法。語法:「regex=[+-]key,regex=[+-]key,...」。範例: «.*=+x,.*=-y,.*=+z» 會將「x」和「z」加入所有動作的執行資訊,並移除「y」。'Genrule=+requires-x' 會將 'requires-x' 新增至所有 Genrule 動作的執行資訊。'(?!Genrule).*=-requires-x' 會從所有非 Genrule 動作的執行資訊中移除 'requires-x'。
標記: executionaffects_outputsloading_and_analysis
--persistent_android_dex_desugar
使用工作者啟用持續性的 Android dex 和 desugar 動作。
展開為:
  --internal_persistent_android_dex_desugar
  --strategy=Desugar=worker
  --strategy=DexBuilder=worker

標記: host_machine_resource_optimizationsexecution
--persistent_android_resource_processor
使用 worker 啟用 Android 資源處理器。
展開為:
  --internal_persistent_busybox_tools
  --strategy=AaptPackage=worker
  --strategy=AndroidResourceParser=worker
  --strategy=AndroidResourceValidator=worker
  --strategy=AndroidResourceCompiler=worker
  --strategy=RClassGenerator=worker
  --strategy=AndroidResourceLink=worker
  --strategy=AndroidAapt2=worker
  --strategy=AndroidAssetMerger=worker
  --strategy=AndroidResourceMerger=worker
  --strategy=AndroidCompiledResourceMerger=worker
  --strategy=ManifestMerger=worker
  --strategy=AndroidManifestMerger=worker
  --strategy=Aapt2Optimize=worker
  --strategy=AARGenerator=worker
  --strategy=ProcessDatabinding=worker
  --strategy=GenerateDataBindingBaseClasses=worker

標記: host_machine_resource_optimizationsexecution
--persistent_multiplex_android_dex_desugar
使用 worker 啟用持續性的多重 Android dex 和 desugar 動作。
展開為:
  --persistent_android_dex_desugar
  --internal_persistent_multiplex_android_dex_desugar

標記: host_machine_resource_optimizationsexecution
--persistent_multiplex_android_resource_processor
使用 worker 啟用持續性的多重 Android 資源處理器。
展開為:
  --persistent_android_resource_processor
  --modify_execution_info=AaptPackage=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceParser=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceValidator=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceCompiler=+supports-multiplex-workers
  --modify_execution_info=RClassGenerator=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceLink=+supports-multiplex-workers
  --modify_execution_info=AndroidAapt2=+supports-multiplex-workers
  --modify_execution_info=AndroidAssetMerger=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceMerger=+supports-multiplex-workers
  --modify_execution_info=AndroidCompiledResourceMerger=+supports-multiplex-workers
  --modify_execution_info=ManifestMerger=+supports-multiplex-workers
  --modify_execution_info=AndroidManifestMerger=+supports-multiplex-workers
  --modify_execution_info=Aapt2Optimize=+supports-multiplex-workers
  --modify_execution_info=AARGenerator=+supports-multiplex-workers

標記: host_machine_resource_optimizations, execution
--persistent_multiplex_android_tools
啟用持續性和多重化的 Android 工具 (dexing、desugaring、資源處理)。
展開為:
  --internal_persistent_multiplex_busybox_tools
  --persistent_multiplex_android_resource_processor
  --persistent_multiplex_android_dex_desugar

標記: host_machine_resource_optimizationsexecution
--[no]use_target_platform_for_tests 預設值:「false」
如果為 true,Bazel 會使用目標平台執行測試,而不是使用測試執行群組。
代碼: execution
設定用於執行動作的工具鍊的選項:
--android_compiler=<a string> 預設值:請參閱說明
Android 目標編譯器。
標記: affects_outputsloading_and_analysisloses_incremental_state
--android_manifest_merger=<legacy, android or force_android> 預設值:「android」
選取要用於 android_binary 規則的資訊清單合併工具。旗標,可協助從舊版合併工具轉換至 Android 資訊清單合併工具。
標記: affects_outputsloading_and_analysisloses_incremental_state
--android_platforms=<a build target label> 預設值:""
設定 android_binary 目標使用的平台。如果指定多個平台,則二進位檔會是笨重的 APK,其中包含每個指定目標平台的原生二進位檔。
標記: changes_inputsloading_and_analysisloses_incremental_state
--apple_crosstool_top=<a build target label> 預設值:"@bazel_tools//tools/cpp:toolchain"
在 Apple 和 Objc 規則及其依附元件中使用的 crosstool 套件標籤。
標記: loses_incremental_statechanges_inputs
--cc_output_directory_tag=<a string> 預設值:""
指定要新增至設定目錄的後置字串。
標記: affects_outputs
--compiler=<a string> 預設值:請參閱說明
用於編譯目標的 C++ 編譯器。
標記: loading_and_analysisexecution
--coverage_output_generator=<a build target label> 預設值:"@bazel_tools//tools/test:lcov_merger"
用於後處理原始涵蓋率報表的二進位檔位置。這個檔案群組目前必須包含單一檔案 (二進位檔)。預設值為 '//tools/test:lcov_merger'。
標記: changes_inputsaffects_outputsloading_and_analysis
--coverage_report_generator=<a build target label> 預設值:"@bazel_tools//tools/test:coverage_report_generator"
用於產生涵蓋率報表的二進位檔位置。這個檔案群組目前必須包含單一檔案 (二進位檔)。預設值為 '//tools/test:coverage_report_generator'。
標記: changes_inputsaffects_outputsloading_and_analysis
--coverage_support=<a build target label> 預設值:"@bazel_tools//tools/test:coverage_support"
收集程式碼涵蓋率的每個測試動作輸入項目所需的支援檔案位置。預設值為 '//tools/test:coverage_support'。
標記: changes_inputsaffects_outputsloading_and_analysis
--custom_malloc=<a build target label> 預設值:請參閱說明
指定自訂 malloc 實作項目。這項設定會覆寫建構規則中的 malloc 屬性。
標記: changes_inputsaffects_outputs
--experimental_add_exec_constraints_to_targets=<a '<RegexFilter>=<label1>[,<label2>,...]' assignment> 累積多次使用
以逗號分隔的規則運算式清單,每個運算式可選擇加上前置字元 - (負值運算式),並將 (=) 指派給以逗號分隔的限制值目標清單。如果目標不符合任何負面運算式,且至少符合一個正面運算式,則會執行工具鍊解析作業,就像宣告限制值為執行限制一樣。範例://demo,-test=@platforms//cpus:x86_64 會將「x86_64」新增至 //demo 下的任何目標,但名稱含有「test」的目標除外。
標記: loading_and_analysis
--[no]experimental_include_xcode_execution_requirements 預設值:「false」
如果已設定,請在每個 Xcode 動作中新增「requires-xcode:{version}」執行需求。如果 Xcode 版本有連字號標籤,請一併新增「requires-xcode-label:{version_label}」執行要求。
標記: loses_incremental_stateloading_and_analysisexecutionexperimental
--[no]experimental_prefer_mutual_xcode 預設值:「true」
如果為 true,請使用在本機和遠端都可用的最新 Xcode。如果為 false,或沒有可用的共同版本,請使用透過 xcode-select 所選的本機 Xcode 版本。
標記: loses_incremental_stateexperimental
--extra_execution_platforms=<comma-separated list of options> 預設值:""
可用於執行動作的執行平台。您可以使用完全比對目標或目標模式指定平台。系統會先考慮這些平台,再考慮由 register_execution_platforms() 在 WORKSPACE 檔案中宣告的平台。這個選項只能設定一次;後續的例項會覆寫先前的標記設定。
標記: execution
--extra_toolchains=<comma-separated list of options> 累積多次使用
在工具鍊解析期間要考量的工具鍊規則。您可以使用確切目標或目標模式指定工具鍊。系統會先考慮這些工具鍊,再考慮 WORKSPACE 檔案中透過 register_toolchains() 宣告的工具鍊。
標記: affects_outputschanges_inputsloading_and_analysis
--grte_top=<a label> 預設值:請參閱說明
已檢查的 libc 程式庫的標籤。預設值是由 crosstool 工具鍊選取,您幾乎不需要覆寫。
標記: action_command_linesaffects_outputs
--host_compiler=<a string> 預設值:請參閱說明
無操作標記。將在日後推出的版本中移除。
標記: loading_and_analysisexecution
--host_grte_top=<a label> 預設值:請參閱說明
如果指定此值,這項設定會覆寫執行設定的 libc 頂層目錄 (--grte_top)。
標記: action_command_linesaffects_outputs
--host_platform=<a build target label> 預設值:"@bazel_tools//tools:host_platform"
平台規則的標籤,用於說明主機系統。
標記: affects_outputschanges_inputsloading_and_analysis
--[no]incompatible_bazel_test_exec_run_under 預設值:「false」
如果啟用,則「bazel test --run_under=//:runner」會在執行設定中建構「//:runner」。如果停用,則會在目標設定中建構「//:runner」。Bazel 會在執行機器上執行測試,因此前者較為正確。這不會影響「bazel run」,因為這項指令會一律在目標設定中建構「--run_under=//foo」。
標記: affects_outputsincompatible_change
--[no]incompatible_dont_enable_host_nonhost_crosstool_features 預設值:「true」
如果設為 true,Bazel 就不會在 c++ 工具鍊中啟用「host」和「nonhost」功能 (詳情請參閱 https://github.com/bazelbuild/bazel/issues/7407)。
標記: loading_and_analysisincompatible_change
--[no]incompatible_enable_apple_toolchain_resolution 預設值:「false」
使用工具鍊解析來選取 Apple 規則的 Apple SDK (Starlark 和原生)
標記: loading_and_analysisincompatible_change
--[no]incompatible_remove_legacy_whole_archive 預設值:「true」
如果為 true,Bazel 預設不會將程式庫依附元件連結為整個封存檔 (如需遷移操作說明,請參閱 https://github.com/bazelbuild/bazel/issues/7362)。
標記: loading_and_analysisincompatible_change
--[no]incompatible_strip_executable_safely 預設值:「false」
如果為 true,可執行檔的剝除動作會使用 -x 標記,不會中斷動態符號解析。
標記: action_command_linesincompatible_change
--[no]interface_shared_objects 預設值:「true」
如果工具鍊支援,請使用介面共用物件。目前所有 ELF 工具鍊都支援這項設定。
標記: loading_and_analysisaffects_outputsaffects_outputs
--ios_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 iOS 應用程式的 iOS SDK 版本。如未指定,系統會使用「xcode_version」的預設 iOS SDK 版本。
標記: loses_incremental_state
--macos_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 macOS 應用程式的 macOS SDK 版本。如未指定,系統會使用「xcode_version」中的預設 macOS SDK 版本。
標記: loses_incremental_state
--minimum_os_version=<a string> 預設值:請參閱說明
編譯目標的最低作業系統版本。
標記: loading_and_analysisaffects_outputs
--platform_mappings=<a main workspace-relative path> 預設值:""
對應檔案的位置,可說明在未設定任何平台時要使用的平台,或在已存在平台時要設定的旗標。必須相對於主要工作區根目錄。預設值為「platform_mappings」(工作區根目錄下方的檔案)。
標記: affects_outputschanges_inputsloading_and_analysisimmutable
--platforms=<a build target label> 預設值:""
平台規則的標籤,說明目前指令的目標平台。
標記: affects_outputschanges_inputsloading_and_analysis
--python_path=<a string> 預設值:請參閱說明
在目標平台上執行 Python 目標時,系統會叫用 Python 解譯器的絕對路徑。已淘汰;已由 --incompatible_use_python_toolchains 停用。
標記: loading_and_analysisaffects_outputs
--python_top=<a build target label> 預設值:請參閱說明
py_runtime 的標籤,代表在目標平台上執行 Python 目標時所叫用的 Python 轉譯器。已淘汰;已由 --incompatible_use_python_toolchains 停用。
標記: loading_and_analysisaffects_outputs
--tvos_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 tvOS 應用程式的 tvOS SDK 版本。如果未指定,系統會使用「xcode_version」中的預設 tvOS SDK 版本。
標記: loses_incremental_state
--watchos_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 watchOS 應用程式的 watchOS SDK 版本。如未指定,系統會使用「xcode_version」的預設 watchOS SDK 版本。
標記: loses_incremental_state
--xcode_version=<a string> 預設值:請參閱說明
如果指定此屬性,系統會使用指定版本的 Xcode 執行相關的建構動作。如未指定,系統會使用執行緒的預設 Xcode 版本。
標記: loses_incremental_state
--xcode_version_config=<a build target label> 預設值:"@bazel_tools//tools/cpp:host_xcodes"
xcode_config 規則的標籤,用於在建構設定中選取 Xcode 版本。
標記: loses_incremental_stateloading_and_analysis
控制指令輸出的選項:
--[no]apple_generate_dsym 預設值:「false」
是否產生偵錯符號 (.dSYM) 檔案。
標記: affects_outputsaction_command_lines
如果為 true,則為所有目標建構 runfiles 符號連結森林。如果為 false,則只有在本機動作、測試或執行指令要求時,才會寫入。
標記: affects_outputs
--[no]build_runfile_manifests 預設值:「true」
如果為 true,則為所有目標寫入 runfiles 資訊清單。如果為 false,則省略這些項目。如果為 false,本機測試就會無法執行。
標記: affects_outputs
--[no]build_test_dwp 預設值:「false」
如果啟用此選項,在使用 Fission 靜態建構 C++ 測試時,系統也會自動建構測試二進位檔的 .dwp 檔案。
標記: loading_and_analysisaffects_outputs
--cc_proto_library_header_suffixes=<comma-separated set of options> 預設值:".pb.h"
設定 cc_proto_library 建立的標頭檔案後置字串。
標記: affects_outputsloading_and_analysis
--cc_proto_library_source_suffixes=<comma-separated set of options> 預設值:「.pb.cc」
設定 cc_proto_library 建立的來源檔案後置字串。
標記: affects_outputsloading_and_analysis
--[no]experimental_proto_descriptor_sets_include_source_info 預設值:「false」
針對 proto_library 中的其他 Java API 版本執行額外動作。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_save_feature_state 預設值:「false」
將已啟用和要求的功能的狀態儲存為編譯的輸出內容。
標記: affects_outputsexperimental
--fission=<a set of compilation modes> 預設值:「no」
指定哪些編譯模式會在 C++ 編譯和連結時使用分裂。可為 {'fastbuild', 'dbg', 'opt'} 或特殊值的任意組合,其中 'yes'可啟用所有模式,'no'可停用所有模式。
標記: loading_and_analysisaction_command_linesaffects_outputs
--[no]incompatible_always_include_files_in_data 預設值:「true」
如果為 true,原生規則會將資料依附元件的 <code>DefaultInfo.files</code> 新增至其執行檔,這與 Starlark 規則的建議行為相符 (https://bazel.build/extending/rules#runfiles_features_to_avoid)。
標記: affects_outputsincompatible_change
--[no]legacy_external_runfiles 預設值:「false」
如果為 true,則會為 .runfiles/wsname/external/repo 下的外部存放區 (除了 .runfiles/repo) 建構執行檔案符號連結森林。
標記: affects_outputs
--[no]objc_generate_linkmap 預設值:「false」
指定是否要產生連結圖檔案。
標記: affects_outputs
--[no]save_temps 預設值:「false」
如果設定,系統會儲存來自 gcc 的臨時輸出內容。包括 .s 檔案 (組譯器程式碼)、.i 檔案 (預處理的 C) 和 .ii 檔案 (預處理的 C++)。
標記: affects_outputs
選項可讓使用者設定預期的輸出內容,影響其值,而非其存在:
--action_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定可供含有目標設定的動作使用的一組環境變數。變數可以透過名稱指定,在這種情況下,系統會從叫用環境取得值;也可以透過名稱=值組合指定,在這種情況下,系統會設定不受叫用環境影響的值。這個選項可以重複使用;如果是針對同一個變數提供的選項,則以最新的選項為準;如果是針對不同變數提供的選項,則會累加。
標記: action_command_lines
--allowed_cpu_values=<comma-separated set of options> 預設值:""
--cpu 標記的有效值。
標記: changes_inputsaffects_outputs
--[no]android_databinding_use_androidx 預設值:「true」
產生與 AndroidX 相容的資料繫結檔案。這個屬性僅適用於資料繫結 v2。這個標記不會執行任何操作。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]android_databinding_use_v3_4_args 預設值:「true」
使用 Android Databinding v2 和 3.4.0 引數。這個標記不會執行任何操作。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--android_dynamic_mode=<off, default or fully> 預設值:「off」
決定在 cc_binary 未明確建立共用程式庫時,是否要動態連結 Android 規則的 C++ 依附元件。「預設」表示 Bazel 會選擇是否要動態連結。「fully」表示所有程式庫都會動態連結。「off」表示所有程式庫都會以靜態模式連結。
標記: affects_outputsloading_and_analysis
--android_manifest_merger_order=<alphabetical, alphabetical_by_configuration or dependency> 預設值:「alphabetical」
設定傳遞至 Android 二進位檔資訊清單合併工具的資訊清單順序。ALPHABETICAL 表示資訊清單會依據相對於執行根目錄的路徑排序。ALPHABETICAL_BY_CONFIGURATION 表示資訊清單會依據輸出目錄中相對於設定目錄的路徑排序。DEPENDENCY 表示資訊清單會依序排列,每個程式庫的資訊清單會排在其依附元件的資訊清單之前。
標記: action_command_linesexecution
--[no]android_resource_shrinking 預設值:「false」
為使用 ProGuard 的 android_binary APK 啟用資源縮減功能。
標記: affects_outputsloading_and_analysis
--[no]build_python_zip 預設值:「auto」
建構 Python 可執行的 zip 檔案;在 Windows 上開啟,在其他平台上關閉
標記: affects_outputs
--catalyst_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的清單,列出要用來建構 Apple Catalyst 二進位檔的架構。
標記: loses_incremental_stateloading_and_analysis
--[no]collect_code_coverage 預設值:「false」
如果指定此選項,Bazel 會檢測程式碼 (盡可能使用離線檢測),並在測試期間收集涵蓋率資訊。只有符合 --instrumentation_filter 的目標才會受到影響。通常不應直接指定這個選項,而應改用「bazel coverage」指令。
標記: affects_outputs
--compilation_mode=<fastbuild, dbg or opt> [-c] 預設值:「fastbuild」
指定要建構二進位檔的模式。值:'fastbuild'、'dbg'、'opt'。
標記: affects_outputsaction_command_lines
--conlyopt=<a string> 累積多次使用
編譯 C 來源檔案時,要傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--copt=<a string> 累積多次使用
傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--cpu=<a string> 預設值:""
目標 CPU。
標記: changes_inputsaffects_outputs
--cs_fdo_absolute_path=<a string> 預設值:請參閱說明
使用 CSFDO 設定檔資訊來最佳化編譯作業。指定內含設定檔檔案的 ZIP 檔案的絕對路徑名稱,也就是原始或索引 LLVM 設定檔檔案。
標記: affects_outputs
--cs_fdo_instrument=<a string> 預設值:請參閱說明
使用情境敏感的 FDO 檢測功能產生二進位檔。使用 Clang/LLVM 編譯器時,它也會接受目錄名稱,以便在執行階段轉儲原始設定檔檔案。
標記: affects_outputs
--cs_fdo_profile=<a build target label> 預設值:請參閱說明
cs_fdo_profile 代表要用於最佳化的內容敏感設定檔。
標記: affects_outputs
--cxxopt=<a string> 累積多次使用
編譯 C++ 來源檔案時,要傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--define=<a 'name=value' assignment> 累積多次使用
每個 --define 選項都會指定建構變數的值。如果變數有多個值,則最後一個值會勝出。
標記: changes_inputsaffects_outputs
--dynamic_mode=<off, default or fully> 預設值:"default"
決定是否要動態連結 C++ 二進位檔。「預設」表示 Bazel 會選擇是否要動態連結。「fully」表示所有程式庫都會動態連結。「off」表示所有程式庫都會以靜態模式連結。
標記: loading_and_analysisaffects_outputs
--[no]enable_propeller_optimize_absolute_paths 預設值:「true」
如果設為此值,任何使用 propeller optimize 的絕對路徑都會發生錯誤。
標記: affects_outputs
--[no]enable_remaining_fdo_absolute_paths 預設值:「true」
如果設為此值,任何使用 FDO 的絕對路徑都會發生錯誤。
標記: affects_outputs
--[no]enable_runfiles 預設值:「auto」
啟用 runfiles 符號連結樹狀結構;預設情況下,Windows 和其他平台都會關閉。
標記: affects_outputs
--experimental_action_listener=<a build target label> 累積多次使用
已淘汰,改用切面。使用 action_listener 將 extra_action 附加至現有的建構動作。
標記: executionexperimental
--[no]experimental_android_compress_java_resources 預設值:「false」
壓縮 APK 中的 Java 資源
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_android_databinding_v2 預設值:「true」
使用 Android Databinding v2。這個標記不會執行任何操作。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]experimental_android_resource_shrinking 預設值:「false」
為使用 ProGuard 的 android_binary APK 啟用資源縮減功能。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_android_rewrite_dexes_with_rex 預設值:「false」
使用 rex 工具重寫 dex 檔案
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]experimental_collect_code_coverage_for_generated_files 預設值:「false」
如果指定,Bazel 也會為產生的檔案產生收集涵蓋率資訊。
標記: affects_outputsexperimental
--experimental_objc_fastbuild_options=<comma-separated list of options> 預設值:"-O0,-DDEBUG=1"
使用這些字串做為 objc fastbuild 編譯器選項。
標記: action_command_lines
--[no]experimental_omitfp 預設值:「false」
如果設為 True,請使用 libunwind 進行堆疊解開作業,並使用 -fomit-frame-pointer 和 -fasynchronous-unwind-tables 進行編譯。
標記: action_command_linesaffects_outputsexperimental
--experimental_output_paths=<off, content or strip> 預設值:「off」
在輸出樹狀結構規則寫入輸出內容時,應使用哪個模型,特別適用於多平台 / 多設定版本。這項功能仍在實驗階段,詳情請參閱 https://github.com/bazelbuild/bazel/issues/6526。Starlark 動作可以選擇啟用路徑對應功能,方法是將「supports-path-mapping」鍵新增至「execution_requirements」字典。
標記: loses_incremental_statebazel_internal_configurationaffects_outputsexecution
--experimental_override_name_platform_in_output_dir=<a 'label=value' assignment> 累積多次使用
每個項目都應採用 label=value 的格式,其中 label 是指平台,而 value 是輸出路徑中要使用的所需簡稱。僅在 --experimental_platform_in_output_dir 為 true 時使用。具有最高的命名優先順序。
標記: affects_outputsexperimental
--[no]experimental_platform_in_output_dir 預設值:「false」
如果為 true,輸出目錄名稱會使用目標平台的短名稱,而非 CPU。具體的配置為實驗性質,可能會變更:首先,在極少數情況下,如果 --platforms 選項不含確切的一個值,系統會使用 platforms 選項的雜湊值。接著,如果目前平台的任何簡稱都已透過 --experimental_override_name_platform_in_output_dir 註冊,系統就會使用該簡稱。接著,如果已設定 --experimental_use_platforms_in_output_dir_legacy_heuristic,請使用目前平台標籤的短名稱。最後,平台選項的雜湊值會用於最後的手段。
標記: affects_outputsexperimental
--[no]experimental_py_binaries_include_label 預設值:「false」
即使停用沖壓功能,py_binary 目標也會包含標籤。
標記: affects_outputsexperimental
--[no]experimental_use_llvm_covmap 預設值:「false」
如果指定此選項,在啟用 collect_code_coverage 時,Bazel 會產生 llvm-cov 涵蓋範圍對應資訊,而非 gcov。
標記: changes_inputsaffects_outputsloading_and_analysisexperimental
--[no]experimental_use_platforms_in_output_dir_legacy_heuristic 預設值:「true」
請僅在建議的遷移或測試策略中使用這個標記。請注意,啟發式搜尋有已知的缺陷,建議您改為只使用 --experimental_override_name_platform_in_output_dir。
標記: affects_outputsexperimental
--fdo_instrument=<a string> 預設值:請參閱說明
使用 FDO 檢測功能產生二進位檔。使用 Clang/LLVM 編譯器時,它也會接受目錄名稱,以便在執行階段轉儲原始設定檔檔案。
標記: affects_outputs
--fdo_optimize=<a string> 預設值:請參閱說明
使用 FDO 設定檔資訊來最佳化編譯作業。指定內含 .gcda 檔案樹狀結構的 ZIP 檔案名稱、內含自動設定檔的 afdo 檔案,或 LLVM 設定檔檔案。這個旗標也接受指定為標籤的檔案 (例如 `//foo/bar:file.afdo` - 您可能需要在對應的套件中新增 `exports_files` 指示),以及指向 `fdo_profile` 目標的標籤。這項標記將由 `fdo_profile` 規則取代。
標記: affects_outputs
--fdo_prefetch_hints=<a build target label> 預設值:請參閱說明
使用快取預先擷取提示。
標記: affects_outputs
--fdo_profile=<a build target label> 預設值:請參閱說明
fdo_profile 代表用於最佳化的設定檔。
標記: affects_outputs
--features=<a string> 累積多次使用
對於在目標設定中建構的目標,系統會預設啟用或停用指定功能。指定 -<feature> 會停用該功能。負面特徵一律會覆寫正面特徵。另請參閱 --host_features
標記: changes_inputsaffects_outputs
--[no]force_pic 預設值:「false」
如果啟用,所有 C++ 編譯作業都會產生位置無關的程式碼 ("-fPIC"),連結會優先使用 PIC 預先建構的程式庫,而非非 PIC 程式庫,且連結會產生位置無關的可執行檔 ("-pie")。
標記: loading_and_analysisaffects_outputs
--host_action_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定執行作業設定可用的環境變數組合。變數可以透過名稱指定,在這種情況下,系統會從叫用環境取得值;也可以透過名稱=值組合指定,在這種情況下,系統會設定不受叫用環境影響的值。這個選項可以重複使用;如果是針對同一個變數提供的選項,則以最新的選項為準;如果是針對不同變數提供的選項,則會累加。
標記: action_command_lines
--host_compilation_mode=<fastbuild, dbg or opt> 預設值:「opt」
指定在建構期間使用的工具將以何種模式建構。值:'fastbuild'、'dbg'、'opt'。
標記: affects_outputsaction_command_lines
--host_conlyopt=<a string> 累積多次使用
在執行設定中編譯 C (但非 C++) 來源檔案時,要傳遞至 C 編譯器的其他選項。
標記: action_command_linesaffects_outputs
--host_copt=<a string> 累積多次使用
為執行設定中建構的工具,傳遞至 C 編譯器的其他選項。
標記: action_command_linesaffects_outputs
--host_cpu=<a string> 預設值:""
主機 CPU。
標記: changes_inputsaffects_outputs
--host_cxxopt=<a string> 累積多次使用
針對在執行設定中建構的工具,傳遞至 C++ 編譯器的其他選項。
標記: action_command_linesaffects_outputs
--host_features=<a string> 累積多次使用
對於在執行設定中建構的目標,系統會依預設啟用或停用指定功能。指定 -<feature> 會停用該功能。負面特徵一律會覆寫正面特徵。
標記: changes_inputsaffects_outputs
--host_force_python=<PY2 or PY3> 預設值:請參閱說明
覆寫執行設定的 Python 版本。可以是「PY2」或「PY3」。
標記: loading_and_analysisaffects_outputs
--host_linkopt=<a string> 累積多次使用
在執行設定中連結工具時,要傳遞至連結器的其他選項。
標記: action_command_linesaffects_outputs
--host_macos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
主機目標的最低相容 macOS 版本。如果未指定,系統會使用「macos_sdk_version」。
標記: loses_incremental_state
--host_per_file_copt=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths followed by an @ and a comma separated list of options> 累積多次使用
在執行設定中編譯特定檔案時,可選擇傳遞至 C/C++ 編譯器的其他選項。這個選項可以多次傳遞。語法:regex_filter@選項_1,選項_2,...,選項_n。其中 regex_filter 代表包含和排除的規則運算式模式清單 (另請參閱 --instrumentation_filter)。option_1 到 option_n 代表任意指令列選項。如果選項包含半形逗號,則必須在半形逗號前後加上反斜線。選項可以包含 @。只有第一個 @ 會用來分割字串。範例:--host_per_file_copt=//foo/.*\.cc,-//foo/bar\.cc@-O0 會將 -O0 指令列選項新增至 //foo/ 中所有 cc 檔案 (除了 bar.cc) 的 gcc 指令列。
標記: action_command_linesaffects_outputs
--[no]incompatible_auto_exec_groups 預設值:「false」
啟用後,系統會為規則使用的每個工具鍊自動建立執行群組。為使這項規則運作,您需要在其動作中指定「toolchain」參數。如需更多資訊,請參閱 https://github.com/bazelbuild/bazel/issues/17134。
標記: affects_outputsincompatible_change
--[no]incompatible_merge_genfiles_directory 預設值:「true」
如果設為 true,系統會將 genfiles 目錄折疊至 bin 目錄。
標記: affects_outputsincompatible_change
--[no]instrument_test_targets 預設值:「false」
啟用涵蓋率時,指定是否要考慮檢測測試規則。設定後,--instrumentation_filter 所包含的測試規則就會進行檢測。否則,測試規則一律會從涵蓋率檢測工具中排除。
標記: affects_outputs
--instrumentation_filter=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths> 預設值:「-/javatests[/:],-/test/java[/:]」
啟用涵蓋率後,系統只會檢測名稱包含指定規則運算式篩選器的規則。系統會排除開頭為「-」的規則。請注意,除非啟用 --instrument_test_targets,否則只會檢測非測試規則。
標記: affects_outputs
--ios_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定模擬器和裝置的最低相容 iOS 版本。如果未指定,系統會使用「ios_sdk_version」。
標記: loses_incremental_state
--ios_multi_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的架構清單,用於建構 ios_application。結果會是包含所有指定架構的通用二進位檔。
標記: loses_incremental_stateloading_and_analysis
--[no]legacy_whole_archive 預設值:「true」
已淘汰,已由 --incompatible_remove_legacy_whole_archive 取代 (詳情請參閱 https://github.com/bazelbuild/bazel/issues/7362)。開啟後,請針對 cc_binary 規則使用 --whole-archive,該規則的 linkshared 為 True,且 linkopts 中為 linkstatic=True 或 '-static'。這項設定僅適用於回溯相容性。更好的做法是在需要時使用 alwayslink=1。
標記: action_command_linesaffects_outputsdeprecated
--linkopt=<a string> 累積多次使用
連結時傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--ltobackendopt=<a string> 累積多次使用
傳遞至 LTO 後端步驟的其他選項 (在 --features=thin_lto 下方)。
標記: action_command_linesaffects_outputs
--ltoindexopt=<a string> 累積多次使用
傳遞至 LTO 索引步驟的其他選項 (在 --features=thin_lto 下方)。
標記: action_command_linesaffects_outputs
--macos_cpus=<comma-separated list of options> 累積多次使用
以逗號分隔的架構清單,用於建構 Apple macOS 二進位檔。
標記: loses_incremental_stateloading_and_analysis
--macos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
目標的最低相容 macOS 版本。如果未指定,系統會使用「macos_sdk_version」。
標記: loses_incremental_state
--memprof_profile=<a build target label> 預設值:請參閱說明
使用 memprof 設定檔。
標記: affects_outputs
--[no]objc_debug_with_GLIBCXX 預設值:「false」
如果已設定,且編譯模式設為「dbg」,請定義 GLIBCXX_DEBUG、GLIBCXX_DEBUG_PEDANTIC 和 GLIBCPP_CONCEPT_CHECKS。
標記: action_command_lines
--[no]objc_enable_binary_stripping 預設值:「false」
是否要在已連結的二進位檔上執行符號和無效程式碼去除作業。如果同時指定這個旗標和 --compilation_mode=opt,系統就會執行二進位碼去除作業。
標記: action_command_lines
--objccopt=<a string> 累積多次使用
編譯 Objective-C/C++ 來源檔案時,要傳遞至 gcc 的其他選項。
標記: action_command_lines
--per_file_copt=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths followed by an @ and a comma separated list of options> 累積多次使用
在編譯特定檔案時,可選擇傳遞至 gcc 的其他選項。這個選項可以多次傳遞。語法:regex_filter@選項_1,選項_2,...,選項_n。其中 regex_filter 代表包含和排除的規則運算式模式清單 (另請參閱 --instrumentation_filter)。option_1 到 option_n 代表任意指令列選項。如果選項包含半形逗號,則必須在半形逗號前後加上反斜線。選項可以包含 @。只有第一個 @ 會用來分割字串。範例:--per_file_copt=//foo/.*\.cc,-//foo/bar\.cc@-O0 會將 -O0 指令列選項新增至 //foo/ 中所有 cc 檔案 (除了 bar.cc) 的 gcc 指令列。
標記: action_command_linesaffects_outputs
--per_file_ltobackendopt=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths followed by an @ and a comma separated list of options> 累積多次使用
編譯特定後端物件時,可選擇將哪些選項傳遞至 LTO 後端 (在 --features=thin_lto 下) 的其他選項。這個選項可以多次傳遞。語法:regex_filter@選項_1,選項_2,...,選項_n。其中 regex_filter 代表包含和排除規則運算式的清單。option_1 到 option_n 代表任意指令列選項。如果選項包含半形逗號,則必須在半形逗號前後加上反斜線。選項可以包含 @。只有第一個 @ 會用來分割字串。範例:--per_file_ltobackendopt=//foo/.*\.o,-//foo/bar\.o@-O0 會將 -O0 指令列選項新增至 //foo/ 中所有 o 檔案 (除了 bar.o) 的 LTO 後端指令列。
標記: action_command_linesaffects_outputs
--platform_suffix=<a string> 預設值:請參閱說明
指定要新增至設定目錄的後置字串。
標記: loses_incremental_stateaffects_outputsloading_and_analysis
--propeller_optimize=<a build target label> 預設值:請參閱說明
使用 Propeller 設定檔資訊來改善建構目標。Propeller 設定檔至少必須包含以下兩個檔案之一:cc 設定檔和 ld 設定檔。這個標記可接受建構標籤,但該標籤必須參照螺旋槳設定檔輸入檔案。舉例來說,定義標籤的 BUILD 檔案,在 a/b/BUILD:propeller_optimize( name = "propeller_profile", cc_profile = "propeller_cc_profile.txt", ld_profile = "propeller_ld_profile.txt",) 中,您可能必須在對應的套件中加入 exports_files 指示詞,才能讓 Bazel 看到這些檔案。這個選項必須以以下方式使用:--propeller_optimize=//a/b:propeller_profile
標記: action_command_linesaffects_outputs
--propeller_optimize_absolute_cc_profile=<a string> 預設值:請參閱說明
Propeller 最佳化版本的 cc_profile 檔案絕對路徑名稱。
標記: affects_outputs
--propeller_optimize_absolute_ld_profile=<a string> 預設值:請參閱說明
Propeller 最佳化版本的 ld_profile 檔案絕對路徑名稱。
標記: affects_outputs
--run_under=<a prefix in front of command> 預設值:請參閱說明
在「test」和「run」指令的可執行檔前插入前置字串。如果值為「foo -bar」,執行指令列為「test_binary -baz」,則最終指令列為「foo -bar test_binary -baz」。這也可以是可執行目標的標籤。以下是一些範例:'valgrind'、'strace'、'strace -c'、'valgrind --quiet --num-callers=20'、'//package:target'、'//package:target --options'。
標記: action_command_lines
--[no]share_native_deps 預設值:「true」
如果為 true,含有相同功能的原生程式庫會在不同目標之間共用
標記: loading_and_analysisaffects_outputs
--[no]stamp 預設值:「false」
在二進位檔上蓋上日期、使用者名稱、主機名稱、工作區資訊等資訊。
標記: affects_outputs
--strip=<always, sometimes or never> 預設值:「sometimes」
用於指定是否要移除二進位檔和共用程式庫 (使用「-Wl,--strip-debug」)。預設值為「sometimes」表示如果 --compilation_mode=fastbuild,則會移除。
標記: affects_outputs
--stripopt=<a string> 累積多次使用
產生 '<name>.stripped'二進位檔時,要傳遞至 strip 的其他選項。
標記: action_command_linesaffects_outputs
--tvos_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的架構清單,用於建構 Apple tvOS 二進位檔。
標記: loses_incremental_stateloading_and_analysis
--tvos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定模擬器和裝置的最低相容 tvOS 版本。如果未指定,系統會使用「tvos_sdk_version」。
標記: loses_incremental_state
--visionos_cpus=<comma-separated list of options> 累積多次使用
以逗號分隔的清單,列出要為其建構 Apple visionOS 二進位檔的架構。
標記: loses_incremental_stateloading_and_analysis
--watchos_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的架構清單,用於建構 Apple watchOS 二進位檔。
標記: loses_incremental_stateloading_and_analysis
--watchos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定模擬器和裝置的最低相容 watchOS 版本。如果未指定,系統會使用「watchos_sdk_version」。
標記: loses_incremental_state
--xbinary_fdo=<a build target label> 預設值:請參閱說明
使用 XbinaryFDO 設定檔資訊來最佳化編譯作業。指定預設交叉二進位設定檔的名稱。當此選項與 --fdo_instrument/--fdo_optimize/--fdo_profile 一起使用時,這些選項一律會優先採用,就好像從未指定 xbinary_fdo 一樣。
標記: affects_outputs
影響 Bazel 如何嚴格執行有效建構輸入內容 (規則定義、標記組合等) 的選項:
--[no]check_licenses 預設值:「false」
請確認依附套件施加的授權限制,不會與建構目標的發布模式衝突。根據預設,系統不會檢查授權。
標記: build_file_semantics
--[no]check_visibility 預設值:「true」
如果停用,目標依附元件中的顯示錯誤會降級為警告。
標記: build_file_semantics
--[no]desugar_for_android 預設值:「true」
是否要在解碼前脫糖 Java 8 位元組碼。
標記: affects_outputsloading_and_analysisloses_incremental_state
--[no]desugar_java8_libs 預設值:「false」
是否要在舊版裝置的應用程式中加入支援的 Java 8 程式庫。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]enforce_constraints 預設值:「true」
檢查每個目標的相容環境,如果任何目標的依附元件不支援相同的環境,就會回報錯誤
標記: build_file_semantics
--[no]experimental_check_desugar_deps 預設值:「true」
是否要再次檢查 Android 二進位檔層級的正確去糖化。
標記: eagerness_to_exitloading_and_analysisexperimental
--experimental_import_deps_checking=<a string> 預設值:請參閱說明
無操作,僅保留用於回溯相容性
標記: loading_and_analysis
--experimental_one_version_enforcement=<off, warning or error> 預設值:「OFF」
啟用後,系統會強制規定 java_binary 規則在 classpath 中不得包含同一個類別檔案的多個版本。這項強制執行措施可能會導致建構作業中斷,或只會產生警告。
標記: loading_and_analysis
--experimental_strict_java_deps=<off, warn, error, strict or default> 預設值:"default"
如果為 true,系統會檢查 Java 目標是否明確將所有直接使用的目標宣告為依附元件。
標記: build_file_semanticseagerness_to_exit
--[no]incompatible_check_testonly_for_output_files 預設值:「false」
如果啟用,請查詢產生規則的 testonly,檢查 testonly 是否為輸出檔案的必要條件目標。這項設定與可見度檢查相符。
標記: build_file_semanticsincompatible_change
--[no]incompatible_check_visibility_for_toolchains 預設值:「false」
如果已啟用,可視性檢查也會套用至工具鍊實作。
標記: build_file_semanticsincompatible_change
--[no]incompatible_disable_native_android_rules 預設值:「false」
如果啟用,系統就會停用原生 Android 規則的直接用法。請使用 https://github.com/bazelbuild/rules_android 中的 Starlark Android 規則
標記: eagerness_to_exitincompatible_change
--[no]incompatible_disable_native_apple_binary_rule 預設值:「false」
無操作。為回溯相容性而保留。
標記: eagerness_to_exitincompatible_change
--[no]incompatible_python_disable_py2 預設值:「true」
如果設為 True,使用 Python 2 設定會導致錯誤。包括 python_version=PY2、srcs_version=PY2 和 srcs_version=PY2ONLY。詳情請參閱 https://github.com/bazelbuild/bazel/issues/15684。
標記: loading_and_analysisincompatible_change
--[no]one_version_enforcement_on_java_tests 預設值:「true」
啟用此選項後,如果 experimental_one_version_enforcement 設為非 NONE 值,系統就會在 java_test 目標上強制執行一個版本。您可以停用這個標記,以便提升增量測試效能,但可能會錯過某個版本的違規項目。
標記: loading_and_analysis
--python_native_rules_allowlist=<a build target label> 預設值:請參閱說明
在強制執行 --incompatible_python_disallow_native_rules 時,要使用的許可清單 (package_group 目標)。
標記: loading_and_analysis
--[no]strict_filesets 預設值:「false」
如果啟用這個選項,系統會將跨越套件邊界的檔案集回報為錯誤。
標記: build_file_semanticseagerness_to_exit
--strict_proto_deps=<off, warn, error, strict or default> 預設值:「error」
除非設為 OFF,否則會檢查 proto_library 目標是否明確將所有直接使用的目標宣告為依附元件。
標記: build_file_semanticseagerness_to_exitincompatible_change
--strict_public_imports=<off, warn, error, strict or default> 預設值:「off」
除非設為 OFF,否則會檢查 proto_library 目標是否明確宣告在「import public」中使用的所有目標為匯出目標。
標記: build_file_semanticseagerness_to_exitincompatible_change
--[no]strict_system_includes 預設值:「false」
如果設為 true,則系統會透過系統包含路徑 (-isystem) 找到的標頭,也必須宣告。
標記: loading_and_analysiseagerness_to_exit
--target_environment=<a build target label> 累積多次使用
宣告此版本的目標環境。必須是「環境」規則的標籤參照。如果指定了這個環境,則所有頂層目標都必須與這個環境相容。
標記: changes_inputs
影響建構簽署輸出內容的選項:
--apk_signing_method=<v1, v2, v1_v2 or v4> 預設值:「v1_v2」
用於簽署 APK 的實作方式
標記: action_command_linesaffects_outputsloading_and_analysis
--[no]device_debug_entitlements 預設值:「true」
如果已設定,且編譯模式不是「opt」,則 objc 應用程式會在簽署時加入偵錯授權。
標記: changes_inputs
--ios_signing_cert_name=<a string> 預設值:請參閱說明
用於 iOS 簽署的憑證名稱。如果未設定,系統會改用佈建設定檔。根據 codesign 的 man 頁面 (SIGNING IDENTITIES),可能為憑證的鑰匙圈身分偏好設定或憑證的常用名稱 (子字串)。
標記: action_command_lines
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_disallow_legacy_py_provider 預設值:「true」
無操作,即將移除。
標記: loading_and_analysisincompatible_change
--[no]incompatible_disallow_sdk_frameworks_attributes 預設值:「false」
如果設為 true,就禁止在 objc_library 和 objc_import 中使用 sdk_frameworks 和 weak_sdk_frameworks 屬性。
標記: build_file_semanticsincompatible_change
如果為 true,請將 objc_library 和 objc_import 中的 alwayslink 屬性預設值設為 true。
標記: build_file_semanticsincompatible_change
--[no]incompatible_python_disallow_native_rules 預設值:「false」
如果為 True,使用內建的 py_* 規則時會發生錯誤;應改用 rule_python 規則。詳情請參閱 https://github.com/bazelbuild/bazel/issues/17773 瞭解遷移操作說明。
標記: loading_and_analysisincompatible_change
用於控管測試環境或測試執行工具行為的選項:
--[no]allow_analysis_failures 預設值:「false」
如果設為 true,規則目標的分析失敗會導致目標傳播包含錯誤說明的 AnalysisFailureInfo 例項,而不會導致建構失敗。
標記: loading_and_analysisexperimental
--analysis_testing_deps_limit=<an integer> 預設值:「2000」
透過規則屬性和 for_analysis_testing 設定轉換,設定遞移依附元件的數量上限。若超出這項限制,就會導致規則錯誤。
標記: loading_and_analysis
--[no]break_build_on_parallel_dex2oat_failure 預設值:「false」
如果為 true,則 dex2oat 動作失敗會導致建構作業中斷,而不會在測試執行階段執行 dex2oat。
標記: loading_and_analysisexperimental
--default_test_resources=<a resource name followed by equal and 1 float or 4 float, e.g memory=10,30,60,100> 累積多次使用
覆寫測試的預設資源量。預期格式為 <resource>=<value>。如果指定單一正整數做為 <value>,則會覆寫所有測試大小的預設資源。如果指定 4 個以逗號分隔的數字,這些數字會分別覆寫小、中、大、特大測試大小的資源數量。值也可以是 HOST_RAM/HOST_CPU,並可選擇加上 [-|*]<浮點> (例如 memory=HOST_RAM*.1,HOST_RAM*.2,HOST_RAM*.3,HOST_RAM*.4)。這個旗標指定的預設測試資源,會遭到標記中明確指定的資源覆寫。
--[no]experimental_android_use_parallel_dex2oat 預設值:「false」
並行使用 dex2oat,可能可加快 android_test 的速度。
標記: loading_and_analysishost_machine_resource_optimizationsexperimental
--[no]ios_memleaks 預設值:「false」
啟用 ios_test 目標的記憶體外洩檢查功能。
標記: action_command_lines
--ios_simulator_device=<a string> 預設值:請參閱說明
在模擬器中執行 iOS 應用程式時要模擬的裝置,例如「iPhone 6」。您可以在要執行模擬器的電腦上執行「xcrun simctl list devicetypes」取得裝置清單。
標記: test_runner
--ios_simulator_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
在執行或測試時,要在模擬器上執行的 iOS 版本。如果規則中指定了目標裝置,系統會忽略 ios_test 規則。
標記: test_runner
--runs_per_test=<a positive integer or test_regex@runs. This flag may be passed more than once> 累積多次使用
指定執行每項測試的次數。如果任何嘗試因任何原因失敗,整個測試就會視為失敗。通常指定的值只是整數。範例:--runs_per_test=3 會執行所有測試 3 次。其他語法:regex_filter@runs_per_test。其中 runs_per_test 代表整數值,而 regex_filter 代表包含和排除的規則運算式清單 (另請參閱 --instrumentation_filter)。範例:--runs_per_test=//foo/.*,-//foo/bar/.*@3 會執行 //foo/ 中的所有測試 (foo/bar 下的測試除外),共三次。這個選項可以多次傳遞。系統會優先採用最近傳遞且相符的引數。如果沒有任何相符項目,則只會執行一次測試。
--test_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定要插入測試執行器環境的其他環境變數。變數可以透過名稱指定,在這種情況下,系統會從 Bazel 用戶端環境讀取其值,也可以透過名稱=值組合指定。您可以多次使用此選項指定多個變數。僅供「bazel test」指令使用。
標記: test_runner
--test_timeout=<a single integer or comma-separated list of 4 integers> 預設值:「-1」
覆寫測試逾時的預設逾時值 (以秒為單位)。如果指定單一正整數值,系統會覆寫所有類別。如果指定 4 個以逗號分隔的整數,系統會覆寫短、中、長和永久 (依序) 的逾時時間。無論是哪種表單,如果值為 -1,blaze 就會使用該類別的預設逾時時間。
--[no]zip_undeclared_test_outputs 預設值:「false」
如果設為 true,系統會將未宣告的測試輸出內容封存為 ZIP 檔案。
標記: test_runner
觸發建構時間最佳化功能的選項:
--[no]experimental_filter_library_jar_with_program_jar 預設值:「false」
篩選 ProGuard ProgramJar,移除 LibraryJar 中也存在的任何類別。
標記: action_command_linesexperimental
--[no]experimental_inmemory_dotd_files 預設值:「true」
如果啟用此選項,C++ .d 檔案會直接從遠端建構節點傳遞至記憶體,而不會寫入磁碟。
標記: loading_and_analysisexecutionaffects_outputsexperimental
--[no]experimental_inmemory_jdeps_files 預設值:「true」
如果啟用此選項,系統會直接從遠端建構節點,透過記憶體傳遞從 Java 編譯產生的依附元件檔案 (.jdeps),而不會寫入磁碟。
標記: loading_and_analysisexecutionaffects_outputsexperimental
--[no]experimental_retain_test_configuration_across_testonly 預設值:「false」
啟用後,--trim_test_configuration 就不會為標示為 testonly=1 的規則裁減測試設定。這項功能旨在減少非測試規則依賴 cc_test 規則時的動作衝突問題。如果 --trim_test_configuration 為 false,就不會產生任何影響。
標記: loading_and_analysisloses_incremental_stateexperimental
--[no]experimental_starlark_cc_import 預設值:「false」
如果啟用,即可使用 Starlark 版本的 cc_import。
標記: loading_and_analysisexperimental
--[no]experimental_unsupported_and_brittle_include_scanning 預設值:「false」
是否要透過剖析輸入檔案中的 #include 行,將輸入內容縮減為 C/C++ 編譯。這可縮減編譯輸入樹狀結構的大小,進而提升效能和增量。不過,由於包含掃描器未完全實作 C 預處理器語意,因此也可能會導致建構作業中斷。具體來說,它無法瞭解動態 #include 指示,並會忽略預處理器條件邏輯。您必須自行承擔使用風險。我們會關閉與這個標記相關的所有已提交問題。
標記: loading_and_analysisexecutionchanges_inputsexperimental
--[no]incremental_dexing 預設值:「true」
針對每個 Jar 檔案分別執行大部分的解析工作。
標記: affects_outputsloading_and_analysisloses_incremental_state
--[no]objc_use_dotd_pruning 預設值:「true」
如果設定,系統會使用 Clang 產生的 .d 檔案,來修剪傳遞至 objc 編譯作業的輸入集合。
標記: changes_inputsloading_and_analysis
--[no]process_headers_in_dependencies 預設值:「false」
建構目標 //a:a 時,請處理 //a:a 依附的所有目標中的標頭 (如果工具鍊啟用了標頭處理功能)。
標記: execution
--[no]trim_test_configuration 預設值:「true」
啟用後,系統會清除版本頂層以下的測試相關選項。啟用此標記後,測試就無法建構為非測試規則的依附元件,但變更測試相關選項不會導致非測試規則重新分析。
標記: loading_and_analysisloses_incremental_state
影響記錄詳細程度、格式或位置的選項:
--toolchain_resolution_debug=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths> 預設值:「-.*」
在工具鍊解析期間列印偵錯資訊。這個標記會採用規則運算式,並根據工具鍊類型和特定目標進行檢查,以便查看要偵錯的目標。您可以使用逗號分隔多個規則運算式,然後分別檢查每個規則運算式。注意:這個標記的輸出內容非常複雜,可能只有工具鍊解析專家才會覺得實用。
標記: terminal_output
選項可指定或變更 Bazel 指令的一般輸入內容,而該輸入內容不屬於其他類別:
--flag_alias=<a 'name=value' flag alias> 累積多次使用
設定 Starlark 標記的簡寫名稱。它會將單一鍵/值組合 (格式為「<鍵>=<值>」) 做為引數。
標記: changes_inputs
--[no]incompatible_default_to_explicit_init_py 預設值:「false」
這個標記會變更預設行為,讓 __init__.py 檔案不再自動建立在 Python 目標的執行檔案中。具體來說,如果 py_binary 或 py_test 目標將 legacy_create_init 設為「auto」(預設值),則只有在設定此標記時,才會視為 false。請參閱 https://github.com/bazelbuild/bazel/issues/10076。
標記: affects_outputsincompatible_change
--[no]incompatible_py2_outputs_are_suffixed 預設值:「true」
如果設為 true,在 Python 2 設定中建構的目標會顯示在包含「-py2」字尾的輸出根目錄下,而為 Python 3 建構的目標則會顯示在沒有 Python 相關字尾的根目錄中。也就是說,`bazel-bin` 方便捷符號會指向 Python 3 目標,而非 Python 2。如果您啟用這個選項,建議也啟用 `--incompatible_py3_is_default`。
標記: affects_outputsincompatible_change
--[no]incompatible_py3_is_default 預設值:「true」
如果為 true,則未設定 `python_version` (或 `default_python_version`) 屬性的 `py_binary` 和 `py_test` 目標,預設會使用 PY3 而非 PY2。如果您設定這個旗標,建議也設定 `--incompatible_py2_outputs_are_suffixed`。
標記: loading_and_analysisaffects_outputsincompatible_change
--[no]incompatible_use_python_toolchains 預設值:「true」
如果設為 true,可執行的原生 Python 規則會使用 Python 工具鍊指定的 Python 執行階段,而非由 --python_top 等舊版標記提供的執行階段。
標記: loading_and_analysisincompatible_change
--python_version=<PY2 or PY3> 預設值:請參閱說明
Python 主要版本模式,可選為 `PY2` 或 `PY3`。請注意,這會由 `py_binary` 和 `py_test` 目標覆寫 (即使未明確指定版本),因此通常沒有提供這個旗標的必要。
標記: loading_and_analysisaffects_outputs
其他選項,不屬於其他類別:
--[no]cache_test_results [-t] 預設值:「auto」
如果設為「auto」,Bazel 只會在下列情況下重新執行測試:(1) Bazel 偵測到測試或其依附元件的變更、(2) 測試標示為外部、(3) 使用 --runs_per_test 要求執行多個測試,或(4) 測試先前失敗。如果設為「是」,Bazel 會快取所有測試結果,但標示為外部的測試除外。如果設為「no」,Bazel 就不會快取任何測試結果。
--[no]experimental_cancel_concurrent_tests 預設值:「false」
如果為 true,Blaze 會在第一次成功執行時取消同時執行的測試。只有在搭配 --runs_per_test_detects_flakes 時才有用。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_fetch_all_coverage_outputs 預設值:「false」
如果為 true,Bazel 就會在執行涵蓋率時,為每項測試擷取整個涵蓋率資料目錄。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_generate_llvm_lcov 預設值:「false」
如果設為 True,clang 的涵蓋率就會產生 LCOV 報表。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_j2objc_header_map 預設值:「true」
是否要在 J2ObjC 轉譯時並行產生 J2ObjC 標頭對應項目。
標記: experimental
--[no]experimental_j2objc_shorter_header_path 預設值:「false」
是否要使用較短的標頭路徑產生 (使用「_ios」而非「_j2objc」)。
標記: affects_outputsexperimental
--experimental_java_classpath=<off, javabuilder or bazel> 預設值:「javabuilder」
啟用 Java 編譯作業的縮減路徑集。
--[no]experimental_limit_android_lint_to_android_constrained_java 預設值:「false」
無操作,僅保留用於向後相容性
標記: affects_outputsexperimental
--[no]experimental_run_android_lint_on_java_rules 預設值:「false」
是否要驗證 java_* 來源。
標記: affects_outputsexperimental
--[no]explicit_java_test_deps 預設值:「false」
在 java_test 中明確指定對 JUnit 或 Hamcrest 的依附元件,而不是意外從 TestRunner 的 deps 取得。目前僅適用於 Bazel。
--host_java_launcher=<a build target label> 預設值:請參閱說明
在建構期間執行的工具所使用的 Java 啟動器。
--host_javacopt=<a string> 累積多次使用
建構在建構期間執行的工具時,要傳遞至 javac 的其他選項。
--host_jvmopt=<a string> 累積多次使用
建構期間執行的工具在建構時,傳遞至 Java VM 的其他選項。這些選項會新增至每個 java_binary 目標的 VM 啟動選項。
--[no]incompatible_check_sharding_support 預設值:「true」
如果為 true,如果測試執行程式未透過觸碰 TEST_SHARD_STATUS_FILE 路徑中的檔案,表示不支援分割,則 Bazel 會失敗執行分割測試。如果為 false,則不支援分割的測試執行程式會導致所有測試在每個分割區中執行。
標記: incompatible_change
--[no]incompatible_exclusive_test_sandboxed 預設值:「true」
如果為 true,系統會使用沙箱策略執行專屬測試。新增「local」標記,強制在本機上執行專屬測試
標記: incompatible_change
--[no]incompatible_strict_action_env 預設值:「false」
如果為 True,Bazel 會使用 PATH 的靜態值環境,且不會繼承 LD_LIBRARY_PATH。如果您想從用戶端繼承特定環境變數,請使用 --action_env=ENV_VARIABLE,但請注意,如果使用共用快取,這麼做可能會導致跨使用者快取無法使用。
標記: loading_and_analysisincompatible_change
--j2objc_translation_flags=<comma-separated list of options> 累積多次使用
傳遞至 J2ObjC 工具的其他選項。
--java_debug
讓 Java 測試的 Java 虛擬機器在開始測試前,等待符合 JDWP 標準的偵錯工具 (例如 jdb) 連線。暗示 -test_output=streamed。
展開為:
  --test_arg=--wrapper_script_flag=--debug
  --test_output=streamed
  --test_strategy=exclusive
  --test_timeout=9999
  --nocache_test_results
--[no]java_deps 預設值:「true」
針對每個 Java 目標產生依附元件資訊 (目前為編譯時間的類別路徑)。
--[no]java_header_compilation 預設值:「true」
直接從來源編譯 ijar。
--java_language_version=<a string> 預設值:""
Java 語言版本
--java_launcher=<a build target label> 預設值:請參閱說明
建構 Java 二進位檔時要使用的 Java 啟動器。如果這個標記設為空字串,系統就會使用 JDK 啟動器。「launcher」屬性會覆寫這個旗標。
--java_runtime_version=<a string> 預設值:「local_jdk」
Java 執行階段版本
--javacopt=<a string> 累積多次使用
傳遞至 javac 的其他選項。
--jvmopt=<a string> 累積多次使用
傳遞至 Java VM 的其他選項。這些選項會新增至每個 java_binary 目標的 VM 啟動選項。
--legacy_main_dex_list_generator=<a build target label> 預設值:請參閱說明
指定要使用的二進位檔,用於產生編譯舊版 Multidex 時,必須位於主 DEX 中的類別清單。
--optimizing_dexer=<a build target label> 預設值:請參閱說明
指定用於在不分割的情況下執行解析的二進位檔。
--plugin=<a build target label> 累積多次使用
在建構中使用的外掛程式。目前支援 java_plugin。
--proguard_top=<a build target label> 預設值:請參閱說明
指定建構 Java 二進位檔時,要使用哪個版本的 ProGuard 來移除程式碼。
--proto_compiler=<a build target label> 預設值:"@bazel_tools//tools/proto:protoc"
Proto 編譯器的標籤。
標記: affects_outputsloading_and_analysis
--[no]proto_profile 預設值:「true」
是否將 profile_path 傳遞至 proto 編譯器。
標記: affects_outputsloading_and_analysis
--proto_profile_path=<a build target label> 預設值:請參閱說明
要以 profile_path 形式傳遞至 Proto 編譯器的設定檔。如果未設定,但 --proto_profile 為 true (預設值),系統會從 --fdo_optimize 推斷路徑。
標記: affects_outputsloading_and_analysis
--proto_toolchain_for_cc=<a build target label> 預設值:"@bazel_tools//tools/proto:cc_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 C++ 原型檔
標記: affects_outputsloading_and_analysis
--proto_toolchain_for_j2objc=<a build target label> 預設值:"@bazel_tools//tools/j2objc:j2objc_proto_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 j2objc 原型檔
標籤: affects_outputsloading_and_analysis
--proto_toolchain_for_java=<a build target label> 預設值:"@bazel_tools//tools/proto:java_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 Java 原型檔
標記: affects_outputsloading_and_analysis
--proto_toolchain_for_javalite=<a build target label> 預設值:"@bazel_tools//tools/proto:javalite_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 JavaLite 原型檔
標記: affects_outputsloading_and_analysis
--protocopt=<a string> 累積多次使用
傳遞至 protobuf 編譯器的其他選項。
標記: affects_outputs
--[no]runs_per_test_detects_flakes 預設值:「false」
如果為 true,則任何具有至少一個成功執行/嘗試,以及至少一個失敗執行/嘗試的區塊,都會獲得「不穩定」狀態。
--shell_executable=<a path> 預設值:請參閱說明
Shell 可執行檔的絕對路徑,供 Bazel 使用。如果未設定此值,但在第一次呼叫 Bazel (啟動 Bazel 伺服器) 時已設定 BAZEL_SH 環境變數,Bazel 就會使用該值。如果未設定這兩者,Bazel 會根據執行的作業系統使用硬式編碼的預設路徑 (Windows:c:/msys64/usr/bin/bash.exe、FreeBSD:/usr/local/bin/bash、其他所有作業系統:/bin/bash)。請注意,使用與 bash 不相容的殼層,可能會導致產生的二進位檔發生建構失敗或執行階段失敗。
標記: loading_and_analysis
--test_arg=<a string> 累積多次使用
指定應傳遞至測試可執行檔的其他選項和引數。可多次使用,用於指定多個引數。如果執行多項測試,每項測試都會收到相同的引數。僅供「bazel test」指令使用。
--test_filter=<a string> 預設值:請參閱說明
指定要轉送至測試架構的篩選器。用於限制執行的測試。請注意,這不會影響要建構的目標。
--test_result_expiration=<an integer> 預設值:「-1」
這個選項已淘汰,不會產生任何作用。
--[no]test_runner_fail_fast 預設值:「false」
將快速失敗選項轉送至測試執行程式。測試執行程式應在第一次失敗時停止執行。
--test_sharding_strategy=<explicit, disabled or forced=k where k is the number of shards to enforce> 預設值:「explicit」
指定測試區塊劃分策略:如果有 'shard_count' BUILD 屬性,則只使用區塊劃分策略。如要一律不使用測試分割,請選擇「disabled」。使用「forced=k」強制執行「k」分片進行測試,無論「shard_count」BUILD 屬性為何都一樣。
--tool_java_language_version=<a string> 預設值:""
用於執行建構期間所需工具的 Java 語言版本
--tool_java_runtime_version=<a string> 預設值:「remotejdk_11」
在建構期間用來執行工具的 Java 執行階段版本
--[no]use_ijars 預設值:「true」
如果啟用此選項,Java 編譯作業就會使用介面 JAR 檔案。這會加快增量編譯作業,但錯誤訊息可能會有所不同。

建構選項

控制建構執行作業的選項:
--[no]check_up_to_date 預設值:「false」
請勿執行建構作業,只需檢查版本是否為最新版本即可。如果所有目標都已更新,建構作業就會順利完成。如果需要執行任何步驟,系統會回報錯誤,並導致建構作業失敗。
標記: execution
--dynamic_local_execution_delay=<an integer> 預設值:「1000」
如果在建構期間至少有一次遠端執行作業速度較快,本機執行作業應延遲多少毫秒?
標記: executionhost_machine_resource_optimizations
--dynamic_local_strategy=<a '[name=]value1[,..,valueN]' assignment> 累積多次使用
為指定助憶法使用的本機策略,依序列出,系統會使用第一個適用的策略。舉例來說,`worker,sandboxed` 會執行使用 worker 策略的永久 worker 支援動作,以及使用 sandboxed 策略的所有其他動作。如果未提供助憶法,系統會使用策略清單做為所有助憶法的備用選項。如果已設定 `experimental_local_lockfree_output`,預設的備用清單為`worker,sandboxed`,或 `worker,sandboxed,standalone`。接受 [mnemonic=]local_strategy[,local_strategy,...]
標記: executionhost_machine_resource_optimizations
--dynamic_remote_strategy=<a '[name=]value1[,..,valueN]' assignment> 累積多次使用
針對指定助憶法使用的遠端策略,依序列出。系統會使用第一個適用的策略。如果未提供助憶法,系統會使用策略清單做為所有助憶法的備用選項。預設的備用清單為 `remote`,因此通常不需要明確設定這個標記。接受 [mnemonic=]remote_strategy[,remote_strategy,...]
標記: executionhost_machine_resource_optimizations
--experimental_docker_image=<a string> 預設值:""
使用 Docker 策略時,如果動作本身在平台說明的 remote_execution_properties 中沒有容器映像檔屬性,請指定 Docker 映像檔名稱 (例如「ubuntu:latest」),以便執行沙箱動作。這個旗標的值會逐字傳遞至「docker run」,因此支援與 Docker 本身相同的語法和機制。
標記: execution
--[no]experimental_docker_use_customized_images 預設值:「true」
如果啟用,系統會在使用 Docker 映像檔前,將目前使用者的 uid 和 gid 插入 Docker 映像檔。如果您的建構 / 測試作業需要使用者在容器中擁有名稱和主目錄,則必須執行此操作。這項功能預設為開啟,但如果自動圖片自訂功能無法正常運作,或您不想使用這項功能,可以將其停用。
標記: execution
--[no]experimental_dynamic_exclude_tools 預設值:「true」
如果已設定,則建構「for tool」的目標就不會受到動態執行的影響。這類目標極不可能以漸進方式建構,因此不值得花費本機週期。
標記: executionhost_machine_resource_optimizations
--experimental_dynamic_local_load_factor=<a double> 預設值:「0」
控管動態執行作業的負載量,以便將其放到本機電腦上。這個標記會調整我們在動態執行作業中同時排定的動作數量。這項值取決於 Blaze 認為可用的 CPU 數量,您可以使用 --local_cpu_resources 標記控制這項值。如果此標記為 0,所有動作都會立即在本機排程。如果 > 0,本機排定的動作數量會受限於可用的 CPU 數量。如果 < 1,當等待排程的動作數量偏高時,系統會使用負載因子減少在本機排定的動作數量。這可在清除建構案例中減少本機電腦的負載,因為本機電腦不會提供太多貢獻。
標記: executionhost_machine_resource_optimizations
--experimental_dynamic_slow_remote_time=<An immutable length of time.> 預設值:「0」
如果 > 0,則動態執行動作必須先以遠端方式執行,我們才能將優先順序給予本地執行作業,以免發生遠端逾時。這可能會隱藏遠端執行系統的部分問題。請勿在未監控遠端執行問題的情況下開啟這項功能。
標記: executionhost_machine_resource_optimizations
--[no]experimental_enable_docker_sandbox 預設值:「false」
啟用 Docker 沙箱功能。如果未安裝 Docker,這個選項就不會發揮作用。
標記: execution
--[no]experimental_inmemory_sandbox_stashes 預設值:「false」
如果設為 true,系統會在記憶體中追蹤重用_sandbox_directories 的暫存沙箱內容。這樣可減少重複使用時所需的 I/O 數量。視建構作業而定,這個標記可能會改善實際時間。視版本而定,這個標記可能會使用大量額外記憶體。
標記: host_machine_resource_optimizationsexecution
--experimental_sandbox_async_tree_delete_idle_threads=<an integer, or a keyword ("auto", "HOST_CPUS", "HOST_RAM"), optionally followed by an operation ([-|*]<float>) eg. "auto", "HOST_CPUS*.5"> 預設值:「4」
如果為 0,系統會在動作完成後立即刪除沙箱樹狀結構 (導致動作完成時間延遲)。如果大於零,則在建構作業執行時,在大小為 1 的非同步執行緒集區中執行刪除此類三重項,並在伺服器閒置時,將大小增加至此旗標指定的大小。
標記: host_machine_resource_optimizationsexecution
--experimental_sandbox_enforce_resources_regexp=<a valid Java regular expression> 預設值:""
如果設為 true,則會將符號代碼與輸入的規則運算式相符的動作,以限制形式強制執行資源要求,並覆寫 --experimental_sandbox_limits 的值 (如果資源類型支援的話)。舉例來說,宣告 cpu:3 和 resources:memory:10 的測試,最多會使用 3 個 CPU 和 10 MB 的記憶體。
標記: execution
--experimental_sandbox_limits=<a named double, 'name=value', where value is an integer, or a keyword ("auto", "HOST_CPUS", "HOST_RAM"), optionally followed by an operation ([-|*]<float>) eg. "auto", "HOST_CPUS*.5"> 累積多次使用
如果大於 0,則每個 Linux 沙箱都會受到指定資源的指定限制。需要使用 --incompatible_use_new_cgroup_implementation,並覆寫 --experimental_sandbox_memory_limit_mb。需要 cgroups v1 或 v2,以及使用者對 cgroups 目錄的權限。
標記: execution
--experimental_sandbox_memory_limit_mb=<an integer number of MBs, or "HOST_RAM", optionally followed by [-|*]<float>.> 預設值:「0」
如果 > 0,則每個 Linux 沙箱都會受到指定記憶體容量 (以 MB 為單位) 的限制。需要 cgroups v1 或 v2,以及使用者對 cgroups 目錄的權限。
標記: execution
--[no]experimental_shrink_worker_pool 預設值:「false」
如果啟用,當工作站記憶體壓力過高時,可能會縮小工作站集區。這個旗標只有在啟用 experimental_total_worker_memory_limit_mb 旗標時才會生效。
標記: executionhost_machine_resource_optimizations
--[no]experimental_split_xml_generation 預設值:「true」
如果設定了這個標記,且測試動作未產生 test.xml 檔案,則 Bazel 會使用另一個動作產生包含測試記錄的虛擬 test.xml 檔案。否則,Bazel 會產生 test.xml 做為測試動作的一部分。
標記: execution
--experimental_total_worker_memory_limit_mb=<an integer number of MBs, or "HOST_RAM", optionally followed by [-|*]<float>.> 預設值:「0」
如果這個限制大於零,當所有 worker 的記憶體用量總和超過限制時,系統可能會終止閒置 worker。
標記: executionhost_machine_resource_optimizations
--[no]experimental_use_hermetic_linux_sandbox 預設值:「false」
如果設為 true,請勿掛載根目錄,只掛載 sandbox_add_mount_pair 提供的內容。輸入檔案會硬連結至沙箱,而非從沙箱建立符號連結。如果動作輸入檔案位於與沙箱不同的檔案系統,系統會改為複製輸入檔案。
標記: execution
--[no]experimental_use_semaphore_for_jobs 預設值:「true」
如果設為 true,請另外使用信號量來限制並行工作的數量。
標記: host_machine_resource_optimizationsexecution
--[no]experimental_use_windows_sandbox 預設值:「false」
使用 Windows 沙箱執行動作。如果為「是」,則 --experimental_windows_sandbox_path 提供的二進位檔必須有效,且對應至支援的 sandboxfs 版本。如果是「auto」,則二進位檔可能遺失或不相容。
標記: execution
--experimental_windows_sandbox_path=<a string> 預設值:「BazelSandbox.exe」
--experimental_use_windows_sandbox 為 true 時,要使用的 Windows 沙箱二進位檔路徑。如果是裸名,請使用 PATH 中找到的第一個同名二進位檔。
標記: execution
--experimental_worker_allowlist=<comma-separated set of options> 預設值:請參閱說明
如果不為空白,則只允許使用指定工作站索引鍵的持久性工作站。
標記: executionhost_machine_resource_optimizations
--[no]experimental_worker_cancellation 預設值:「false」
如果啟用,Bazel 可能會向支援的 worker 傳送取消要求。
標記: execution
--experimental_worker_memory_limit_mb=<an integer number of MBs, or "HOST_RAM", optionally followed by [-|*]<float>.> 預設值:「0」
如果此限制大於零,當工作站的記憶體用量超過限制時,系統可能會終止工作站。如果未與動態執行和 `--experimental_dynamic_ignore_local_signals=9` 搭配使用,這可能會導致建構作業異常終止。
標記: executionhost_machine_resource_optimizations
--experimental_worker_metrics_poll_interval=<An immutable length of time.> 預設值:「5 秒」
收集 worker 指標與嘗試淘汰之間的間隔。基於效能考量,實際上不得少於 1 秒。
標記: executionhost_machine_resource_optimizations
--[no]experimental_worker_multiplex_sandboxing 預設值:「false」
如果啟用此選項,具有「supports-multiplex-sandboxing」執行需求的多重工作人員就會在沙盒環境中執行,並為每個工作要求使用個別的沙盒目錄。無論是否設定此標記,在動態執行策略下執行時,具有執行要求的多重工作項一律會處於沙箱中。
標記: execution
--[no]experimental_worker_sandbox_hardening 預設值:「false」
如果啟用這項功能,系統會在實作允許的情況下,在強化的沙箱中執行 worker。如果啟用強化功能,則不同 worker 的 tmp 目錄會有所不同。
標記: execution
--experimental_worker_sandbox_inmemory_tracking=<a string> 累積多次使用
工作站金鑰助憶法,Sandbox 目錄的內容會在記憶體中追蹤。這可能會改善建構效能,但會增加記憶體用量。只會影響沙箱 worker。可為不同的助憶法指定多次。
標記: execution
--[no]experimental_worker_strict_flagfiles 預設值:「false」
如果啟用這項功能,如果 worker 的動作引數不符合 worker 規格,就會發生錯誤。工作站引數必須有一個 @flagfile 引數,做為引數清單的最後一個引數。
標記: execution
--genrule_strategy=<comma-separated list of options> 預設值:""
指定執行 genrules 的方式。這個標記將逐步淘汰。請改用 --spawn_strategy=<value> 來控制所有動作,或使用 --strategy=Genrule=<value> 只控制 genrule。
標記: execution
--[no]incompatible_sandbox_hermetic_tmp 預設值:「true」
如果設為 true,每個 Linux 沙箱都會有專屬的空目錄,並掛載為 /tmp,而不是與主機檔案系統共用 /tmp。使用 --sandbox_add_mount_pair=/tmp 可在所有沙箱中繼續查看主機的 /tmp。
標記: execution
--[no]incompatible_use_new_cgroup_implementation 預設值:「false」
如果為 true,請使用新的 cgroups 實作。舊版實作方式僅支援記憶體控制器,並忽略 --experimental_sandbox_limits 的值。
標記: execution
--[no]internal_spawn_scheduler 預設值:「true」
預留位置選項,以便我們在 Blaze 中判斷是否已啟用產生調度器。
標記: executionhost_machine_resource_optimizations
--jobs=<an integer, or a keyword ("auto", "HOST_CPUS", "HOST_RAM"), optionally followed by an operation ([-|*]<float>) eg. "auto", "HOST_CPUS*.5"> [-j] 預設值:「auto」
要執行的並行工作數量。可接受整數或關鍵字 (「auto」、「HOST_CPUS」、「HOST_RAM」),後面可選擇加上運算符號 ([-|*]<浮點>),例如「auto」、「HOST_CPUS*.5」等。值必須介於 1 至 5000 之間。值超過 2500 可能會導致記憶體問題。「auto」會根據主機資源計算合理的預設值。
標記: host_machine_resource_optimizationsexecution
--[no]keep_going [-k] 預設值:「false」
盡可能在發生錯誤後繼續執行。雖然無法分析失敗的目標和依附於該目標的其他目標,但可以分析這些目標的其他必要條件。
標記: eagerness_to_exit
--loading_phase_threads=<an integer, or a keyword ("auto", "HOST_CPUS", "HOST_RAM"), optionally followed by an operation ([-|*]<float>) eg. "auto", "HOST_CPUS*.5"> 預設值:「auto」
在載入/分析階段要使用的平行執行緒數量。可接受整數或關鍵字 (「auto」、「HOST_CPUS」、「HOST_RAM」),並可選擇加上運算符號 ([-|*]<float>),例如 「auto」、「HOST_CPUS*.5」等。「auto」會根據主機資源設定合理的預設值。不得小於 1。
標記: bazel_internal_configuration
--[no]reuse_sandbox_directories 預設值:「true」
如果設為 true,沙箱非 worker 執行作業所使用的目錄可能會重複使用,以避免不必要的設定成本。
標記: host_machine_resource_optimizationsexecution
--sandbox_base=<a string> 預設值:""
讓沙箱在這個路徑下建立沙箱目錄。在 tmpfs (例如 /run/shm) 上指定路徑,可能會在建構 / 測試包含許多輸入檔案時,大幅提升效能。注意:您需要在 tmpfs 中保留足夠的 RAM 和可用空間,才能容納執行動作所產生的輸出和中繼檔案。
標記: host_machine_resource_optimizationsexecution
--[no]sandbox_explicit_pseudoterminal 預設值:「false」
明確啟用為沙箱動作建立偽終端機的功能。部分 Linux 發行版本需要在沙箱中將程序的群組 ID 設為「tty」,才能讓擬端運作。如果這會導致問題,您可以停用這個標記,以便使用其他群組。
標記: execution
--sandbox_tmpfs_path=<an absolute path> 累積多次使用
對於沙箱動作,請在這個絕對路徑中掛接可寫入的空目錄 (如果沙箱實作支援,否則會忽略)。
標記: host_machine_resource_optimizationsexecution
--[no]skip_incompatible_explicit_targets 預設值:「false」
略過指令列中明確列出的不相容目標。根據預設,建構這類目標會導致錯誤,但啟用此選項時,系統會自動略過這些目標。請參閱:https://bazel.build/extending/platforms#skipping-incompatible-targets
標記: loading_and_analysis
--spawn_strategy=<comma-separated list of options> 預設值:""
指定產生動作的預設執行方式。接受以半形逗號分隔的策略清單,優先順序由高至低。針對每個動作,Bazel 會挑選優先順序最高的策略,以便執行該動作。預設值為「remote,worker,sandboxed,local」。詳情請參閱 https://blog.bazel.build/2019/06/19/list-strategy.html。
標記: execution
--strategy=<a '[name=]value1[,..,valueN]' assignment> 累積多次使用
指定如何分發其他產生動作的編譯作業。接受以半形逗號分隔的策略清單,優先順序由高至低。針對每個動作,Bazel 會挑選優先順序最高的策略,以便執行該動作。預設值為「remote,worker,sandboxed,local」。這個標記會覆寫 --spawn_strategy 設定的值 (如果與 Genrule 助憶法一起使用,則會覆寫 --genrule_strategy 設定的值)。詳情請參閱 https://blog.bazel.build/2019/06/19/list-strategy.html。
標記: execution
--strategy_regexp=<a '<RegexFilter>=value[,value]' assignment> 累積多次使用
覆寫應使用哪種產生策略,執行說明與特定 regex_filter 相符的產生動作。如要進一步瞭解 regex_filter 比對功能,請參閱 --per_file_copt。系統會使用與說明相符的最後一個 regex_filter。這個選項會覆寫其他用於指定策略的旗標。範例:--strategy_regexp=//foo.*\.cc,-//foo/bar=local 表示如果動作的說明與 //foo.*.cc 相符,但與 //foo/bar 不相符,則使用本機策略執行動作。範例:--strategy_regexp=Compiling.*/bar=local --strategy_regexp=Compiling=sandboxed 會以「local」策略執行「Compiling //foo/bar/baz」,但反轉順序則會以「sandboxed」策略執行。
標記: execution
--worker_extra_flag=<a 'name=value' assignment> 累積多次使用
除了 --persistent_worker 之外,會傳遞至 worker 程序的額外指令標記,以助憶法為索引 (例如 --worker_extra_flag=Javac=--debug)。
標記: executionhost_machine_resource_optimizations
--worker_max_instances=<[name=]value, where value is an integer, or a keyword ("auto", "HOST_CPUS", "HOST_RAM"), optionally followed by an operation ([-|*]<float>) eg. "auto", "HOST_CPUS*.5"> 累積多次使用
如果您使用「worker」策略,每種永久工作站的執行個體數量。可指定為 [name=value],為每個助憶法提供不同的值。限制取決於 worker 鍵,這些鍵會根據助憶法和啟動旗標和環境進行區分,因此在某些情況下,每個助憶法可能會有比此旗標指定的更多 worker。可接受整數或關鍵字 (「auto」、「HOST_CPUS」、「HOST_RAM」),後面可選擇加上運算符號 ([-|*]<浮點>),例如「auto」、「HOST_CPUS*.5」等。系統會根據機器容量計算「自動」的合理預設值。「=value」會為未指定的助憶法設定預設值。
標記: executionhost_machine_resource_optimizations
--worker_max_multiplex_instances=<[name=]value, where value is an integer, or a keyword ("auto", "HOST_CPUS", "HOST_RAM"), optionally followed by an operation ([-|*]<float>) eg. "auto", "HOST_CPUS*.5"> 累積多次使用
如果您使用「worker」策略搭配 --worker_multiplex,多工序工作站程序可能會並行收到多少個 WorkRequest?可指定為 [name=value],為每個助憶法提供不同的值。限制取決於 worker 鍵,這些鍵會根據助憶法和啟動旗標和環境進行區分,因此在某些情況下,每個助憶法可能會有比此旗標指定的更多 worker。可接受整數或關鍵字 (「auto」、「HOST_CPUS」、「HOST_RAM」),後面可選擇加上運算符號 ([-|*]<浮點>),例如「auto」、「HOST_CPUS*.5」等。系統會根據機器容量計算「自動」的合理預設值。「=value」會為未指定的助憶法設定預設值。
標記: executionhost_machine_resource_optimizations
--[no]worker_multiplex 預設值:「true」
如果啟用,工作站會在支援時使用多重處理。
標記: executionhost_machine_resource_optimizations
--[no]worker_quit_after_build 預設值:「false」
如果啟用,則在建構完成後,所有 worker 都會結束。
標記: executionhost_machine_resource_optimizations
--[no]worker_sandboxing 預設值:「false」
如果啟用這項功能,單一工作站會在沙箱環境中執行。無論是否設定此標記,在動態執行策略下執行時,Singleplex 工作者一律會處於沙箱中。
標記: execution
--[no]worker_verbose 預設值:「false」
如果啟用,在 worker 啟動、關閉時會顯示詳細訊息。
控制指令輸出的選項:
--[no]build 預設值:「true」
執行建構作業,這是一般行為。指定 --nobuild 會在執行建構動作前停止建構,並在套件載入和分析階段成功完成時傳回零;這個模式可用於測試這些階段。
標記: executionaffects_outputs
--[no]experimental_use_validation_aspect 預設值:「false」
是否要使用切面執行驗證動作 (以便與測試並行)。
標記: executionaffects_outputs
--output_groups=<comma-separated list of options> 累積多次使用
以半形逗號分隔的輸出群組名稱清單,每個名稱的前置字串可選為 + 或 -。前置字串為 + 的群組會加入預設的輸出群組集,而前置字串為 - 的群組會從預設集中移除。如果至少有一個群組未加上前置字串,則會略過預設的輸出群組組合。舉例來說,--output_groups=+foo,+bar 會建構預設集合 foo 和 bar 的聯集,而 --output_groups=foo,bar 會覆寫預設集合,只建構 foo 和 bar。
標記: executionaffects_outputs
--[no]run_validations 預設值:「true」
是否要在建構期間執行驗證動作。請參閱 https://bazel.build/extending/rules#validation_actions
標記: executionaffects_outputs
--serialized_frontier_profile=<a string> 預設值:""
傾印序列化邊界位元組的設定檔。指定輸出路徑。
代碼: bazel_monitoring
讓使用者設定預期輸出內容的選項,影響其值,而非其存在:
--aspects=<comma-separated list of options> 累積多次使用
以逗號分隔的清單,列出要套用至頂層目標的面向。如果清單中的某個層面 (some_aspect) 透過 required_aspect_providers 指定必要的層面供應商,則系統會在清單中先前提到的每個層面 (如果廣告供應商符合某個層面的必要層面供應商) 之後執行某個層面。此外,some_aspect 會在所有由 requires 屬性指定的必要面向執行後執行。接著,some_aspect 就能存取這些面向提供者的值。<bzl-file-label>%<aspect_name>,例如 '//tools:my_def.bzl%my_aspect',其中 'my_aspect' 是檔案 tools/my_def.bzl 中的頂層值
--bep_maximum_open_remote_upload_files=<an integer> 預設值:「-1」
BEP 構件上傳期間允許開啟的檔案數量上限。
標記: affects_outputs
這個標記可控管便利快捷連結 (在建構後顯示於工作區中的快捷連結) 的管理方式。可能的值: normal (預設):系統會根據建構作業決定是否建立或刪除每種便利捷連結。clean:系統會無條件刪除所有符號連結。ignore:系統不會建立或清除符號連結。log_only:產生記錄訊息,就像「正常」傳遞一樣,但實際上不會執行任何檔案系統作業 (適用於工具)。請注意,只有名稱是由 --symlink_prefix 目前值產生的符號連結會受到影響;如果前置字串變更,則任何現有的符號連結都不會受到影響。
標記: affects_outputs
這個標記可控制是否要將已識別的事件「eventConvenienceSymlinks」發布至 BuildEventProtocol。如果值為 true,BuildEventProtocol 就會包含方便性符號連結已識別的項目,列出工作區中建立的所有方便性符號連結。如果為 false,BuildEventProtocol 中的 convenienceSymlinksIdentified 項目會為空白。
標記: affects_outputs
--remote_download_all
將所有遠端輸出內容下載至本機。這個標記是 --remote_download_outputs=all 的別名。
展開為:
  --remote_download_outputs=all

標記: affects_outputs
--remote_download_minimal
不會將任何遠端建構輸出內容下載到本機。這個旗標是 --remote_download_outputs=minimal 的別名。
展開為:
  --remote_download_outputs=minimal

標記: affects_outputs
--remote_download_outputs=<all, minimal or toplevel> 預設值:「toplevel」
如果設為「最小」,則不會將任何遠端建構輸出內容下載到本機電腦,但本機動作所需的輸出內容除外。如果設為「toplevel」,則會像「minimal」一樣運作,但會將頂層目標的輸出內容下載到本機。如果網路頻寬是瓶頸,這兩種做法都能大幅縮短建構時間。
標記: affects_outputs
請勿將遠端建構輸出內容下載到本機電腦,而是建立符號連結。符號連結的目標可以使用範本字串的形式指定。這個範本字串可能包含 {hash} 和 {size_bytes},分別會展開為物件的雜湊和以位元組為單位的大小。例如,這些符號連結可能會指向 FUSE 檔案系統,該系統會視需要從 CAS 載入物件。
標記: affects_outputs
--remote_download_toplevel
只會將頂層目標的遠端輸出內容下載到本機。這個旗標是 --remote_download_outputs=toplevel 的別名。
展開為:
  --remote_download_outputs=toplevel

標記: affects_outputs
在建構後建立的任何便利捷徑前方加上的前置字串。如果省略此欄位,預設值為建構工具名稱,後面加上連字號。如果傳遞「/」,系統就不會建立符號連結,也不會發出警告。警告:'/' 的特殊功能即將淘汰,請改用 --experimental_convenience_symlinks=ignore。
標記: affects_outputs
影響 Bazel 如何嚴格執行有效建構輸入內容 (規則定義、標記組合等) 的選項:
--[no]experimental_docker_privileged 預設值:「false」
如果啟用,Bazel 會在執行動作時,將 --privileged 標記傳遞至「docker run」。您的建構作業可能需要這麼做,但這也可能導致密封性降低。
標記: execution
無操作
標記: host_machine_resource_optimizationsexecution
--[no]incompatible_legacy_local_fallback 預設值:「false」
如果設為 true,則會啟用從沙箱到本機策略的舊版隱含備用機制。這個標記最終會預設為 false,然後變成無操作。請改用 --strategy、--spawn_strategy 或 --dynamic_local_strategy 設定備用方案。
標記: executionincompatible_change
--sandbox_add_mount_pair=<a single path or a 'source:target' pair> 累積多次使用
新增其他路徑組合,以便在沙箱中掛載。
標記: execution
--sandbox_block_path=<a string> 累積多次使用
如果是沙箱動作,請禁止存取這個路徑。
標記: execution
--[no]sandbox_default_allow_network 預設值:「true」
根據預設,允許動作使用網路存取權;這項設定可能不適用於所有沙箱實作。
標記: execution
--[no]sandbox_fake_hostname 預設值:「false」
如果是沙箱動作,請將目前的主機名稱變更為「localhost」。
標記: execution
--[no]sandbox_fake_username 預設值:「false」
如要使用沙箱動作,請將目前的使用者名稱變更為「nobody」。
標記: execution
--sandbox_writable_path=<a string> 累積多次使用
針對沙箱動作,讓現有目錄可在沙箱中寫入 (如果沙箱實作支援,否則會忽略)。
標記: execution
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_config_setting_private_default_visibility 預設值:「false」
如果 incompatible_enforce_config_setting_visibility=false,則此方法不會執行任何操作。否則,如果這個標記為 false,則任何沒有明確顯示屬性的 config_setting 都是 //visibility:public。如果這個標記設為 True,config_setting 就會遵循與所有其他規則相同的瀏覽權限邏輯。請參閱 https://github.com/bazelbuild/bazel/issues/12933。
標記: loading_and_analysisincompatible_change
--[no]incompatible_enforce_config_setting_visibility 預設值:「true」
如果設為 true,系統就會強制執行 config_setting 曝光度限制。如果為 false,則每個目標都能看到每個 config_setting。請參閱 https://github.com/bazelbuild/bazel/issues/12932。
標記: loading_and_analysisincompatible_change
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
標記: loading_and_analysis
用於控制測試環境或測試執行工具行為的選項:
--[no]check_tests_up_to_date 預設值:「false」
不要執行測試,只需檢查測試是否為最新版本。如果所有測試結果都已更新,表示測試已順利完成。如果需要建構或執行任何測試,系統會回報錯誤,且測試會失敗。這個選項會暗示 --check_up_to_date 行為。
標記: execution
--flaky_test_attempts=<a positive integer, the string "default", or test_regex@attempts. This flag may be passed more than once> 累積多次使用
如果任何測試失敗,系統會重試各項測試,最多重試指定次數。測試摘要中,需要多次嘗試才能通過的測試會標示為「FLAKY」。通常指定的值只是整數或字串「default」。如果是整數,則會執行最多 N 次的所有測試。如果是「預設」,則系統只會為一般測試執行一次測試,而為規則明確標示為不穩定的測試執行三次測試 (flaky=1 屬性)。其他語法:regex_filter@flaky_test_attempts。其中 flaky_test_attempts 的用法如上所述,而 regex_filter 代表包含和排除的規則運算式模式清單 (另請參閱 --runs_per_test)。範例:--flaky_test_attempts=//foo/.*,-//foo/bar/.*@3 會將 //foo/ 中的所有測試 (foo/bar 底下的測試除外) 重複執行三次,以便排除問題。這個選項可以多次傳遞。系統會優先採用最近傳遞且相符的引數。如果沒有任何相符項目,行為就會如上述的「預設」一樣。
標記: execution
--local_test_jobs=<an integer, or a keyword ("auto", "HOST_CPUS", "HOST_RAM"), optionally followed by an operation ([-|*]<float>) eg. "auto", "HOST_CPUS*.5"> 預設值:「auto」
同時執行的本機測試工作數量上限。可接受整數或關鍵字 (「auto」、「HOST_CPUS」、「HOST_RAM」),後面可選擇加上運算符號 ([-|*]<浮點>),例如「auto」、「HOST_CPUS*.5」等。0 表示本機資源會限制同時執行的本機測試工作數量。如果將這個值設為大於 --jobs 的值,則不會生效。
標記: execution
--[no]test_keep_going 預設值:「true」
如果停用這項設定,任何未通過的測試都會導致整個建構作業停止。根據預設,即使部分測試未通過,系統也會執行所有測試。
標記: execution
--test_strategy=<a string> 預設值:""
指定執行測試時要使用的策略。
標記: execution
--test_tmpdir=<a path> 預設值:請參閱說明
指定「bazel test」要使用的基礎暫時目錄。
觸發建構時間最佳化選項:
--cache_computed_file_digests=<a long integer> 預設值:「50000」
如果大於 0,則會將 Bazel 設為根據中繼資料在記憶體中快取檔案摘要,而非每次需要時都從磁碟重新計算摘要。將此值設為 0 可確保正確性,因為並非所有檔案變更都能從檔案中繼資料中記錄。如果不是 0,這個數字代表快取的大小,也就是要快取的檔案摘要數量。
--[no]experimental_cpu_load_scheduling 預設值:「false」
啟用根據 CPU 負載而非逐一估算動作的實驗性本機執行排程。實驗性排程顯示,在擁有大量核心的強大機器上進行大型本機建構作業,可帶來極大效益。建議搭配使用 --local_resources=cpu=HOST_CPUS
標記: execution
--experimental_dynamic_ignore_local_signals=<a comma-separated list of signal numbers> 預設值:請參閱說明
會接受 OS 信號號碼清單。如果動態執行的本機分支因任何信號而終止,系統會改為允許遠端分支完成。對於持續性工作者,這只會影響終止 worker 程序的信號。
標記: execution
--[no]experimental_enable_skyfocus 預設值:「false」
如果設為 true,系統會啟用 --experimental_working_set,以減少 Bazel 在增量建構作業中的記憶體占用空間。這項功能稱為 Skyfocus。
標記: host_machine_resource_optimizations
--experimental_working_set=<comma-separated list of options> 預設值:""
Skyfocus 的工作組。以半形逗號分隔的工作區根目錄相對於路徑指定。這是具狀態的旗標。定義工作集後,系統會將其保留供後續叫用,直到使用新集合重新定義為止。
標記: host_machine_resource_optimizations
--local_cpu_resources=<an integer, or "HOST_CPUS", optionally followed by [-|*]<float>.> 預設值:「HOST_CPUS」
明確設定 Bazel 可用於在本機執行建構動作的本機 CPU 核心總數。會接收整數或「HOST_CPUS」,後面可選擇接收 [-|*]<浮點數> (例如 HOST_CPUS*.5 可使用可用 CPU 核心的一半。根據預設 (「HOST_CPUS」),Bazel 會查詢系統設定,以估算可用的 CPU 核心數量。
標記: host_machine_resource_optimizations
--local_extra_resources=<a named float, 'name=value'> 累積多次使用
設定 Bazel 可用的額外資源數量。會擷取字串-浮點值組合。可多次使用,用於指定多種額外資源。Bazel 會根據可用的額外資源和所需額外資源,限制同時執行的動作數量。測試可以使用「resources:<resoucename>:<amount>」格式的標記,宣告所需的額外資源數量。您無法使用這個標記設定可用的 CPU、RAM 和資源。
標記: host_machine_resource_optimizations
--local_ram_resources=<an integer number of MBs, or "HOST_RAM", optionally followed by [-|*]<float>.> 預設值:「HOST_RAM*.67」
明確設定 Bazel 可用於在本機執行建構動作的本機主機 RAM 總量 (以 MB 為單位)。可接受整數或「HOST_RAM」,並可選擇後接 [-|*]<浮點數> (例如 HOST_RAM*.5 可使用可用 RAM 的一半。根據預設 (「HOST_RAM*.67」),Bazel 會查詢系統設定,估算可用的 RAM 容量,並使用其中的 67%。
標記: host_machine_resource_optimizations
--local_resources=<a named double, 'name=value', where value is an integer, or a keyword ("auto", "HOST_CPUS", "HOST_RAM"), optionally followed by an operation ([-|*]<float>) eg. "auto", "HOST_CPUS*.5"> 累積多次使用
設定 Bazel 可用的資源數量。將指派值傳遞至浮點值或 HOST_RAM/HOST_CPUS,並可選擇接續 [-|*]<浮點值> (例如 memory=HOST_RAM*.5 可使用一半的 RAM)。可多次使用,用於指定多種資源類型。Bazel 會根據可用的資源和所需資源,限制同時執行的動作數量。測試可以使用「resources:<resource name>:<amount>」格式的標記,宣告所需的資源數量。覆寫由 --local_{cpu|ram|extra}_resources 指定的資源。
標記: host_machine_resource_optimizations
影響記錄詳細程度、格式或位置的選項:
--build_event_upload_max_retries=<an integer> 預設值:「4」
Bazel 重試上傳建構事件的次數上限。
標記: bazel_internal_configuration
--[no]debug_spawn_scheduler 預設值:「false」
--[no]experimental_bep_target_summary 預設值:「false」
是否要發布 TargetSummary 事件。
--[no]experimental_build_event_expand_filesets 預設值:「false」
如果為 true,則在呈現輸出檔案時,會在 BEP 中展開 Fileset。
標記: affects_outputs
如果設為 true,在呈現輸出檔案時,BEP 會完全解析相對檔案集符號連結。需要使用 --experimental_build_event_expand_filesets。
標記: affects_outputs
--experimental_build_event_output_group_mode=<an output group name followed by an OutputGroupFileMode, e.g. default=both> 累積多次使用
指定輸出群組的檔案在 TargetComplete/AspectComplete BEP 事件中如何顯示。值是將輸出群組名稱指派給「NAMED_SET_OF_FILES_ONLY」、「INLINE_ONLY」或「BOTH」其中一個。預設值為「NAMED_SET_OF_FILES_ONLY」。如果重複輸出群組,系統會使用最後顯示的值。預設值會將涵蓋率構件模式設為「BOTH」:--experimental_build_event_output_group_mode=baseline.lcov=both
標記: affects_outputs
--experimental_build_event_upload_retry_minimum_delay=<An immutable length of time.> 預設值:「1 秒」
BEP 上傳失敗時,指數輪詢重試的初始最小延遲時間。(指數:1.6)
標記: bazel_internal_configuration
--experimental_build_event_upload_strategy=<a string> 預設值:請參閱說明
選取如何上傳在建構事件通訊協定中參照的構件。在 Bazel 中,有效的選項包括「local」和「remote」。預設值為「local」。
標記: affects_outputs
--[no]experimental_docker_verbose 預設值:「false」
如果啟用,Bazel 會列印更多有關 Docker 沙箱策略的詳細訊息。
標記: execution
--[no]experimental_materialize_param_files_directly 預設值:「false」
如果要實體化參數檔案,請直接寫入磁碟。
標記: execution
--experimental_repository_resolved_file=<a string> 預設值:""
如果不為空白,請寫入 Starlark 值,其中包含已執行的所有 Starlark 存放區規則的解析資訊。
標記: affects_outputs
--[no]experimental_run_bep_event_include_residue 預設值:「false」
是否要在可能包含殘留內容的執行建構事件中加入指令列殘留內容。根據預設,執行指令的建構事件不會包含殘留物。
標記: affects_outputs
--experimental_skyfocus_dump_keys=<none, count or verbose> 預設值:「none」
用於 Skyfocus 偵錯。傾印已聚焦的 SkyKeys (根、葉、已聚焦的依附元件、已聚焦的 rdeps)。
標記: terminal_output
--[no]experimental_skyfocus_dump_post_gc_stats 預設值:「false」
用於 Skyfocus 偵錯。如果啟用,系統會在聚焦前/後觸發手動 GC,以便回報堆積大小的減少情形。這會增加 Skyfocus 延遲時間。
標記: terminal_output
--experimental_skyfocus_handling_strategy=<strict or warn> 預設值:「strict」
Skyfocus 處理工作集以外變更的策略。
標記: eagerness_to_exit
--[no]experimental_stream_log_file_uploads 預設值:「false」
直接將記錄檔案串流上傳至遠端儲存空間,而非寫入磁碟。
標記: affects_outputs
--explain=<a path> 預設值:請參閱說明
會讓建構系統說明建構作業的每個執行步驟。說明會寫入指定的記錄檔案。
標記: affects_outputs
--[no]ignore_unsupported_sandboxing 預設值:「false」
如果系統不支援沙箱執行作業,則不要顯示警告。
標記: terminal_output
--[no]legacy_important_outputs 預設值:「false」
使用此選項可在 TargetComplete 事件中抑制產生舊版 important_outputs 欄位。如果要將 Bazel 與 ResultStore/BTX 整合,就必須使用 important_outputs。
標記: affects_outputs
--[no]materialize_param_files 預設值:「false」
即使使用遠端動作執行作業,也會將中繼參數檔案寫入輸出樹狀結構。在除錯動作時相當實用。這可透過 --subcommands 和 --verbose_failures 推斷。
標記: execution
--max_config_changes_to_show=<an integer> 預設值:「3」
當建構選項發生變更而捨棄分析快取時,最多會顯示指定數量的變更選項名稱。如果指定的數字為 -1,系統會顯示所有變更的選項。
標記: terminal_output
--max_test_output_bytes=<an integer> 預設值:「-1」
指定 --test_output 為「errors」或「all」時,可產生的每個測試記錄大小上限。可避免因測試輸出內容過於雜亂而導致輸出內容過多。記錄大小中包含測試標頭。負值表示沒有限制。輸出內容為全部或完全不顯示。
標記: test_runnerterminal_outputexecution
--output_filter=<a valid Java regular expression> 預設值:請參閱說明
只會針對名稱符合提供的規則運算式的規則顯示警告和動作輸出內容。
標記: affects_outputs
--progress_report_interval=<an integer in 0-3600 range> 預設值:「0」
每份仍在執行的工作報表之間的等待秒數。預設值 0 表示系統會在 10 秒後列印第一份報表,然後每 30 秒列印一次進度報告,直到每分鐘列印一次為止。啟用 --curses 後,系統會每秒回報進度。
標記: affects_outputs
--remote_print_execution_messages=<failure, success or all> 預設值:「failure」
選擇要何時列印遠端執行訊息。有效值為 `failure` (只在失敗時列印)、`success` (只在成功時列印) 和 `all` (一律列印)。
標記: terminal_output
--[no]sandbox_debug 預設值:「false」
啟用沙箱功能的偵錯功能。這包括兩件事:首先,沙箱根目錄內容在建構後不會受到影響;其次,執行時會顯示額外的偵錯資訊。這有助於 Bazel 或 Starlark 規則的開發人員,解決因缺少輸入檔案而導致的偵錯失敗問題。
標記: terminal_output
--show_result=<an integer> 預設值:「1」
顯示建構結果。針對每個目標,指出是否已更新,如果是,則列出已建構的輸出檔案。這些輸出的檔案是方便的字串,可複製並貼到 Shell 中執行。這個選項需要整數引數,也就是目標的閾值數量,超過這個數量就不會列印結果資訊。因此,零會導致訊息遭到抑制,而 MAX_INT 會導致結果一律會顯示。預設值為 1。如果沒有為目標建立任何內容,系統可能會略過該目標的結果,以便將輸出內容控制在閾值以下。
標記: affects_outputs
--[no]subcommands [-s] 預設值:「false」
顯示在建構期間執行的子指令。相關旗標:--execution_log_json_file、--execution_log_binary_file (用於以工具友善格式將子指令記錄到檔案)。
標記: terminal_output
--test_output=<summary, errors, all or streamed> 預設值:「summary」
指定所需的輸出模式。有效值包括「summary」(僅輸出測試狀態摘要)、「errors」(同時列印失敗測試的測試記錄)、「all」(列印所有測試的記錄) 和「streamed」(即時輸出所有測試的記錄)。請注意,這會強制在本機執行測試,且不論 --test_strategy 值為何,都會一次執行一項測試。
標記: test_runnerterminal_outputexecution
--test_summary=<short, terse, detailed, none or testcase> 預設值:「short」
指定所需的測試摘要格式。有效值包括「short」(僅列印執行的測試資訊)、「terse」(僅列印執行的失敗測試資訊)、「detailed」(列印失敗測試案例的詳細資訊)、「testcase」(列印測試案例解決方案摘要,但不列印失敗測試案例的詳細資訊) 和「none」(省略摘要)。
標記: terminal_output
--[no]verbose_explanations 預設值:「false」
如果啟用 --explain,就會提高說明的詳細程度。如果未啟用 --explain,這個指令就不會產生任何作用。
標記: affects_outputs
--[no]verbose_failures 預設值:「false」
如果指令失敗,請輸出完整指令列。
標記: terminal_output
選項可指定或變更 Bazel 指令的一般輸入內容,而該輸入內容不屬於其他類別:
--aspects_parameters=<a 'name=value' assignment> 累積多次使用
指定指令列面向參數的值。每個參數值都會透過 <param_name>=<param_value> 指定,例如「my_param=my_val」,其中「my_param」是 --aspects 清單中某個面向的參數,或清單中某個面向所需的參數。這個選項可以多次使用。不過,您無法為同一個參數指派多個值。
標記: loading_and_analysis
--target_pattern_file=<a string> 預設值:""
如果設定此值,建構作業會從此處指定的檔案讀取模式,而不是從指令列讀取。在此處指定檔案和指令列模式是錯誤的做法。
代碼: changes_inputs
遠端快取和執行選項:
--experimental_circuit_breaker_strategy=<failure> 預設值:請參閱說明
指定斷路器要使用的策略。可用的策略為「failure」。選項的無效值會與未設定選項的行為相同。
標記: execution
--[no]experimental_guard_against_concurrent_changes 預設值:「false」
將此選項設為關閉,即可停用檢查動作輸入檔案 ctime 的功能,然後上傳至遠端快取。在某些情況下,Linux 核心可能會延遲寫入檔案,導致誤判。
--experimental_remote_cache_compression_threshold=<an integer> 預設值:「100」
使用 zstd 壓縮/解壓縮時所需的 Blob 大小下限。除非設定 --remote_cache_compression,否則無效。
--experimental_remote_cache_eviction_retries=<an integer> 預設值:「5」
如果建構作業遇到會導致建構作業失敗的暫時性遠端快取錯誤,則重試的最大次數。例如,當構件從遠端快取中移除,或在特定快取失敗情況下,就會套用這項設定。非零值會隱含地將 --incompatible_remote_use_new_exit_code_for_lost_inputs 設為 true。系統會為每次嘗試產生新的叫用 ID。如果您產生叫用 ID,並透過 --invocation_id 提供給 Bazel,則不應使用這個標記。請改為設定標記 --incompatible_remote_use_new_exit_code_for_lost_inputs,並檢查退出代碼 39。
標記: execution
--[no]experimental_remote_cache_lease_extension 預設值:「false」
如果設為 true,Bazel 會在建構期間定期將 `FindMissingBlobs` 呼叫傳送至遠端快取,藉此延長遠端動作輸出的租約。頻率取決於 `--experimental_remote_cache_ttl` 的值。
--experimental_remote_cache_ttl=<An immutable length of time.> 預設值:「3h」
在最近參照 Blob 摘要 (例如透過 ActionResult 或 FindMissingBlobs) 後,保證遠端快取中 Blob 的最短 TTL。Bazel 會根據 Blob 的 TTL 執行多項最佳化作業,例如在漸進式建構作業中不重複呼叫 GetActionResult。這個值應設為略低於實際的 TTL,因為伺服器傳回摘要與 Bazel 收到摘要之間存在時間差。
標記: execution
--experimental_remote_capture_corrupted_outputs=<a path> 預設值:請參閱說明
要擷取損毀輸出內容的目錄路徑。
--[no]experimental_remote_discard_merkle_trees 預設值:「true」
如果設為 true,系統會在呼叫 GetActionResult() 和 Execute() 時,捨棄輸入根目錄的 Merkle 樹狀結構和相關輸入對應項目的記憶體副本。這麼做可大幅減少記憶體使用量,但需要在遠端快取遺漏和重試時,由 Bazel 重新計算這些項目。
--experimental_remote_downloader=<a string> 預設值:請參閱說明
Remote Asset API 端點 URI,用於做為遠端下載 Proxy。支援的結構定義為 grpc、grpcs (已啟用 TLS 的 grpc) 和 unix (本機 UNIX 通訊端)。如果未提供結構定義,Bazel 會預設為使用 grpcs。請參閱:https://github.com/bazelbuild/remote-apis/blob/master/build/bazel/remote/asset/v1/remote_asset.proto
--[no]experimental_remote_downloader_local_fallback 預設值:「false」
如果遠端下載器失敗,是否要改用本機下載器。
--[no]experimental_remote_downloader_propagate_credentials 預設值:「false」
是否要從 netrc 和憑證輔助程式,將憑證傳播至遠端下載器伺服器。伺服器實作項目必須支援新的 `http_header_url:<url-index>:<header-key>` 限定詞,其中 `<url-index>` 是 FetchBlobRequest 的 `uris` 欄位中網址的 0 為起點位置。網址專屬標頭應優先於全域標頭。
--[no]experimental_remote_execution_keepalive 預設值:「false」
是否要為遠端執行呼叫使用保留機制。
--experimental_remote_failure_rate_threshold=<an integer in 0-100 range> 預設值:「10」
設定特定時間區間內允許的失敗率百分比,超過此百分比後,系統就會停止呼叫遠端快取/執行緒。預設值為 10。將這個值設為 0 表示沒有限制。
標記: execution
--experimental_remote_failure_window_interval=<An immutable length of time.> 預設值:「60 秒」
計算遠端要求失敗率的間隔。如果值為零或負值,系統會將執行作業的整個期間計算為失敗時間。您可以使用以下單位:天 (d)、小時 (h)、分鐘 (m)、秒 (s) 和毫秒 (ms)。如果省略單位,系統會將值解讀為秒。
標記: execution
--[no]experimental_remote_mark_tool_inputs 預設值:「false」
如果設為 True,Bazel 就會將輸入內容標示為遠端執行工具的輸入內容。這可用於實作遠端持續性工作者。
--[no]experimental_remote_merkle_tree_cache 預設值:「false」
如果設為 true,系統會記錄 Merkle 樹狀圖計算結果,以改善遠端快取命中檢查速度。快取的記憶體足跡會由 --experimental_remote_merkle_tree_cache_size 控制。
--experimental_remote_merkle_tree_cache_size=<a long integer> 預設值:「1000」
要快取的 Merkle 樹狀圖數量,以改善遠端快取命中檢查速度。雖然快取會根據 Java 處理軟性參照的方式自動裁剪,但如果設定過高,就可能發生記憶體不足錯誤。如果設為 0,快取大小就沒有限制。最佳值會因專案大小而異。預設為 1000。
--experimental_remote_output_service=<a string> 預設值:請參閱說明
遠端輸出服務端點的 HOST 或 HOST:PORT。支援的結構定義為 grpc、grpcs (已啟用 TLS 的 grpc) 和 unix (本機 UNIX 通訊端)。如果未提供結構定義,Bazel 會預設為使用 grpcs。指定 grpc:// 或 unix: 結構定義,以停用 TLS。
--experimental_remote_output_service_output_path_prefix=<a string> 預設值:""
--experimental_remote_output_service 管理的輸出目錄內容會放在這個路徑下。實際上,建構作業所使用的輸出目錄會是這個路徑的子項,並由輸出服務決定。
--[no]experimental_remote_require_cached 預設值:「false」
如果設為 true,系統會強制將所有可在遠端執行的動作儲存為快取,否則建構作業會失敗。這有助於排解非決定論問題,因為您可以檢查應快取的動作是否確實已快取,而不會將新結果誤植入快取。
--experimental_remote_scrubbing_config=<Converts to a Scrubber> 預設值:請參閱說明
透過提供的設定檔啟用遠端快取索引鍵清除功能,該設定檔必須是文字格式的通訊協定緩衝區 (請參閱 src/main/protobuf/remote_scrubbing.proto)。 這項功能旨在協助在不同平台上執行但指定相同平台的動作之間共用遠端/磁碟快取。請務必謹慎使用,因為設定不當可能會導致意外共用快取項目,進而導致不正確的建構作業。清除作業不會影響動作的執行方式,只會影響系統如何計算遠端/磁碟快取金鑰,以便擷取或儲存動作結果。經過修飾的動作與遠端執行作業不相容,因此一律會改為在本機執行。修改清除設定不會使本機檔案系統或內部快取中的輸出內容失效;您必須執行清除建構作業,才能重新執行受影響的動作。為了成功使用這項功能,您可能會想設定自訂的 --host_platform,並搭配 --experimental_platform_in_output_dir (用於標準化輸出前置字串) 和 --incompatible_strict_action_env (用於標準化環境變數)。
--[no]incompatible_remote_use_new_exit_code_for_lost_inputs 預設值:「true」
如果設為 true,當快取錯誤 (包括快取淘汰) 導致建構失敗時,Bazel 會使用新的結束代碼 39 而非 34。
標記: incompatible_change
--[no]remote_accept_cached 預設值:「true」
是否接受遠端快取的動作結果。
--remote_build_event_upload=<all or minimal> 預設值:「minimal」
如果設為「all」,BEP 參照的所有本機輸出內容都會上傳至遠端快取。如果設為「minimal」,BEP 參照的本機輸出內容就不會上傳至遠端快取,但對 BEP 使用者而言重要的檔案 (例如測試記錄和時間設定檔) 除外。即使檔案未出現在遠端快取中,檔案的 URI 一律會使用 bytestream:// 配置。預設為「minimal」。
--remote_bytestream_uri_prefix=<a string> 預設值:請參閱說明
在寫入建構事件串流的 bytestream:// URI 中,要使用的主機名稱和執行個體名稱。您可以在使用 Proxy 執行建構作業時設定這個選項,這會導致 --remote_executor 和 --remote_instance_name 的值不再對應至遠端執行服務的標準名稱。如未設定,則預設為「${hostname}/${instance_name}」。
--remote_cache=<a string> 預設值:請參閱說明
快取端點的 URI。支援的結構定義為 http、https、grpc、grpcs (已啟用 TLS 的 grpc) 和 unix (本機 UNIX 通訊端)。如果未提供結構定義,Bazel 會預設為使用 grpcs。指定 grpc://、http:// 或 unix: 結構定義,即可停用 TLS。請參閱 https://bazel.build/remote/caching
--[no]remote_cache_async 預設值:「true」
如果設為 true,系統會在背景上傳動作結果至磁碟或遠端快取,而不會阻斷動作的完成。某些動作與背景上傳功能不相容,即使設定了這個標記,也可能仍會遭到封鎖。
--[no]remote_cache_compression 預設值:「false」
如果啟用,當快取 blob 的大小至少達到 --experimental_remote_cache_compression_threshold 時,系統就會使用 zstd 進行壓縮/解壓縮。
--remote_cache_header=<a 'name=value' assignment> 累積多次使用
指定要納入快取要求的標頭:--remote_cache_header=Name=Value。您可以多次指定標記,藉此傳遞多個標頭。同一個名稱的多個值會轉換為以半形逗號分隔的清單。
--remote_default_exec_properties=<a 'name=value' assignment> 累積多次使用
如果執行平台尚未設定 exec_properties,請設定要用於遠端執行平台的預設執行屬性。
標記: affects_outputs
--remote_default_platform_properties=<a string> 預設值:""
如果執行平台尚未設定 remote_execution_properties,請設定要為遠端執行 API 設定的預設平台屬性。如果主機平台已選為遠端執行的執行平台,系統也會使用這個值。
--remote_download_regex=<a valid Java regular expression> 累積多次使用
強制下載路徑符合此模式的遠端建構輸出內容,不受 --remote_download_outputs 影響。您可以重複使用這個旗標來指定多個模式。
標記: affects_outputs
--remote_downloader_header=<a 'name=value' assignment> 累積多次使用
指定要納入遠端下載器要求的標頭:--remote_downloader_header=名稱=值。您可以多次指定標記,藉此傳遞多個標頭。同一個名稱的多個值會轉換為以半形逗號分隔的清單。
--remote_exec_header=<a 'name=value' assignment> 累積多次使用
指定執行要求中要納入的標頭:--remote_exec_header=Name=Value。您可以多次指定標記,藉此傳遞多個標頭。同一個名稱的多個值會轉換為以半形逗號分隔的清單。
--remote_execution_priority=<an integer> 預設值:「0」
要遠端執行的動作相對優先順序。特定優先值的語意取決於伺服器。
--remote_executor=<a string> 預設值:請參閱說明
遠端執行端點的 HOST 或 HOST:PORT。支援的結構定義為 grpc、grpcs (已啟用 TLS 的 grpc) 和 unix (本機 UNIX 通訊端)。如果未提供結構定義,Bazel 會預設為使用 grpcs。指定 grpc:// 或 unix: 結構定義,以停用 TLS。
--remote_grpc_log=<a path> 預設值:請參閱說明
如果指定,則為記錄 gRPC 呼叫相關詳細資料的檔案路徑。此記錄包含序列化的 com.google.devtools.build.lib.remote.logging.RemoteExecutionLog.LogEntry protobuf,每則訊息的前置字串為 varint,表示下一個序列化 protobuf 訊息的大小,如 LogEntry.writeDelimitedTo(OutputStream) 方法所執行。
--remote_header=<a 'name=value' assignment> 累積多次使用
指定要納入要求的標頭:--remote_header=名稱=值。您可以多次指定標記,藉此傳遞多個標頭。同一個名稱的多個值會轉換為以半形逗號分隔的清單。
--remote_instance_name=<a string> 預設值:""
在遠端執行 API 中,要做為 instance_name 傳遞的值。
--[no]remote_local_fallback 預設值:「false」
如果遠端執行作業失敗,是否要改用獨立的本機執行策略。
--remote_local_fallback_strategy=<a string> 預設值:「local」
已淘汰。詳情請參閱 https://github.com/bazelbuild/bazel/issues/7480。
--remote_max_connections=<an integer> 預設值:「100」
限制遠端快取/執行工具的並行連線數上限。預設值為 100。將這個值設為 0 表示沒有限制。對於 HTTP 遠端快取,一個 TCP 連線可同時處理一個要求,因此 Bazel 最多可提出 --remote_max_connections 個並行要求。對於 gRPC 遠端快取/執行緒,一個 gRPC 管道通常可處理 100 個以上的並發要求,因此 Bazel 可以發出約 `--remote_max_connections * 100` 個並發要求。
標記: host_machine_resource_optimizations
--remote_proxy=<a string> 預設值:請參閱說明
透過 Proxy 連線至遠端快取。目前這個旗標只能用於設定 Unix 網域 Socket (unix:/path/to/socket)。
--remote_result_cache_priority=<an integer> 預設值:「0」
要儲存在遠端快取中的遠端動作相對優先順序。特定優先值的語意取決於伺服器。
--remote_retries=<an integer> 預設值:「5」
重試暫時性錯誤的最大次數。如果設為 0,則會停用重試。
--remote_retry_max_delay=<An immutable length of time.> 預設值:「5 秒」
遠端重試之間的最大輪詢延遲時間。可使用的單位包括:天數 (d)、小時 (h)、分鐘 (m)、秒數 (s) 和毫秒 (ms)。如果省略單位,系統會將值解讀為秒。
--remote_timeout=<An immutable length of time.> 預設值:「60 秒」
等待遠端執行作業和快取呼叫的時間上限。對於 REST 快取,這同時是連線和讀取逾時時間。可使用的單位包括:天數 (d)、小時 (h)、分鐘 (m)、秒數 (s) 和毫秒 (ms)。如果省略單位,系統會將值解讀為秒。
--[no]remote_upload_local_results 預設值:「true」
如果遠端快取支援上傳,且使用者已獲授權,則是否將本機執行的動作結果上傳至遠端快取。
--[no]remote_verify_downloads 預設值:「true」
如果設為 true,Bazel 會計算所有遠端下載的雜湊總和,並在遠端快取的值不符合預期值時丟棄。
其他選項,未歸類於其他類別:
--[no]allow_analysis_cache_discard 預設值:「true」
如果因建構系統變更而捨棄分析快取,將此選項設為 false 會導致 Bazel 退出,而非繼續建構。如果同時設定「discard_analysis_cache」,這個選項就不會生效。
標記: eagerness_to_exit
--auto_output_filter=<none, all, packages or subpackages> 預設值:「none」
如果未指定 --output_filter,系統會使用這個選項的值自動建立篩選器。可用的值包括「none」(不篩選 / 顯示所有項目)、「all」(篩選所有項目 / 不顯示任何項目)、「packages」(包含 Blaze 指令列中提及的套件中規則的輸出內容) 和「subpackages」(類似「packages」,但也包含子套件)。對於「packages」和「subpackages」值,系統會將 //java/foo 和 //javatests/foo 視為一個套件。
--[no]build_manual_tests 預設值:「false」
強制建構標記為「手動」的測試目標。系統會排除「手動」測試。這個選項會強制建構 (但不會執行)。
--build_tag_filters=<comma-separated list of options> 預設值:""
指定以半形逗號分隔的標記清單。您可以選擇在每個標記前加上「-」來指定排除的標記。系統只會建構至少包含一個已納入的標記,且不包含任何排除標記的目標。這個選項不會影響使用「test」指令執行的測試集,這些測試受測試篩選選項 (例如「--test_tag_filters」) 的規範。
--[no]build_tests_only 預設值:「false」
如果指定此選項,系統只會建構 *_test 和 test_suite 規則,並忽略指令列上指定的其他目標。根據預設,系統會建構所有要求的項目。
--combined_report=<none or lcov> 預設值:「none」
指定所需的累積涵蓋率報表類型。目前僅支援 LCOV。
--[no]compile_one_dependency 預設值:「false」
編譯引數檔案的單一依附元件。這項功能可用於在 IDE 中檢查語法來源檔案,例如,藉由重建依賴來源檔案的單一目標,盡可能在編輯/建構/測試週期中及早偵測錯誤。這個引數會影響所有非標記引數的解讀方式,並將其視為來源檔案名稱,而非建構目標。針對每個來源檔案名稱,系統都會建構依附於該檔案的任意目標。
--deleted_packages=<comma-separated list of package names> 累積多次使用
以半形逗號分隔的套件名稱清單,即使這些套件名稱在套件路徑的某處可見,建構系統仍會視為不存在。刪除現有套件「x」的子套件「x/y」時,請使用這個選項。舉例來說,在刪除用戶端中的 x/y/BUILD 後,如果建構系統遇到標籤「//x:y/z」,但該標籤仍由另一個 package_path 項目提供,系統可能會發出錯誤訊息。指定 --deleted_packages x/y 即可避免這個問題。
--[no]discard_analysis_cache 預設值:「false」
分析階段完成後,立即捨棄分析快取。可減少約 10% 的記憶體用量,但會使後續的漸進式建構作業速度變慢。
--disk_cache=<a path> 預設值:請參閱說明
Bazel 可讀取及寫入動作和動作輸出的目錄路徑。如果目錄不存在,系統會建立該目錄。
--embed_label=<a one-line string> 預設值:""
在二進位檔中嵌入來源控管修訂版本或版本標籤
--execution_log_binary_file=<a path> 預設值:請參閱說明
根據 src/main/protobuf/spawn.proto 的規定,將執行的產生事件記錄為長度分隔的 SpawnExec 原型檔,並儲存在這個檔案中。建議使用 --execution_log_compact_file,因為產生的檔案大小較小,產生成本也較低。相關標記:--execution_log_compact_file (精簡格式;互斥)、--execution_log_json_file (文字 JSON 格式;互斥)、--execution_log_sort (是否要排序執行記錄)、--subcommands (用於在終端機輸出內容中顯示子指令)。
--execution_log_compact_file=<a path> 預設值:請參閱說明
根據 src/main/protobuf/spawn.proto 的說明,將執行的產生事件記錄為長度分隔的 ExecLogEntry 原型檔,並儲存在這個檔案中。整個檔案都會經過 zstd 壓縮。相關標記:--execution_log_binary_file (二進位 protobuf 格式;互斥)、--execution_log_json_file (文字 JSON 格式;互斥)、--subcommands (用於在終端機輸出中顯示子指令)。
--execution_log_json_file=<a path> 預設值:請參閱說明
根據 src/main/protobuf/spawn.proto 的規定,將執行的產生事件記錄到這個檔案中,做為 SpawnExec 原型結構的以換行符號分隔的 JSON 表示法。建議使用 --execution_log_compact_file,因為產生的檔案大小較小,產生成本也較低。相關標記:--execution_log_compact_file (精簡格式;互斥)、--execution_log_binary_file (二進位 protobuf 格式;互斥)、--execution_log_sort (是否要排序執行記錄)、--subcommands (用於在終端機輸出中顯示子指令)。
--[no]execution_log_sort 預設值:「true」
是否要排序執行記錄,方便比較不同叫用作業的記錄。將其設為 false 可避免在叫用作業結束時,出現可能會大量使用 CPU 和記憶體的情況,但代價是會以非確定性的執行順序產生記錄。僅適用於二進位和 JSON 格式;精簡格式不會排序。
--[no]expand_test_suites 預設值:「true」
在分析前,將 test_suite 目標展開為其構成的測試。開啟此旗標 (預設) 後,系統會將負向目標模式套用至屬於測試套件的測試,否則不會套用。在指令列中套用頂層層面時,關閉這個標記很有用,因為這樣才能分析 test_suite 目標。
標記: loading_and_analysis
--experimental_disk_cache_gc_idle_delay=<An immutable length of time.> 預設值:「5m」
在磁碟快取進行垃圾收集前,伺服器必須閒置多久。如要指定垃圾收集政策,請設定 --experimental_disk_cache_gc_max_size 和/或 --experimental_disk_cache_gc_max_age。
--experimental_disk_cache_gc_max_age=<An immutable length of time.> 預設值:「0」
如果設為正值,系統會定期執行垃圾收集作業,移除超過此年齡的項目。如果與 --experimental_disk_cache_gc_max_size 搭配使用,系統會套用兩項條件。伺服器閒置後,系統會根據 --experimental_disk_cache_gc_idle_delay 標記,在背景執行垃圾收集作業。
--experimental_disk_cache_gc_max_size=<a size in bytes, optionally followed by a K, M, G or T multiplier> 預設值:「0」
如果設為正值,系統會定期執行垃圾收集作業,確保磁碟快取大小不超過這個值。如果與 --experimental_disk_cache_gc_max_age 搭配使用,系統會套用這兩項條件。伺服器閒置後,系統會根據 --experimental_disk_cache_gc_idle_delay 標記,在背景執行垃圾收集作業。
--experimental_extra_action_filter=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths> 預設值:""
已淘汰,改用切面。篩選要為其排定 extra_actions 的目標。
--[no]experimental_extra_action_top_level_only 預設值:「false」
已淘汰,改用切面。僅為頂層目標排定 extra_actions。
--experimental_spawn_scheduler
在本機和遠端平行執行動作,啟用動態執行功能。Bazel 會在本機和遠端產生每項動作,並挑選最先完成的動作。如果動作支援工作站,本機動作就會以持續工作站模式執行。如要為個別動作助憶碼啟用動態執行功能,請改用 `--internal_spawn_scheduler` 和 `--strategy=<mnemonic>=dynamic` 標記。
展開為:
  --internal_spawn_scheduler
  --spawn_strategy=dynamic
--[no]fetch 預設值:「true」
允許指令擷取外部依附元件。如果設為 false,指令會使用任何快取的依附元件版本,如果沒有任何版本,指令就會失敗。
--local_termination_grace_seconds=<an integer> 預設值:「15」
由於逾時而終止本機程序,以及強制關閉程序之間的等待時間。
--package_path=<colon-separated list of options> 預設值:「%workspace%」
以冒號分隔的清單,列出尋找套件的來源。以「%workspace%」開頭的元素是相對於包含工作區的元素。如果省略或留空,預設值為執行「bazel info default-package-path」的輸出內容。
--[no]show_loading_progress 預設值:「true」
如果啟用,Bazel 就會顯示「Loading package:」訊息。
--test_lang_filters=<comma-separated list of options> 預設值:""
指定以半形逗號分隔的測試語言清單。每種語言可選擇在前方加上「-」來指定排除的語言。系統只會找出以指定語言撰寫的測試目標。每種語言使用的名稱應與 *_test 規則中的語言前置字元相同,例如 'cc'、'java'、'py' 等。此選項會影響 --build_tests_only 行為和測試指令。
--test_size_filters=<comma-separated list of values: small, medium, large, or enormous> 預設值:""
指定以半形逗號分隔的測試大小清單。每個尺寸可選擇在前方加上「-」來指定排除的尺寸。系統只會找出包含至少一個已納入大小,且不包含任何已排除大小的測試目標。這個選項會影響 --build_tests_only 行為和測試指令。
--test_tag_filters=<comma-separated list of options> 預設值:""
指定以半形逗號分隔的測試標記清單。您可以選擇在每個標記前加上「-」來指定排除的標記。系統只會找出至少包含一個已納入標記,且不包含任何已排除標記的測試目標。這個選項會影響 --build_tests_only 行為和測試指令。
--test_timeout_filters=<comma-separated list of values: short, moderate, long, or eternal> 預設值:""
指定以半形逗號分隔的測試逾時清單。您可以選擇在每個逾時值前加上「-」指定排除的逾時值。系統只會找出至少包含一個已納入的逾時時間,且不含任何已排除的逾時時間的測試目標。這個選項會影響 --build_tests_only 行為和測試指令。
--workspace_status_command=<path> 預設值:""
在建構作業開始時叫用的指令,可以鍵/值組合的形式提供工作區的狀態資訊。如需完整規格,請參閱使用手冊。如需範例,請參閱 tools/buildstamp/get_workspace_status。
控制建構執行作業的選項:
是否要直接呼叫檔案系統以建立符號連結樹狀結構,而非委派給輔助程序。
標記: loading_and_analysisexecutionexperimental
--[no]experimental_persistent_aar_extractor 預設值:「false」
使用 worker 啟用持續性 AAR Extractor。
標記: executionexperimental
--[no]experimental_remotable_source_manifests 預設值:「false」
是否要讓來源資訊清單動作可遠端執行
標記: loading_and_analysisexecutionexperimental
--[no]experimental_split_coverage_postprocessing 預設值:「false」
如果為 true,Bazel 就會在新的產生事件中執行測試的涵蓋率後置處理程序。
標記: executionexperimental
--[no]experimental_strict_fileset_output 預設值:「false」
如果啟用這個選項,檔案集會將所有輸出構件視為一般檔案。不會遍歷目錄,也不會對符號連結敏感。
標記: executionexperimental
--[no]incompatible_modify_execution_info_additive 預設值:「false」
啟用後,傳遞多個 --modify_execution_info 標記會相加。停用時,系統只會考量最後一個標記。
標記: executionaffects_outputsloading_and_analysisincompatible_change
--modify_execution_info=<regex=[+-]key,regex=[+-]key,...> 累積多次使用
根據動作助憶法,新增或移除動作執行資訊中的鍵。僅適用於支援執行資訊的動作。許多常見動作都支援執行資訊,例如 Genrule、CppCompile、Javac、StarlarkAction、TestRunner。指定多個值時,順序很重要,因為許多規則運算式可能會套用相同的助憶法。語法:「regex=[+-]key,regex=[+-]key,...」。範例: «.*=+x,.*=-y,.*=+z» 會將「x」和「z」加入所有動作的執行資訊,並移除「y」。'Genrule=+requires-x' 會將 'requires-x' 新增至所有 Genrule 動作的執行資訊。'(?!Genrule).*=-requires-x' 會從所有非 Genrule 動作的執行資訊中移除 'requires-x'。
標記: executionaffects_outputsloading_and_analysis
--persistent_android_dex_desugar
使用工作者啟用持續性的 Android dex 和 desugar 動作。
展開為:
  --internal_persistent_android_dex_desugar
  --strategy=Desugar=worker
  --strategy=DexBuilder=worker

標記: host_machine_resource_optimizationsexecution
--persistent_android_resource_processor
使用 worker 啟用 Android 資源處理器。
展開為:
  --internal_persistent_busybox_tools
  --strategy=AaptPackage=worker
  --strategy=AndroidResourceParser=worker
  --strategy=AndroidResourceValidator=worker
  --strategy=AndroidResourceCompiler=worker
  --strategy=RClassGenerator=worker
  --strategy=AndroidResourceLink=worker
  --strategy=AndroidAapt2=worker
  --strategy=AndroidAssetMerger=worker
  --strategy=AndroidResourceMerger=worker
  --strategy=AndroidCompiledResourceMerger=worker
  --strategy=ManifestMerger=worker
  --strategy=AndroidManifestMerger=worker
  --strategy=Aapt2Optimize=worker
  --strategy=AARGenerator=worker
  --strategy=ProcessDatabinding=worker
  --strategy=GenerateDataBindingBaseClasses=worker

標記: host_machine_resource_optimizationsexecution
--persistent_multiplex_android_dex_desugar
使用 worker 啟用持續性的多重 Android dex 和 desugar 動作。
展開為:
  --persistent_android_dex_desugar
  --internal_persistent_multiplex_android_dex_desugar

標記: host_machine_resource_optimizationsexecution
--persistent_multiplex_android_resource_processor
使用 worker 啟用持續性的多重 Android 資源處理器。
展開為:
  --persistent_android_resource_processor
  --modify_execution_info=AaptPackage=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceParser=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceValidator=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceCompiler=+supports-multiplex-workers
  --modify_execution_info=RClassGenerator=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceLink=+supports-multiplex-workers
  --modify_execution_info=AndroidAapt2=+supports-multiplex-workers
  --modify_execution_info=AndroidAssetMerger=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceMerger=+supports-multiplex-workers
  --modify_execution_info=AndroidCompiledResourceMerger=+supports-multiplex-workers
  --modify_execution_info=ManifestMerger=+supports-multiplex-workers
  --modify_execution_info=AndroidManifestMerger=+supports-multiplex-workers
  --modify_execution_info=Aapt2Optimize=+supports-multiplex-workers
  --modify_execution_info=AARGenerator=+supports-multiplex-workers

標記: host_machine_resource_optimizations, execution
--persistent_multiplex_android_tools
啟用持續性和多重化的 Android 工具 (dexing、desugaring、資源處理)。
展開為:
  --internal_persistent_multiplex_busybox_tools
  --persistent_multiplex_android_resource_processor
  --persistent_multiplex_android_dex_desugar

標記: host_machine_resource_optimizationsexecution
--[no]use_target_platform_for_tests 預設值:「false」
如果為 true,Bazel 會使用目標平台執行測試,而不是使用測試執行群組。
代碼: execution
設定用於執行動作的工具鍊的選項:
--android_compiler=<a string> 預設值:請參閱說明
Android 目標編譯器。
標記: affects_outputsloading_and_analysisloses_incremental_state
--android_manifest_merger=<legacy, android or force_android> 預設值:「android」
選取要用於 android_binary 規則的資訊清單合併工具。旗標,可協助從舊版合併工具轉換至 Android 資訊清單合併工具。
標記: affects_outputsloading_and_analysisloses_incremental_state
--android_platforms=<a build target label> 預設值:""
設定 android_binary 目標使用的平台。如果指定多個平台,則二進位檔會是笨重的 APK,其中包含每個指定目標平台的原生二進位檔。
標記: changes_inputsloading_and_analysisloses_incremental_state
--apple_crosstool_top=<a build target label> 預設值:"@bazel_tools//tools/cpp:toolchain"
在 Apple 和 Objc 規則及其依附元件中使用的 crosstool 套件標籤。
標記: loses_incremental_statechanges_inputs
--cc_output_directory_tag=<a string> 預設值:""
指定要新增至設定目錄的後置字串。
標記: affects_outputs
--compiler=<a string> 預設值:請參閱說明
用於編譯目標的 C++ 編譯器。
標記: loading_and_analysisexecution
--coverage_output_generator=<a build target label> 預設值:"@bazel_tools//tools/test:lcov_merger"
用於後處理原始涵蓋率報表的二進位檔位置。這個檔案群組目前必須包含單一檔案 (二進位檔)。預設值為 '//tools/test:lcov_merger'。
標記: changes_inputsaffects_outputsloading_and_analysis
--coverage_report_generator=<a build target label> 預設值:"@bazel_tools//tools/test:coverage_report_generator"
用於產生涵蓋率報表的二進位檔位置。這個檔案群組目前必須包含單一檔案 (二進位檔)。預設值為 '//tools/test:coverage_report_generator'。
標記: changes_inputsaffects_outputsloading_and_analysis
--coverage_support=<a build target label> 預設值:"@bazel_tools//tools/test:coverage_support"
收集程式碼涵蓋率的每個測試動作輸入項目所需的支援檔案位置。預設值為 '//tools/test:coverage_support'。
標記: changes_inputsaffects_outputsloading_and_analysis
--custom_malloc=<a build target label> 預設值:請參閱說明
指定自訂 malloc 實作項目。這項設定會覆寫建構規則中的 malloc 屬性。
標記: changes_inputsaffects_outputs
--experimental_add_exec_constraints_to_targets=<a '<RegexFilter>=<label1>[,<label2>,...]' assignment> 累積多次使用
以逗號分隔的規則運算式清單,每個運算式可選擇加上前置字元 - (負值運算式),並將 (=) 指派給以逗號分隔的限制值目標清單。如果目標不符合任何負面運算式,且至少符合一個正面運算式,則會執行工具鍊解析作業,就像宣告限制值為執行限制一樣。範例://demo,-test=@platforms//cpus:x86_64 會將「x86_64」新增至 //demo 下的任何目標,但名稱含有「test」的目標除外。
標記: loading_and_analysis
--[no]experimental_include_xcode_execution_requirements 預設值:「false」
如果已設定,請在每個 Xcode 動作中新增「requires-xcode:{version}」執行需求。如果 Xcode 版本有連字號標籤,請一併新增「requires-xcode-label:{version_label}」執行要求。
標記: loses_incremental_stateloading_and_analysisexecutionexperimental
--[no]experimental_prefer_mutual_xcode 預設值:「true」
如果為 true,請使用在本機和遠端都可用的最新 Xcode。如果為 false,或沒有可用的共同版本,請使用透過 xcode-select 所選的本機 Xcode 版本。
標記: loses_incremental_stateexperimental
--extra_execution_platforms=<comma-separated list of options> 預設值:""
可用於執行動作的執行平台。您可以使用完全比對目標或目標模式指定平台。系統會先考慮這些平台,再考慮由 register_execution_platforms() 在 WORKSPACE 檔案中宣告的平台。這個選項只能設定一次;後續的例項會覆寫先前的標記設定。
標記: execution
--extra_toolchains=<comma-separated list of options> 累積多次使用
在工具鍊解析期間要考量的工具鍊規則。您可以使用確切目標或目標模式指定工具鍊。系統會先考慮這些工具鍊,再考慮 WORKSPACE 檔案中透過 register_toolchains() 宣告的工具鍊。
標記: affects_outputschanges_inputsloading_and_analysis
--grte_top=<a label> 預設值:請參閱說明
已檢查的 libc 程式庫的標籤。預設值是由 crosstool 工具鍊選取,您幾乎不需要覆寫。
標記: action_command_linesaffects_outputs
--host_compiler=<a string> 預設值:請參閱說明
無操作標記。將在日後推出的版本中移除。
標記: loading_and_analysisexecution
--host_grte_top=<a label> 預設值:請參閱說明
如果指定此值,這項設定會覆寫執行設定的 libc 頂層目錄 (--grte_top)。
標記: action_command_linesaffects_outputs
--host_platform=<a build target label> 預設值:"@bazel_tools//tools:host_platform"
平台規則的標籤,用於說明主機系統。
標記: affects_outputschanges_inputsloading_and_analysis
--[no]incompatible_bazel_test_exec_run_under 預設值:「false」
如果啟用,則「bazel test --run_under=//:runner」會在執行設定中建構「//:runner」。如果停用,則會在目標設定中建構「//:runner」。Bazel 會在執行機器上執行測試,因此前者較為正確。這不會影響「bazel run」,因為這項指令會一律在目標設定中建構「--run_under=//foo」。
標記: affects_outputsincompatible_change
--[no]incompatible_dont_enable_host_nonhost_crosstool_features 預設值:「true」
如果設為 true,Bazel 就不會在 c++ 工具鍊中啟用「host」和「nonhost」功能 (詳情請參閱 https://github.com/bazelbuild/bazel/issues/7407)。
標記: loading_and_analysisincompatible_change
--[no]incompatible_enable_apple_toolchain_resolution 預設值:「false」
使用工具鍊解析來選取 Apple 規則的 Apple SDK (Starlark 和原生)
標記: loading_and_analysisincompatible_change
--[no]incompatible_remove_legacy_whole_archive 預設值:「true」
如果為 true,Bazel 預設不會將程式庫依附元件連結為整個封存檔 (如需遷移操作說明,請參閱 https://github.com/bazelbuild/bazel/issues/7362)。
標記: loading_and_analysisincompatible_change
--[no]incompatible_strip_executable_safely 預設值:「false」
如果為 true,可執行檔的剝除動作會使用 -x 標記,不會中斷動態符號解析。
標記: action_command_linesincompatible_change
--[no]interface_shared_objects 預設值:「true」
如果工具鍊支援,請使用介面共用物件。目前所有 ELF 工具鍊都支援這項設定。
標記: loading_and_analysisaffects_outputsaffects_outputs
--ios_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 iOS 應用程式的 iOS SDK 版本。如未指定,系統會使用「xcode_version」的預設 iOS SDK 版本。
標記: loses_incremental_state
--macos_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 macOS 應用程式的 macOS SDK 版本。如未指定,系統會使用「xcode_version」中的預設 macOS SDK 版本。
標記: loses_incremental_state
--minimum_os_version=<a string> 預設值:請參閱說明
編譯目標的最低作業系統版本。
標記: loading_and_analysisaffects_outputs
--platform_mappings=<a main workspace-relative path> 預設值:""
對應檔案的位置,可說明在未設定任何平台時要使用的平台,或在已存在平台時要設定的旗標。必須相對於主要工作區根目錄。預設值為「platform_mappings」(工作區根目錄下方的檔案)。
標記: affects_outputschanges_inputsloading_and_analysisimmutable
--platforms=<a build target label> 預設值:""
平台規則的標籤,說明目前指令的目標平台。
標記: affects_outputschanges_inputsloading_and_analysis
--python_path=<a string> 預設值:請參閱說明
在目標平台上執行 Python 目標時,系統會叫用 Python 解譯器的絕對路徑。已淘汰;已由 --incompatible_use_python_toolchains 停用。
標記: loading_and_analysisaffects_outputs
--python_top=<a build target label> 預設值:請參閱說明
py_runtime 的標籤,代表在目標平台上執行 Python 目標時所叫用的 Python 轉譯器。已淘汰;已由 --incompatible_use_python_toolchains 停用。
標記: loading_and_analysisaffects_outputs
--tvos_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 tvOS 應用程式的 tvOS SDK 版本。如果未指定,系統會使用「xcode_version」中的預設 tvOS SDK 版本。
標記: loses_incremental_state
--watchos_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 watchOS 應用程式的 watchOS SDK 版本。如未指定,系統會使用「xcode_version」的預設 watchOS SDK 版本。
標記: loses_incremental_state
--xcode_version=<a string> 預設值:請參閱說明
如果指定此屬性,系統會使用指定版本的 Xcode 執行相關的建構動作。如未指定,系統會使用執行緒的預設 Xcode 版本。
標記: loses_incremental_state
--xcode_version_config=<a build target label> 預設值:"@bazel_tools//tools/cpp:host_xcodes"
xcode_config 規則的標籤,用於在建構設定中選取 Xcode 版本。
標記: loses_incremental_stateloading_and_analysis
控制指令輸出的選項:
--[no]apple_generate_dsym 預設值:「false」
是否產生偵錯符號 (.dSYM) 檔案。
標記: affects_outputsaction_command_lines
如果為 true,則為所有目標建構 runfiles 符號連結森林。如果為 false,則只有在本機動作、測試或執行指令要求時,才會寫入。
標記: affects_outputs
--[no]build_runfile_manifests 預設值:「true」
如果為 true,則為所有目標寫入 runfiles 資訊清單。如果為 false,則省略這些項目。如果為 false,本機測試就會無法執行。
標記: affects_outputs
--[no]build_test_dwp 預設值:「false」
如果啟用此選項,在使用 Fission 靜態建構 C++ 測試時,系統也會自動建構測試二進位檔的 .dwp 檔案。
標記: loading_and_analysisaffects_outputs
--cc_proto_library_header_suffixes=<comma-separated set of options> 預設值:".pb.h"
設定 cc_proto_library 建立的標頭檔案後置字串。
標記: affects_outputsloading_and_analysis
--cc_proto_library_source_suffixes=<comma-separated set of options> 預設值:「.pb.cc」
設定 cc_proto_library 建立的來源檔案後置字串。
標記: affects_outputsloading_and_analysis
--[no]experimental_proto_descriptor_sets_include_source_info 預設值:「false」
針對 proto_library 中的其他 Java API 版本執行額外動作。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_save_feature_state 預設值:「false」
將已啟用和要求的功能的狀態儲存為編譯的輸出內容。
標記: affects_outputsexperimental
--fission=<a set of compilation modes> 預設值:「no」
指定哪些編譯模式會在 C++ 編譯和連結時使用分裂。可為 {'fastbuild', 'dbg', 'opt'} 或特殊值的任意組合,其中 'yes'可啟用所有模式,'no'可停用所有模式。
標記: loading_and_analysisaction_command_linesaffects_outputs
--[no]incompatible_always_include_files_in_data 預設值:「true」
如果為 true,原生規則會將資料依附元件的 <code>DefaultInfo.files</code> 新增至其執行檔,這與 Starlark 規則的建議行為相符 (https://bazel.build/extending/rules#runfiles_features_to_avoid)。
標記: affects_outputsincompatible_change
--[no]legacy_external_runfiles 預設值:「false」
如果為 true,則會為 .runfiles/wsname/external/repo 下的外部存放區 (除了 .runfiles/repo) 建構執行檔案符號連結森林。
標記: affects_outputs
--[no]objc_generate_linkmap 預設值:「false」
指定是否要產生連結圖檔案。
標記: affects_outputs
--[no]save_temps 預設值:「false」
如果設定,系統會儲存來自 gcc 的臨時輸出內容。包括 .s 檔案 (組譯器程式碼)、.i 檔案 (預處理的 C) 和 .ii 檔案 (預處理的 C++)。
標記: affects_outputs
選項可讓使用者設定預期的輸出內容,影響其值,而非其存在:
--action_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定可供含有目標設定的動作使用的一組環境變數。變數可以透過名稱指定,在這種情況下,系統會從叫用環境取得值;也可以透過名稱=值組合指定,在這種情況下,系統會設定不受叫用環境影響的值。這個選項可以重複使用;如果是針對同一個變數提供的選項,則以最新的選項為準;如果是針對不同變數提供的選項,則會累加。
標記: action_command_lines
--allowed_cpu_values=<comma-separated set of options> 預設值:""
--cpu 標記的有效值。
標記: changes_inputsaffects_outputs
--[no]android_databinding_use_androidx 預設值:「true」
產生與 AndroidX 相容的資料繫結檔案。這個屬性僅適用於資料繫結 v2。這個標記不會執行任何操作。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]android_databinding_use_v3_4_args 預設值:「true」
使用 Android Databinding v2 和 3.4.0 引數。這個標記不會執行任何操作。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--android_dynamic_mode=<off, default or fully> 預設值:「off」
決定在 cc_binary 未明確建立共用程式庫時,是否要動態連結 Android 規則的 C++ 依附元件。「預設」表示 Bazel 會選擇是否要動態連結。「fully」表示所有程式庫都會動態連結。「off」表示所有程式庫都會以靜態模式連結。
標記: affects_outputsloading_and_analysis
--android_manifest_merger_order=<alphabetical, alphabetical_by_configuration or dependency> 預設值:「alphabetical」
設定傳遞至 Android 二進位檔資訊清單合併工具的資訊清單順序。ALPHABETICAL 表示資訊清單會依據相對於執行根目錄的路徑排序。ALPHABETICAL_BY_CONFIGURATION 表示資訊清單會依據輸出目錄中相對於設定目錄的路徑排序。DEPENDENCY 表示資訊清單會依序排列,每個程式庫的資訊清單會排在其依附元件的資訊清單之前。
標記: action_command_linesexecution
--[no]android_resource_shrinking 預設值:「false」
為使用 ProGuard 的 android_binary APK 啟用資源縮減功能。
標記: affects_outputsloading_and_analysis
--[no]build_python_zip 預設值:「auto」
建構 Python 可執行的 zip 檔案;在 Windows 上開啟,在其他平台上關閉
標記: affects_outputs
--catalyst_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的清單,列出要用來建構 Apple Catalyst 二進位檔的架構。
標記: loses_incremental_stateloading_and_analysis
--[no]collect_code_coverage 預設值:「false」
如果指定此選項,Bazel 會檢測程式碼 (盡可能使用離線檢測),並在測試期間收集涵蓋率資訊。只有符合 --instrumentation_filter 的目標才會受到影響。通常不應直接指定這個選項,而應改用「bazel coverage」指令。
標記: affects_outputs
--compilation_mode=<fastbuild, dbg or opt> [-c] 預設值:「fastbuild」
指定要建構二進位檔的模式。值:'fastbuild'、'dbg'、'opt'。
標記: affects_outputsaction_command_lines
--conlyopt=<a string> 累積多次使用
編譯 C 來源檔案時,要傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--copt=<a string> 累積多次使用
傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--cpu=<a string> 預設值:""
目標 CPU。
標記: changes_inputsaffects_outputs
--cs_fdo_absolute_path=<a string> 預設值:請參閱說明
使用 CSFDO 設定檔資訊來最佳化編譯作業。指定內含設定檔檔案的 ZIP 檔案的絕對路徑名稱,也就是原始或索引 LLVM 設定檔檔案。
標記: affects_outputs
--cs_fdo_instrument=<a string> 預設值:請參閱說明
使用情境敏感的 FDO 檢測功能產生二進位檔。使用 Clang/LLVM 編譯器時,它也會接受目錄名稱,以便在執行階段轉儲原始設定檔檔案。
標記: affects_outputs
--cs_fdo_profile=<a build target label> 預設值:請參閱說明
cs_fdo_profile 代表要用於最佳化的內容敏感設定檔。
標記: affects_outputs
--cxxopt=<a string> 累積多次使用
編譯 C++ 來源檔案時,要傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--define=<a 'name=value' assignment> 累積多次使用
每個 --define 選項都會指定建構變數的值。如果變數有多個值,則最後一個值會勝出。
標記: changes_inputsaffects_outputs
--dynamic_mode=<off, default or fully> 預設值:"default"
決定是否要動態連結 C++ 二進位檔。「預設」表示 Bazel 會選擇是否要動態連結。「fully」表示所有程式庫都會動態連結。「off」表示所有程式庫都會以靜態模式連結。
標記: loading_and_analysisaffects_outputs
--[no]enable_propeller_optimize_absolute_paths 預設值:「true」
如果設為此值,任何使用 propeller optimize 的絕對路徑都會發生錯誤。
標記: affects_outputs
--[no]enable_remaining_fdo_absolute_paths 預設值:「true」
如果設為此值,任何使用 FDO 的絕對路徑都會發生錯誤。
標記: affects_outputs
--[no]enable_runfiles 預設值:「auto」
啟用 runfiles 符號連結樹狀結構;預設情況下,Windows 和其他平台都會關閉。
標記: affects_outputs
--experimental_action_listener=<a build target label> 累積多次使用
已淘汰,改用切面。使用 action_listener 將 extra_action 附加至現有的建構動作。
標記: executionexperimental
--[no]experimental_android_compress_java_resources 預設值:「false」
壓縮 APK 中的 Java 資源
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_android_databinding_v2 預設值:「true」
使用 Android Databinding v2。這個標記不會執行任何操作。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]experimental_android_resource_shrinking 預設值:「false」
為使用 ProGuard 的 android_binary APK 啟用資源縮減功能。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_android_rewrite_dexes_with_rex 預設值:「false」
使用 rex 工具重寫 dex 檔案
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]experimental_collect_code_coverage_for_generated_files 預設值:「false」
如果指定,Bazel 也會為產生的檔案產生收集涵蓋率資訊。
標記: affects_outputsexperimental
--experimental_objc_fastbuild_options=<comma-separated list of options> 預設值:"-O0,-DDEBUG=1"
使用這些字串做為 objc fastbuild 編譯器選項。
標記: action_command_lines
--[no]experimental_omitfp 預設值:「false」
如果設為 True,請使用 libunwind 進行堆疊解開作業,並使用 -fomit-frame-pointer 和 -fasynchronous-unwind-tables 進行編譯。
標記: action_command_linesaffects_outputsexperimental
--experimental_output_paths=<off, content or strip> 預設值:「off」
在輸出樹狀結構規則寫入輸出內容時,應使用哪個模型,特別適用於多平台 / 多設定版本。這項功能仍在實驗階段,詳情請參閱 https://github.com/bazelbuild/bazel/issues/6526。Starlark 動作可以選擇啟用路徑對應功能,方法是將「supports-path-mapping」鍵新增至「execution_requirements」字典。
標記: loses_incremental_statebazel_internal_configurationaffects_outputsexecution
--experimental_override_name_platform_in_output_dir=<a 'label=value' assignment> 累積多次使用
每個項目都應採用 label=value 的格式,其中 label 是指平台,而 value 是輸出路徑中要使用的所需簡稱。僅在 --experimental_platform_in_output_dir 為 true 時使用。具有最高的命名優先順序。
標記: affects_outputsexperimental
--[no]experimental_platform_in_output_dir 預設值:「false」
如果為 true,輸出目錄名稱會使用目標平台的短名稱,而非 CPU。具體的配置為實驗性質,可能會變更:首先,在極少數情況下,如果 --platforms 選項不含確切的一個值,系統會使用 platforms 選項的雜湊值。接著,如果目前平台的任何簡稱都已透過 --experimental_override_name_platform_in_output_dir 註冊,系統就會使用該簡稱。接著,如果已設定 --experimental_use_platforms_in_output_dir_legacy_heuristic,請使用目前平台標籤的短名稱。最後,平台選項的雜湊值會用於最後的手段。
標記: affects_outputsexperimental
--[no]experimental_py_binaries_include_label 預設值:「false」
即使停用沖壓功能,py_binary 目標也會包含標籤。
標記: affects_outputsexperimental
--[no]experimental_use_llvm_covmap 預設值:「false」
如果指定此選項,在啟用 collect_code_coverage 時,Bazel 會產生 llvm-cov 涵蓋範圍對應資訊,而非 gcov。
標記: changes_inputsaffects_outputsloading_and_analysisexperimental
--[no]experimental_use_platforms_in_output_dir_legacy_heuristic 預設值:「true」
請僅在建議的遷移或測試策略中使用這個標記。請注意,啟發式搜尋有已知的缺陷,建議您改為只使用 --experimental_override_name_platform_in_output_dir。
標記: affects_outputsexperimental
--fdo_instrument=<a string> 預設值:請參閱說明
使用 FDO 檢測功能產生二進位檔。使用 Clang/LLVM 編譯器時,它也會接受目錄名稱,以便在執行階段轉儲原始設定檔檔案。
標記: affects_outputs
--fdo_optimize=<a string> 預設值:請參閱說明
使用 FDO 設定檔資訊來最佳化編譯作業。指定內含 .gcda 檔案樹狀結構的 ZIP 檔案名稱、內含自動設定檔的 afdo 檔案,或 LLVM 設定檔檔案。這個旗標也接受指定為標籤的檔案 (例如 `//foo/bar:file.afdo` - 您可能需要在對應的套件中新增 `exports_files` 指示),以及指向 `fdo_profile` 目標的標籤。這項標記將由 `fdo_profile` 規則取代。
標記: affects_outputs
--fdo_prefetch_hints=<a build target label> 預設值:請參閱說明
使用快取預先擷取提示。
標記: affects_outputs
--fdo_profile=<a build target label> 預設值:請參閱說明
fdo_profile 代表用於最佳化的設定檔。
標記: affects_outputs
--features=<a string> 累積多次使用
對於在目標設定中建構的目標,系統會預設啟用或停用指定功能。指定 -<feature> 會停用該功能。負面特徵一律會覆寫正面特徵。另請參閱 --host_features
標記: changes_inputsaffects_outputs
--[no]force_pic 預設值:「false」
如果啟用,所有 C++ 編譯作業都會產生位置無關的程式碼 ("-fPIC"),連結會優先使用 PIC 預先建構的程式庫,而非非 PIC 程式庫,且連結會產生位置無關的可執行檔 ("-pie")。
標記: loading_and_analysisaffects_outputs
--host_action_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定執行作業設定可用的環境變數組合。變數可以透過名稱指定,在這種情況下,系統會從叫用環境取得值;也可以透過名稱=值組合指定,在這種情況下,系統會設定不受叫用環境影響的值。這個選項可以重複使用;如果是針對同一個變數提供的選項,則以最新的選項為準;如果是針對不同變數提供的選項,則會累加。
標記: action_command_lines
--host_compilation_mode=<fastbuild, dbg or opt> 預設值:「opt」
指定在建構期間使用的工具將以何種模式建構。值:'fastbuild'、'dbg'、'opt'。
標記: affects_outputsaction_command_lines
--host_conlyopt=<a string> 累積多次使用
在執行設定中編譯 C (但非 C++) 來源檔案時,要傳遞至 C 編譯器的其他選項。
標記: action_command_linesaffects_outputs
--host_copt=<a string> 累積多次使用
為執行設定中建構的工具,傳遞至 C 編譯器的其他選項。
標記: action_command_linesaffects_outputs
--host_cpu=<a string> 預設值:""
主機 CPU。
標記: changes_inputsaffects_outputs
--host_cxxopt=<a string> 累積多次使用
針對在執行設定中建構的工具,傳遞至 C++ 編譯器的其他選項。
標記: action_command_linesaffects_outputs
--host_features=<a string> 累積多次使用
對於在執行設定中建構的目標,系統會依預設啟用或停用指定功能。指定 -<feature> 會停用該功能。負面特徵一律會覆寫正面特徵。
標記: changes_inputsaffects_outputs
--host_force_python=<PY2 or PY3> 預設值:請參閱說明
覆寫執行設定的 Python 版本。可以是「PY2」或「PY3」。
標記: loading_and_analysisaffects_outputs
--host_linkopt=<a string> 累積多次使用
在執行設定中連結工具時,要傳遞至連結器的其他選項。
標記: action_command_linesaffects_outputs
--host_macos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
主機目標的最低相容 macOS 版本。如果未指定,系統會使用「macos_sdk_version」。
標記: loses_incremental_state
--host_per_file_copt=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths followed by an @ and a comma separated list of options> 累積多次使用
在執行設定中編譯特定檔案時,可選擇傳遞至 C/C++ 編譯器的其他選項。這個選項可以多次傳遞。語法:regex_filter@選項_1,選項_2,...,選項_n。其中 regex_filter 代表包含和排除的規則運算式模式清單 (另請參閱 --instrumentation_filter)。option_1 到 option_n 代表任意指令列選項。如果選項包含半形逗號,則必須在半形逗號前後加上反斜線。選項可以包含 @。只有第一個 @ 會用來分割字串。範例:--host_per_file_copt=//foo/.*\.cc,-//foo/bar\.cc@-O0 會將 -O0 指令列選項新增至 //foo/ 中所有 cc 檔案 (除了 bar.cc) 的 gcc 指令列。
標記: action_command_linesaffects_outputs
--[no]incompatible_auto_exec_groups 預設值:「false」
啟用後,系統會為規則使用的每個工具鍊自動建立執行群組。為使這項規則運作,您需要在其動作中指定「toolchain」參數。如需更多資訊,請參閱 https://github.com/bazelbuild/bazel/issues/17134。
標記: affects_outputsincompatible_change
--[no]incompatible_merge_genfiles_directory 預設值:「true」
如果設為 true,系統會將 genfiles 目錄折疊至 bin 目錄。
標記: affects_outputsincompatible_change
--[no]instrument_test_targets 預設值:「false」
啟用涵蓋率時,指定是否要考慮檢測測試規則。設定後,--instrumentation_filter 所包含的測試規則就會進行檢測。否則,測試規則一律會從涵蓋率檢測工具中排除。
標記: affects_outputs
--instrumentation_filter=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths> 預設值:「-/javatests[/:],-/test/java[/:]」
啟用涵蓋率後,系統只會檢測名稱包含指定規則運算式篩選器的規則。系統會排除開頭為「-」的規則。請注意,除非啟用 --instrument_test_targets,否則只會檢測非測試規則。
標記: affects_outputs
--ios_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定模擬器和裝置的最低相容 iOS 版本。如果未指定,系統會使用「ios_sdk_version」。
標記: loses_incremental_state
--ios_multi_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的架構清單,用於建構 ios_application。結果會是包含所有指定架構的通用二進位檔。
標記: loses_incremental_stateloading_and_analysis
--[no]legacy_whole_archive 預設值:「true」
已淘汰,已由 --incompatible_remove_legacy_whole_archive 取代 (詳情請參閱 https://github.com/bazelbuild/bazel/issues/7362)。開啟後,請針對 cc_binary 規則使用 --whole-archive,該規則的 linkshared 為 True,且 linkopts 中為 linkstatic=True 或 '-static'。這項設定僅適用於回溯相容性。更好的做法是在需要時使用 alwayslink=1。
標記: action_command_linesaffects_outputsdeprecated
--linkopt=<a string> 累積多次使用
連結時傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--ltobackendopt=<a string> 累積多次使用
傳遞至 LTO 後端步驟的其他選項 (在 --features=thin_lto 下方)。
標記: action_command_linesaffects_outputs
--ltoindexopt=<a string> 累積多次使用
傳遞至 LTO 索引步驟的其他選項 (在 --features=thin_lto 下方)。
標記: action_command_linesaffects_outputs
--macos_cpus=<comma-separated list of options> 累積多次使用
以逗號分隔的架構清單,用於建構 Apple macOS 二進位檔。
標記: loses_incremental_stateloading_and_analysis
--macos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
目標的最低相容 macOS 版本。如果未指定,系統會使用「macos_sdk_version」。
標記: loses_incremental_state
--memprof_profile=<a build target label> 預設值:請參閱說明
使用 memprof 設定檔。
標記: affects_outputs
--[no]objc_debug_with_GLIBCXX 預設值:「false」
如果已設定,且編譯模式設為「dbg」,請定義 GLIBCXX_DEBUG、GLIBCXX_DEBUG_PEDANTIC 和 GLIBCPP_CONCEPT_CHECKS。
標記: action_command_lines
--[no]objc_enable_binary_stripping 預設值:「false」
是否要在已連結的二進位檔上執行符號和無效程式碼去除作業。如果同時指定這個旗標和 --compilation_mode=opt,系統就會執行二進位碼去除作業。
標記: action_command_lines
--objccopt=<a string> 累積多次使用
編譯 Objective-C/C++ 來源檔案時,要傳遞至 gcc 的其他選項。
標記: action_command_lines
--per_file_copt=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths followed by an @ and a comma separated list of options> 累積多次使用
在編譯特定檔案時,可選擇傳遞至 gcc 的其他選項。這個選項可以多次傳遞。語法:regex_filter@選項_1,選項_2,...,選項_n。其中 regex_filter 代表包含和排除的規則運算式模式清單 (另請參閱 --instrumentation_filter)。option_1 到 option_n 代表任意指令列選項。如果選項包含半形逗號,則必須在半形逗號前後加上反斜線。選項可以包含 @。只有第一個 @ 會用來分割字串。範例:--per_file_copt=//foo/.*\.cc,-//foo/bar\.cc@-O0 會將 -O0 指令列選項新增至 //foo/ 中所有 cc 檔案 (除了 bar.cc) 的 gcc 指令列。
標記: action_command_linesaffects_outputs
--per_file_ltobackendopt=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths followed by an @ and a comma separated list of options> 累積多次使用
編譯特定後端物件時,可選擇將哪些選項傳遞至 LTO 後端 (在 --features=thin_lto 下) 的其他選項。這個選項可以多次傳遞。語法:regex_filter@選項_1,選項_2,...,選項_n。其中 regex_filter 代表包含和排除規則運算式的清單。option_1 到 option_n 代表任意指令列選項。如果選項包含半形逗號,則必須在半形逗號前後加上反斜線。選項可以包含 @。只有第一個 @ 會用來分割字串。範例:--per_file_ltobackendopt=//foo/.*\.o,-//foo/bar\.o@-O0 會將 -O0 指令列選項新增至 //foo/ 中所有 o 檔案 (除了 bar.o) 的 LTO 後端指令列。
標記: action_command_linesaffects_outputs
--platform_suffix=<a string> 預設值:請參閱說明
指定要新增至設定目錄的後置字串。
標記: loses_incremental_stateaffects_outputsloading_and_analysis
--propeller_optimize=<a build target label> 預設值:請參閱說明
使用 Propeller 設定檔資訊來改善建構目標。Propeller 設定檔至少必須包含以下兩個檔案之一:cc 設定檔和 ld 設定檔。這個標記可接受建構標籤,但該標籤必須參照螺旋槳設定檔輸入檔案。舉例來說,定義標籤的 BUILD 檔案,在 a/b/BUILD:propeller_optimize( name = "propeller_profile", cc_profile = "propeller_cc_profile.txt", ld_profile = "propeller_ld_profile.txt",) 中,您可能必須在對應的套件中加入 exports_files 指示詞,才能讓 Bazel 看到這些檔案。這個選項必須以以下方式使用:--propeller_optimize=//a/b:propeller_profile
標記: action_command_linesaffects_outputs
--propeller_optimize_absolute_cc_profile=<a string> 預設值:請參閱說明
Propeller 最佳化版本的 cc_profile 檔案絕對路徑名稱。
標記: affects_outputs
--propeller_optimize_absolute_ld_profile=<a string> 預設值:請參閱說明
Propeller 最佳化版本的 ld_profile 檔案絕對路徑名稱。
標記: affects_outputs
--run_under=<a prefix in front of command> 預設值:請參閱說明
在「test」和「run」指令的可執行檔前插入前置字串。如果值為「foo -bar」,執行指令列為「test_binary -baz」,則最終指令列為「foo -bar test_binary -baz」。這也可以是可執行目標的標籤。以下是一些範例:'valgrind'、'strace'、'strace -c'、'valgrind --quiet --num-callers=20'、'//package:target'、'//package:target --options'。
標記: action_command_lines
--[no]share_native_deps 預設值:「true」
如果為 true,含有相同功能的原生程式庫會在不同目標之間共用
標記: loading_and_analysisaffects_outputs
--[no]stamp 預設值:「false」
在二進位檔上蓋上日期、使用者名稱、主機名稱、工作區資訊等資訊。
標記: affects_outputs
--strip=<always, sometimes or never> 預設值:「sometimes」
用於指定是否要移除二進位檔和共用程式庫 (使用「-Wl,--strip-debug」)。預設值為「sometimes」表示如果 --compilation_mode=fastbuild,則會移除。
標記: affects_outputs
--stripopt=<a string> 累積多次使用
產生 '<name>.stripped'二進位檔時,要傳遞至 strip 的其他選項。
標記: action_command_linesaffects_outputs
--tvos_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的架構清單,用於建構 Apple tvOS 二進位檔。
標記: loses_incremental_stateloading_and_analysis
--tvos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定模擬器和裝置的最低相容 tvOS 版本。如果未指定,系統會使用「tvos_sdk_version」。
標記: loses_incremental_state
--visionos_cpus=<comma-separated list of options> 累積多次使用
以逗號分隔的清單,列出要為其建構 Apple visionOS 二進位檔的架構。
標記: loses_incremental_stateloading_and_analysis
--watchos_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的架構清單,用於建構 Apple watchOS 二進位檔。
標記: loses_incremental_stateloading_and_analysis
--watchos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定模擬器和裝置的最低相容 watchOS 版本。如果未指定,系統會使用「watchos_sdk_version」。
標記: loses_incremental_state
--xbinary_fdo=<a build target label> 預設值:請參閱說明
使用 XbinaryFDO 設定檔資訊來最佳化編譯作業。指定預設交叉二進位設定檔的名稱。當此選項與 --fdo_instrument/--fdo_optimize/--fdo_profile 一起使用時,這些選項一律會優先採用,就好像從未指定 xbinary_fdo 一樣。
標記: affects_outputs
影響 Bazel 如何嚴格執行有效建構輸入內容 (規則定義、標記組合等) 的選項:
--[no]check_licenses 預設值:「false」
請確認依附套件施加的授權限制,不會與建構目標的發布模式衝突。根據預設,系統不會檢查授權。
標記: build_file_semantics
--[no]check_visibility 預設值:「true」
如果停用,目標依附元件中的顯示錯誤會降級為警告。
標記: build_file_semantics
--[no]desugar_for_android 預設值:「true」
是否要在解碼前脫糖 Java 8 位元組碼。
標記: affects_outputsloading_and_analysisloses_incremental_state
--[no]desugar_java8_libs 預設值:「false」
是否要在舊版裝置的應用程式中加入支援的 Java 8 程式庫。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]enforce_constraints 預設值:「true」
檢查每個目標的相容環境,如果任何目標的依附元件不支援相同的環境,就會回報錯誤
標記: build_file_semantics
--[no]experimental_check_desugar_deps 預設值:「true」
是否要再次檢查 Android 二進位檔層級的正確去糖化。
標記: eagerness_to_exitloading_and_analysisexperimental
--experimental_import_deps_checking=<a string> 預設值:請參閱說明
無操作,僅保留用於回溯相容性
標記: loading_and_analysis
--experimental_one_version_enforcement=<off, warning or error> 預設值:「OFF」
啟用後,系統會強制規定 java_binary 規則在 classpath 中不得包含同一個類別檔案的多個版本。這項強制執行措施可能會導致建構作業中斷,或只會產生警告。
標記: loading_and_analysis
--experimental_strict_java_deps=<off, warn, error, strict or default> 預設值:"default"
如果為 true,系統會檢查 Java 目標是否明確將所有直接使用的目標宣告為依附元件。
標記: build_file_semanticseagerness_to_exit
--[no]incompatible_check_testonly_for_output_files 預設值:「false」
如果啟用,請查詢產生規則的 testonly,檢查 testonly 是否為輸出檔案的必要條件目標。這項設定與可見度檢查相符。
標記: build_file_semanticsincompatible_change
--[no]incompatible_check_visibility_for_toolchains 預設值:「false」
如果已啟用,可視性檢查也會套用至工具鍊實作。
標記: build_file_semanticsincompatible_change
--[no]incompatible_disable_native_android_rules 預設值:「false」
如果啟用,系統就會停用原生 Android 規則的直接用法。請使用 https://github.com/bazelbuild/rules_android 中的 Starlark Android 規則
標記: eagerness_to_exitincompatible_change
--[no]incompatible_disable_native_apple_binary_rule 預設值:「false」
無操作。為回溯相容性而保留。
標記: eagerness_to_exitincompatible_change
--[no]incompatible_python_disable_py2 預設值:「true」
如果設為 True,使用 Python 2 設定會導致錯誤。包括 python_version=PY2、srcs_version=PY2 和 srcs_version=PY2ONLY。詳情請參閱 https://github.com/bazelbuild/bazel/issues/15684。
標記: loading_and_analysisincompatible_change
--[no]one_version_enforcement_on_java_tests 預設值:「true」
啟用此選項後,如果 experimental_one_version_enforcement 設為非 NONE 值,系統就會在 java_test 目標上強制執行一個版本。您可以停用這個標記,以便提升增量測試效能,但可能會錯過某個版本的違規項目。
標記: loading_and_analysis
--python_native_rules_allowlist=<a build target label> 預設值:請參閱說明
在強制執行 --incompatible_python_disallow_native_rules 時,要使用的許可清單 (package_group 目標)。
標記: loading_and_analysis
--[no]strict_filesets 預設值:「false」
如果啟用這個選項,系統會將跨越套件邊界的檔案集回報為錯誤。
標記: build_file_semanticseagerness_to_exit
--strict_proto_deps=<off, warn, error, strict or default> 預設值:「error」
除非設為 OFF,否則會檢查 proto_library 目標是否明確將所有直接使用的目標宣告為依附元件。
標記: build_file_semanticseagerness_to_exitincompatible_change
--strict_public_imports=<off, warn, error, strict or default> 預設值:「off」
除非設為 OFF,否則會檢查 proto_library 目標是否明確宣告在「import public」中使用的所有目標為匯出目標。
標記: build_file_semanticseagerness_to_exitincompatible_change
--[no]strict_system_includes 預設值:「false」
如果設為 true,則系統會透過系統包含路徑 (-isystem) 找到的標頭,也必須宣告。
標記: loading_and_analysiseagerness_to_exit
--target_environment=<a build target label> 累積多次使用
宣告此版本的目標環境。必須是「環境」規則的標籤參照。如果指定了這個環境,則所有頂層目標都必須與這個環境相容。
標記: changes_inputs
影響建構簽署輸出內容的選項:
--apk_signing_method=<v1, v2, v1_v2 or v4> 預設值:「v1_v2」
用於簽署 APK 的實作方式
標記: action_command_linesaffects_outputsloading_and_analysis
--[no]device_debug_entitlements 預設值:「true」
如果已設定,且編譯模式不是「opt」,則 objc 應用程式會在簽署時加入偵錯授權。
標記: changes_inputs
--ios_signing_cert_name=<a string> 預設值:請參閱說明
用於 iOS 簽署的憑證名稱。如果未設定,系統會改用佈建設定檔。根據 codesign 的 man 頁面 (SIGNING IDENTITIES),可能為憑證的鑰匙圈身分偏好設定或憑證的常用名稱 (子字串)。
標記: action_command_lines
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_disallow_legacy_py_provider 預設值:「true」
無操作,即將移除。
標記: loading_and_analysisincompatible_change
--[no]incompatible_disallow_sdk_frameworks_attributes 預設值:「false」
如果設為 true,就禁止在 objc_library 和 objc_import 中使用 sdk_frameworks 和 weak_sdk_frameworks 屬性。
標記: build_file_semanticsincompatible_change
如果為 true,請將 objc_library 和 objc_import 中的 alwayslink 屬性預設值設為 true。
標記: build_file_semanticsincompatible_change
--[no]incompatible_python_disallow_native_rules 預設值:「false」
如果為 True,使用內建的 py_* 規則時會發生錯誤;應改用 rule_python 規則。詳情請參閱 https://github.com/bazelbuild/bazel/issues/17773 瞭解遷移操作說明。
標記: loading_and_analysisincompatible_change
用於控管測試環境或測試執行工具行為的選項:
--[no]allow_analysis_failures 預設值:「false」
如果設為 true,規則目標的分析失敗會導致目標傳播包含錯誤說明的 AnalysisFailureInfo 例項,而不會導致建構失敗。
標記: loading_and_analysisexperimental
--analysis_testing_deps_limit=<an integer> 預設值:「2000」
透過規則屬性和 for_analysis_testing 設定轉換,設定遞移依附元件的數量上限。若超出這項限制,就會導致規則錯誤。
標記: loading_and_analysis
--[no]break_build_on_parallel_dex2oat_failure 預設值:「false」
如果為 true,則 dex2oat 動作失敗會導致建構作業中斷,而不會在測試執行階段執行 dex2oat。
標記: loading_and_analysisexperimental
--default_test_resources=<a resource name followed by equal and 1 float or 4 float, e.g memory=10,30,60,100> 累積多次使用
覆寫測試的預設資源量。預期格式為 <resource>=<value>。如果指定單一正整數做為 <value>,則會覆寫所有測試大小的預設資源。如果指定 4 個以逗號分隔的數字,這些數字會分別覆寫小、中、大、特大測試大小的資源數量。值也可以是 HOST_RAM/HOST_CPU,並可選擇加上 [-|*]<浮點> (例如 memory=HOST_RAM*.1,HOST_RAM*.2,HOST_RAM*.3,HOST_RAM*.4)。這個旗標指定的預設測試資源,會遭到標記中明確指定的資源覆寫。
--[no]experimental_android_use_parallel_dex2oat 預設值:「false」
並行使用 dex2oat,可能可加快 android_test 的速度。
標記: loading_and_analysishost_machine_resource_optimizationsexperimental
--[no]ios_memleaks 預設值:「false」
啟用 ios_test 目標的記憶體外洩檢查功能。
標記: action_command_lines
--ios_simulator_device=<a string> 預設值:請參閱說明
在模擬器中執行 iOS 應用程式時要模擬的裝置,例如「iPhone 6」。您可以在要執行模擬器的電腦上執行「xcrun simctl list devicetypes」取得裝置清單。
標記: test_runner
--ios_simulator_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
在執行或測試時,要在模擬器上執行的 iOS 版本。如果規則中指定了目標裝置,系統會忽略 ios_test 規則。
標記: test_runner
--runs_per_test=<a positive integer or test_regex@runs. This flag may be passed more than once> 累積多次使用
指定執行每項測試的次數。如果任何嘗試因任何原因失敗,整個測試就會視為失敗。通常指定的值只是整數。範例:--runs_per_test=3 會執行所有測試 3 次。其他語法:regex_filter@runs_per_test。其中 runs_per_test 代表整數值,而 regex_filter 代表包含和排除的規則運算式清單 (另請參閱 --instrumentation_filter)。範例:--runs_per_test=//foo/.*,-//foo/bar/.*@3 會執行 //foo/ 中的所有測試 (foo/bar 下的測試除外),共三次。這個選項可以多次傳遞。系統會優先採用最近傳遞且相符的引數。如果沒有任何相符項目,則只會執行一次測試。
--test_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定要插入測試執行器環境的其他環境變數。變數可以透過名稱指定,在這種情況下,系統會從 Bazel 用戶端環境讀取其值,也可以透過名稱=值組合指定。您可以多次使用此選項指定多個變數。僅供「bazel test」指令使用。
標記: test_runner
--test_timeout=<a single integer or comma-separated list of 4 integers> 預設值:「-1」
覆寫測試逾時的預設逾時值 (以秒為單位)。如果指定單一正整數值,系統會覆寫所有類別。如果指定 4 個以逗號分隔的整數,系統會覆寫短、中、長和永久 (依序) 的逾時時間。無論是哪種表單,如果值為 -1,blaze 就會使用該類別的預設逾時時間。
--[no]zip_undeclared_test_outputs 預設值:「false」
如果設為 true,系統會將未宣告的測試輸出內容封存為 ZIP 檔案。
標記: test_runner
觸發建構時間最佳化功能的選項:
--[no]experimental_filter_library_jar_with_program_jar 預設值:「false」
篩選 ProGuard ProgramJar,移除 LibraryJar 中也存在的任何類別。
標記: action_command_linesexperimental
--[no]experimental_inmemory_dotd_files 預設值:「true」
如果啟用此選項,C++ .d 檔案會直接從遠端建構節點傳遞至記憶體,而不會寫入磁碟。
標記: loading_and_analysisexecutionaffects_outputsexperimental
--[no]experimental_inmemory_jdeps_files 預設值:「true」
如果啟用此選項,系統會直接從遠端建構節點,透過記憶體傳遞從 Java 編譯產生的依附元件檔案 (.jdeps),而不會寫入磁碟。
標記: loading_and_analysisexecutionaffects_outputsexperimental
--[no]experimental_retain_test_configuration_across_testonly 預設值:「false」
啟用後,--trim_test_configuration 就不會為標示為 testonly=1 的規則裁減測試設定。這項功能旨在減少非測試規則依賴 cc_test 規則時的動作衝突問題。如果 --trim_test_configuration 為 false,就不會產生任何影響。
標記: loading_and_analysisloses_incremental_stateexperimental
--[no]experimental_starlark_cc_import 預設值:「false」
如果啟用,即可使用 Starlark 版本的 cc_import。
標記: loading_and_analysisexperimental
--[no]experimental_unsupported_and_brittle_include_scanning 預設值:「false」
是否要透過剖析輸入檔案中的 #include 行,將輸入內容縮減為 C/C++ 編譯。這可縮減編譯輸入樹狀結構的大小,進而提升效能和增量。不過,由於包含掃描器未完全實作 C 預處理器語意,因此也可能會導致建構作業中斷。具體來說,它無法瞭解動態 #include 指示,並會忽略預處理器條件邏輯。您必須自行承擔使用風險。我們會關閉與這個標記相關的所有已提交問題。
標記: loading_and_analysisexecutionchanges_inputsexperimental
--[no]incremental_dexing 預設值:「true」
針對每個 Jar 檔案分別執行大部分的解析工作。
標記: affects_outputsloading_and_analysisloses_incremental_state
--[no]objc_use_dotd_pruning 預設值:「true」
如果設定,系統會使用 Clang 產生的 .d 檔案,來修剪傳遞至 objc 編譯作業的輸入集合。
標記: changes_inputsloading_and_analysis
--[no]process_headers_in_dependencies 預設值:「false」
建構目標 //a:a 時,請處理 //a:a 依附的所有目標中的標頭 (如果工具鍊啟用了標頭處理功能)。
標記: execution
--[no]trim_test_configuration 預設值:「true」
啟用後,系統會清除版本頂層以下的測試相關選項。啟用此標記後,測試就無法建構為非測試規則的依附元件,但變更測試相關選項不會導致非測試規則重新分析。
標記: loading_and_analysisloses_incremental_state
影響記錄詳細程度、格式或位置的選項:
--toolchain_resolution_debug=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths> 預設值:「-.*」
在工具鍊解析期間列印偵錯資訊。這個標記會採用規則運算式,並根據工具鍊類型和特定目標進行檢查,以便查看要偵錯的目標。您可以使用逗號分隔多個規則運算式,然後分別檢查每個規則運算式。注意:這個標記的輸出內容非常複雜,可能只有工具鍊解析專家才會覺得實用。
標記: terminal_output
選項可指定或變更 Bazel 指令的一般輸入內容,而該輸入內容不屬於其他類別:
--flag_alias=<a 'name=value' flag alias> 累積多次使用
設定 Starlark 標記的簡寫名稱。它會將單一鍵/值組合 (格式為「<鍵>=<值>」) 做為引數。
標記: changes_inputs
--[no]incompatible_default_to_explicit_init_py 預設值:「false」
這個標記會變更預設行為,讓 __init__.py 檔案不再自動建立在 Python 目標的執行檔案中。具體來說,如果 py_binary 或 py_test 目標將 legacy_create_init 設為「auto」(預設值),則只有在設定此標記時,才會視為 false。請參閱 https://github.com/bazelbuild/bazel/issues/10076。
標記: affects_outputsincompatible_change
--[no]incompatible_py2_outputs_are_suffixed 預設值:「true」
如果設為 true,在 Python 2 設定中建構的目標會顯示在包含「-py2」字尾的輸出根目錄下,而為 Python 3 建構的目標則會顯示在沒有 Python 相關字尾的根目錄中。也就是說,`bazel-bin` 方便捷符號會指向 Python 3 目標,而非 Python 2。如果您啟用這個選項,建議也啟用 `--incompatible_py3_is_default`。
標記: affects_outputsincompatible_change
--[no]incompatible_py3_is_default 預設值:「true」
如果為 true,則未設定 `python_version` (或 `default_python_version`) 屬性的 `py_binary` 和 `py_test` 目標,預設會使用 PY3 而非 PY2。如果您設定這個旗標,建議也設定 `--incompatible_py2_outputs_are_suffixed`。
標記: loading_and_analysisaffects_outputsincompatible_change
--[no]incompatible_use_python_toolchains 預設值:「true」
如果設為 true,可執行的原生 Python 規則會使用 Python 工具鍊指定的 Python 執行階段,而非由 --python_top 等舊版標記提供的執行階段。
標記: loading_and_analysisincompatible_change
--python_version=<PY2 or PY3> 預設值:請參閱說明
Python 主要版本模式,可選為 `PY2` 或 `PY3`。請注意,這會由 `py_binary` 和 `py_test` 目標覆寫 (即使未明確指定版本),因此通常沒有提供這個旗標的必要。
標記: loading_and_analysisaffects_outputs
其他選項,不屬於其他類別:
--[no]cache_test_results [-t] 預設值:「auto」
如果設為「auto」,Bazel 只會在下列情況下重新執行測試:(1) Bazel 偵測到測試或其依附元件的變更、(2) 測試標示為外部、(3) 使用 --runs_per_test 要求執行多個測試,或(4) 測試先前失敗。如果設為「是」,Bazel 會快取所有測試結果,但標示為外部的測試除外。如果設為「no」,Bazel 就不會快取任何測試結果。
--[no]experimental_cancel_concurrent_tests 預設值:「false」
如果為 true,Blaze 會在第一次成功執行時取消同時執行的測試。只有在搭配 --runs_per_test_detects_flakes 時才有用。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_fetch_all_coverage_outputs 預設值:「false」
如果為 true,Bazel 就會在執行涵蓋率時,為每項測試擷取整個涵蓋率資料目錄。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_generate_llvm_lcov 預設值:「false」
如果設為 True,clang 的涵蓋率就會產生 LCOV 報表。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_j2objc_header_map 預設值:「true」
是否要在 J2ObjC 轉譯時並行產生 J2ObjC 標頭對應項目。
標記: experimental
--[no]experimental_j2objc_shorter_header_path 預設值:「false」
是否要使用較短的標頭路徑產生 (使用「_ios」而非「_j2objc」)。
標記: affects_outputsexperimental
--experimental_java_classpath=<off, javabuilder or bazel> 預設值:「javabuilder」
啟用 Java 編譯作業的縮減路徑集。
--[no]experimental_limit_android_lint_to_android_constrained_java 預設值:「false」
無操作,僅保留用於向後相容性
標記: affects_outputsexperimental
--[no]experimental_run_android_lint_on_java_rules 預設值:「false」
是否要驗證 java_* 來源。
標記: affects_outputsexperimental
--[no]explicit_java_test_deps 預設值:「false」
在 java_test 中明確指定對 JUnit 或 Hamcrest 的依附元件,而不是意外從 TestRunner 的 deps 取得。目前僅適用於 Bazel。
--host_java_launcher=<a build target label> 預設值:請參閱說明
在建構期間執行的工具所使用的 Java 啟動器。
--host_javacopt=<a string> 累積多次使用
建構在建構期間執行的工具時,要傳遞至 javac 的其他選項。
--host_jvmopt=<a string> 累積多次使用
建構期間執行的工具在建構時,傳遞至 Java VM 的其他選項。這些選項會新增至每個 java_binary 目標的 VM 啟動選項。
--[no]incompatible_check_sharding_support 預設值:「true」
如果為 true,如果測試執行程式未透過觸碰 TEST_SHARD_STATUS_FILE 路徑中的檔案,表示不支援分割,則 Bazel 會失敗執行分割測試。如果為 false,則不支援分割的測試執行程式會導致所有測試在每個分割區中執行。
標記: incompatible_change
--[no]incompatible_exclusive_test_sandboxed 預設值:「true」
如果為 true,系統會使用沙箱策略執行專屬測試。新增「local」標記,強制在本機上執行專屬測試
標記: incompatible_change
--[no]incompatible_strict_action_env 預設值:「false」
如果為 True,Bazel 會使用 PATH 的靜態值環境,且不會繼承 LD_LIBRARY_PATH。如果您想從用戶端繼承特定環境變數,請使用 --action_env=ENV_VARIABLE,但請注意,如果使用共用快取,這麼做可能會導致跨使用者快取無法使用。
標記: loading_and_analysisincompatible_change
--j2objc_translation_flags=<comma-separated list of options> 累積多次使用
傳遞至 J2ObjC 工具的其他選項。
--java_debug
讓 Java 測試的 Java 虛擬機器在開始測試前,等待符合 JDWP 標準的偵錯工具 (例如 jdb) 連線。暗示 -test_output=streamed。
展開為:
  --test_arg=--wrapper_script_flag=--debug
  --test_output=streamed
  --test_strategy=exclusive
  --test_timeout=9999
  --nocache_test_results
--[no]java_deps 預設值:「true」
針對每個 Java 目標產生依附元件資訊 (目前為編譯時間的類別路徑)。
--[no]java_header_compilation 預設值:「true」
直接從來源編譯 ijar。
--java_language_version=<a string> 預設值:""
Java 語言版本
--java_launcher=<a build target label> 預設值:請參閱說明
建構 Java 二進位檔時要使用的 Java 啟動器。如果這個標記設為空字串,系統就會使用 JDK 啟動器。「launcher」屬性會覆寫這個旗標。
--java_runtime_version=<a string> 預設值:「local_jdk」
Java 執行階段版本
--javacopt=<a string> 累積多次使用
傳遞至 javac 的其他選項。
--jvmopt=<a string> 累積多次使用
傳遞至 Java VM 的其他選項。這些選項會新增至每個 java_binary 目標的 VM 啟動選項。
--legacy_main_dex_list_generator=<a build target label> 預設值:請參閱說明
指定要使用的二進位檔,用於產生編譯舊版 Multidex 時,必須位於主 DEX 中的類別清單。
--optimizing_dexer=<a build target label> 預設值:請參閱說明
指定用於在不分割的情況下執行解析的二進位檔。
--plugin=<a build target label> 累積多次使用
在建構中使用的外掛程式。目前支援 java_plugin。
--proguard_top=<a build target label> 預設值:請參閱說明
指定建構 Java 二進位檔時,要使用哪個版本的 ProGuard 來移除程式碼。
--proto_compiler=<a build target label> 預設值:"@bazel_tools//tools/proto:protoc"
Proto 編譯器的標籤。
標記: affects_outputsloading_and_analysis
--[no]proto_profile 預設值:「true」
是否將 profile_path 傳遞至 proto 編譯器。
標記: affects_outputsloading_and_analysis
--proto_profile_path=<a build target label> 預設值:請參閱說明
要以 profile_path 形式傳遞至 Proto 編譯器的設定檔。如果未設定,但 --proto_profile 為 true (預設值),系統會從 --fdo_optimize 推斷路徑。
標記: affects_outputsloading_and_analysis
--proto_toolchain_for_cc=<a build target label> 預設值:"@bazel_tools//tools/proto:cc_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 C++ 原型檔
標記: affects_outputsloading_and_analysis
--proto_toolchain_for_j2objc=<a build target label> 預設值:"@bazel_tools//tools/j2objc:j2objc_proto_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 j2objc 原型檔
標籤: affects_outputsloading_and_analysis
--proto_toolchain_for_java=<a build target label> 預設值:"@bazel_tools//tools/proto:java_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 Java 原型檔
標記: affects_outputsloading_and_analysis
--proto_toolchain_for_javalite=<a build target label> 預設值:"@bazel_tools//tools/proto:javalite_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 JavaLite 原型檔
標記: affects_outputsloading_and_analysis
--protocopt=<a string> 累積多次使用
傳遞至 protobuf 編譯器的其他選項。
標記: affects_outputs
--[no]runs_per_test_detects_flakes 預設值:「false」
如果為 true,則任何具有至少一個成功執行/嘗試,以及至少一個失敗執行/嘗試的區塊,都會獲得「不穩定」狀態。
--shell_executable=<a path> 預設值:請參閱說明
Shell 可執行檔的絕對路徑,供 Bazel 使用。如果未設定此值,但在第一次呼叫 Bazel (啟動 Bazel 伺服器) 時已設定 BAZEL_SH 環境變數,Bazel 就會使用該值。如果未設定這兩者,Bazel 會根據執行的作業系統使用硬式編碼的預設路徑 (Windows:c:/msys64/usr/bin/bash.exe、FreeBSD:/usr/local/bin/bash、其他所有作業系統:/bin/bash)。請注意,使用與 bash 不相容的殼層,可能會導致產生的二進位檔發生建構失敗或執行階段失敗。
標記: loading_and_analysis
--test_arg=<a string> 累積多次使用
指定應傳遞至測試可執行檔的其他選項和引數。可多次使用,用於指定多個引數。如果執行多項測試,每項測試都會收到相同的引數。僅供「bazel test」指令使用。
--test_filter=<a string> 預設值:請參閱說明
指定要轉送至測試架構的篩選器。用於限制執行的測試。請注意,這不會影響要建構的目標。
--test_result_expiration=<an integer> 預設值:「-1」
這個選項已淘汰,不會產生任何作用。
--[no]test_runner_fail_fast 預設值:「false」
將快速失敗選項轉送至測試執行程式。測試執行程式應在第一次失敗時停止執行。
--test_sharding_strategy=<explicit, disabled or forced=k where k is the number of shards to enforce> 預設值:「explicit」
指定測試區塊劃分策略:如果有 'shard_count' BUILD 屬性,則只使用區塊劃分策略。如要一律不使用測試分割,請選擇「disabled」。使用「forced=k」強制執行「k」分片進行測試,無論「shard_count」BUILD 屬性為何都一樣。
--tool_java_language_version=<a string> 預設值:""
用於執行建構期間所需工具的 Java 語言版本
--tool_java_runtime_version=<a string> 預設值:「remotejdk_11」
在建構期間用來執行工具的 Java 執行階段版本
--[no]use_ijars 預設值:「true」
如果啟用此選項,Java 編譯作業就會使用介面 JAR 檔案。這會加快增量編譯作業,但錯誤訊息可能會有所不同。

Canonicalize-flags 選項

繼承「build」的所有選項。

用於控制指令輸出的選項:
--[no]canonicalize_policy 預設值:「false」
展開及篩選後,輸出標準政策。為保持輸出內容簡潔,如果將這個選項設為 true,系統就不會顯示標準化指令引數。請注意,--for_command 指定的指令會影響篩除的政策,如果未指定任何指令,預設指令為「build」。
標記: affects_outputsterminal_output
--[no]experimental_include_default_values 預設值:「true」
是否將 Starlark 選項設為預設值,並納入輸出內容。
標記: affects_outputsterminal_output
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_config_setting_private_default_visibility 預設值:「false」
如果 incompatible_enforce_config_setting_visibility=false,則此方法不會執行任何操作。否則,如果這個標記為 false,則任何沒有明確顯示屬性的 config_setting 都是 //visibility:public。如果這個標記設為 True,config_setting 就會遵循與所有其他規則相同的瀏覽權限邏輯。請參閱 https://github.com/bazelbuild/bazel/issues/12933。
標記: loading_and_analysisincompatible_change
--[no]incompatible_enforce_config_setting_visibility 預設值:「true」
如果設為 true,系統就會強制執行 config_setting 曝光度限制。如果為 false,則每個目標都能看到每個 config_setting。請參閱 https://github.com/bazelbuild/bazel/issues/12932。
標記: loading_and_analysisincompatible_change
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
標記: loading_and_analysis
選項可指定或變更一般輸入內容,以便將 Bazel 指令套用至不屬於其他類別的內容:
--for_command=<a string> 預設值:「build」
應將選項標準化的指令。
標記: affects_outputsterminal_output
--invocation_policy=<a string> 預設值:""
將叫用政策套用至要正規化的選項。
標記: affects_outputsterminal_output
其他選項,不屬於其他類別:
--deleted_packages=<comma-separated list of package names> 累積多次使用
以半形逗號分隔的套件名稱清單,即使這些套件名稱在套件路徑的某處可見,建構系統仍會視為不存在。刪除現有套件「x」的子套件「x/y」時,請使用這個選項。舉例來說,在刪除用戶端中的 x/y/BUILD 後,如果建構系統遇到標籤「//x:y/z」,但該標籤仍由另一個 package_path 項目提供,系統可能會發出錯誤訊息。指定 --deleted_packages x/y 即可避免這個問題。
--[no]fetch 預設值:「true」
允許指令擷取外部依附元件。如果設為 false,指令會使用任何快取的依附元件版本,如果沒有任何版本,指令就會失敗。
--package_path=<colon-separated list of options> 預設值:「%workspace%」
以冒號分隔的清單,列出尋找套件的來源。以「%workspace%」開頭的元素是相對於包含工作區的元素。如果省略或留空,預設值為執行「bazel info default-package-path」的輸出內容。
--[no]show_loading_progress 預設值:「true」
如果啟用,Bazel 就會顯示「Loading package:」訊息。

清除選項

繼承「build」的所有選項。

用於控制指令輸出的選項:
--[no]async 預設值:「false」
如果為 true,輸出清理作業會以非同步方式執行。這個指令完成後,即使刪除作業可能會在背景繼續執行,您還是可以在同一個用戶端中安全地執行新指令。
標記: host_machine_resource_optimizations
--[no]expunge 預設值:「false」
如果為 true,clean 會移除此 Bazel 例項的整個工作樹狀結構 (包括所有 Bazel 建立的暫時性和建構輸出檔案),並在 Bazel 伺服器執行時將其停止。
標記: host_machine_resource_optimizations
--expunge_async
如果指定此選項,clean 會非同步移除這個 bazel 例項的整個工作樹狀結構 (包括所有由 bazel 建立的暫存檔和建構輸出檔案),並且在執行時停止 bazel 伺服器。這個指令完成後,即使刪除作業可能會在背景繼續執行,您還是可以在同一個用戶端中安全地執行新指令。
展開為:
  --expunge
  --async

標記: host_machine_resource_optimizations
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
代碼: loading_and_analysis

設定選項

涵蓋率選項

繼承 test 的所有選項。

這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
代碼: loading_and_analysis

Cquery 選項

繼承 test 的所有選項。

這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
標記: loading_and_analysis
與查詢輸出和語義相關的選項:
--aspect_deps=<off, conservative or precise> 預設值:「conservative」
如何在輸出格式為 {xml,proto,record} 的情況下解析面向依附元件。「off」表示不會解析任何面向依賴項、「conservative」(預設值) 表示會新增所有已宣告的面向依賴項,無論其是否已指定直接依賴項的規則類別;「precise」表示只會新增那些在直接依賴項的規則類別中可能處於作用中的面向。請注意,精確模式需要載入其他套件才能評估單一目標,因此速度會比其他模式慢。另請注意,即使是精確模式也不完全精確:決定是否要計算某個面向的決定是在分析階段做出,而這並不會在「bazel 查詢」期間執行。
標記: build_file_semantics
--[no]consistent_labels 預設值:「false」
如果啟用,每個查詢指令都會像是將 Starlark <code>str</code> 函式套用至 <code>Label</code> 例項時一樣,發出標籤。這項功能對於需要比對不同查詢指令和/或規則產生標籤的工具來說非常實用。如果未啟用,輸出格式化器可以自由發出明顯的存放區名稱 (相對於主要存放區),以便讓輸出內容更易讀。
標記: terminal_output
--[no]experimental_explicit_aspects 預設值:「false」
aquery、cquery:是否要在輸出內容中加入由子集產生的動作。query:無操作 (一律會遵循子集)。
標記: terminal_output
--[no]graph:factored 預設值:「true」
如果設為 true,系統會「分解」圖表,也就是將拓樸上等價的節點合併,並連結其標籤。這個選項僅適用於 --output=graph。
標記: terminal_output
--graph:node_limit=<an integer> 預設值:「512」
輸出內容中圖形節點標籤字串的長度上限。較長的標籤會遭到截斷;-1 表示不截斷。這個選項僅適用於 --output=graph。
標記: terminal_output
--[no]implicit_deps 預設值:「true」
如果啟用,系統會在查詢運作的依附元件圖表中加入隱含依附元件。隱含依附元件是指未在 BUILD 檔案中明確指定,但由 Bazel 新增的依附元件。針對 cquery,這個選項會控制篩選已解析的工具鍊。
標記: build_file_semantics
--[no]include_aspects 預設值:「true」
aquery、cquery:是否要在輸出內容中加入由子集產生的動作。query:無操作 (一律會遵循子集)。
標記: terminal_output
--[no]incompatible_package_group_includes_double_slash 預設值:「true」
如果啟用此選項,在輸出 package_group 的 `packages` 屬性時,系統就不會省略開頭的 `//`。
標記: terminal_outputincompatible_change
--[no]infer_universe_scope 預設值:「false」
如果已設定且未設定 --universe_scope,系統會將 --universe_scope 的值推斷為查詢運算式中的不重複目標模式清單。請注意,如果查詢運算式使用全域範圍函式 (例如 `allrdeps`),系統推斷的 --universe_scope 值可能不是您想要的,因此請務必確實瞭解這個選項的用途後再使用。如需詳細資訊和範例,請參閱 https://bazel.build/reference/query#sky-query。如果已設定 --universe_scope,系統會忽略這個選項的值。注意:這個選項僅適用於 `query` (即非 `cquery`)。
代碼: loading_and_analysis
--[no]line_terminator_null 預設值:「false」
是否以 \0 而非換行符號結束每個格式。
標記: terminal_output
--[no]nodep_deps 預設值:「true」
如果啟用,系統會在查詢運作的依附元件圖中納入「nodep」屬性的依附元件。「nodep」屬性的常見例子為「visibility」。執行並剖析 `info build-language` 的輸出內容,瞭解建構語言中的所有「nodep」屬性。
標記: build_file_semantics
--output=<a string> 預設值:"label"
cquery 結果的輸出格式。cquery 的允許值為:label、label_kind、textproto、transitions、proto、streamed_proto、jsonproto。如果選取「transitions」,您也必須指定 --transitions=(lite|full) 選項。
標記: terminal_output
--[no]proto:default_values 預設值:「true」
如果為 true,則會納入 BUILD 檔案中未明確指定值的屬性;否則會略過這些屬性。這個選項適用於 --output=proto
標記: terminal_output
--[no]proto:definition_stack 預設值:「false」
為 definition_stack proto 欄位填入資料,為每個規則例項記錄規則類別定義時的 Starlark 呼叫堆疊。
標記: terminal_output
--[no]proto:flatten_selects 預設值:「true」
如果啟用,則由 select() 建立的可設定屬性會扁平化。對於清單類型,平坦化表示法是清單,其中只包含所選對應項目的每個值一次。純量型別會扁平化為空值。
標記: build_file_semantics
--[no]proto:include_attribute_source_aspects 預設值:「false」
將屬性來源的來源層面填入每個屬性的 source_aspect_name 原型欄位 (如果沒有,則為空字串)。
標記: terminal_output
--[no]proto:include_configurations 預設值:「true」
如果啟用,Proto 輸出內容就會包含設定資訊。停用時,cquery proto 輸出格式會類似查詢輸出格式。
標記: affects_outputs
--[no]proto:include_synthetic_attribute_hash 預設值:「false」
是否要計算並填入 $internal_attr_hash 屬性。
標記: terminal_output
--[no]proto:instantiation_stack 預設值:「false」
填入每項規則的例項化呼叫堆疊。請注意,這需要堆疊存在
標記: terminal_output
--[no]proto:locations 預設值:「true」
是否在 Proto 輸出內容中輸出位置資訊。
標記: terminal_output
--proto:output_rule_attrs=<comma-separated list of options> 預設值:「all」
以半形逗號分隔的屬性清單,用於納入輸出內容。預設為所有屬性。如要不輸出任何屬性,請將其設為空字串。這個選項適用於 --output=proto。
標記: terminal_output
--[no]proto:rule_classes 預設值:「false」
為每項規則填入 rule_class_key 欄位;如果第一個規則具有指定的 rule_class_key,請為其填入 rule_class_info 原型欄位。rule_class_key 欄位可唯一識別規則類別,而 rule_class_info 欄位則是 Stardoc 格式的規則類別 API 定義。
標記: terminal_output
--[no]proto:rule_inputs_and_outputs 預設值:「true」
是否要填入 rule_input 和 rule_output 欄位。
標記: terminal_output
--query_file=<a string> 預設值:""
如果設定此值,查詢會從此處指定的檔案讀取查詢,而不是從指令列讀取。在此處指定檔案和指令列查詢是錯誤的做法。
標記: changes_inputs
--[no]relative_locations 預設值:「false」
如果設為 true,XML 和 Proto 輸出內容中的 BUILD 檔案位置會是相對位置。根據預設,位置輸出內容為絕對路徑,且在不同機器上不會一致。您可以將這個選項設為 true,讓各機器的結果保持一致。
標記: terminal_output
--show_config_fragments=<off, direct or transitive> 預設值:「off」
顯示規則和其間接依附元件所需的設定片段。這項功能可用於評估可裁減的已設定目標圖表數量。
標記: affects_outputs
--starlark:expr=<a string> 預設值:""
Starlark 運算式,用於在 cquery 的 --output=starlark 模式中格式化每個已設定的目標。已設定的目標會繫結至「target」。如果未指定 --starlark:expr 或 --starlark:file,此選項的預設值為 'str(target.label)'。請勿同時指定 --starlark:expr 和 --starlark:file。
標記: terminal_output
--starlark:file=<a string> 預設值:""
定義名為「format」的 Starlark 函式檔案名稱,該函式會套用至每個已設定的目標,並將其格式化為字串。請勿同時指定 --starlark:expr 和 --starlark:file,否則會發生錯誤。如需更多詳細資訊,請參閱 --output=starlark 的說明。
標記: terminal_output
--[no]tool_deps 預設值:「true」
查詢:如果停用,系統就不會在查詢運作的依附元件圖中納入「執行設定」的依附元件。「執行設定」依附元件邊緣 (例如從任何「proto_library」規則到 Protocol Compiler 的邊緣),通常會指向建構期間執行的工具,而非同一個「target」程式的一部分。Cquery:如果停用,系統會篩除所有從發現此已設定目標的頂層目標跨越執行轉換的已設定目標。也就是說,如果頂層目標位於目標設定中,則系統只會傳回目標設定中已設定的目標。如果頂層目標位於執行設定中,系統只會傳回執行設定的目標。這個選項不會排除已解析的工具鍊。
標記: build_file_semantics
--transitions=<full, lite or none> 預設值:「none」
cquery 會以此格式列印轉換資訊。
標記: affects_outputs
--universe_scope=<comma-separated list of options> 預設值:""
以逗號分隔的目標模式組合 (加法和減法)。查詢可能會在指定目標的傳遞閉包所定義的宇宙中執行。這個選項可用於查詢和 cquery 指令。對於 cquery,這個選項的輸入內容是所有答案的目標,因此這個選項可能會影響設定和轉換。如果未指定這個選項,系統會假設頂層目標是從查詢運算式解析的目標。注意:如果從查詢運算式解析的目標無法使用頂層選項進行建構,則針對 cquery 未指定此選項可能會導致建構作業中斷。
代碼: loading_and_analysis
控制建構執行作業的選項:
是否要直接呼叫檔案系統以建立符號連結樹狀結構,而非委派給輔助程序。
標記: loading_and_analysisexecutionexperimental
--[no]experimental_persistent_aar_extractor 預設值:「false」
使用 worker 啟用持續性 AAR Extractor。
標記: executionexperimental
--[no]experimental_remotable_source_manifests 預設值:「false」
是否要讓來源資訊清單動作可遠端執行
標記: loading_and_analysisexecutionexperimental
--[no]experimental_split_coverage_postprocessing 預設值:「false」
如果為 true,Bazel 就會在新的產生事件中執行測試的涵蓋率後置處理程序。
標記: executionexperimental
--[no]experimental_strict_fileset_output 預設值:「false」
如果啟用這個選項,檔案集會將所有輸出構件視為一般檔案。不會遍歷目錄,也不會對符號連結敏感。
標記: executionexperimental
--[no]incompatible_modify_execution_info_additive 預設值:「false」
啟用後,傳遞多個 --modify_execution_info 標記會相加。停用時,系統只會考量最後一個標記。
標記: executionaffects_outputsloading_and_analysisincompatible_change
--modify_execution_info=<regex=[+-]key,regex=[+-]key,...> 累積多次使用
根據動作助憶法,新增或移除動作執行資訊中的鍵。僅適用於支援執行資訊的動作。許多常見動作都支援執行資訊,例如 Genrule、CppCompile、Javac、StarlarkAction、TestRunner。指定多個值時,順序很重要,因為許多規則運算式可能會套用相同的助憶法。語法:「regex=[+-]key,regex=[+-]key,...」。範例: «.*=+x,.*=-y,.*=+z» 會將「x」和「z」加入所有動作的執行資訊,並移除「y」。'Genrule=+requires-x' 會將 'requires-x' 新增至所有 Genrule 動作的執行資訊。'(?!Genrule).*=-requires-x' 會從所有非 Genrule 動作的執行資訊中移除 'requires-x'。
標記: executionaffects_outputsloading_and_analysis
--persistent_android_dex_desugar
使用工作者啟用持續性的 Android dex 和 desugar 動作。
展開為:
  --internal_persistent_android_dex_desugar
  --strategy=Desugar=worker
  --strategy=DexBuilder=worker

標記: host_machine_resource_optimizationsexecution
--persistent_android_resource_processor
使用 worker 啟用 Android 資源處理器。
展開為:
  --internal_persistent_busybox_tools
  --strategy=AaptPackage=worker
  --strategy=AndroidResourceParser=worker
  --strategy=AndroidResourceValidator=worker
  --strategy=AndroidResourceCompiler=worker
  --strategy=RClassGenerator=worker
  --strategy=AndroidResourceLink=worker
  --strategy=AndroidAapt2=worker
  --strategy=AndroidAssetMerger=worker
  --strategy=AndroidResourceMerger=worker
  --strategy=AndroidCompiledResourceMerger=worker
  --strategy=ManifestMerger=worker
  --strategy=AndroidManifestMerger=worker
  --strategy=Aapt2Optimize=worker
  --strategy=AARGenerator=worker
  --strategy=ProcessDatabinding=worker
  --strategy=GenerateDataBindingBaseClasses=worker

標記: host_machine_resource_optimizationsexecution
--persistent_multiplex_android_dex_desugar
使用 worker 啟用持續性的多重 Android dex 和 desugar 動作。
展開為:
  --persistent_android_dex_desugar
  --internal_persistent_multiplex_android_dex_desugar

標記: host_machine_resource_optimizationsexecution
--persistent_multiplex_android_resource_processor
使用 worker 啟用持續性的多重 Android 資源處理器。
展開為:
  --persistent_android_resource_processor
  --modify_execution_info=AaptPackage=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceParser=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceValidator=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceCompiler=+supports-multiplex-workers
  --modify_execution_info=RClassGenerator=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceLink=+supports-multiplex-workers
  --modify_execution_info=AndroidAapt2=+supports-multiplex-workers
  --modify_execution_info=AndroidAssetMerger=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceMerger=+supports-multiplex-workers
  --modify_execution_info=AndroidCompiledResourceMerger=+supports-multiplex-workers
  --modify_execution_info=ManifestMerger=+supports-multiplex-workers
  --modify_execution_info=AndroidManifestMerger=+supports-multiplex-workers
  --modify_execution_info=Aapt2Optimize=+supports-multiplex-workers
  --modify_execution_info=AARGenerator=+supports-multiplex-workers

標記: host_machine_resource_optimizations, execution
--persistent_multiplex_android_tools
啟用持續性和多重化的 Android 工具 (dexing、desugaring、資源處理)。
展開為:
  --internal_persistent_multiplex_busybox_tools
  --persistent_multiplex_android_resource_processor
  --persistent_multiplex_android_dex_desugar

標記: host_machine_resource_optimizationsexecution
--[no]use_target_platform_for_tests 預設值:「false」
如果為 true,Bazel 會使用目標平台執行測試,而不是使用測試執行群組。
代碼: execution
設定用於執行動作的工具鍊的選項:
--android_compiler=<a string> 預設值:請參閱說明
Android 目標編譯器。
標記: affects_outputsloading_and_analysisloses_incremental_state
--android_manifest_merger=<legacy, android or force_android> 預設值:「android」
選取要用於 android_binary 規則的資訊清單合併工具。旗標,可協助從舊版合併工具轉換至 Android 資訊清單合併工具。
標記: affects_outputsloading_and_analysisloses_incremental_state
--android_platforms=<a build target label> 預設值:""
設定 android_binary 目標使用的平台。如果指定多個平台,則二進位檔會是笨重的 APK,其中包含每個指定目標平台的原生二進位檔。
標記: changes_inputsloading_and_analysisloses_incremental_state
--apple_crosstool_top=<a build target label> 預設值:"@bazel_tools//tools/cpp:toolchain"
在 Apple 和 Objc 規則及其依附元件中使用的 crosstool 套件標籤。
標記: loses_incremental_statechanges_inputs
--cc_output_directory_tag=<a string> 預設值:""
指定要新增至設定目錄的後置字串。
標記: affects_outputs
--compiler=<a string> 預設值:請參閱說明
用於編譯目標的 C++ 編譯器。
標記: loading_and_analysisexecution
--coverage_output_generator=<a build target label> 預設值:"@bazel_tools//tools/test:lcov_merger"
用於後處理原始涵蓋率報表的二進位檔位置。這個檔案群組目前必須包含單一檔案 (二進位檔)。預設值為 '//tools/test:lcov_merger'。
標記: changes_inputsaffects_outputsloading_and_analysis
--coverage_report_generator=<a build target label> 預設值:"@bazel_tools//tools/test:coverage_report_generator"
用於產生涵蓋率報表的二進位檔位置。這個檔案群組目前必須包含單一檔案 (二進位檔)。預設值為 '//tools/test:coverage_report_generator'。
標記: changes_inputsaffects_outputsloading_and_analysis
--coverage_support=<a build target label> 預設值:"@bazel_tools//tools/test:coverage_support"
收集程式碼涵蓋率的每個測試動作輸入項目所需的支援檔案位置。預設值為 '//tools/test:coverage_support'。
標記: changes_inputsaffects_outputsloading_and_analysis
--custom_malloc=<a build target label> 預設值:請參閱說明
指定自訂 malloc 實作項目。這項設定會覆寫建構規則中的 malloc 屬性。
標記: changes_inputsaffects_outputs
--experimental_add_exec_constraints_to_targets=<a '<RegexFilter>=<label1>[,<label2>,...]' assignment> 累積多次使用
以逗號分隔的規則運算式清單,每個運算式可選擇加上前置字元 - (負值運算式),並將 (=) 指派給以逗號分隔的限制值目標清單。如果目標不符合任何負面運算式,且至少符合一個正面運算式,則會執行工具鍊解析作業,就像宣告限制值為執行限制一樣。範例://demo,-test=@platforms//cpus:x86_64 會將「x86_64」新增至 //demo 下的任何目標,但名稱含有「test」的目標除外。
標記: loading_and_analysis
--[no]experimental_include_xcode_execution_requirements 預設值:「false」
如果已設定,請在每個 Xcode 動作中新增「requires-xcode:{version}」執行需求。如果 Xcode 版本有連字號標籤,請一併新增「requires-xcode-label:{version_label}」執行要求。
標記: loses_incremental_stateloading_and_analysisexecutionexperimental
--[no]experimental_prefer_mutual_xcode 預設值:「true」
如果為 true,請使用在本機和遠端都可用的最新 Xcode。如果為 false,或沒有可用的共同版本,請使用透過 xcode-select 所選的本機 Xcode 版本。
標記: loses_incremental_stateexperimental
--extra_execution_platforms=<comma-separated list of options> 預設值:""
可用於執行動作的執行平台。您可以使用完全比對目標或目標模式指定平台。系統會先考慮這些平台,再考慮由 register_execution_platforms() 在 WORKSPACE 檔案中宣告的平台。這個選項只能設定一次;後續的例項會覆寫先前的標記設定。
標記: execution
--extra_toolchains=<comma-separated list of options> 累積多次使用
在工具鍊解析期間要考量的工具鍊規則。您可以使用確切目標或目標模式指定工具鍊。系統會先考慮這些工具鍊,再考慮 WORKSPACE 檔案中透過 register_toolchains() 宣告的工具鍊。
標記: affects_outputschanges_inputsloading_and_analysis
--grte_top=<a label> 預設值:請參閱說明
已檢查的 libc 程式庫的標籤。預設值是由 crosstool 工具鍊選取,您幾乎不需要覆寫。
標記: action_command_linesaffects_outputs
--host_compiler=<a string> 預設值:請參閱說明
無操作標記。將在日後推出的版本中移除。
標記: loading_and_analysisexecution
--host_grte_top=<a label> 預設值:請參閱說明
如果指定此值,這項設定會覆寫執行設定的 libc 頂層目錄 (--grte_top)。
標記: action_command_linesaffects_outputs
--host_platform=<a build target label> 預設值:"@bazel_tools//tools:host_platform"
平台規則的標籤,用於說明主機系統。
標記: affects_outputschanges_inputsloading_and_analysis
--[no]incompatible_bazel_test_exec_run_under 預設值:「false」
如果啟用,則「bazel test --run_under=//:runner」會在執行設定中建構「//:runner」。如果停用,則會在目標設定中建構「//:runner」。Bazel 會在執行機器上執行測試,因此前者較為正確。這不會影響「bazel run」,因為這項指令會一律在目標設定中建構「--run_under=//foo」。
標記: affects_outputsincompatible_change
--[no]incompatible_dont_enable_host_nonhost_crosstool_features 預設值:「true」
如果設為 true,Bazel 就不會在 c++ 工具鍊中啟用「host」和「nonhost」功能 (詳情請參閱 https://github.com/bazelbuild/bazel/issues/7407)。
標記: loading_and_analysisincompatible_change
--[no]incompatible_enable_apple_toolchain_resolution 預設值:「false」
使用工具鍊解析來選取 Apple 規則的 Apple SDK (Starlark 和原生)
標記: loading_and_analysisincompatible_change
--[no]incompatible_remove_legacy_whole_archive 預設值:「true」
如果為 true,Bazel 預設不會將程式庫依附元件連結為整個封存檔 (如需遷移操作說明,請參閱 https://github.com/bazelbuild/bazel/issues/7362)。
標記: loading_and_analysisincompatible_change
--[no]incompatible_strip_executable_safely 預設值:「false」
如果為 true,可執行檔的剝除動作會使用 -x 標記,不會中斷動態符號解析。
標記: action_command_linesincompatible_change
--[no]interface_shared_objects 預設值:「true」
如果工具鍊支援,請使用介面共用物件。目前所有 ELF 工具鍊都支援這項設定。
標記: loading_and_analysisaffects_outputsaffects_outputs
--ios_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 iOS 應用程式的 iOS SDK 版本。如未指定,系統會使用「xcode_version」的預設 iOS SDK 版本。
標記: loses_incremental_state
--macos_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 macOS 應用程式的 macOS SDK 版本。如未指定,系統會使用「xcode_version」中的預設 macOS SDK 版本。
標記: loses_incremental_state
--minimum_os_version=<a string> 預設值:請參閱說明
編譯目標的最低作業系統版本。
標記: loading_and_analysisaffects_outputs
--platform_mappings=<a main workspace-relative path> 預設值:""
對應檔案的位置,可說明在未設定任何平台時要使用的平台,或在已存在平台時要設定的旗標。必須相對於主要工作區根目錄。預設值為「platform_mappings」(工作區根目錄下方的檔案)。
標記: affects_outputschanges_inputsloading_and_analysisimmutable
--platforms=<a build target label> 預設值:""
平台規則的標籤,說明目前指令的目標平台。
標記: affects_outputschanges_inputsloading_and_analysis
--python_path=<a string> 預設值:請參閱說明
在目標平台上執行 Python 目標時,系統會叫用 Python 解譯器的絕對路徑。已淘汰;已由 --incompatible_use_python_toolchains 停用。
標記: loading_and_analysisaffects_outputs
--python_top=<a build target label> 預設值:請參閱說明
py_runtime 的標籤,代表在目標平台上執行 Python 目標時所叫用的 Python 轉譯器。已淘汰;已由 --incompatible_use_python_toolchains 停用。
標記: loading_and_analysisaffects_outputs
--tvos_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 tvOS 應用程式的 tvOS SDK 版本。如果未指定,系統會使用「xcode_version」中的預設 tvOS SDK 版本。
標記: loses_incremental_state
--watchos_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 watchOS 應用程式的 watchOS SDK 版本。如未指定,系統會使用「xcode_version」的預設 watchOS SDK 版本。
標記: loses_incremental_state
--xcode_version=<a string> 預設值:請參閱說明
如果指定此屬性,系統會使用指定版本的 Xcode 執行相關的建構動作。如未指定,系統會使用執行緒的預設 Xcode 版本。
標記: loses_incremental_state
--xcode_version_config=<a build target label> 預設值:"@bazel_tools//tools/cpp:host_xcodes"
xcode_config 規則的標籤,用於在建構設定中選取 Xcode 版本。
標記: loses_incremental_stateloading_and_analysis
控制指令輸出的選項:
--[no]apple_generate_dsym 預設值:「false」
是否產生偵錯符號 (.dSYM) 檔案。
標記: affects_outputsaction_command_lines
如果為 true,則為所有目標建構 runfiles 符號連結森林。如果為 false,則只有在本機動作、測試或執行指令要求時,才會寫入。
標記: affects_outputs
--[no]build_runfile_manifests 預設值:「true」
如果為 true,則為所有目標寫入 runfiles 資訊清單。如果為 false,則省略這些項目。如果為 false,本機測試就會無法執行。
標記: affects_outputs
--[no]build_test_dwp 預設值:「false」
如果啟用此選項,在使用 Fission 靜態建構 C++ 測試時,系統也會自動建構測試二進位檔的 .dwp 檔案。
標記: loading_and_analysisaffects_outputs
--cc_proto_library_header_suffixes=<comma-separated set of options> 預設值:".pb.h"
設定 cc_proto_library 建立的標頭檔案後置字串。
標記: affects_outputsloading_and_analysis
--cc_proto_library_source_suffixes=<comma-separated set of options> 預設值:「.pb.cc」
設定 cc_proto_library 建立的來源檔案後置字串。
標記: affects_outputsloading_and_analysis
--[no]experimental_proto_descriptor_sets_include_source_info 預設值:「false」
針對 proto_library 中的其他 Java API 版本執行額外動作。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_save_feature_state 預設值:「false」
將已啟用和要求的功能的狀態儲存為編譯的輸出內容。
標記: affects_outputsexperimental
--fission=<a set of compilation modes> 預設值:「no」
指定哪些編譯模式會在 C++ 編譯和連結時使用分裂。可為 {'fastbuild', 'dbg', 'opt'} 或特殊值的任意組合,其中 'yes'可啟用所有模式,'no'可停用所有模式。
標記: loading_and_analysisaction_command_linesaffects_outputs
--[no]incompatible_always_include_files_in_data 預設值:「true」
如果為 true,原生規則會將資料依附元件的 <code>DefaultInfo.files</code> 新增至其執行檔,這與 Starlark 規則的建議行為相符 (https://bazel.build/extending/rules#runfiles_features_to_avoid)。
標記: affects_outputsincompatible_change
--[no]legacy_external_runfiles 預設值:「false」
如果為 true,則會為 .runfiles/wsname/external/repo 下的外部存放區 (除了 .runfiles/repo) 建構執行檔案符號連結森林。
標記: affects_outputs
--[no]objc_generate_linkmap 預設值:「false」
指定是否要產生連結圖檔案。
標記: affects_outputs
--[no]save_temps 預設值:「false」
如果設定,系統會儲存來自 gcc 的臨時輸出內容。包括 .s 檔案 (組譯器程式碼)、.i 檔案 (預處理的 C) 和 .ii 檔案 (預處理的 C++)。
標記: affects_outputs
選項可讓使用者設定預期的輸出內容,影響其值,而非其存在:
--action_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定可供含有目標設定的動作使用的一組環境變數。變數可以透過名稱指定,在這種情況下,系統會從叫用環境取得值;也可以透過名稱=值組合指定,在這種情況下,系統會設定不受叫用環境影響的值。這個選項可以重複使用;如果是針對同一個變數提供的選項,則以最新的選項為準;如果是針對不同變數提供的選項,則會累加。
標記: action_command_lines
--allowed_cpu_values=<comma-separated set of options> 預設值:""
--cpu 標記的有效值。
標記: changes_inputsaffects_outputs
--[no]android_databinding_use_androidx 預設值:「true」
產生與 AndroidX 相容的資料繫結檔案。這個屬性僅適用於資料繫結 v2。這個標記不會執行任何操作。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]android_databinding_use_v3_4_args 預設值:「true」
使用 Android Databinding v2 和 3.4.0 引數。這個標記不會執行任何操作。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--android_dynamic_mode=<off, default or fully> 預設值:「off」
決定在 cc_binary 未明確建立共用程式庫時,是否要動態連結 Android 規則的 C++ 依附元件。「預設」表示 Bazel 會選擇是否要動態連結。「fully」表示所有程式庫都會動態連結。「off」表示所有程式庫都會以靜態模式連結。
標記: affects_outputsloading_and_analysis
--android_manifest_merger_order=<alphabetical, alphabetical_by_configuration or dependency> 預設值:「alphabetical」
設定傳遞至 Android 二進位檔資訊清單合併工具的資訊清單順序。ALPHABETICAL 表示資訊清單會依據相對於執行根目錄的路徑排序。ALPHABETICAL_BY_CONFIGURATION 表示資訊清單會依據輸出目錄中相對於設定目錄的路徑排序。DEPENDENCY 表示資訊清單會依序排列,每個程式庫的資訊清單會排在其依附元件的資訊清單之前。
標記: action_command_linesexecution
--[no]android_resource_shrinking 預設值:「false」
為使用 ProGuard 的 android_binary APK 啟用資源縮減功能。
標記: affects_outputsloading_and_analysis
--[no]build_python_zip 預設值:「auto」
建構 Python 可執行的 zip 檔案;在 Windows 上開啟,在其他平台上關閉
標記: affects_outputs
--catalyst_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的清單,列出要用來建構 Apple Catalyst 二進位檔的架構。
標記: loses_incremental_stateloading_and_analysis
--[no]collect_code_coverage 預設值:「false」
如果指定此選項,Bazel 會檢測程式碼 (盡可能使用離線檢測),並在測試期間收集涵蓋率資訊。只有符合 --instrumentation_filter 的目標才會受到影響。通常不應直接指定這個選項,而應改用「bazel coverage」指令。
標記: affects_outputs
--compilation_mode=<fastbuild, dbg or opt> [-c] 預設值:「fastbuild」
指定要建構二進位檔的模式。值:'fastbuild'、'dbg'、'opt'。
標記: affects_outputsaction_command_lines
--conlyopt=<a string> 累積多次使用
編譯 C 來源檔案時,要傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--copt=<a string> 累積多次使用
傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--cpu=<a string> 預設值:""
目標 CPU。
標記: changes_inputsaffects_outputs
--cs_fdo_absolute_path=<a string> 預設值:請參閱說明
使用 CSFDO 設定檔資訊來最佳化編譯作業。指定內含設定檔檔案的 ZIP 檔案的絕對路徑名稱,也就是原始或索引 LLVM 設定檔檔案。
標記: affects_outputs
--cs_fdo_instrument=<a string> 預設值:請參閱說明
使用情境敏感的 FDO 檢測功能產生二進位檔。使用 Clang/LLVM 編譯器時,它也會接受目錄名稱,以便在執行階段轉儲原始設定檔檔案。
標記: affects_outputs
--cs_fdo_profile=<a build target label> 預設值:請參閱說明
cs_fdo_profile 代表要用於最佳化的內容敏感設定檔。
標記: affects_outputs
--cxxopt=<a string> 累積多次使用
編譯 C++ 來源檔案時,要傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--define=<a 'name=value' assignment> 累積多次使用
每個 --define 選項都會指定建構變數的值。如果變數有多個值,則最後一個值會勝出。
標記: changes_inputsaffects_outputs
--dynamic_mode=<off, default or fully> 預設值:"default"
決定是否要動態連結 C++ 二進位檔。「預設」表示 Bazel 會選擇是否要動態連結。「fully」表示所有程式庫都會動態連結。「off」表示所有程式庫都會以靜態模式連結。
標記: loading_and_analysisaffects_outputs
--[no]enable_propeller_optimize_absolute_paths 預設值:「true」
如果設為此值,任何使用 propeller optimize 的絕對路徑都會發生錯誤。
標記: affects_outputs
--[no]enable_remaining_fdo_absolute_paths 預設值:「true」
如果設為此值,任何使用 FDO 的絕對路徑都會發生錯誤。
標記: affects_outputs
--[no]enable_runfiles 預設值:「auto」
啟用 runfiles 符號連結樹狀結構;預設情況下,Windows 和其他平台都會關閉。
標記: affects_outputs
--experimental_action_listener=<a build target label> 累積多次使用
已淘汰,改用切面。使用 action_listener 將 extra_action 附加至現有的建構動作。
標記: executionexperimental
--[no]experimental_android_compress_java_resources 預設值:「false」
壓縮 APK 中的 Java 資源
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_android_databinding_v2 預設值:「true」
使用 Android Databinding v2。這個標記不會執行任何操作。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]experimental_android_resource_shrinking 預設值:「false」
為使用 ProGuard 的 android_binary APK 啟用資源縮減功能。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_android_rewrite_dexes_with_rex 預設值:「false」
使用 rex 工具重寫 dex 檔案
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]experimental_collect_code_coverage_for_generated_files 預設值:「false」
如果指定,Bazel 也會為產生的檔案產生收集涵蓋率資訊。
標記: affects_outputsexperimental
--experimental_objc_fastbuild_options=<comma-separated list of options> 預設值:"-O0,-DDEBUG=1"
使用這些字串做為 objc fastbuild 編譯器選項。
標記: action_command_lines
--[no]experimental_omitfp 預設值:「false」
如果設為 True,請使用 libunwind 進行堆疊解開作業,並使用 -fomit-frame-pointer 和 -fasynchronous-unwind-tables 進行編譯。
標記: action_command_linesaffects_outputsexperimental
--experimental_output_paths=<off, content or strip> 預設值:「off」
在輸出樹狀結構規則寫入輸出內容時,應使用哪個模型,特別適用於多平台 / 多設定版本。這項功能仍在實驗階段,詳情請參閱 https://github.com/bazelbuild/bazel/issues/6526。Starlark 動作可以選擇啟用路徑對應功能,方法是將「supports-path-mapping」鍵新增至「execution_requirements」字典。
標記: loses_incremental_statebazel_internal_configurationaffects_outputsexecution
--experimental_override_name_platform_in_output_dir=<a 'label=value' assignment> 累積多次使用
每個項目都應採用 label=value 的格式,其中 label 是指平台,而 value 是輸出路徑中要使用的所需簡稱。僅在 --experimental_platform_in_output_dir 為 true 時使用。具有最高的命名優先順序。
標記: affects_outputsexperimental
--[no]experimental_platform_in_output_dir 預設值:「false」
如果為 true,輸出目錄名稱會使用目標平台的短名稱,而非 CPU。具體的配置為實驗性質,可能會變更:首先,在極少數情況下,如果 --platforms 選項不含確切的一個值,系統會使用 platforms 選項的雜湊值。接著,如果目前平台的任何簡稱都已透過 --experimental_override_name_platform_in_output_dir 註冊,系統就會使用該簡稱。接著,如果已設定 --experimental_use_platforms_in_output_dir_legacy_heuristic,請使用目前平台標籤的短名稱。最後,平台選項的雜湊值會用於最後的手段。
標記: affects_outputsexperimental
--[no]experimental_py_binaries_include_label 預設值:「false」
即使停用沖壓功能,py_binary 目標也會包含標籤。
標記: affects_outputsexperimental
--[no]experimental_use_llvm_covmap 預設值:「false」
如果指定此選項,在啟用 collect_code_coverage 時,Bazel 會產生 llvm-cov 涵蓋範圍對應資訊,而非 gcov。
標記: changes_inputsaffects_outputsloading_and_analysisexperimental
--[no]experimental_use_platforms_in_output_dir_legacy_heuristic 預設值:「true」
請僅在建議的遷移或測試策略中使用這個標記。請注意,啟發式搜尋有已知的缺陷,建議您改為只使用 --experimental_override_name_platform_in_output_dir。
標記: affects_outputsexperimental
--fdo_instrument=<a string> 預設值:請參閱說明
使用 FDO 檢測功能產生二進位檔。使用 Clang/LLVM 編譯器時,它也會接受目錄名稱,以便在執行階段轉儲原始設定檔檔案。
標記: affects_outputs
--fdo_optimize=<a string> 預設值:請參閱說明
使用 FDO 設定檔資訊來最佳化編譯作業。指定內含 .gcda 檔案樹狀結構的 ZIP 檔案名稱、內含自動設定檔的 afdo 檔案,或 LLVM 設定檔檔案。這個旗標也接受指定為標籤的檔案 (例如 `//foo/bar:file.afdo` - 您可能需要在對應的套件中新增 `exports_files` 指示),以及指向 `fdo_profile` 目標的標籤。這項標記將由 `fdo_profile` 規則取代。
標記: affects_outputs
--fdo_prefetch_hints=<a build target label> 預設值:請參閱說明
使用快取預先擷取提示。
標記: affects_outputs
--fdo_profile=<a build target label> 預設值:請參閱說明
fdo_profile 代表用於最佳化的設定檔。
標記: affects_outputs
--features=<a string> 累積多次使用
對於在目標設定中建構的目標,系統會預設啟用或停用指定功能。指定 -<feature> 會停用該功能。負面特徵一律會覆寫正面特徵。另請參閱 --host_features
標記: changes_inputsaffects_outputs
--[no]force_pic 預設值:「false」
如果啟用,所有 C++ 編譯作業都會產生位置無關的程式碼 ("-fPIC"),連結會優先使用 PIC 預先建構的程式庫,而非非 PIC 程式庫,且連結會產生位置無關的可執行檔 ("-pie")。
標記: loading_and_analysisaffects_outputs
--host_action_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定執行作業設定可用的環境變數組合。變數可以透過名稱指定,在這種情況下,系統會從叫用環境取得值;也可以透過名稱=值組合指定,在這種情況下,系統會設定不受叫用環境影響的值。這個選項可以重複使用;如果是針對同一個變數提供的選項,則以最新的選項為準;如果是針對不同變數提供的選項,則會累加。
標記: action_command_lines
--host_compilation_mode=<fastbuild, dbg or opt> 預設值:「opt」
指定在建構期間使用的工具將以何種模式建構。值:'fastbuild'、'dbg'、'opt'。
標記: affects_outputsaction_command_lines
--host_conlyopt=<a string> 累積多次使用
在執行設定中編譯 C (但非 C++) 來源檔案時,要傳遞至 C 編譯器的其他選項。
標記: action_command_linesaffects_outputs
--host_copt=<a string> 累積多次使用
為執行設定中建構的工具,傳遞至 C 編譯器的其他選項。
標記: action_command_linesaffects_outputs
--host_cpu=<a string> 預設值:""
主機 CPU。
標記: changes_inputsaffects_outputs
--host_cxxopt=<a string> 累積多次使用
針對在執行設定中建構的工具,傳遞至 C++ 編譯器的其他選項。
標記: action_command_linesaffects_outputs
--host_features=<a string> 累積多次使用
對於在執行設定中建構的目標,系統會依預設啟用或停用指定功能。指定 -<feature> 會停用該功能。負面特徵一律會覆寫正面特徵。
標記: changes_inputsaffects_outputs
--host_force_python=<PY2 or PY3> 預設值:請參閱說明
覆寫執行設定的 Python 版本。可以是「PY2」或「PY3」。
標記: loading_and_analysisaffects_outputs
--host_linkopt=<a string> 累積多次使用
在執行設定中連結工具時,要傳遞至連結器的其他選項。
標記: action_command_linesaffects_outputs
--host_macos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
主機目標的最低相容 macOS 版本。如果未指定,系統會使用「macos_sdk_version」。
標記: loses_incremental_state
--host_per_file_copt=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths followed by an @ and a comma separated list of options> 累積多次使用
在執行設定中編譯特定檔案時,可選擇傳遞至 C/C++ 編譯器的其他選項。這個選項可以多次傳遞。語法:regex_filter@選項_1,選項_2,...,選項_n。其中 regex_filter 代表包含和排除的規則運算式模式清單 (另請參閱 --instrumentation_filter)。option_1 到 option_n 代表任意指令列選項。如果選項包含半形逗號,則必須在半形逗號前後加上反斜線。選項可以包含 @。只有第一個 @ 會用來分割字串。範例:--host_per_file_copt=//foo/.*\.cc,-//foo/bar\.cc@-O0 會將 -O0 指令列選項新增至 //foo/ 中所有 cc 檔案 (除了 bar.cc) 的 gcc 指令列。
標記: action_command_linesaffects_outputs
--[no]incompatible_auto_exec_groups 預設值:「false」
啟用後,系統會為規則使用的每個工具鍊自動建立執行群組。為使這項規則運作,您需要在其動作中指定「toolchain」參數。如需更多資訊,請參閱 https://github.com/bazelbuild/bazel/issues/17134。
標記: affects_outputsincompatible_change
--[no]incompatible_merge_genfiles_directory 預設值:「true」
如果設為 true,系統會將 genfiles 目錄折疊至 bin 目錄。
標記: affects_outputsincompatible_change
--[no]instrument_test_targets 預設值:「false」
啟用涵蓋率時,指定是否要考慮檢測測試規則。設定後,--instrumentation_filter 所包含的測試規則就會進行檢測。否則,測試規則一律會從涵蓋率檢測工具中排除。
標記: affects_outputs
--instrumentation_filter=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths> 預設值:「-/javatests[/:],-/test/java[/:]」
啟用涵蓋率後,系統只會檢測名稱包含指定規則運算式篩選器的規則。系統會排除開頭為「-」的規則。請注意,除非啟用 --instrument_test_targets,否則只會檢測非測試規則。
標記: affects_outputs
--ios_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定模擬器和裝置的最低相容 iOS 版本。如果未指定,系統會使用「ios_sdk_version」。
標記: loses_incremental_state
--ios_multi_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的架構清單,用於建構 ios_application。結果會是包含所有指定架構的通用二進位檔。
標記: loses_incremental_stateloading_and_analysis
--[no]legacy_whole_archive 預設值:「true」
已淘汰,已由 --incompatible_remove_legacy_whole_archive 取代 (詳情請參閱 https://github.com/bazelbuild/bazel/issues/7362)。開啟後,請針對 cc_binary 規則使用 --whole-archive,該規則的 linkshared 為 True,且 linkopts 中為 linkstatic=True 或 '-static'。這項設定僅適用於回溯相容性。更好的做法是在需要時使用 alwayslink=1。
標記: action_command_linesaffects_outputsdeprecated
--linkopt=<a string> 累積多次使用
連結時傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--ltobackendopt=<a string> 累積多次使用
傳遞至 LTO 後端步驟的其他選項 (在 --features=thin_lto 下方)。
標記: action_command_linesaffects_outputs
--ltoindexopt=<a string> 累積多次使用
傳遞至 LTO 索引步驟的其他選項 (在 --features=thin_lto 下方)。
標記: action_command_linesaffects_outputs
--macos_cpus=<comma-separated list of options> 累積多次使用
以逗號分隔的架構清單,用於建構 Apple macOS 二進位檔。
標記: loses_incremental_stateloading_and_analysis
--macos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
目標的最低相容 macOS 版本。如果未指定,系統會使用「macos_sdk_version」。
標記: loses_incremental_state
--memprof_profile=<a build target label> 預設值:請參閱說明
使用 memprof 設定檔。
標記: affects_outputs
--[no]objc_debug_with_GLIBCXX 預設值:「false」
如果已設定,且編譯模式設為「dbg」,請定義 GLIBCXX_DEBUG、GLIBCXX_DEBUG_PEDANTIC 和 GLIBCPP_CONCEPT_CHECKS。
標記: action_command_lines
--[no]objc_enable_binary_stripping 預設值:「false」
是否要在已連結的二進位檔上執行符號和無效程式碼去除作業。如果同時指定這個旗標和 --compilation_mode=opt,系統就會執行二進位碼去除作業。
標記: action_command_lines
--objccopt=<a string> 累積多次使用
編譯 Objective-C/C++ 來源檔案時,要傳遞至 gcc 的其他選項。
標記: action_command_lines
--per_file_copt=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths followed by an @ and a comma separated list of options> 累積多次使用
在編譯特定檔案時,可選擇傳遞至 gcc 的其他選項。這個選項可以多次傳遞。語法:regex_filter@選項_1,選項_2,...,選項_n。其中 regex_filter 代表包含和排除的規則運算式模式清單 (另請參閱 --instrumentation_filter)。option_1 到 option_n 代表任意指令列選項。如果選項包含半形逗號,則必須在半形逗號前後加上反斜線。選項可以包含 @。只有第一個 @ 會用來分割字串。範例:--per_file_copt=//foo/.*\.cc,-//foo/bar\.cc@-O0 會將 -O0 指令列選項新增至 //foo/ 中所有 cc 檔案 (除了 bar.cc) 的 gcc 指令列。
標記: action_command_linesaffects_outputs
--per_file_ltobackendopt=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths followed by an @ and a comma separated list of options> 累積多次使用
編譯特定後端物件時,可選擇將哪些選項傳遞至 LTO 後端 (在 --features=thin_lto 下) 的其他選項。這個選項可以多次傳遞。語法:regex_filter@選項_1,選項_2,...,選項_n。其中 regex_filter 代表包含和排除規則運算式的清單。option_1 到 option_n 代表任意指令列選項。如果選項包含半形逗號,則必須在半形逗號前後加上反斜線。選項可以包含 @。只有第一個 @ 會用來分割字串。範例:--per_file_ltobackendopt=//foo/.*\.o,-//foo/bar\.o@-O0 會將 -O0 指令列選項新增至 //foo/ 中所有 o 檔案 (除了 bar.o) 的 LTO 後端指令列。
標記: action_command_linesaffects_outputs
--platform_suffix=<a string> 預設值:請參閱說明
指定要新增至設定目錄的後置字串。
標記: loses_incremental_stateaffects_outputsloading_and_analysis
--propeller_optimize=<a build target label> 預設值:請參閱說明
使用 Propeller 設定檔資訊來改善建構目標。Propeller 設定檔至少必須包含以下兩個檔案之一:cc 設定檔和 ld 設定檔。這個標記可接受建構標籤,但該標籤必須參照螺旋槳設定檔輸入檔案。舉例來說,定義標籤的 BUILD 檔案,在 a/b/BUILD:propeller_optimize( name = "propeller_profile", cc_profile = "propeller_cc_profile.txt", ld_profile = "propeller_ld_profile.txt",) 中,您可能必須在對應的套件中加入 exports_files 指示詞,才能讓 Bazel 看到這些檔案。這個選項必須以以下方式使用:--propeller_optimize=//a/b:propeller_profile
標記: action_command_linesaffects_outputs
--propeller_optimize_absolute_cc_profile=<a string> 預設值:請參閱說明
Propeller 最佳化版本的 cc_profile 檔案絕對路徑名稱。
標記: affects_outputs
--propeller_optimize_absolute_ld_profile=<a string> 預設值:請參閱說明
Propeller 最佳化版本的 ld_profile 檔案絕對路徑名稱。
標記: affects_outputs
--run_under=<a prefix in front of command> 預設值:請參閱說明
在「test」和「run」指令的可執行檔前插入前置字串。如果值為「foo -bar」,執行指令列為「test_binary -baz」,則最終指令列為「foo -bar test_binary -baz」。這也可以是可執行目標的標籤。以下是一些範例:'valgrind'、'strace'、'strace -c'、'valgrind --quiet --num-callers=20'、'//package:target'、'//package:target --options'。
標記: action_command_lines
--[no]share_native_deps 預設值:「true」
如果為 true,含有相同功能的原生程式庫會在不同目標之間共用
標記: loading_and_analysisaffects_outputs
--[no]stamp 預設值:「false」
在二進位檔上蓋上日期、使用者名稱、主機名稱、工作區資訊等資訊。
標記: affects_outputs
--strip=<always, sometimes or never> 預設值:「sometimes」
用於指定是否要移除二進位檔和共用程式庫 (使用「-Wl,--strip-debug」)。預設值為「sometimes」表示如果 --compilation_mode=fastbuild,則會移除。
標記: affects_outputs
--stripopt=<a string> 累積多次使用
產生 '<name>.stripped'二進位檔時,要傳遞至 strip 的其他選項。
標記: action_command_linesaffects_outputs
--tvos_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的架構清單,用於建構 Apple tvOS 二進位檔。
標記: loses_incremental_stateloading_and_analysis
--tvos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定模擬器和裝置的最低相容 tvOS 版本。如果未指定,系統會使用「tvos_sdk_version」。
標記: loses_incremental_state
--visionos_cpus=<comma-separated list of options> 累積多次使用
以逗號分隔的清單,列出要為其建構 Apple visionOS 二進位檔的架構。
標記: loses_incremental_stateloading_and_analysis
--watchos_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的架構清單,用於建構 Apple watchOS 二進位檔。
標記: loses_incremental_stateloading_and_analysis
--watchos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定模擬器和裝置的最低相容 watchOS 版本。如果未指定,系統會使用「watchos_sdk_version」。
標記: loses_incremental_state
--xbinary_fdo=<a build target label> 預設值:請參閱說明
使用 XbinaryFDO 設定檔資訊來最佳化編譯作業。指定預設交叉二進位設定檔的名稱。當此選項與 --fdo_instrument/--fdo_optimize/--fdo_profile 一起使用時,這些選項一律會優先採用,就好像從未指定 xbinary_fdo 一樣。
標記: affects_outputs
影響 Bazel 如何嚴格執行有效建構輸入內容 (規則定義、標記組合等) 的選項:
--[no]check_licenses 預設值:「false」
請確認依附套件施加的授權限制,不會與建構目標的發布模式衝突。根據預設,系統不會檢查授權。
標記: build_file_semantics
--[no]check_visibility 預設值:「true」
如果停用,目標依附元件中的顯示錯誤會降級為警告。
標記: build_file_semantics
--[no]desugar_for_android 預設值:「true」
是否要在解碼前脫糖 Java 8 位元組碼。
標記: affects_outputsloading_and_analysisloses_incremental_state
--[no]desugar_java8_libs 預設值:「false」
是否要在舊版裝置的應用程式中加入支援的 Java 8 程式庫。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]enforce_constraints 預設值:「true」
檢查每個目標的相容環境,如果任何目標的依附元件不支援相同的環境,就會回報錯誤
標記: build_file_semantics
--[no]experimental_check_desugar_deps 預設值:「true」
是否要再次檢查 Android 二進位檔層級的正確去糖化。
標記: eagerness_to_exitloading_and_analysisexperimental
--experimental_import_deps_checking=<a string> 預設值:請參閱說明
無操作,僅保留用於回溯相容性
標記: loading_and_analysis
--experimental_one_version_enforcement=<off, warning or error> 預設值:「OFF」
啟用後,系統會強制規定 java_binary 規則在 classpath 中不得包含同一個類別檔案的多個版本。這項強制執行措施可能會導致建構作業中斷,或只會產生警告。
標記: loading_and_analysis
--experimental_strict_java_deps=<off, warn, error, strict or default> 預設值:"default"
如果為 true,系統會檢查 Java 目標是否明確將所有直接使用的目標宣告為依附元件。
標記: build_file_semanticseagerness_to_exit
--[no]incompatible_check_testonly_for_output_files 預設值:「false」
如果啟用,請查詢產生規則的 testonly,檢查 testonly 是否為輸出檔案的必要條件目標。這項設定與可見度檢查相符。
標記: build_file_semanticsincompatible_change
--[no]incompatible_check_visibility_for_toolchains 預設值:「false」
如果已啟用,可視性檢查也會套用至工具鍊實作。
標記: build_file_semanticsincompatible_change
--[no]incompatible_disable_native_android_rules 預設值:「false」
如果啟用,系統就會停用原生 Android 規則的直接用法。請使用 https://github.com/bazelbuild/rules_android 中的 Starlark Android 規則
標記: eagerness_to_exitincompatible_change
--[no]incompatible_disable_native_apple_binary_rule 預設值:「false」
無操作。為回溯相容性而保留。
標記: eagerness_to_exitincompatible_change
--[no]incompatible_python_disable_py2 預設值:「true」
如果設為 True,使用 Python 2 設定會導致錯誤。包括 python_version=PY2、srcs_version=PY2 和 srcs_version=PY2ONLY。詳情請參閱 https://github.com/bazelbuild/bazel/issues/15684。
標記: loading_and_analysisincompatible_change
--[no]one_version_enforcement_on_java_tests 預設值:「true」
啟用此選項後,如果 experimental_one_version_enforcement 設為非 NONE 值,系統就會在 java_test 目標上強制執行一個版本。您可以停用這個標記,以便提升增量測試效能,但可能會錯過某個版本的違規項目。
標記: loading_and_analysis
--python_native_rules_allowlist=<a build target label> 預設值:請參閱說明
在強制執行 --incompatible_python_disallow_native_rules 時,要使用的許可清單 (package_group 目標)。
標記: loading_and_analysis
--[no]strict_filesets 預設值:「false」
如果啟用這個選項,系統會將跨越套件邊界的檔案集回報為錯誤。
標記: build_file_semanticseagerness_to_exit
--strict_proto_deps=<off, warn, error, strict or default> 預設值:「error」
除非設為 OFF,否則會檢查 proto_library 目標是否明確將所有直接使用的目標宣告為依附元件。
標記: build_file_semanticseagerness_to_exitincompatible_change
--strict_public_imports=<off, warn, error, strict or default> 預設值:「off」
除非設為 OFF,否則會檢查 proto_library 目標是否明確宣告在「import public」中使用的所有目標為匯出目標。
標記: build_file_semanticseagerness_to_exitincompatible_change
--[no]strict_system_includes 預設值:「false」
如果設為 true,則系統會透過系統包含路徑 (-isystem) 找到的標頭,也必須宣告。
標記: loading_and_analysiseagerness_to_exit
--target_environment=<a build target label> 累積多次使用
宣告此版本的目標環境。必須是「環境」規則的標籤參照。如果指定了這個環境,則所有頂層目標都必須與這個環境相容。
標記: changes_inputs
影響建構簽署輸出內容的選項:
--apk_signing_method=<v1, v2, v1_v2 or v4> 預設值:「v1_v2」
用於簽署 APK 的實作方式
標記: action_command_linesaffects_outputsloading_and_analysis
--[no]device_debug_entitlements 預設值:「true」
如果已設定,且編譯模式不是「opt」,則 objc 應用程式會在簽署時加入偵錯授權。
標記: changes_inputs
--ios_signing_cert_name=<a string> 預設值:請參閱說明
用於 iOS 簽署的憑證名稱。如果未設定,系統會改用佈建設定檔。根據 codesign 的 man 頁面 (SIGNING IDENTITIES),可能為憑證的鑰匙圈身分偏好設定或憑證的常用名稱 (子字串)。
標記: action_command_lines
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_disallow_legacy_py_provider 預設值:「true」
無操作,即將移除。
標記: loading_and_analysisincompatible_change
--[no]incompatible_disallow_sdk_frameworks_attributes 預設值:「false」
如果設為 true,就禁止在 objc_library 和 objc_import 中使用 sdk_frameworks 和 weak_sdk_frameworks 屬性。
標記: build_file_semanticsincompatible_change
如果為 true,請將 objc_library 和 objc_import 中的 alwayslink 屬性預設值設為 true。
標記: build_file_semanticsincompatible_change
--[no]incompatible_python_disallow_native_rules 預設值:「false」
如果為 True,使用內建的 py_* 規則時會發生錯誤;應改用 rule_python 規則。詳情請參閱 https://github.com/bazelbuild/bazel/issues/17773 瞭解遷移操作說明。
標記: loading_and_analysisincompatible_change
用於控管測試環境或測試執行工具行為的選項:
--[no]allow_analysis_failures 預設值:「false」
如果設為 true,規則目標的分析失敗會導致目標傳播包含錯誤說明的 AnalysisFailureInfo 例項,而不會導致建構失敗。
標記: loading_and_analysisexperimental
--analysis_testing_deps_limit=<an integer> 預設值:「2000」
透過規則屬性和 for_analysis_testing 設定轉換,設定遞移依附元件的數量上限。若超出這項限制,就會導致規則錯誤。
標記: loading_and_analysis
--[no]break_build_on_parallel_dex2oat_failure 預設值:「false」
如果為 true,則 dex2oat 動作失敗會導致建構作業中斷,而不會在測試執行階段執行 dex2oat。
標記: loading_and_analysisexperimental
--default_test_resources=<a resource name followed by equal and 1 float or 4 float, e.g memory=10,30,60,100> 累積多次使用
覆寫測試的預設資源量。預期格式為 <resource>=<value>。如果指定單一正整數做為 <value>,則會覆寫所有測試大小的預設資源。如果指定 4 個以逗號分隔的數字,這些數字會分別覆寫小、中、大、特大測試大小的資源數量。值也可以是 HOST_RAM/HOST_CPU,並可選擇加上 [-|*]<浮點> (例如 memory=HOST_RAM*.1,HOST_RAM*.2,HOST_RAM*.3,HOST_RAM*.4)。這個旗標指定的預設測試資源,會遭到標記中明確指定的資源覆寫。
--[no]experimental_android_use_parallel_dex2oat 預設值:「false」
並行使用 dex2oat,可能可加快 android_test 的速度。
標記: loading_and_analysishost_machine_resource_optimizationsexperimental
--[no]ios_memleaks 預設值:「false」
啟用 ios_test 目標的記憶體外洩檢查功能。
標記: action_command_lines
--ios_simulator_device=<a string> 預設值:請參閱說明
在模擬器中執行 iOS 應用程式時要模擬的裝置,例如「iPhone 6」。您可以在要執行模擬器的電腦上執行「xcrun simctl list devicetypes」取得裝置清單。
標記: test_runner
--ios_simulator_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
在執行或測試時,要在模擬器上執行的 iOS 版本。如果規則中指定了目標裝置,系統會忽略 ios_test 規則。
標記: test_runner
--runs_per_test=<a positive integer or test_regex@runs. This flag may be passed more than once> 累積多次使用
指定執行每項測試的次數。如果任何嘗試因任何原因失敗,整個測試就會視為失敗。通常指定的值只是整數。範例:--runs_per_test=3 會執行所有測試 3 次。其他語法:regex_filter@runs_per_test。其中 runs_per_test 代表整數值,而 regex_filter 代表包含和排除的規則運算式清單 (另請參閱 --instrumentation_filter)。範例:--runs_per_test=//foo/.*,-//foo/bar/.*@3 會執行 //foo/ 中的所有測試 (foo/bar 下的測試除外),共三次。這個選項可以多次傳遞。系統會優先採用最近傳遞且相符的引數。如果沒有任何相符項目,則只會執行一次測試。
--test_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定要插入測試執行器環境的其他環境變數。變數可以透過名稱指定,在這種情況下,系統會從 Bazel 用戶端環境讀取其值,也可以透過名稱=值組合指定。您可以多次使用此選項指定多個變數。僅供「bazel test」指令使用。
標記: test_runner
--test_timeout=<a single integer or comma-separated list of 4 integers> 預設值:「-1」
覆寫測試逾時的預設逾時值 (以秒為單位)。如果指定單一正整數值,系統會覆寫所有類別。如果指定 4 個以逗號分隔的整數,系統會覆寫短、中、長和永久 (依序) 的逾時時間。無論是哪種表單,如果值為 -1,blaze 就會使用該類別的預設逾時時間。
--[no]zip_undeclared_test_outputs 預設值:「false」
如果設為 true,系統會將未宣告的測試輸出內容封存為 ZIP 檔案。
標記: test_runner
觸發建構時間最佳化功能的選項:
--[no]experimental_filter_library_jar_with_program_jar 預設值:「false」
篩選 ProGuard ProgramJar,移除 LibraryJar 中也存在的任何類別。
標記: action_command_linesexperimental
--[no]experimental_inmemory_dotd_files 預設值:「true」
如果啟用此選項,C++ .d 檔案會直接從遠端建構節點傳遞至記憶體,而不會寫入磁碟。
標記: loading_and_analysisexecutionaffects_outputsexperimental
--[no]experimental_inmemory_jdeps_files 預設值:「true」
如果啟用此選項,系統會直接從遠端建構節點,透過記憶體傳遞從 Java 編譯產生的依附元件檔案 (.jdeps),而不會寫入磁碟。
標記: loading_and_analysisexecutionaffects_outputsexperimental
--[no]experimental_retain_test_configuration_across_testonly 預設值:「false」
啟用後,--trim_test_configuration 就不會為標示為 testonly=1 的規則裁減測試設定。這項功能旨在減少非測試規則依賴 cc_test 規則時的動作衝突問題。如果 --trim_test_configuration 為 false,就不會產生任何影響。
標記: loading_and_analysisloses_incremental_stateexperimental
--[no]experimental_starlark_cc_import 預設值:「false」
如果啟用,即可使用 Starlark 版本的 cc_import。
標記: loading_and_analysisexperimental
--[no]experimental_unsupported_and_brittle_include_scanning 預設值:「false」
是否要透過剖析輸入檔案中的 #include 行,將輸入內容縮減為 C/C++ 編譯。這可縮減編譯輸入樹狀結構的大小,進而提升效能和增量。不過,由於包含掃描器未完全實作 C 預處理器語意,因此也可能會導致建構作業中斷。具體來說,它無法瞭解動態 #include 指示,並會忽略預處理器條件邏輯。您必須自行承擔使用風險。我們會關閉與這個標記相關的所有已提交問題。
標記: loading_and_analysisexecutionchanges_inputsexperimental
--[no]incremental_dexing 預設值:「true」
針對每個 Jar 檔案分別執行大部分的解析工作。
標記: affects_outputsloading_and_analysisloses_incremental_state
--[no]objc_use_dotd_pruning 預設值:「true」
如果設定,系統會使用 Clang 產生的 .d 檔案,來修剪傳遞至 objc 編譯作業的輸入集合。
標記: changes_inputsloading_and_analysis
--[no]process_headers_in_dependencies 預設值:「false」
建構目標 //a:a 時,請處理 //a:a 依附的所有目標中的標頭 (如果工具鍊啟用了標頭處理功能)。
標記: execution
--[no]trim_test_configuration 預設值:「true」
啟用後,系統會清除版本頂層以下的測試相關選項。啟用此標記後,測試就無法建構為非測試規則的依附元件,但變更測試相關選項不會導致非測試規則重新分析。
標記: loading_and_analysisloses_incremental_state
影響記錄詳細程度、格式或位置的選項:
--toolchain_resolution_debug=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths> 預設值:「-.*」
在工具鍊解析期間列印偵錯資訊。這個標記會採用規則運算式,並根據工具鍊類型和特定目標進行檢查,以便查看要偵錯的目標。您可以使用逗號分隔多個規則運算式,然後分別檢查每個規則運算式。注意:這個標記的輸出內容非常複雜,可能只有工具鍊解析專家才會覺得實用。
標記: terminal_output
選項可指定或變更 Bazel 指令的一般輸入內容,而該輸入內容不屬於其他類別:
--flag_alias=<a 'name=value' flag alias> 累積多次使用
設定 Starlark 標記的簡寫名稱。它會將單一鍵/值組合 (格式為「<鍵>=<值>」) 做為引數。
標記: changes_inputs
--[no]incompatible_default_to_explicit_init_py 預設值:「false」
這個標記會變更預設行為,讓 __init__.py 檔案不再自動建立在 Python 目標的執行檔案中。具體來說,如果 py_binary 或 py_test 目標將 legacy_create_init 設為「auto」(預設值),則只有在設定此標記時,才會視為 false。請參閱 https://github.com/bazelbuild/bazel/issues/10076。
標記: affects_outputsincompatible_change
--[no]incompatible_py2_outputs_are_suffixed 預設值:「true」
如果設為 true,在 Python 2 設定中建構的目標會顯示在包含「-py2」字尾的輸出根目錄下,而為 Python 3 建構的目標則會顯示在沒有 Python 相關字尾的根目錄中。也就是說,`bazel-bin` 方便捷符號會指向 Python 3 目標,而非 Python 2。如果您啟用這個選項,建議也啟用 `--incompatible_py3_is_default`。
標記: affects_outputsincompatible_change
--[no]incompatible_py3_is_default 預設值:「true」
如果為 true,則未設定 `python_version` (或 `default_python_version`) 屬性的 `py_binary` 和 `py_test` 目標,預設會使用 PY3 而非 PY2。如果您設定這個旗標,建議也設定 `--incompatible_py2_outputs_are_suffixed`。
標記: loading_and_analysisaffects_outputsincompatible_change
--[no]incompatible_use_python_toolchains 預設值:「true」
如果設為 true,可執行的原生 Python 規則會使用 Python 工具鍊指定的 Python 執行階段,而非由 --python_top 等舊版標記提供的執行階段。
標記: loading_and_analysisincompatible_change
--python_version=<PY2 or PY3> 預設值:請參閱說明
Python 主要版本模式,可選為 `PY2` 或 `PY3`。請注意,這會由 `py_binary` 和 `py_test` 目標覆寫 (即使未明確指定版本),因此通常沒有提供這個旗標的必要。
標記: loading_and_analysisaffects_outputs
其他選項,不屬於其他類別:
--[no]cache_test_results [-t] 預設值:「auto」
如果設為「auto」,Bazel 只會在下列情況下重新執行測試:(1) Bazel 偵測到測試或其依附元件的變更、(2) 測試標示為外部、(3) 使用 --runs_per_test 要求執行多個測試,或(4) 測試先前失敗。如果設為「是」,Bazel 會快取所有測試結果,但標示為外部的測試除外。如果設為「no」,Bazel 就不會快取任何測試結果。
--[no]experimental_cancel_concurrent_tests 預設值:「false」
如果為 true,Blaze 會在第一次成功執行時取消同時執行的測試。只有在搭配 --runs_per_test_detects_flakes 時才有用。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_fetch_all_coverage_outputs 預設值:「false」
如果為 true,Bazel 就會在執行涵蓋率時,為每項測試擷取整個涵蓋率資料目錄。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_generate_llvm_lcov 預設值:「false」
如果設為 True,clang 的涵蓋率就會產生 LCOV 報表。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_j2objc_header_map 預設值:「true」
是否要在 J2ObjC 轉譯時並行產生 J2ObjC 標頭對應項目。
標記: experimental
--[no]experimental_j2objc_shorter_header_path 預設值:「false」
是否要使用較短的標頭路徑產生 (使用「_ios」而非「_j2objc」)。
標記: affects_outputsexperimental
--experimental_java_classpath=<off, javabuilder or bazel> 預設值:「javabuilder」
啟用 Java 編譯作業的縮減路徑集。
--[no]experimental_limit_android_lint_to_android_constrained_java 預設值:「false」
無操作,僅保留用於向後相容性
標記: affects_outputsexperimental
--[no]experimental_run_android_lint_on_java_rules 預設值:「false」
是否要驗證 java_* 來源。
標記: affects_outputsexperimental
--[no]explicit_java_test_deps 預設值:「false」
在 java_test 中明確指定對 JUnit 或 Hamcrest 的依附元件,而不是意外從 TestRunner 的 deps 取得。目前僅適用於 Bazel。
--host_java_launcher=<a build target label> 預設值:請參閱說明
在建構期間執行的工具所使用的 Java 啟動器。
--host_javacopt=<a string> 累積多次使用
建構在建構期間執行的工具時,要傳遞至 javac 的其他選項。
--host_jvmopt=<a string> 累積多次使用
建構期間執行的工具在建構時,傳遞至 Java VM 的其他選項。這些選項會新增至每個 java_binary 目標的 VM 啟動選項。
--[no]incompatible_check_sharding_support 預設值:「true」
如果為 true,如果測試執行程式未透過觸碰 TEST_SHARD_STATUS_FILE 路徑中的檔案,表示不支援分割,則 Bazel 會失敗執行分割測試。如果為 false,則不支援分割的測試執行程式會導致所有測試在每個分割區中執行。
標記: incompatible_change
--[no]incompatible_exclusive_test_sandboxed 預設值:「true」
如果為 true,系統會使用沙箱策略執行專屬測試。新增「local」標記,強制在本機上執行專屬測試
標記: incompatible_change
--[no]incompatible_strict_action_env 預設值:「false」
如果為 True,Bazel 會使用 PATH 的靜態值環境,且不會繼承 LD_LIBRARY_PATH。如果您想從用戶端繼承特定環境變數,請使用 --action_env=ENV_VARIABLE,但請注意,如果使用共用快取,這麼做可能會導致跨使用者快取無法使用。
標記: loading_and_analysisincompatible_change
--j2objc_translation_flags=<comma-separated list of options> 累積多次使用
傳遞至 J2ObjC 工具的其他選項。
--java_debug
讓 Java 測試的 Java 虛擬機器在開始測試前,等待符合 JDWP 標準的偵錯工具 (例如 jdb) 連線。暗示 -test_output=streamed。
展開為:
  --test_arg=--wrapper_script_flag=--debug
  --test_output=streamed
  --test_strategy=exclusive
  --test_timeout=9999
  --nocache_test_results
--[no]java_deps 預設值:「true」
針對每個 Java 目標產生依附元件資訊 (目前為編譯時間的類別路徑)。
--[no]java_header_compilation 預設值:「true」
直接從來源編譯 ijar。
--java_language_version=<a string> 預設值:""
Java 語言版本
--java_launcher=<a build target label> 預設值:請參閱說明
建構 Java 二進位檔時要使用的 Java 啟動器。如果這個標記設為空字串,系統就會使用 JDK 啟動器。「launcher」屬性會覆寫這個旗標。
--java_runtime_version=<a string> 預設值:「local_jdk」
Java 執行階段版本
--javacopt=<a string> 累積多次使用
傳遞至 javac 的其他選項。
--jvmopt=<a string> 累積多次使用
傳遞至 Java VM 的其他選項。這些選項會新增至每個 java_binary 目標的 VM 啟動選項。
--legacy_main_dex_list_generator=<a build target label> 預設值:請參閱說明
指定要使用的二進位檔,用於產生編譯舊版 Multidex 時,必須位於主 DEX 中的類別清單。
--optimizing_dexer=<a build target label> 預設值:請參閱說明
指定用於在不分割的情況下執行解析的二進位檔。
--plugin=<a build target label> 累積多次使用
在建構中使用的外掛程式。目前支援 java_plugin。
--proguard_top=<a build target label> 預設值:請參閱說明
指定建構 Java 二進位檔時,要使用哪個版本的 ProGuard 來移除程式碼。
--proto_compiler=<a build target label> 預設值:"@bazel_tools//tools/proto:protoc"
Proto 編譯器的標籤。
標記: affects_outputsloading_and_analysis
--[no]proto_profile 預設值:「true」
是否將 profile_path 傳遞至 proto 編譯器。
標記: affects_outputsloading_and_analysis
--proto_profile_path=<a build target label> 預設值:請參閱說明
要以 profile_path 形式傳遞至 Proto 編譯器的設定檔。如果未設定,但 --proto_profile 為 true (預設值),系統會從 --fdo_optimize 推斷路徑。
標記: affects_outputsloading_and_analysis
--proto_toolchain_for_cc=<a build target label> 預設值:"@bazel_tools//tools/proto:cc_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 C++ 原型檔
標記: affects_outputsloading_and_analysis
--proto_toolchain_for_j2objc=<a build target label> 預設值:"@bazel_tools//tools/j2objc:j2objc_proto_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 j2objc 原型檔
標籤: affects_outputsloading_and_analysis
--proto_toolchain_for_java=<a build target label> 預設值:"@bazel_tools//tools/proto:java_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 Java 原型檔
標記: affects_outputsloading_and_analysis
--proto_toolchain_for_javalite=<a build target label> 預設值:"@bazel_tools//tools/proto:javalite_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 JavaLite 原型檔
標記: affects_outputsloading_and_analysis
--protocopt=<a string> 累積多次使用
傳遞至 protobuf 編譯器的其他選項。
標記: affects_outputs
--[no]runs_per_test_detects_flakes 預設值:「false」
如果為 true,則任何具有至少一個成功執行/嘗試,以及至少一個失敗執行/嘗試的區塊,都會獲得「不穩定」狀態。
--shell_executable=<a path> 預設值:請參閱說明
Shell 可執行檔的絕對路徑,供 Bazel 使用。如果未設定此值,但在第一次呼叫 Bazel (啟動 Bazel 伺服器) 時已設定 BAZEL_SH 環境變數,Bazel 就會使用該值。如果未設定這兩者,Bazel 會根據執行的作業系統使用硬式編碼的預設路徑 (Windows:c:/msys64/usr/bin/bash.exe、FreeBSD:/usr/local/bin/bash、其他所有作業系統:/bin/bash)。請注意,使用與 bash 不相容的殼層,可能會導致產生的二進位檔發生建構失敗或執行階段失敗。
標記: loading_and_analysis
--test_arg=<a string> 累積多次使用
指定應傳遞至測試可執行檔的其他選項和引數。可多次使用,用於指定多個引數。如果執行多項測試,每項測試都會收到相同的引數。僅供「bazel test」指令使用。
--test_filter=<a string> 預設值:請參閱說明
指定要轉送至測試架構的篩選器。用於限制執行的測試。請注意,這不會影響要建構的目標。
--test_result_expiration=<an integer> 預設值:「-1」
這個選項已淘汰,不會產生任何作用。
--[no]test_runner_fail_fast 預設值:「false」
將快速失敗選項轉送至測試執行程式。測試執行程式應在第一次失敗時停止執行。
--test_sharding_strategy=<explicit, disabled or forced=k where k is the number of shards to enforce> 預設值:「explicit」
指定測試區塊劃分策略:如果有 'shard_count' BUILD 屬性,則只使用區塊劃分策略。如要一律不使用測試分割,請選擇「disabled」。使用「forced=k」強制執行「k」分片進行測試,無論「shard_count」BUILD 屬性為何都一樣。
--tool_java_language_version=<a string> 預設值:""
用於執行建構期間所需工具的 Java 語言版本
--tool_java_runtime_version=<a string> 預設值:「remotejdk_11」
在建構期間用來執行工具的 Java 執行階段版本
--[no]use_ijars 預設值:「true」
如果啟用此選項,Java 編譯作業就會使用介面 JAR 檔案。這會加快增量編譯作業,但錯誤訊息可能會有所不同。

傾印選項

用於控制指令輸出的選項:
--[no]action_cache 預設值:「false」
傾印動作快取內容。
標記: bazel_monitoring
--memory=<memory mode> 預設值:請參閱說明
轉儲指定 Skyframe 節點的記憶體用量。
標記: bazel_monitoring
--[no]packages 預設值:「false」
傾印封裝內容快取內容。
標記: bazel_monitoring
--[no]rule_classes 預設值:「false」
傾印規則類別。
標記: bazel_monitoring
--[no]rules 預設值:「false」
傾印規則,包括計數和記憶體用量 (如果追蹤記憶體)。
標記: bazel_monitoring
--skyframe=<off, summary, count, value, deps, rdeps, function_graph, working_set or working_set_frontier_deps> 預設值:「off」
轉儲 Skyframe 圖表。
標記: bazel_monitoring
--skykey_filter=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths> 預設值:「.*」
SkyKey 名稱的規則運算式篩選器,用於輸出內容。僅用於 --skyframe=deps、rdeps、function_graph。
標記: bazel_monitoring
--skylark_memory=<a string> 預設值:請參閱說明
將與 pprof 相容的記憶體設定檔轉儲至指定路徑。詳情請參閱 https://github.com/google/pprof。
標記: bazel_monitoring
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
代碼: loading_and_analysis

擷取選項

繼承 test 的所有選項。

控制建構執行作業的選項:
--[no]all 預設值:「false」
擷取建構任何目標或存放區所需的所有外部存放區。如果未提供其他旗標和引數,則此為預設值。只有在 --enable_bzlmod 開啟時才有效。
標記: changes_inputs
--[no]keep_going [-k] 預設值:「false」
盡可能在發生錯誤後繼續執行。雖然無法分析失敗的目標和依附於該目標的其他目標,但可以分析這些目標的其他必要條件。
標記: eagerness_to_exit
--loading_phase_threads=<an integer, or a keyword ("auto", "HOST_CPUS", "HOST_RAM"), optionally followed by an operation ([-|*]<float>) eg. "auto", "HOST_CPUS*.5"> 預設值:「auto」
在載入/分析階段要使用的平行執行緒數量。可接受整數或關鍵字 (「auto」、「HOST_CPUS」、「HOST_RAM」),並可選擇加上運算符號 ([-|*]<float>),例如 「auto」、「HOST_CPUS*.5」等。「auto」會根據主機資源設定合理的預設值。不得小於 1。
標記: bazel_internal_configuration
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_config_setting_private_default_visibility 預設值:「false」
如果 incompatible_enforce_config_setting_visibility=false,則此方法不會執行任何操作。否則,如果這個標記為 false,則任何沒有明確顯示屬性的 config_setting 都是 //visibility:public。如果這個標記設為 True,config_setting 就會遵循與所有其他規則相同的瀏覽權限邏輯。請參閱 https://github.com/bazelbuild/bazel/issues/12933。
標記: loading_and_analysisincompatible_change
--[no]incompatible_enforce_config_setting_visibility 預設值:「true」
如果設為 true,系統就會強制執行 config_setting 曝光度限制。如果為 false,則每個目標都能看到每個 config_setting。請參閱 https://github.com/bazelbuild/bazel/issues/12932。
標記: loading_and_analysisincompatible_change
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
標記: loading_and_analysis
與 Bzlmod 輸出內容和語義相關的選項:
--[no]configure 預設值:「false」
系統只會擷取標示為「configure」的存放區,用於系統設定。只有在 --enable_bzlmod 開啟時才有效。
標記: changes_inputs
--[no]force 預設值:「false」
忽略現有的存放區 (如果有),並強制再次擷取存放區。只有在 --enable_bzlmod 開啟時才有效。
標記: changes_inputs
--repo=<a string> 累積多次使用
只擷取指定的存放區,可以是 {@apparent_repo_name} 或 {@@canonical_repo_name}。只有在 --enable_bzlmod 開啟時才有效。
標記: changes_inputs
影響記錄詳細程度、格式或位置的選項:
--experimental_repository_resolved_file=<a string> 預設值:""
如果不為空白,請寫入 Starlark 值,其中包含已執行的所有 Starlark 存放區規則的解析資訊。
標記: affects_outputs
其他選項,未歸類於其他類別:
--deleted_packages=<comma-separated list of package names> 累積多次使用
以半形逗號分隔的套件名稱清單,即使這些套件名稱在套件路徑的某處可見,建構系統仍會視為不存在。刪除現有套件「x」的子套件「x/y」時,請使用這個選項。舉例來說,在刪除用戶端中的 x/y/BUILD 後,如果建構系統遇到標籤「//x:y/z」,但該標籤仍由另一個 package_path 項目提供,系統可能會發出錯誤訊息。指定 --deleted_packages x/y 即可避免這個問題。
--[no]fetch 預設值:「true」
允許指令擷取外部依附元件。如果設為 false,指令會使用任何快取的依附元件版本,如果沒有任何版本,指令就會失敗。
--package_path=<colon-separated list of options> 預設值:「%workspace%」
以冒號分隔的清單,列出尋找套件的來源。以「%workspace%」開頭的元素是相對於包含工作區的元素。如果省略或留空,預設值為執行「bazel info default-package-path」的輸出內容。
--[no]show_loading_progress 預設值:「true」
如果啟用,Bazel 就會顯示「Loading package:」訊息。
控制建構執行作業的選項:
是否要直接呼叫檔案系統以建立符號連結樹狀結構,而非委派給輔助程序。
標記: loading_and_analysisexecutionexperimental
--[no]experimental_persistent_aar_extractor 預設值:「false」
使用 worker 啟用持續性 AAR Extractor。
標記: executionexperimental
--[no]experimental_remotable_source_manifests 預設值:「false」
是否要讓來源資訊清單動作可遠端執行
標記: loading_and_analysisexecutionexperimental
--[no]experimental_split_coverage_postprocessing 預設值:「false」
如果為 true,Bazel 就會在新的產生事件中執行測試的涵蓋率後置處理程序。
標記: executionexperimental
--[no]experimental_strict_fileset_output 預設值:「false」
如果啟用這個選項,檔案集會將所有輸出構件視為一般檔案。不會遍歷目錄,也不會對符號連結敏感。
標記: executionexperimental
--[no]incompatible_modify_execution_info_additive 預設值:「false」
啟用後,傳遞多個 --modify_execution_info 標記會相加。停用時,系統只會考量最後一個標記。
標記: executionaffects_outputsloading_and_analysisincompatible_change
--modify_execution_info=<regex=[+-]key,regex=[+-]key,...> 累積多次使用
根據動作助憶法,新增或移除動作執行資訊中的鍵。僅適用於支援執行資訊的動作。許多常見動作都支援執行資訊,例如 Genrule、CppCompile、Javac、StarlarkAction、TestRunner。指定多個值時,順序很重要,因為許多規則運算式可能會套用相同的助憶法。語法:「regex=[+-]key,regex=[+-]key,...」。範例: «.*=+x,.*=-y,.*=+z» 會將「x」和「z」加入所有動作的執行資訊,並移除「y」。'Genrule=+requires-x' 會將 'requires-x' 新增至所有 Genrule 動作的執行資訊。'(?!Genrule).*=-requires-x' 會從所有非 Genrule 動作的執行資訊中移除 'requires-x'。
標記: executionaffects_outputsloading_and_analysis
--persistent_android_dex_desugar
使用工作者啟用持續性的 Android dex 和 desugar 動作。
展開為:
  --internal_persistent_android_dex_desugar
  --strategy=Desugar=worker
  --strategy=DexBuilder=worker

標記: host_machine_resource_optimizationsexecution
--persistent_android_resource_processor
使用 worker 啟用 Android 資源處理器。
展開為:
  --internal_persistent_busybox_tools
  --strategy=AaptPackage=worker
  --strategy=AndroidResourceParser=worker
  --strategy=AndroidResourceValidator=worker
  --strategy=AndroidResourceCompiler=worker
  --strategy=RClassGenerator=worker
  --strategy=AndroidResourceLink=worker
  --strategy=AndroidAapt2=worker
  --strategy=AndroidAssetMerger=worker
  --strategy=AndroidResourceMerger=worker
  --strategy=AndroidCompiledResourceMerger=worker
  --strategy=ManifestMerger=worker
  --strategy=AndroidManifestMerger=worker
  --strategy=Aapt2Optimize=worker
  --strategy=AARGenerator=worker
  --strategy=ProcessDatabinding=worker
  --strategy=GenerateDataBindingBaseClasses=worker

標記: host_machine_resource_optimizationsexecution
--persistent_multiplex_android_dex_desugar
使用 worker 啟用持續性的多重 Android dex 和 desugar 動作。
展開為:
  --persistent_android_dex_desugar
  --internal_persistent_multiplex_android_dex_desugar

標記: host_machine_resource_optimizationsexecution
--persistent_multiplex_android_resource_processor
使用 worker 啟用持續性的多重 Android 資源處理器。
展開為:
  --persistent_android_resource_processor
  --modify_execution_info=AaptPackage=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceParser=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceValidator=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceCompiler=+supports-multiplex-workers
  --modify_execution_info=RClassGenerator=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceLink=+supports-multiplex-workers
  --modify_execution_info=AndroidAapt2=+supports-multiplex-workers
  --modify_execution_info=AndroidAssetMerger=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceMerger=+supports-multiplex-workers
  --modify_execution_info=AndroidCompiledResourceMerger=+supports-multiplex-workers
  --modify_execution_info=ManifestMerger=+supports-multiplex-workers
  --modify_execution_info=AndroidManifestMerger=+supports-multiplex-workers
  --modify_execution_info=Aapt2Optimize=+supports-multiplex-workers
  --modify_execution_info=AARGenerator=+supports-multiplex-workers

標記: host_machine_resource_optimizations, execution
--persistent_multiplex_android_tools
啟用持續性和多重化的 Android 工具 (dexing、desugaring、資源處理)。
展開為:
  --internal_persistent_multiplex_busybox_tools
  --persistent_multiplex_android_resource_processor
  --persistent_multiplex_android_dex_desugar

標記: host_machine_resource_optimizationsexecution
--[no]use_target_platform_for_tests 預設值:「false」
如果為 true,Bazel 會使用目標平台執行測試,而不是使用測試執行群組。
代碼: execution
設定用於執行動作的工具鍊的選項:
--android_compiler=<a string> 預設值:請參閱說明
Android 目標編譯器。
標記: affects_outputsloading_and_analysisloses_incremental_state
--android_manifest_merger=<legacy, android or force_android> 預設值:「android」
選取要用於 android_binary 規則的資訊清單合併工具。旗標,可協助從舊版合併工具轉換至 Android 資訊清單合併工具。
標記: affects_outputsloading_and_analysisloses_incremental_state
--android_platforms=<a build target label> 預設值:""
設定 android_binary 目標使用的平台。如果指定多個平台,則二進位檔會是笨重的 APK,其中包含每個指定目標平台的原生二進位檔。
標記: changes_inputsloading_and_analysisloses_incremental_state
--apple_crosstool_top=<a build target label> 預設值:"@bazel_tools//tools/cpp:toolchain"
在 Apple 和 Objc 規則及其依附元件中使用的 crosstool 套件標籤。
標記: loses_incremental_statechanges_inputs
--cc_output_directory_tag=<a string> 預設值:""
指定要新增至設定目錄的後置字串。
標記: affects_outputs
--compiler=<a string> 預設值:請參閱說明
用於編譯目標的 C++ 編譯器。
標記: loading_and_analysisexecution
--coverage_output_generator=<a build target label> 預設值:"@bazel_tools//tools/test:lcov_merger"
用於後處理原始涵蓋率報表的二進位檔位置。這個檔案群組目前必須包含單一檔案 (二進位檔)。預設值為 '//tools/test:lcov_merger'。
標記: changes_inputsaffects_outputsloading_and_analysis
--coverage_report_generator=<a build target label> 預設值:"@bazel_tools//tools/test:coverage_report_generator"
用於產生涵蓋率報表的二進位檔位置。這個檔案群組目前必須包含單一檔案 (二進位檔)。預設值為 '//tools/test:coverage_report_generator'。
標記: changes_inputsaffects_outputsloading_and_analysis
--coverage_support=<a build target label> 預設值:"@bazel_tools//tools/test:coverage_support"
收集程式碼涵蓋率的每個測試動作輸入項目所需的支援檔案位置。預設值為 '//tools/test:coverage_support'。
標記: changes_inputsaffects_outputsloading_and_analysis
--custom_malloc=<a build target label> 預設值:請參閱說明
指定自訂 malloc 實作項目。這項設定會覆寫建構規則中的 malloc 屬性。
標記: changes_inputsaffects_outputs
--experimental_add_exec_constraints_to_targets=<a '<RegexFilter>=<label1>[,<label2>,...]' assignment> 累積多次使用
以逗號分隔的規則運算式清單,每個運算式可選擇加上前置字元 - (負值運算式),並將 (=) 指派給以逗號分隔的限制值目標清單。如果目標不符合任何負面運算式,且至少符合一個正面運算式,則會執行工具鍊解析作業,就像宣告限制值為執行限制一樣。範例://demo,-test=@platforms//cpus:x86_64 會將「x86_64」新增至 //demo 下的任何目標,但名稱含有「test」的目標除外。
標記: loading_and_analysis
--[no]experimental_include_xcode_execution_requirements 預設值:「false」
如果已設定,請在每個 Xcode 動作中新增「requires-xcode:{version}」執行需求。如果 Xcode 版本有連字號標籤,請一併新增「requires-xcode-label:{version_label}」執行要求。
標記: loses_incremental_stateloading_and_analysisexecutionexperimental
--[no]experimental_prefer_mutual_xcode 預設值:「true」
如果為 true,請使用在本機和遠端都可用的最新 Xcode。如果為 false,或沒有可用的共同版本,請使用透過 xcode-select 所選的本機 Xcode 版本。
標記: loses_incremental_stateexperimental
--extra_execution_platforms=<comma-separated list of options> 預設值:""
可用於執行動作的執行平台。您可以使用完全比對目標或目標模式指定平台。系統會先考慮這些平台,再考慮由 register_execution_platforms() 在 WORKSPACE 檔案中宣告的平台。這個選項只能設定一次;後續的例項會覆寫先前的標記設定。
標記: execution
--extra_toolchains=<comma-separated list of options> 累積多次使用
在工具鍊解析期間要考量的工具鍊規則。您可以使用確切目標或目標模式指定工具鍊。系統會先考慮這些工具鍊,再考慮 WORKSPACE 檔案中透過 register_toolchains() 宣告的工具鍊。
標記: affects_outputschanges_inputsloading_and_analysis
--grte_top=<a label> 預設值:請參閱說明
已檢查的 libc 程式庫的標籤。預設值是由 crosstool 工具鍊選取,您幾乎不需要覆寫。
標記: action_command_linesaffects_outputs
--host_compiler=<a string> 預設值:請參閱說明
無操作標記。將在日後推出的版本中移除。
標記: loading_and_analysisexecution
--host_grte_top=<a label> 預設值:請參閱說明
如果指定此值,這項設定會覆寫執行設定的 libc 頂層目錄 (--grte_top)。
標記: action_command_linesaffects_outputs
--host_platform=<a build target label> 預設值:"@bazel_tools//tools:host_platform"
平台規則的標籤,用於說明主機系統。
標記: affects_outputschanges_inputsloading_and_analysis
--[no]incompatible_bazel_test_exec_run_under 預設值:「false」
如果啟用,則「bazel test --run_under=//:runner」會在執行設定中建構「//:runner」。如果停用,則會在目標設定中建構「//:runner」。Bazel 會在執行機器上執行測試,因此前者較為正確。這不會影響「bazel run」,因為這項指令會一律在目標設定中建構「--run_under=//foo」。
標記: affects_outputsincompatible_change
--[no]incompatible_dont_enable_host_nonhost_crosstool_features 預設值:「true」
如果設為 true,Bazel 就不會在 c++ 工具鍊中啟用「host」和「nonhost」功能 (詳情請參閱 https://github.com/bazelbuild/bazel/issues/7407)。
標記: loading_and_analysisincompatible_change
--[no]incompatible_enable_apple_toolchain_resolution 預設值:「false」
使用工具鍊解析來選取 Apple 規則的 Apple SDK (Starlark 和原生)
標記: loading_and_analysisincompatible_change
--[no]incompatible_remove_legacy_whole_archive 預設值:「true」
如果為 true,Bazel 預設不會將程式庫依附元件連結為整個封存檔 (如需遷移操作說明,請參閱 https://github.com/bazelbuild/bazel/issues/7362)。
標記: loading_and_analysisincompatible_change
--[no]incompatible_strip_executable_safely 預設值:「false」
如果為 true,可執行檔的剝除動作會使用 -x 標記,不會中斷動態符號解析。
標記: action_command_linesincompatible_change
--[no]interface_shared_objects 預設值:「true」
如果工具鍊支援,請使用介面共用物件。目前所有 ELF 工具鍊都支援這項設定。
標記: loading_and_analysisaffects_outputsaffects_outputs
--ios_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 iOS 應用程式的 iOS SDK 版本。如未指定,系統會使用「xcode_version」的預設 iOS SDK 版本。
標記: loses_incremental_state
--macos_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 macOS 應用程式的 macOS SDK 版本。如未指定,系統會使用「xcode_version」中的預設 macOS SDK 版本。
標記: loses_incremental_state
--minimum_os_version=<a string> 預設值:請參閱說明
編譯目標的最低作業系統版本。
標記: loading_and_analysisaffects_outputs
--platform_mappings=<a main workspace-relative path> 預設值:""
對應檔案的位置,可說明在未設定任何平台時要使用的平台,或在已存在平台時要設定的旗標。必須相對於主要工作區根目錄。預設值為「platform_mappings」(工作區根目錄下方的檔案)。
標記: affects_outputschanges_inputsloading_and_analysisimmutable
--platforms=<a build target label> 預設值:""
平台規則的標籤,說明目前指令的目標平台。
標記: affects_outputschanges_inputsloading_and_analysis
--python_path=<a string> 預設值:請參閱說明
在目標平台上執行 Python 目標時,系統會叫用 Python 解譯器的絕對路徑。已淘汰;已由 --incompatible_use_python_toolchains 停用。
標記: loading_and_analysisaffects_outputs
--python_top=<a build target label> 預設值:請參閱說明
py_runtime 的標籤,代表在目標平台上執行 Python 目標時所叫用的 Python 轉譯器。已淘汰;已由 --incompatible_use_python_toolchains 停用。
標記: loading_and_analysisaffects_outputs
--tvos_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 tvOS 應用程式的 tvOS SDK 版本。如果未指定,系統會使用「xcode_version」中的預設 tvOS SDK 版本。
標記: loses_incremental_state
--watchos_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 watchOS 應用程式的 watchOS SDK 版本。如未指定,系統會使用「xcode_version」的預設 watchOS SDK 版本。
標記: loses_incremental_state
--xcode_version=<a string> 預設值:請參閱說明
如果指定此屬性,系統會使用指定版本的 Xcode 執行相關的建構動作。如未指定,系統會使用執行緒的預設 Xcode 版本。
標記: loses_incremental_state
--xcode_version_config=<a build target label> 預設值:"@bazel_tools//tools/cpp:host_xcodes"
xcode_config 規則的標籤,用於在建構設定中選取 Xcode 版本。
標記: loses_incremental_stateloading_and_analysis
控制指令輸出的選項:
--[no]apple_generate_dsym 預設值:「false」
是否產生偵錯符號 (.dSYM) 檔案。
標記: affects_outputsaction_command_lines
如果為 true,則為所有目標建構 runfiles 符號連結森林。如果為 false,則只有在本機動作、測試或執行指令要求時,才會寫入。
標記: affects_outputs
--[no]build_runfile_manifests 預設值:「true」
如果為 true,則為所有目標寫入 runfiles 資訊清單。如果為 false,則省略這些項目。如果為 false,本機測試就會無法執行。
標記: affects_outputs
--[no]build_test_dwp 預設值:「false」
如果啟用此選項,在使用 Fission 靜態建構 C++ 測試時,系統也會自動建構測試二進位檔的 .dwp 檔案。
標記: loading_and_analysisaffects_outputs
--cc_proto_library_header_suffixes=<comma-separated set of options> 預設值:".pb.h"
設定 cc_proto_library 建立的標頭檔案後置字串。
標記: affects_outputsloading_and_analysis
--cc_proto_library_source_suffixes=<comma-separated set of options> 預設值:「.pb.cc」
設定 cc_proto_library 建立的來源檔案後置字串。
標記: affects_outputsloading_and_analysis
--[no]experimental_proto_descriptor_sets_include_source_info 預設值:「false」
針對 proto_library 中的其他 Java API 版本執行額外動作。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_save_feature_state 預設值:「false」
將已啟用和要求的功能的狀態儲存為編譯的輸出內容。
標記: affects_outputsexperimental
--fission=<a set of compilation modes> 預設值:「no」
指定哪些編譯模式會在 C++ 編譯和連結時使用分裂。可為 {'fastbuild', 'dbg', 'opt'} 或特殊值的任意組合,其中 'yes'可啟用所有模式,'no'可停用所有模式。
標記: loading_and_analysisaction_command_linesaffects_outputs
--[no]incompatible_always_include_files_in_data 預設值:「true」
如果為 true,原生規則會將資料依附元件的 <code>DefaultInfo.files</code> 新增至其執行檔,這與 Starlark 規則的建議行為相符 (https://bazel.build/extending/rules#runfiles_features_to_avoid)。
標記: affects_outputsincompatible_change
--[no]legacy_external_runfiles 預設值:「false」
如果為 true,則會為 .runfiles/wsname/external/repo 下的外部存放區 (除了 .runfiles/repo) 建構執行檔案符號連結森林。
標記: affects_outputs
--[no]objc_generate_linkmap 預設值:「false」
指定是否要產生連結圖檔案。
標記: affects_outputs
--[no]save_temps 預設值:「false」
如果設定,系統會儲存來自 gcc 的臨時輸出內容。包括 .s 檔案 (組譯器程式碼)、.i 檔案 (預處理的 C) 和 .ii 檔案 (預處理的 C++)。
標記: affects_outputs
選項可讓使用者設定預期的輸出內容,影響其值,而非其存在:
--action_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定可供含有目標設定的動作使用的一組環境變數。變數可以透過名稱指定,在這種情況下,系統會從叫用環境取得值;也可以透過名稱=值組合指定,在這種情況下,系統會設定不受叫用環境影響的值。這個選項可以重複使用;如果是針對同一個變數提供的選項,則以最新的選項為準;如果是針對不同變數提供的選項,則會累加。
標記: action_command_lines
--allowed_cpu_values=<comma-separated set of options> 預設值:""
--cpu 標記的有效值。
標記: changes_inputsaffects_outputs
--[no]android_databinding_use_androidx 預設值:「true」
產生與 AndroidX 相容的資料繫結檔案。這個屬性僅適用於資料繫結 v2。這個標記不會執行任何操作。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]android_databinding_use_v3_4_args 預設值:「true」
使用 Android Databinding v2 和 3.4.0 引數。這個標記不會執行任何操作。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--android_dynamic_mode=<off, default or fully> 預設值:「off」
決定在 cc_binary 未明確建立共用程式庫時,是否要動態連結 Android 規則的 C++ 依附元件。「預設」表示 Bazel 會選擇是否要動態連結。「fully」表示所有程式庫都會動態連結。「off」表示所有程式庫都會以靜態模式連結。
標記: affects_outputsloading_and_analysis
--android_manifest_merger_order=<alphabetical, alphabetical_by_configuration or dependency> 預設值:「alphabetical」
設定傳遞至 Android 二進位檔資訊清單合併工具的資訊清單順序。ALPHABETICAL 表示資訊清單會依據相對於執行根目錄的路徑排序。ALPHABETICAL_BY_CONFIGURATION 表示資訊清單會依據輸出目錄中相對於設定目錄的路徑排序。DEPENDENCY 表示資訊清單會依序排列,每個程式庫的資訊清單會排在其依附元件的資訊清單之前。
標記: action_command_linesexecution
--[no]android_resource_shrinking 預設值:「false」
為使用 ProGuard 的 android_binary APK 啟用資源縮減功能。
標記: affects_outputsloading_and_analysis
--[no]build_python_zip 預設值:「auto」
建構 Python 可執行的 zip 檔案;在 Windows 上開啟,在其他平台上關閉
標記: affects_outputs
--catalyst_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的清單,列出要用來建構 Apple Catalyst 二進位檔的架構。
標記: loses_incremental_stateloading_and_analysis
--[no]collect_code_coverage 預設值:「false」
如果指定此選項,Bazel 會檢測程式碼 (盡可能使用離線檢測),並在測試期間收集涵蓋率資訊。只有符合 --instrumentation_filter 的目標才會受到影響。通常不應直接指定這個選項,而應改用「bazel coverage」指令。
標記: affects_outputs
--compilation_mode=<fastbuild, dbg or opt> [-c] 預設值:「fastbuild」
指定要建構二進位檔的模式。值:'fastbuild'、'dbg'、'opt'。
標記: affects_outputsaction_command_lines
--conlyopt=<a string> 累積多次使用
編譯 C 來源檔案時,要傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--copt=<a string> 累積多次使用
傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--cpu=<a string> 預設值:""
目標 CPU。
標記: changes_inputsaffects_outputs
--cs_fdo_absolute_path=<a string> 預設值:請參閱說明
使用 CSFDO 設定檔資訊來最佳化編譯作業。指定內含設定檔檔案的 ZIP 檔案的絕對路徑名稱,也就是原始或索引 LLVM 設定檔檔案。
標記: affects_outputs
--cs_fdo_instrument=<a string> 預設值:請參閱說明
使用情境敏感的 FDO 檢測功能產生二進位檔。使用 Clang/LLVM 編譯器時,它也會接受目錄名稱,以便在執行階段轉儲原始設定檔檔案。
標記: affects_outputs
--cs_fdo_profile=<a build target label> 預設值:請參閱說明
cs_fdo_profile 代表要用於最佳化的內容敏感設定檔。
標記: affects_outputs
--cxxopt=<a string> 累積多次使用
編譯 C++ 來源檔案時,要傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--define=<a 'name=value' assignment> 累積多次使用
每個 --define 選項都會指定建構變數的值。如果變數有多個值,則最後一個值會勝出。
標記: changes_inputsaffects_outputs
--dynamic_mode=<off, default or fully> 預設值:"default"
決定是否要動態連結 C++ 二進位檔。「預設」表示 Bazel 會選擇是否要動態連結。「fully」表示所有程式庫都會動態連結。「off」表示所有程式庫都會以靜態模式連結。
標記: loading_and_analysisaffects_outputs
--[no]enable_propeller_optimize_absolute_paths 預設值:「true」
如果設為此值,任何使用 propeller optimize 的絕對路徑都會發生錯誤。
標記: affects_outputs
--[no]enable_remaining_fdo_absolute_paths 預設值:「true」
如果設為此值,任何使用 FDO 的絕對路徑都會發生錯誤。
標記: affects_outputs
--[no]enable_runfiles 預設值:「auto」
啟用 runfiles 符號連結樹狀結構;預設情況下,Windows 和其他平台都會關閉。
標記: affects_outputs
--experimental_action_listener=<a build target label> 累積多次使用
已淘汰,改用切面。使用 action_listener 將 extra_action 附加至現有的建構動作。
標記: executionexperimental
--[no]experimental_android_compress_java_resources 預設值:「false」
壓縮 APK 中的 Java 資源
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_android_databinding_v2 預設值:「true」
使用 Android Databinding v2。這個標記不會執行任何操作。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]experimental_android_resource_shrinking 預設值:「false」
為使用 ProGuard 的 android_binary APK 啟用資源縮減功能。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_android_rewrite_dexes_with_rex 預設值:「false」
使用 rex 工具重寫 dex 檔案
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]experimental_collect_code_coverage_for_generated_files 預設值:「false」
如果指定,Bazel 也會為產生的檔案產生收集涵蓋率資訊。
標記: affects_outputsexperimental
--experimental_objc_fastbuild_options=<comma-separated list of options> 預設值:"-O0,-DDEBUG=1"
使用這些字串做為 objc fastbuild 編譯器選項。
標記: action_command_lines
--[no]experimental_omitfp 預設值:「false」
如果設為 True,請使用 libunwind 進行堆疊解開作業,並使用 -fomit-frame-pointer 和 -fasynchronous-unwind-tables 進行編譯。
標記: action_command_linesaffects_outputsexperimental
--experimental_output_paths=<off, content or strip> 預設值:「off」
在輸出樹狀結構規則寫入輸出內容時,應使用哪個模型,特別適用於多平台 / 多設定版本。這項功能仍在實驗階段,詳情請參閱 https://github.com/bazelbuild/bazel/issues/6526。Starlark 動作可以選擇啟用路徑對應功能,方法是將「supports-path-mapping」鍵新增至「execution_requirements」字典。
標記: loses_incremental_statebazel_internal_configurationaffects_outputsexecution
--experimental_override_name_platform_in_output_dir=<a 'label=value' assignment> 累積多次使用
每個項目都應採用 label=value 的格式,其中 label 是指平台,而 value 是輸出路徑中要使用的所需簡稱。僅在 --experimental_platform_in_output_dir 為 true 時使用。具有最高的命名優先順序。
標記: affects_outputsexperimental
--[no]experimental_platform_in_output_dir 預設值:「false」
如果為 true,輸出目錄名稱會使用目標平台的短名稱,而非 CPU。具體的配置為實驗性質,可能會變更:首先,在極少數情況下,如果 --platforms 選項不含確切的一個值,系統會使用 platforms 選項的雜湊值。接著,如果目前平台的任何簡稱都已透過 --experimental_override_name_platform_in_output_dir 註冊,系統就會使用該簡稱。接著,如果已設定 --experimental_use_platforms_in_output_dir_legacy_heuristic,請使用目前平台標籤的短名稱。最後,平台選項的雜湊值會用於最後的手段。
標記: affects_outputsexperimental
--[no]experimental_py_binaries_include_label 預設值:「false」
即使停用沖壓功能,py_binary 目標也會包含標籤。
標記: affects_outputsexperimental
--[no]experimental_use_llvm_covmap 預設值:「false」
如果指定此選項,在啟用 collect_code_coverage 時,Bazel 會產生 llvm-cov 涵蓋範圍對應資訊,而非 gcov。
標記: changes_inputsaffects_outputsloading_and_analysisexperimental
--[no]experimental_use_platforms_in_output_dir_legacy_heuristic 預設值:「true」
請僅在建議的遷移或測試策略中使用這個標記。請注意,啟發式搜尋有已知的缺陷,建議您改為只使用 --experimental_override_name_platform_in_output_dir。
標記: affects_outputsexperimental
--fdo_instrument=<a string> 預設值:請參閱說明
使用 FDO 檢測功能產生二進位檔。使用 Clang/LLVM 編譯器時,它也會接受目錄名稱,以便在執行階段轉儲原始設定檔檔案。
標記: affects_outputs
--fdo_optimize=<a string> 預設值:請參閱說明
使用 FDO 設定檔資訊來最佳化編譯作業。指定內含 .gcda 檔案樹狀結構的 ZIP 檔案名稱、內含自動設定檔的 afdo 檔案,或 LLVM 設定檔檔案。這個旗標也接受指定為標籤的檔案 (例如 `//foo/bar:file.afdo` - 您可能需要在對應的套件中新增 `exports_files` 指示),以及指向 `fdo_profile` 目標的標籤。這項標記將由 `fdo_profile` 規則取代。
標記: affects_outputs
--fdo_prefetch_hints=<a build target label> 預設值:請參閱說明
使用快取預先擷取提示。
標記: affects_outputs
--fdo_profile=<a build target label> 預設值:請參閱說明
fdo_profile 代表用於最佳化的設定檔。
標記: affects_outputs
--features=<a string> 累積多次使用
對於在目標設定中建構的目標,系統會預設啟用或停用指定功能。指定 -<feature> 會停用該功能。負面特徵一律會覆寫正面特徵。另請參閱 --host_features
標記: changes_inputsaffects_outputs
--[no]force_pic 預設值:「false」
如果啟用,所有 C++ 編譯作業都會產生位置無關的程式碼 ("-fPIC"),連結會優先使用 PIC 預先建構的程式庫,而非非 PIC 程式庫,且連結會產生位置無關的可執行檔 ("-pie")。
標記: loading_and_analysisaffects_outputs
--host_action_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定執行作業設定可用的環境變數組合。變數可以透過名稱指定,在這種情況下,系統會從叫用環境取得值;也可以透過名稱=值組合指定,在這種情況下,系統會設定不受叫用環境影響的值。這個選項可以重複使用;如果是針對同一個變數提供的選項,則以最新的選項為準;如果是針對不同變數提供的選項,則會累加。
標記: action_command_lines
--host_compilation_mode=<fastbuild, dbg or opt> 預設值:「opt」
指定在建構期間使用的工具將以何種模式建構。值:'fastbuild'、'dbg'、'opt'。
標記: affects_outputsaction_command_lines
--host_conlyopt=<a string> 累積多次使用
在執行設定中編譯 C (但非 C++) 來源檔案時,要傳遞至 C 編譯器的其他選項。
標記: action_command_linesaffects_outputs
--host_copt=<a string> 累積多次使用
為執行設定中建構的工具,傳遞至 C 編譯器的其他選項。
標記: action_command_linesaffects_outputs
--host_cpu=<a string> 預設值:""
主機 CPU。
標記: changes_inputsaffects_outputs
--host_cxxopt=<a string> 累積多次使用
針對在執行設定中建構的工具,傳遞至 C++ 編譯器的其他選項。
標記: action_command_linesaffects_outputs
--host_features=<a string> 累積多次使用
對於在執行設定中建構的目標,系統會依預設啟用或停用指定功能。指定 -<feature> 會停用該功能。負面特徵一律會覆寫正面特徵。
標記: changes_inputsaffects_outputs
--host_force_python=<PY2 or PY3> 預設值:請參閱說明
覆寫執行設定的 Python 版本。可以是「PY2」或「PY3」。
標記: loading_and_analysisaffects_outputs
--host_linkopt=<a string> 累積多次使用
在執行設定中連結工具時,要傳遞至連結器的其他選項。
標記: action_command_linesaffects_outputs
--host_macos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
主機目標的最低相容 macOS 版本。如果未指定,系統會使用「macos_sdk_version」。
標記: loses_incremental_state
--host_per_file_copt=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths followed by an @ and a comma separated list of options> 累積多次使用
在執行設定中編譯特定檔案時,可選擇傳遞至 C/C++ 編譯器的其他選項。這個選項可以多次傳遞。語法:regex_filter@選項_1,選項_2,...,選項_n。其中 regex_filter 代表包含和排除的規則運算式模式清單 (另請參閱 --instrumentation_filter)。option_1 到 option_n 代表任意指令列選項。如果選項包含半形逗號,則必須在半形逗號前後加上反斜線。選項可以包含 @。只有第一個 @ 會用來分割字串。範例:--host_per_file_copt=//foo/.*\.cc,-//foo/bar\.cc@-O0 會將 -O0 指令列選項新增至 //foo/ 中所有 cc 檔案 (除了 bar.cc) 的 gcc 指令列。
標記: action_command_linesaffects_outputs
--[no]incompatible_auto_exec_groups 預設值:「false」
啟用後,系統會為規則使用的每個工具鍊自動建立執行群組。為使這項規則運作,您需要在其動作中指定「toolchain」參數。如需更多資訊,請參閱 https://github.com/bazelbuild/bazel/issues/17134。
標記: affects_outputsincompatible_change
--[no]incompatible_merge_genfiles_directory 預設值:「true」
如果設為 true,系統會將 genfiles 目錄折疊至 bin 目錄。
標記: affects_outputsincompatible_change
--[no]instrument_test_targets 預設值:「false」
啟用涵蓋率時,指定是否要考慮檢測測試規則。設定後,--instrumentation_filter 所包含的測試規則就會進行檢測。否則,測試規則一律會從涵蓋率檢測工具中排除。
標記: affects_outputs
--instrumentation_filter=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths> 預設值:「-/javatests[/:],-/test/java[/:]」
啟用涵蓋率後,系統只會檢測名稱包含指定規則運算式篩選器的規則。系統會排除開頭為「-」的規則。請注意,除非啟用 --instrument_test_targets,否則只會檢測非測試規則。
標記: affects_outputs
--ios_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定模擬器和裝置的最低相容 iOS 版本。如果未指定,系統會使用「ios_sdk_version」。
標記: loses_incremental_state
--ios_multi_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的架構清單,用於建構 ios_application。結果會是包含所有指定架構的通用二進位檔。
標記: loses_incremental_stateloading_and_analysis
--[no]legacy_whole_archive 預設值:「true」
已淘汰,已由 --incompatible_remove_legacy_whole_archive 取代 (詳情請參閱 https://github.com/bazelbuild/bazel/issues/7362)。開啟後,請針對 cc_binary 規則使用 --whole-archive,該規則的 linkshared 為 True,且 linkopts 中為 linkstatic=True 或 '-static'。這項設定僅適用於回溯相容性。更好的做法是在需要時使用 alwayslink=1。
標記: action_command_linesaffects_outputsdeprecated
--linkopt=<a string> 累積多次使用
連結時傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--ltobackendopt=<a string> 累積多次使用
傳遞至 LTO 後端步驟的其他選項 (在 --features=thin_lto 下方)。
標記: action_command_linesaffects_outputs
--ltoindexopt=<a string> 累積多次使用
傳遞至 LTO 索引步驟的其他選項 (在 --features=thin_lto 下方)。
標記: action_command_linesaffects_outputs
--macos_cpus=<comma-separated list of options> 累積多次使用
以逗號分隔的架構清單,用於建構 Apple macOS 二進位檔。
標記: loses_incremental_stateloading_and_analysis
--macos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
目標的最低相容 macOS 版本。如果未指定,系統會使用「macos_sdk_version」。
標記: loses_incremental_state
--memprof_profile=<a build target label> 預設值:請參閱說明
使用 memprof 設定檔。
標記: affects_outputs
--[no]objc_debug_with_GLIBCXX 預設值:「false」
如果已設定,且編譯模式設為「dbg」,請定義 GLIBCXX_DEBUG、GLIBCXX_DEBUG_PEDANTIC 和 GLIBCPP_CONCEPT_CHECKS。
標記: action_command_lines
--[no]objc_enable_binary_stripping 預設值:「false」
是否要在已連結的二進位檔上執行符號和無效程式碼去除作業。如果同時指定這個旗標和 --compilation_mode=opt,系統就會執行二進位碼去除作業。
標記: action_command_lines
--objccopt=<a string> 累積多次使用
編譯 Objective-C/C++ 來源檔案時,要傳遞至 gcc 的其他選項。
標記: action_command_lines
--per_file_copt=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths followed by an @ and a comma separated list of options> 累積多次使用
在編譯特定檔案時,可選擇傳遞至 gcc 的其他選項。這個選項可以多次傳遞。語法:regex_filter@選項_1,選項_2,...,選項_n。其中 regex_filter 代表包含和排除的規則運算式模式清單 (另請參閱 --instrumentation_filter)。option_1 到 option_n 代表任意指令列選項。如果選項包含半形逗號,則必須在半形逗號前後加上反斜線。選項可以包含 @。只有第一個 @ 會用來分割字串。範例:--per_file_copt=//foo/.*\.cc,-//foo/bar\.cc@-O0 會將 -O0 指令列選項新增至 //foo/ 中所有 cc 檔案 (除了 bar.cc) 的 gcc 指令列。
標記: action_command_linesaffects_outputs
--per_file_ltobackendopt=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths followed by an @ and a comma separated list of options> 累積多次使用
編譯特定後端物件時,可選擇將哪些選項傳遞至 LTO 後端 (在 --features=thin_lto 下) 的其他選項。這個選項可以多次傳遞。語法:regex_filter@選項_1,選項_2,...,選項_n。其中 regex_filter 代表包含和排除規則運算式的清單。option_1 到 option_n 代表任意指令列選項。如果選項包含半形逗號,則必須在半形逗號前後加上反斜線。選項可以包含 @。只有第一個 @ 會用來分割字串。範例:--per_file_ltobackendopt=//foo/.*\.o,-//foo/bar\.o@-O0 會將 -O0 指令列選項新增至 //foo/ 中所有 o 檔案 (除了 bar.o) 的 LTO 後端指令列。
標記: action_command_linesaffects_outputs
--platform_suffix=<a string> 預設值:請參閱說明
指定要新增至設定目錄的後置字串。
標記: loses_incremental_stateaffects_outputsloading_and_analysis
--propeller_optimize=<a build target label> 預設值:請參閱說明
使用 Propeller 設定檔資訊來改善建構目標。Propeller 設定檔至少必須包含以下兩個檔案之一:cc 設定檔和 ld 設定檔。這個標記可接受建構標籤,但該標籤必須參照螺旋槳設定檔輸入檔案。舉例來說,定義標籤的 BUILD 檔案,在 a/b/BUILD:propeller_optimize( name = "propeller_profile", cc_profile = "propeller_cc_profile.txt", ld_profile = "propeller_ld_profile.txt",) 中,您可能必須在對應的套件中加入 exports_files 指示詞,才能讓 Bazel 看到這些檔案。這個選項必須以以下方式使用:--propeller_optimize=//a/b:propeller_profile
標記: action_command_linesaffects_outputs
--propeller_optimize_absolute_cc_profile=<a string> 預設值:請參閱說明
Propeller 最佳化版本的 cc_profile 檔案絕對路徑名稱。
標記: affects_outputs
--propeller_optimize_absolute_ld_profile=<a string> 預設值:請參閱說明
Propeller 最佳化版本的 ld_profile 檔案絕對路徑名稱。
標記: affects_outputs
--run_under=<a prefix in front of command> 預設值:請參閱說明
在「test」和「run」指令的可執行檔前插入前置字串。如果值為「foo -bar」,執行指令列為「test_binary -baz」,則最終指令列為「foo -bar test_binary -baz」。這也可以是可執行目標的標籤。以下是一些範例:'valgrind'、'strace'、'strace -c'、'valgrind --quiet --num-callers=20'、'//package:target'、'//package:target --options'。
標記: action_command_lines
--[no]share_native_deps 預設值:「true」
如果為 true,含有相同功能的原生程式庫會在不同目標之間共用
標記: loading_and_analysisaffects_outputs
--[no]stamp 預設值:「false」
在二進位檔上蓋上日期、使用者名稱、主機名稱、工作區資訊等資訊。
標記: affects_outputs
--strip=<always, sometimes or never> 預設值:「sometimes」
用於指定是否要移除二進位檔和共用程式庫 (使用「-Wl,--strip-debug」)。預設值為「sometimes」表示如果 --compilation_mode=fastbuild,則會移除。
標記: affects_outputs
--stripopt=<a string> 累積多次使用
產生 '<name>.stripped'二進位檔時,要傳遞至 strip 的其他選項。
標記: action_command_linesaffects_outputs
--tvos_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的架構清單,用於建構 Apple tvOS 二進位檔。
標記: loses_incremental_stateloading_and_analysis
--tvos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定模擬器和裝置的最低相容 tvOS 版本。如果未指定,系統會使用「tvos_sdk_version」。
標記: loses_incremental_state
--visionos_cpus=<comma-separated list of options> 累積多次使用
以逗號分隔的清單,列出要為其建構 Apple visionOS 二進位檔的架構。
標記: loses_incremental_stateloading_and_analysis
--watchos_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的架構清單,用於建構 Apple watchOS 二進位檔。
標記: loses_incremental_stateloading_and_analysis
--watchos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定模擬器和裝置的最低相容 watchOS 版本。如果未指定,系統會使用「watchos_sdk_version」。
標記: loses_incremental_state
--xbinary_fdo=<a build target label> 預設值:請參閱說明
使用 XbinaryFDO 設定檔資訊來最佳化編譯作業。指定預設交叉二進位設定檔的名稱。當此選項與 --fdo_instrument/--fdo_optimize/--fdo_profile 一起使用時,這些選項一律會優先採用,就好像從未指定 xbinary_fdo 一樣。
標記: affects_outputs
影響 Bazel 如何嚴格執行有效建構輸入內容 (規則定義、標記組合等) 的選項:
--[no]check_licenses 預設值:「false」
請確認依附套件施加的授權限制,不會與建構目標的發布模式衝突。根據預設,系統不會檢查授權。
標記: build_file_semantics
--[no]check_visibility 預設值:「true」
如果停用,目標依附元件中的顯示錯誤會降級為警告。
標記: build_file_semantics
--[no]desugar_for_android 預設值:「true」
是否要在解碼前脫糖 Java 8 位元組碼。
標記: affects_outputsloading_and_analysisloses_incremental_state
--[no]desugar_java8_libs 預設值:「false」
是否要在舊版裝置的應用程式中加入支援的 Java 8 程式庫。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]enforce_constraints 預設值:「true」
檢查每個目標的相容環境,如果任何目標的依附元件不支援相同的環境,就會回報錯誤
標記: build_file_semantics
--[no]experimental_check_desugar_deps 預設值:「true」
是否要再次檢查 Android 二進位檔層級的正確去糖化。
標記: eagerness_to_exitloading_and_analysisexperimental
--experimental_import_deps_checking=<a string> 預設值:請參閱說明
無操作,僅保留用於回溯相容性
標記: loading_and_analysis
--experimental_one_version_enforcement=<off, warning or error> 預設值:「OFF」
啟用後,系統會強制規定 java_binary 規則在 classpath 中不得包含同一個類別檔案的多個版本。這項強制執行措施可能會導致建構作業中斷,或只會產生警告。
標記: loading_and_analysis
--experimental_strict_java_deps=<off, warn, error, strict or default> 預設值:"default"
如果為 true,系統會檢查 Java 目標是否明確將所有直接使用的目標宣告為依附元件。
標記: build_file_semanticseagerness_to_exit
--[no]incompatible_check_testonly_for_output_files 預設值:「false」
如果啟用,請查詢產生規則的 testonly,檢查 testonly 是否為輸出檔案的必要條件目標。這項設定與可見度檢查相符。
標記: build_file_semanticsincompatible_change
--[no]incompatible_check_visibility_for_toolchains 預設值:「false」
如果已啟用,可視性檢查也會套用至工具鍊實作。
標記: build_file_semanticsincompatible_change
--[no]incompatible_disable_native_android_rules 預設值:「false」
如果啟用,系統就會停用原生 Android 規則的直接用法。請使用 https://github.com/bazelbuild/rules_android 中的 Starlark Android 規則
標記: eagerness_to_exitincompatible_change
--[no]incompatible_disable_native_apple_binary_rule 預設值:「false」
無操作。為回溯相容性而保留。
標記: eagerness_to_exitincompatible_change
--[no]incompatible_python_disable_py2 預設值:「true」
如果設為 True,使用 Python 2 設定會導致錯誤。包括 python_version=PY2、srcs_version=PY2 和 srcs_version=PY2ONLY。詳情請參閱 https://github.com/bazelbuild/bazel/issues/15684。
標記: loading_and_analysisincompatible_change
--[no]one_version_enforcement_on_java_tests 預設值:「true」
啟用此選項後,如果 experimental_one_version_enforcement 設為非 NONE 值,系統就會在 java_test 目標上強制執行一個版本。您可以停用這個標記,以便提升增量測試效能,但可能會錯過某個版本的違規項目。
標記: loading_and_analysis
--python_native_rules_allowlist=<a build target label> 預設值:請參閱說明
在強制執行 --incompatible_python_disallow_native_rules 時,要使用的許可清單 (package_group 目標)。
標記: loading_and_analysis
--[no]strict_filesets 預設值:「false」
如果啟用這個選項,系統會將跨越套件邊界的檔案集回報為錯誤。
標記: build_file_semanticseagerness_to_exit
--strict_proto_deps=<off, warn, error, strict or default> 預設值:「error」
除非設為 OFF,否則會檢查 proto_library 目標是否明確將所有直接使用的目標宣告為依附元件。
標記: build_file_semanticseagerness_to_exitincompatible_change
--strict_public_imports=<off, warn, error, strict or default> 預設值:「off」
除非設為 OFF,否則會檢查 proto_library 目標是否明確宣告在「import public」中使用的所有目標為匯出目標。
標記: build_file_semanticseagerness_to_exitincompatible_change
--[no]strict_system_includes 預設值:「false」
如果設為 true,則系統會透過系統包含路徑 (-isystem) 找到的標頭,也必須宣告。
標記: loading_and_analysiseagerness_to_exit
--target_environment=<a build target label> 累積多次使用
宣告此版本的目標環境。必須是「環境」規則的標籤參照。如果指定了這個環境,則所有頂層目標都必須與這個環境相容。
標記: changes_inputs
影響建構簽署輸出內容的選項:
--apk_signing_method=<v1, v2, v1_v2 or v4> 預設值:「v1_v2」
用於簽署 APK 的實作方式
標記: action_command_linesaffects_outputsloading_and_analysis
--[no]device_debug_entitlements 預設值:「true」
如果已設定,且編譯模式不是「opt」,則 objc 應用程式會在簽署時加入偵錯授權。
標記: changes_inputs
--ios_signing_cert_name=<a string> 預設值:請參閱說明
用於 iOS 簽署的憑證名稱。如果未設定,系統會改用佈建設定檔。根據 codesign 的 man 頁面 (SIGNING IDENTITIES),可能為憑證的鑰匙圈身分偏好設定或憑證的常用名稱 (子字串)。
標記: action_command_lines
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_disallow_legacy_py_provider 預設值:「true」
無操作,即將移除。
標記: loading_and_analysisincompatible_change
--[no]incompatible_disallow_sdk_frameworks_attributes 預設值:「false」
如果設為 true,就禁止在 objc_library 和 objc_import 中使用 sdk_frameworks 和 weak_sdk_frameworks 屬性。
標記: build_file_semanticsincompatible_change
如果為 true,請將 objc_library 和 objc_import 中的 alwayslink 屬性預設值設為 true。
標記: build_file_semanticsincompatible_change
--[no]incompatible_python_disallow_native_rules 預設值:「false」
如果為 True,使用內建的 py_* 規則時會發生錯誤;應改用 rule_python 規則。詳情請參閱 https://github.com/bazelbuild/bazel/issues/17773 瞭解遷移操作說明。
標記: loading_and_analysisincompatible_change
用於控管測試環境或測試執行工具行為的選項:
--[no]allow_analysis_failures 預設值:「false」
如果設為 true,規則目標的分析失敗會導致目標傳播包含錯誤說明的 AnalysisFailureInfo 例項,而不會導致建構失敗。
標記: loading_and_analysisexperimental
--analysis_testing_deps_limit=<an integer> 預設值:「2000」
透過規則屬性和 for_analysis_testing 設定轉換,設定遞移依附元件的數量上限。若超出這項限制,就會導致規則錯誤。
標記: loading_and_analysis
--[no]break_build_on_parallel_dex2oat_failure 預設值:「false」
如果為 true,則 dex2oat 動作失敗會導致建構作業中斷,而不會在測試執行階段執行 dex2oat。
標記: loading_and_analysisexperimental
--default_test_resources=<a resource name followed by equal and 1 float or 4 float, e.g memory=10,30,60,100> 累積多次使用
覆寫測試的預設資源量。預期格式為 <resource>=<value>。如果指定單一正整數做為 <value>,則會覆寫所有測試大小的預設資源。如果指定 4 個以逗號分隔的數字,這些數字會分別覆寫小、中、大、特大測試大小的資源數量。值也可以是 HOST_RAM/HOST_CPU,並可選擇加上 [-|*]<浮點> (例如 memory=HOST_RAM*.1,HOST_RAM*.2,HOST_RAM*.3,HOST_RAM*.4)。這個旗標指定的預設測試資源,會遭到標記中明確指定的資源覆寫。
--[no]experimental_android_use_parallel_dex2oat 預設值:「false」
並行使用 dex2oat,可能可加快 android_test 的速度。
標記: loading_and_analysishost_machine_resource_optimizationsexperimental
--[no]ios_memleaks 預設值:「false」
啟用 ios_test 目標的記憶體外洩檢查功能。
標記: action_command_lines
--ios_simulator_device=<a string> 預設值:請參閱說明
在模擬器中執行 iOS 應用程式時要模擬的裝置,例如「iPhone 6」。您可以在要執行模擬器的電腦上執行「xcrun simctl list devicetypes」取得裝置清單。
標記: test_runner
--ios_simulator_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
在執行或測試時,要在模擬器上執行的 iOS 版本。如果規則中指定了目標裝置,系統會忽略 ios_test 規則。
標記: test_runner
--runs_per_test=<a positive integer or test_regex@runs. This flag may be passed more than once> 累積多次使用
指定執行每項測試的次數。如果任何嘗試因任何原因失敗,整個測試就會視為失敗。通常指定的值只是整數。範例:--runs_per_test=3 會執行所有測試 3 次。其他語法:regex_filter@runs_per_test。其中 runs_per_test 代表整數值,而 regex_filter 代表包含和排除的規則運算式清單 (另請參閱 --instrumentation_filter)。範例:--runs_per_test=//foo/.*,-//foo/bar/.*@3 會執行 //foo/ 中的所有測試 (foo/bar 下的測試除外),共三次。這個選項可以多次傳遞。系統會優先採用最近傳遞且相符的引數。如果沒有任何相符項目,則只會執行一次測試。
--test_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定要插入測試執行器環境的其他環境變數。變數可以透過名稱指定,在這種情況下,系統會從 Bazel 用戶端環境讀取其值,也可以透過名稱=值組合指定。您可以多次使用此選項指定多個變數。僅供「bazel test」指令使用。
標記: test_runner
--test_timeout=<a single integer or comma-separated list of 4 integers> 預設值:「-1」
覆寫測試逾時的預設逾時值 (以秒為單位)。如果指定單一正整數值,系統會覆寫所有類別。如果指定 4 個以逗號分隔的整數,系統會覆寫短、中、長和永久 (依序) 的逾時時間。無論是哪種表單,如果值為 -1,blaze 就會使用該類別的預設逾時時間。
--[no]zip_undeclared_test_outputs 預設值:「false」
如果設為 true,系統會將未宣告的測試輸出內容封存為 ZIP 檔案。
標記: test_runner
觸發建構時間最佳化功能的選項:
--[no]experimental_filter_library_jar_with_program_jar 預設值:「false」
篩選 ProGuard ProgramJar,移除 LibraryJar 中也存在的任何類別。
標記: action_command_linesexperimental
--[no]experimental_inmemory_dotd_files 預設值:「true」
如果啟用此選項,C++ .d 檔案會直接從遠端建構節點傳遞至記憶體,而不會寫入磁碟。
標記: loading_and_analysisexecutionaffects_outputsexperimental
--[no]experimental_inmemory_jdeps_files 預設值:「true」
如果啟用此選項,系統會直接從遠端建構節點,透過記憶體傳遞從 Java 編譯產生的依附元件檔案 (.jdeps),而不會寫入磁碟。
標記: loading_and_analysisexecutionaffects_outputsexperimental
--[no]experimental_retain_test_configuration_across_testonly 預設值:「false」
啟用後,--trim_test_configuration 就不會為標示為 testonly=1 的規則裁減測試設定。這項功能旨在減少非測試規則依賴 cc_test 規則時的動作衝突問題。如果 --trim_test_configuration 為 false,就不會產生任何影響。
標記: loading_and_analysisloses_incremental_stateexperimental
--[no]experimental_starlark_cc_import 預設值:「false」
如果啟用,即可使用 Starlark 版本的 cc_import。
標記: loading_and_analysisexperimental
--[no]experimental_unsupported_and_brittle_include_scanning 預設值:「false」
是否要透過剖析輸入檔案中的 #include 行,將輸入內容縮減為 C/C++ 編譯。這可縮減編譯輸入樹狀結構的大小,進而提升效能和增量。不過,由於包含掃描器未完全實作 C 預處理器語意,因此也可能會導致建構作業中斷。具體來說,它無法瞭解動態 #include 指示,並會忽略預處理器條件邏輯。您必須自行承擔使用風險。我們會關閉與這個標記相關的所有已提交問題。
標記: loading_and_analysisexecutionchanges_inputsexperimental
--[no]incremental_dexing 預設值:「true」
針對每個 Jar 檔案分別執行大部分的解析工作。
標記: affects_outputsloading_and_analysisloses_incremental_state
--[no]objc_use_dotd_pruning 預設值:「true」
如果設定,系統會使用 Clang 產生的 .d 檔案,來修剪傳遞至 objc 編譯作業的輸入集合。
標記: changes_inputsloading_and_analysis
--[no]process_headers_in_dependencies 預設值:「false」
建構目標 //a:a 時,請處理 //a:a 依附的所有目標中的標頭 (如果工具鍊啟用了標頭處理功能)。
標記: execution
--[no]trim_test_configuration 預設值:「true」
啟用後,系統會清除版本頂層以下的測試相關選項。啟用此標記後,測試就無法建構為非測試規則的依附元件,但變更測試相關選項不會導致非測試規則重新分析。
標記: loading_and_analysisloses_incremental_state
影響記錄詳細程度、格式或位置的選項:
--toolchain_resolution_debug=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths> 預設值:「-.*」
在工具鍊解析期間列印偵錯資訊。這個標記會採用規則運算式,並根據工具鍊類型和特定目標進行檢查,以便查看要偵錯的目標。您可以使用逗號分隔多個規則運算式,然後分別檢查每個規則運算式。注意:這個標記的輸出內容非常複雜,可能只有工具鍊解析專家才會覺得實用。
標記: terminal_output
選項可指定或變更 Bazel 指令的一般輸入內容,而該輸入內容不屬於其他類別:
--flag_alias=<a 'name=value' flag alias> 累積多次使用
設定 Starlark 標記的簡寫名稱。它會將單一鍵/值組合 (格式為「<鍵>=<值>」) 做為引數。
標記: changes_inputs
--[no]incompatible_default_to_explicit_init_py 預設值:「false」
這個標記會變更預設行為,讓 __init__.py 檔案不再自動建立在 Python 目標的執行檔案中。具體來說,如果 py_binary 或 py_test 目標將 legacy_create_init 設為「auto」(預設值),則只有在設定此標記時,才會視為 false。請參閱 https://github.com/bazelbuild/bazel/issues/10076。
標記: affects_outputsincompatible_change
--[no]incompatible_py2_outputs_are_suffixed 預設值:「true」
如果設為 true,在 Python 2 設定中建構的目標會顯示在包含「-py2」字尾的輸出根目錄下,而為 Python 3 建構的目標則會顯示在沒有 Python 相關字尾的根目錄中。也就是說,`bazel-bin` 方便捷符號會指向 Python 3 目標,而非 Python 2。如果您啟用這個選項,建議也啟用 `--incompatible_py3_is_default`。
標記: affects_outputsincompatible_change
--[no]incompatible_py3_is_default 預設值:「true」
如果為 true,則未設定 `python_version` (或 `default_python_version`) 屬性的 `py_binary` 和 `py_test` 目標,預設會使用 PY3 而非 PY2。如果您設定這個旗標,建議也設定 `--incompatible_py2_outputs_are_suffixed`。
標記: loading_and_analysisaffects_outputsincompatible_change
--[no]incompatible_use_python_toolchains 預設值:「true」
如果設為 true,可執行的原生 Python 規則會使用 Python 工具鍊指定的 Python 執行階段,而非由 --python_top 等舊版標記提供的執行階段。
標記: loading_and_analysisincompatible_change
--python_version=<PY2 or PY3> 預設值:請參閱說明
Python 主要版本模式,可選為 `PY2` 或 `PY3`。請注意,這會由 `py_binary` 和 `py_test` 目標覆寫 (即使未明確指定版本),因此通常沒有提供這個旗標的必要。
標記: loading_and_analysisaffects_outputs
其他選項,不屬於其他類別:
--[no]cache_test_results [-t] 預設值:「auto」
如果設為「auto」,Bazel 只會在下列情況下重新執行測試:(1) Bazel 偵測到測試或其依附元件的變更、(2) 測試標示為外部、(3) 使用 --runs_per_test 要求執行多個測試,或(4) 測試先前失敗。如果設為「是」,Bazel 會快取所有測試結果,但標示為外部的測試除外。如果設為「no」,Bazel 就不會快取任何測試結果。
--[no]experimental_cancel_concurrent_tests 預設值:「false」
如果為 true,Blaze 會在第一次成功執行時取消同時執行的測試。只有在搭配 --runs_per_test_detects_flakes 時才有用。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_fetch_all_coverage_outputs 預設值:「false」
如果為 true,Bazel 就會在執行涵蓋率時,為每項測試擷取整個涵蓋率資料目錄。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_generate_llvm_lcov 預設值:「false」
如果設為 True,clang 的涵蓋率就會產生 LCOV 報表。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_j2objc_header_map 預設值:「true」
是否要在 J2ObjC 轉譯時並行產生 J2ObjC 標頭對應項目。
標記: experimental
--[no]experimental_j2objc_shorter_header_path 預設值:「false」
是否要使用較短的標頭路徑產生 (使用「_ios」而非「_j2objc」)。
標記: affects_outputsexperimental
--experimental_java_classpath=<off, javabuilder or bazel> 預設值:「javabuilder」
啟用 Java 編譯作業的縮減路徑集。
--[no]experimental_limit_android_lint_to_android_constrained_java 預設值:「false」
無操作,僅保留用於向後相容性
標記: affects_outputsexperimental
--[no]experimental_run_android_lint_on_java_rules 預設值:「false」
是否要驗證 java_* 來源。
標記: affects_outputsexperimental
--[no]explicit_java_test_deps 預設值:「false」
在 java_test 中明確指定對 JUnit 或 Hamcrest 的依附元件,而不是意外從 TestRunner 的 deps 取得。目前僅適用於 Bazel。
--host_java_launcher=<a build target label> 預設值:請參閱說明
在建構期間執行的工具所使用的 Java 啟動器。
--host_javacopt=<a string> 累積多次使用
建構在建構期間執行的工具時,要傳遞至 javac 的其他選項。
--host_jvmopt=<a string> 累積多次使用
建構期間執行的工具在建構時,傳遞至 Java VM 的其他選項。這些選項會新增至每個 java_binary 目標的 VM 啟動選項。
--[no]incompatible_check_sharding_support 預設值:「true」
如果為 true,如果測試執行程式未透過觸碰 TEST_SHARD_STATUS_FILE 路徑中的檔案,表示不支援分割,則 Bazel 會失敗執行分割測試。如果為 false,則不支援分割的測試執行程式會導致所有測試在每個分割區中執行。
標記: incompatible_change
--[no]incompatible_exclusive_test_sandboxed 預設值:「true」
如果為 true,系統會使用沙箱策略執行專屬測試。新增「local」標記,強制在本機上執行專屬測試
標記: incompatible_change
--[no]incompatible_strict_action_env 預設值:「false」
如果為 True,Bazel 會使用 PATH 的靜態值環境,且不會繼承 LD_LIBRARY_PATH。如果您想從用戶端繼承特定環境變數,請使用 --action_env=ENV_VARIABLE,但請注意,如果使用共用快取,這麼做可能會導致跨使用者快取無法使用。
標記: loading_and_analysisincompatible_change
--j2objc_translation_flags=<comma-separated list of options> 累積多次使用
傳遞至 J2ObjC 工具的其他選項。
--java_debug
讓 Java 測試的 Java 虛擬機器在開始測試前,等待符合 JDWP 標準的偵錯工具 (例如 jdb) 連線。暗示 -test_output=streamed。
展開為:
  --test_arg=--wrapper_script_flag=--debug
  --test_output=streamed
  --test_strategy=exclusive
  --test_timeout=9999
  --nocache_test_results
--[no]java_deps 預設值:「true」
針對每個 Java 目標產生依附元件資訊 (目前為編譯時間的類別路徑)。
--[no]java_header_compilation 預設值:「true」
直接從來源編譯 ijar。
--java_language_version=<a string> 預設值:""
Java 語言版本
--java_launcher=<a build target label> 預設值:請參閱說明
建構 Java 二進位檔時要使用的 Java 啟動器。如果這個標記設為空字串,系統就會使用 JDK 啟動器。「launcher」屬性會覆寫這個旗標。
--java_runtime_version=<a string> 預設值:「local_jdk」
Java 執行階段版本
--javacopt=<a string> 累積多次使用
傳遞至 javac 的其他選項。
--jvmopt=<a string> 累積多次使用
傳遞至 Java VM 的其他選項。這些選項會新增至每個 java_binary 目標的 VM 啟動選項。
--legacy_main_dex_list_generator=<a build target label> 預設值:請參閱說明
指定要使用的二進位檔,用於產生編譯舊版 Multidex 時,必須位於主 DEX 中的類別清單。
--optimizing_dexer=<a build target label> 預設值:請參閱說明
指定用於在不分割的情況下執行解析的二進位檔。
--plugin=<a build target label> 累積多次使用
在建構中使用的外掛程式。目前支援 java_plugin。
--proguard_top=<a build target label> 預設值:請參閱說明
指定建構 Java 二進位檔時,要使用哪個版本的 ProGuard 來移除程式碼。
--proto_compiler=<a build target label> 預設值:"@bazel_tools//tools/proto:protoc"
Proto 編譯器的標籤。
標記: affects_outputsloading_and_analysis
--[no]proto_profile 預設值:「true」
是否將 profile_path 傳遞至 proto 編譯器。
標記: affects_outputsloading_and_analysis
--proto_profile_path=<a build target label> 預設值:請參閱說明
要以 profile_path 形式傳遞至 Proto 編譯器的設定檔。如果未設定,但 --proto_profile 為 true (預設值),系統會從 --fdo_optimize 推斷路徑。
標記: affects_outputsloading_and_analysis
--proto_toolchain_for_cc=<a build target label> 預設值:"@bazel_tools//tools/proto:cc_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 C++ 原型檔
標記: affects_outputsloading_and_analysis
--proto_toolchain_for_j2objc=<a build target label> 預設值:"@bazel_tools//tools/j2objc:j2objc_proto_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 j2objc 原型檔
標籤: affects_outputsloading_and_analysis
--proto_toolchain_for_java=<a build target label> 預設值:"@bazel_tools//tools/proto:java_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 Java 原型檔
標記: affects_outputsloading_and_analysis
--proto_toolchain_for_javalite=<a build target label> 預設值:"@bazel_tools//tools/proto:javalite_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 JavaLite 原型檔
標記: affects_outputsloading_and_analysis
--protocopt=<a string> 累積多次使用
傳遞至 protobuf 編譯器的其他選項。
標記: affects_outputs
--[no]runs_per_test_detects_flakes 預設值:「false」
如果為 true,則任何具有至少一個成功執行/嘗試,以及至少一個失敗執行/嘗試的區塊,都會獲得「不穩定」狀態。
--shell_executable=<a path> 預設值:請參閱說明
Shell 可執行檔的絕對路徑,供 Bazel 使用。如果未設定此值,但在第一次呼叫 Bazel (啟動 Bazel 伺服器) 時已設定 BAZEL_SH 環境變數,Bazel 就會使用該值。如果未設定這兩者,Bazel 會根據執行的作業系統使用硬式編碼的預設路徑 (Windows:c:/msys64/usr/bin/bash.exe、FreeBSD:/usr/local/bin/bash、其他所有作業系統:/bin/bash)。請注意,使用與 bash 不相容的殼層,可能會導致產生的二進位檔發生建構失敗或執行階段失敗。
標記: loading_and_analysis
--test_arg=<a string> 累積多次使用
指定應傳遞至測試可執行檔的其他選項和引數。可多次使用,用於指定多個引數。如果執行多項測試,每項測試都會收到相同的引數。僅供「bazel test」指令使用。
--test_filter=<a string> 預設值:請參閱說明
指定要轉送至測試架構的篩選器。用於限制執行的測試。請注意,這不會影響要建構的目標。
--test_result_expiration=<an integer> 預設值:「-1」
這個選項已淘汰,不會產生任何作用。
--[no]test_runner_fail_fast 預設值:「false」
將快速失敗選項轉送至測試執行程式。測試執行程式應在第一次失敗時停止執行。
--test_sharding_strategy=<explicit, disabled or forced=k where k is the number of shards to enforce> 預設值:「explicit」
指定測試區塊劃分策略:如果有 'shard_count' BUILD 屬性,則只使用區塊劃分策略。如要一律不使用測試分割,請選擇「disabled」。使用「forced=k」強制執行「k」分片進行測試,無論「shard_count」BUILD 屬性為何都一樣。
--tool_java_language_version=<a string> 預設值:""
用於執行建構期間所需工具的 Java 語言版本
--tool_java_runtime_version=<a string> 預設值:「remotejdk_11」
在建構期間用來執行工具的 Java 執行階段版本
--[no]use_ijars 預設值:「true」
如果啟用此選項,Java 編譯作業就會使用介面 JAR 檔案。這會加快增量編譯作業,但錯誤訊息可能會有所不同。

說明選項

這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
代碼: loading_and_analysis
影響記錄詳細程度、格式或位置的選項:
--help_verbosity=<long, medium or short> 預設值:「medium」
選取 help 指令的詳細程度。
標記: terminal_output
--long [-l]
顯示每個選項的完整說明,而非僅顯示名稱。
展開為:
  --help_verbosity=long

標記: terminal_output
--short
只顯示選項名稱,不顯示類型或意義。
展開為:
  --help_verbosity=short

標記: terminal_output

資訊選項

繼承「build」的所有選項。

這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
代碼: loading_and_analysis
影響記錄詳細程度、格式或位置的選項:
--[no]show_make_env 預設值:「false」
在輸出內容中加入「Make」環境。
標記: affects_outputsterminal_output

授權選項

這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
代碼: loading_and_analysis

行動安裝選項

繼承「build」的所有選項。

控制建構執行作業的選項:
--mode=<classic, classic_internal_test_do_not_use or skylark> 預設值:「skylark」
已淘汰的無效旗標。目前仍只支援 Skylark 模式。
標記: loading_and_analysisexecutionincompatible_change
設定用於執行動作的工具鍊的選項:
--adb=<a string> 預設值:""
adb 二進位檔,用於執行「mobile-install」指令。如果未指定,系統會使用由 --android_sdk_channel 指令列選項指定的 Android SDK (如果未指定 --android_sdk_channel,則會使用預設 SDK)。
標記: changes_inputs
控制指令輸出的選項:
--[no]incremental 預設值:「false」
是否要進行增量安裝。如果為 true,請讀取要安裝程式碼的裝置狀態,並利用該資訊避免不必要的額外工作。如果為 false (預設值),則一律執行完整安裝作業。
標記: loading_and_analysis
--[no]split_apks 預設值:「false」
是否使用分割 APK 在裝置上安裝及更新應用程式。僅適用於搭載 Marshmallow 以上版本的裝置
標記: loading_and_analysisaffects_outputs
選項可讓使用者設定預期的輸出內容,影響其值,而非其存在:
--adb_arg=<a string> 累積多次使用
要傳遞至 ADB 的其他引數。通常用於指定要安裝的裝置。
標記: action_command_lines
--debug_app
是否在啟動應用程式前等待偵錯工具。
展開為:
  --start=DEBUG

標記: execution
--device=<a string> 預設值:""
adb 裝置序號。如未指定,系統會使用第一個裝置。
標記: action_command_lines
--start=<no, cold, warm or debug> 預設值:「否」
安裝應用程式後應如何啟動應用程式。將其設為 WARM,即可在增量安裝時保留及還原應用程式狀態。
標記: execution
--start_app
安裝應用程式後是否啟動應用程式。
展開為:
  --start=COLD

標記: execution
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
代碼: loading_and_analysis
影響記錄詳細程度、格式或位置的選項:
--incremental_install_verbosity=<a string> 預設值:""
漸進式安裝的詳細程度。將值設為 1 可啟用偵錯記錄。
標記: bazel_monitoring

模組選項

控制建構執行作業的選項:
--loading_phase_threads=<an integer, or a keyword ("auto", "HOST_CPUS", "HOST_RAM"), optionally followed by an operation ([-|*]<float>) eg. "auto", "HOST_CPUS*.5"> 預設值:「auto」
在載入/分析階段要使用的平行執行緒數量。可接受整數或關鍵字 (「auto」、「HOST_CPUS」、「HOST_RAM」),並可選擇加上運算符號 ([-|*]<float>),例如 「auto」、「HOST_CPUS*.5」等。「auto」會根據主機資源設定合理的預設值。不得小於 1。
標記: bazel_internal_configuration
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_config_setting_private_default_visibility 預設值:「false」
如果 incompatible_enforce_config_setting_visibility=false,則此方法不會執行任何操作。否則,如果這個標記為 false,則任何沒有明確顯示屬性的 config_setting 都是 //visibility:public。如果這個標記設為 True,config_setting 就會遵循與所有其他規則相同的瀏覽權限邏輯。請參閱 https://github.com/bazelbuild/bazel/issues/12933。
標記: loading_and_analysisincompatible_change
--[no]incompatible_enforce_config_setting_visibility 預設值:「true」
如果設為 true,系統就會強制執行 config_setting 曝光度限制。如果為 false,則每個目標都能看到每個 config_setting。請參閱 https://github.com/bazelbuild/bazel/issues/12932。
標記: loading_and_analysisincompatible_change
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
標記: loading_and_analysis
與 `mod` 子命令的輸出內容和語義相關的選項:
--base_module=<"<root>" for the root module; <module>@<version> for a specific version of a module; <module> for all versions of a module; @<name> for a repo with the given apparent name; or @@<name> for a repo with the given canonical name> 預設值:"<root>"
指定相對於指定目標存放區的模組,以便進行解讀。
標記: terminal_output
--charset=<utf8 or ascii> 預設值:「utf8」
選擇要用於樹狀結構的字元集。只會影響文字輸出。有效值為「utf8」或「ascii」。預設為「utf8」
標記: terminal_output
--[no]cycles 預設值:「false」
指出顯示樹狀結構中的依附元件循環,這些循環通常會在預設情況下遭到忽略。
標記: terminal_output
--depth=<an integer> 預設值:「-1」
依附元件樹狀結構的顯示深度上限。舉例來說,深度 1 會顯示直接依附元件。對於樹狀結構、path 和 all_paths,預設值為 Integer.MAX_VALUE,而對於 deps 和 explain,預設值為 1 (只會顯示根目錄的直接依附元件,不包括目標葉節點及其父項)。
標記: terminal_output
--extension_filter=<a comma-separated list of <extension>s> 預設值:請參閱說明
只有在設定了相應的標記時,才會顯示這些模組擴充功能的用法,以及這些擴充功能產生的 repo。如果已設定,結果圖表只會包含包含使用指定擴充功能的模組的路徑。空白清單會停用篩選器,有效地指定所有可能的擴充功能。
標記: terminal_output
--extension_info=<hidden, usages, repos or all> 預設值:「隱藏」
指定要在查詢結果中納入的擴充功能使用情形詳細資料量。「用途」只會顯示擴充功能名稱、「repos」也會納入使用 use_repo 匯入的 repos,而「all」也會顯示擴充功能產生的其他存放區。
標記: terminal_output
--extension_usages=<a comma-separated list of <module>s> 預設值:""
指定擴充功能用途會顯示在 show_extension 查詢中的模組。
標記: terminal_output
--from=<a comma-separated list of <module>s> 預設值:"<root>"
從哪個模組開始顯示依附元件圖表查詢。請查看每個查詢的說明,瞭解確切的語意。預設為 <root>。
標記: terminal_output
--[no]include_builtin 預設值:「false」
在依附元件圖表中納入內建模組。由於這項功能會產生大量雜訊,因此預設為停用。
標記: terminal_output
--[no]include_unused 預設值:「false」
此外,查詢也會考量未使用的模組,並顯示這些模組。這些模組不會出現在選取後的模組解析圖表中 (因為有 Minimal-Version Selection 或覆寫規則)。這可能會對每種查詢類型產生不同的影響,例如在 all_paths 指令中加入新路徑,或在 explain 指令中加入額外依附項目。
標記: terminal_output
--output=<text, json or graph> 預設值:「text」
查詢結果的輸出格式。查詢的有效值為:text、json、graph
標記: terminal_output
--[no]verbose 預設值:「false」
查詢也會顯示模組為何解析為目前的版本 (如果有變更)。預設值為 true,但僅適用於 explain 查詢。
標記: terminal_output
其他選項,未歸類於其他類別:
--deleted_packages=<comma-separated list of package names> 累積多次使用
以半形逗號分隔的套件名稱清單,即使這些套件名稱在套件路徑的某處可見,建構系統仍會視為不存在。刪除現有套件「x」的子套件「x/y」時,請使用這個選項。舉例來說,在刪除用戶端中的 x/y/BUILD 後,如果建構系統遇到標籤「//x:y/z」,但該標籤仍由另一個 package_path 項目提供,系統可能會發出錯誤訊息。指定 --deleted_packages x/y 即可避免這個問題。
--[no]fetch 預設值:「true」
允許指令擷取外部依附元件。如果設為 false,指令會使用任何快取的依附元件版本,如果沒有任何版本,指令就會失敗。
--package_path=<colon-separated list of options> 預設值:「%workspace%」
以冒號分隔的清單,列出尋找套件的來源。以「%workspace%」開頭的元素是相對於包含工作區的元素。如果省略或留空,預設值為執行「bazel info default-package-path」的輸出內容。
--[no]show_loading_progress 預設值:「true」
如果啟用,Bazel 就會顯示「Loading package:」訊息。

繼承「build」的所有選項。

這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
標記: loading_and_analysis
其他未分類的選項:
--print_action_mnemonics=<a string> 累積多次使用
列出要篩選 print_action 資料的助憶法,如果留空,系統就不會篩選。

查詢選項

控制建構執行作業的選項:
--[no]keep_going [-k] 預設值:「false」
盡可能在發生錯誤後繼續執行。雖然無法分析失敗的目標和依附於該目標的其他目標,但可以分析這些目標的其他必要條件。
標記: eagerness_to_exit
--loading_phase_threads=<an integer, or a keyword ("auto", "HOST_CPUS", "HOST_RAM"), optionally followed by an operation ([-|*]<float>) eg. "auto", "HOST_CPUS*.5"> 預設值:「auto」
在載入/分析階段要使用的平行執行緒數量。可接受整數或關鍵字 (「auto」、「HOST_CPUS」、「HOST_RAM」),並可選擇加上運算符號 ([-|*]<float>),例如 「auto」、「HOST_CPUS*.5」等。「auto」會根據主機資源設定合理的預設值。不得小於 1。
標記: bazel_internal_configuration
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_config_setting_private_default_visibility 預設值:「false」
如果 incompatible_enforce_config_setting_visibility=false,則此方法不會執行任何操作。否則,如果這個標記為 false,則任何沒有明確顯示屬性的 config_setting 都是 //visibility:public。如果這個標記設為 True,config_setting 就會遵循與所有其他規則相同的瀏覽權限邏輯。請參閱 https://github.com/bazelbuild/bazel/issues/12933。
標記: loading_and_analysisincompatible_change
--[no]incompatible_enforce_config_setting_visibility 預設值:「true」
如果設為 true,系統就會強制執行 config_setting 曝光度限制。如果為 false,則每個目標都能看到每個 config_setting。請參閱 https://github.com/bazelbuild/bazel/issues/12932。
標記: loading_and_analysisincompatible_change
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
標記: loading_and_analysis
與查詢輸出和語義相關的選項:
--aspect_deps=<off, conservative or precise> 預設值:「conservative」
如何在輸出格式為 {xml,proto,record} 的情況下解析面向依附元件。「off」表示不會解析任何面向依賴項、「conservative」(預設值) 表示會新增所有已宣告的面向依賴項,無論其是否已指定直接依賴項的規則類別;「precise」表示只會新增那些在直接依賴項的規則類別中可能處於作用中的面向。請注意,精確模式需要載入其他套件才能評估單一目標,因此速度會比其他模式慢。另請注意,即使是精確模式也不完全精確:決定是否要計算某個面向的決定是在分析階段做出,而這並不會在「bazel 查詢」期間執行。
標記: build_file_semantics
--[no]consistent_labels 預設值:「false」
如果啟用,每個查詢指令都會像是將 Starlark <code>str</code> 函式套用至 <code>Label</code> 例項時一樣,發出標籤。這項功能對於需要比對不同查詢指令和/或規則產生標籤的工具來說非常實用。如果未啟用,輸出格式化器可以自由發出明顯的存放區名稱 (相對於主要存放區),以便讓輸出內容更易讀。
標記: terminal_output
--[no]experimental_explicit_aspects 預設值:「false」
aquery、cquery:是否要在輸出內容中加入由子集產生的動作。query:無操作 (一律會遵循子集)。
標記: terminal_output
--[no]experimental_graphless_query 預設值:「auto」
如果為 true,則會使用不會建立圖表副本的查詢實作。新實作方式僅支援 --order_output=no,以及部分輸出格式化工具。
標記: build_file_semanticseagerness_to_exit
--graph:conditional_edges_limit=<an integer> 預設值:「4」
顯示的條件標籤數量上限。-1 表示不截斷,0 表示不加註解。這個選項僅適用於 --output=graph。
標記: terminal_output
--[no]graph:factored 預設值:「true」
如果設為 true,系統會「分解」圖表,也就是將拓樸上等價的節點合併,並連結其標籤。這個選項僅適用於 --output=graph。
標記: terminal_output
--graph:node_limit=<an integer> 預設值:「512」
輸出內容中圖形節點標籤字串的長度上限。較長的標籤會遭到截斷;-1 表示不截斷。這個選項僅適用於 --output=graph。
標記: terminal_output
--[no]implicit_deps 預設值:「true」
如果啟用,系統會在查詢運作的依附元件圖表中加入隱含依附元件。隱含依附元件是指未在 BUILD 檔案中明確指定,但由 Bazel 新增的依附元件。針對 cquery,這個選項會控制篩選已解析的工具鍊。
標記: build_file_semantics
--[no]include_aspects 預設值:「true」
aquery、cquery:是否要在輸出內容中加入由子集產生的動作。query:無操作 (一律會遵循子集)。
標記: terminal_output
--[no]incompatible_lexicographical_output 預設值:「true」
如果設定這個選項,系統會依字典順序排序 --order_output=auto 的輸出內容。
標記: terminal_outputincompatible_change
--[no]incompatible_package_group_includes_double_slash 預設值:「true」
如果啟用此選項,在輸出 package_group 的 `packages` 屬性時,系統就不會省略開頭的 `//`。
標記: terminal_outputincompatible_change
--[no]infer_universe_scope 預設值:「false」
如果已設定且未設定 --universe_scope,系統會將 --universe_scope 的值推斷為查詢運算式中的不重複目標模式清單。請注意,如果查詢運算式使用全域範圍函式 (例如 `allrdeps`),系統推斷的 --universe_scope 值可能不是您想要的,因此請務必確實瞭解這個選項的用途後再使用。如需詳細資訊和範例,請參閱 https://bazel.build/reference/query#sky-query。如果已設定 --universe_scope,系統會忽略這個選項的值。注意:這個選項僅適用於 `query` (即非 `cquery`)。
代碼: loading_and_analysis
--[no]line_terminator_null 預設值:「false」
是否以 \0 而非換行符號結束每個格式。
標記: terminal_output
--[no]nodep_deps 預設值:「true」
如果啟用,系統會在查詢運作的依附元件圖中納入「nodep」屬性的依附元件。「nodep」屬性的常見例子為「visibility」。執行並剖析 `info build-language` 的輸出內容,瞭解建構語言中的所有「nodep」屬性。
標記: build_file_semantics
--noorder_results
以依賴項排序 (預設) 或無序方式輸出結果。無序輸出速度較快,但僅支援 --output 不是 minrank、maxrank 或 graph 的情況。
展開為:
  --order_output=no

標記: terminal_output
--null
是否以 \0 而非換行符號結束每個格式。
展開為:
  --line_terminator_null=true

標記: terminal_output
--order_output=<no, deps, auto or full> 預設值:「auto」
輸出結果時,不排序 (no)、依依附元件排序 (deps) 或完全排序 (full)。預設值為「auto」,表示結果輸出順序會依據輸出格式化程式而為依附元件排序或完全排序 (proto、minrank、maxrank 和圖表為依附元件排序,所有其他為完全排序)。當輸出順序完全排序時,節點會以完全確定 (總) 順序列印。首先,所有節點會按照字母順序排列。接著,清單中的每個節點都會用於後序深度優先搜尋的起始點,其中會依照後續節點的字母順序,沿著未造訪節點的出站邊緣進行搜尋。最後,節點會以相反的順序列印,也就是與訪問順序相反。
標記: terminal_output
--order_results
以依賴項排序 (預設) 或無序方式輸出結果。無序輸出速度較快,但僅支援 --output 不是 minrank、maxrank 或 graph 的情況。
展開為:
  --order_output=auto

標記: terminal_output
--output=<a string> 預設值:"label"
查詢結果的輸出格式。查詢的允許值為:build、graph、streamed_jsonproto、label、label_kind、location、maxrank、minrank、package、proto、streamed_proto、xml。
標記: terminal_output
--[no]proto:default_values 預設值:「true」
如果為 true,則會納入 BUILD 檔案中未明確指定值的屬性;否則會略過這些屬性。這個選項適用於 --output=proto
標記: terminal_output
--[no]proto:definition_stack 預設值:「false」
為 definition_stack proto 欄位填入資料,為每個規則例項記錄規則類別定義時的 Starlark 呼叫堆疊。
標記: terminal_output
--[no]proto:flatten_selects 預設值:「true」
如果啟用,則由 select() 建立的可設定屬性會扁平化。對於清單類型,平坦化表示法是清單,其中只包含所選對應項目的每個值一次。純量型別會扁平化為空值。
標記: build_file_semantics
--[no]proto:include_attribute_source_aspects 預設值:「false」
將屬性來源的來源層面填入每個屬性的 source_aspect_name 原型欄位 (如果沒有,則為空字串)。
標記: terminal_output
--[no]proto:include_synthetic_attribute_hash 預設值:「false」
是否要計算並填入 $internal_attr_hash 屬性。
標記: terminal_output
--[no]proto:instantiation_stack 預設值:「false」
填入每項規則的例項化呼叫堆疊。請注意,這需要堆疊存在
標記: terminal_output
--[no]proto:locations 預設值:「true」
是否在 Proto 輸出內容中輸出位置資訊。
標記: terminal_output
--proto:output_rule_attrs=<comma-separated list of options> 預設值:「all」
以半形逗號分隔的屬性清單,用於納入輸出內容。預設為所有屬性。如要不輸出任何屬性,請將其設為空字串。這個選項適用於 --output=proto。
標記: terminal_output
--[no]proto:rule_classes 預設值:「false」
為每項規則填入 rule_class_key 欄位;如果第一個規則具有指定的 rule_class_key,請為其填入 rule_class_info 原型欄位。rule_class_key 欄位可唯一識別規則類別,而 rule_class_info 欄位則是 Stardoc 格式的規則類別 API 定義。
標記: terminal_output
--[no]proto:rule_inputs_and_outputs 預設值:「true」
是否要填入 rule_input 和 rule_output 欄位。
標記: terminal_output
--query_file=<a string> 預設值:""
如果設定此值,查詢會從此處指定的檔案讀取查詢,而不是從指令列讀取。在此處指定檔案和指令列查詢是錯誤的做法。
標記: changes_inputs
--[no]relative_locations 預設值:「false」
如果設為 true,XML 和 Proto 輸出內容中的 BUILD 檔案位置會是相對位置。根據預設,位置輸出內容為絕對路徑,且在不同機器上不會一致。您可以將這個選項設為 true,讓各機器的結果保持一致。
標記: terminal_output
--[no]strict_test_suite 預設值:「false」
如果為 true,當遇到含有非測試目標的 test_suite 時,tests() 運算式會傳回錯誤。
標記: build_file_semanticseagerness_to_exit
--[no]tool_deps 預設值:「true」
查詢:如果停用,系統就不會在查詢運作的依附元件圖中納入「執行設定」的依附元件。「執行設定」依附元件邊緣 (例如從任何「proto_library」規則到 Protocol Compiler 的邊緣),通常會指向建構期間執行的工具,而非同一個「target」程式的一部分。Cquery:如果停用,系統會篩除所有從發現此已設定目標的頂層目標跨越執行轉換的已設定目標。也就是說,如果頂層目標位於目標設定中,則系統只會傳回目標設定中已設定的目標。如果頂層目標位於執行設定中,系統只會傳回執行設定的目標。這個選項不會排除已解析的工具鍊。
標記: build_file_semantics
--universe_scope=<comma-separated list of options> 預設值:""
以逗號分隔的目標模式組合 (加法和減法)。查詢可能會在指定目標的傳遞閉包所定義的宇宙中執行。這個選項可用於查詢和 cquery 指令。對於 cquery,這個選項的輸入內容是所有答案的目標,因此這個選項可能會影響設定和轉換。如果未指定這個選項,系統會假設頂層目標是從查詢運算式解析的目標。注意:如果從查詢運算式解析的目標無法使用頂層選項進行建構,則針對 cquery 未指定此選項可能會導致建構作業中斷。
標記: loading_and_analysis
--[no]xml:default_values 預設值:「false」
如果為 true,則會列印 BUILD 檔案中未明確指定值的規則屬性;否則會略過。
標記: terminal_output
--[no]xml:line_numbers 預設值:「true」
如果為 true,XML 輸出內容就會包含行號。停用這個選項可能會讓差異比較更容易閱讀。這個選項僅適用於 --output=xml。
標記: terminal_output
影響記錄詳細程度、格式或位置的選項:
--experimental_repository_resolved_file=<a string> 預設值:""
如果不為空白,請寫入 Starlark 值,其中包含已執行的所有 Starlark 存放區規則的解析資訊。
標記: affects_outputs
其他選項,未歸類於其他類別:
--deleted_packages=<comma-separated list of package names> 累積多次使用
以半形逗號分隔的套件名稱清單,即使這些套件名稱在套件路徑的某處可見,建構系統仍會視為不存在。刪除現有套件「x」的子套件「x/y」時,請使用這個選項。舉例來說,在刪除用戶端中的 x/y/BUILD 後,如果建構系統遇到標籤「//x:y/z」,但該標籤仍由另一個 package_path 項目提供,系統可能會發出錯誤訊息。指定 --deleted_packages x/y 即可避免這個問題。
--[no]fetch 預設值:「true」
允許指令擷取外部依附元件。如果設為 false,指令會使用任何快取的依附元件版本,如果沒有任何版本,指令就會失敗。
--package_path=<colon-separated list of options> 預設值:「%workspace%」
以冒號分隔的清單,列出尋找套件的來源。以「%workspace%」開頭的元素是相對於包含工作區的元素。如果省略或留空,預設值為執行「bazel info default-package-path」的輸出內容。
--[no]show_loading_progress 預設值:「true」
如果啟用,Bazel 就會顯示「Loading package:」訊息。

執行選項

繼承「build」的所有選項。

顯示在指令前方且由用戶端剖析的選項:
--[no]portable_paths 預設值:「false」
如果為 true,則會納入要取代 ExecRequest 中的路徑,以便產生的路徑可移植。
標記: affects_outputs
--[no]run 預設值:「true」
如果為 false,則會略過為已建構目標建構的指令列。請注意,系統會忽略所有 --script_path 建構作業的這個標記。
標記: affects_outputs
--run_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定可供含有目標設定的動作使用的一組環境變數。變數可以透過名稱指定,在這種情況下,系統會從叫用環境取得值;也可以透過名稱=值組合指定,在這種情況下,系統會設定不受叫用環境影響的值。這個選項可以重複使用;如果是針對同一個變數提供的選項,則以最新的選項為準;如果是針對不同變數提供的選項,則會累加。
代碼: affects_outputs
讓使用者設定預期輸出內容的選項,影響其值,而非其存在:
--script_path=<a path> 預設值:請參閱說明
如果已設定,就會將 Shell 指令碼寫入叫用目標的指定檔案。如果設定這個選項,系統就不會從 bazel 執行目標。使用 'bazel run --script_path=foo //foo && ./foo' 來叫用目標 '//foo'。與 'bazel run //foo' 不同的是,bazel 鎖定會釋放,且可執行檔會連線至終端的 stdin。
標記: affects_outputsexecution
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
代碼: loading_and_analysis

關機選項

用於控制指令輸出的選項:
--iff_heap_size_greater_than=<an integer> 預設值:「0」
如果值不為零,則只有在 JVM 使用的總記憶體 (以 MB 為單位) 超過這個值時,系統才會關閉伺服器。
標記: loses_incremental_stateeagerness_to_exit
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
代碼: loading_and_analysis

同步處理選項

控制建構執行作業的選項:
--[no]configure 預設值:「False」
系統設定目的的同步處理存放區只能標示為「configure」。
標記: changes_inputs
--[no]keep_going [-k] 預設值:「false」
盡可能在發生錯誤後繼續執行。雖然無法分析失敗的目標和依附於該目標的其他目標,但可以分析這些目標的其他必要條件。
標記: eagerness_to_exit
--loading_phase_threads=<an integer, or a keyword ("auto", "HOST_CPUS", "HOST_RAM"), optionally followed by an operation ([-|*]<float>) eg. "auto", "HOST_CPUS*.5"> 預設值:「auto」
在載入/分析階段要使用的平行執行緒數量。可接受整數或關鍵字 (「auto」、「HOST_CPUS」、「HOST_RAM」),並可選擇加上運算符號 ([-|*]<float>),例如 「auto」、「HOST_CPUS*.5」等。「auto」會根據主機資源設定合理的預設值。不得小於 1。
標記: bazel_internal_configuration
--only=<a string> 累積多次使用
如果提供此選項,系統只會同步處理使用此選項指定的存放區。仍將所有 (或所有類似設定,如果提供 --configure 則為) 過時的設定視為過時。
標記: changes_inputs
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_config_setting_private_default_visibility 預設值:「false」
如果 incompatible_enforce_config_setting_visibility=false,則此方法不會執行任何操作。否則,如果這個標記為 false,則任何沒有明確顯示屬性的 config_setting 都是 //visibility:public。如果這個標記設為 True,config_setting 就會遵循與所有其他規則相同的瀏覽權限邏輯。請參閱 https://github.com/bazelbuild/bazel/issues/12933。
標記: loading_and_analysisincompatible_change
--[no]incompatible_enforce_config_setting_visibility 預設值:「true」
如果設為 true,系統就會強制執行 config_setting 曝光度限制。如果為 false,則每個目標都能看到每個 config_setting。請參閱 https://github.com/bazelbuild/bazel/issues/12932。
標記: loading_and_analysisincompatible_change
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
代碼: loading_and_analysis
影響記錄詳細程度、格式或位置的選項:
--experimental_repository_resolved_file=<a string> 預設值:""
如果不為空白,請寫入 Starlark 值,其中包含已執行的所有 Starlark 存放區規則的解析資訊。
標記: affects_outputs
其他選項,未歸類於其他類別:
--deleted_packages=<comma-separated list of package names> 累積多次使用
以半形逗號分隔的套件名稱清單,即使這些套件名稱在套件路徑的某處可見,建構系統仍會視為不存在。刪除現有套件「x」的子套件「x/y」時,請使用這個選項。舉例來說,在刪除用戶端中的 x/y/BUILD 後,如果建構系統遇到標籤「//x:y/z」,但該標籤仍由另一個 package_path 項目提供,系統可能會發出錯誤訊息。指定 --deleted_packages x/y 即可避免這個問題。
--[no]fetch 預設值:「true」
允許指令擷取外部依附元件。如果設為 false,指令會使用任何快取的依附元件版本,如果沒有任何版本,指令就會失敗。
--package_path=<colon-separated list of options> 預設值:「%workspace%」
以冒號分隔的清單,列出尋找套件的來源。以「%workspace%」開頭的元素是相對於包含工作區的元素。如果省略或留空,預設值為執行「bazel info default-package-path」的輸出內容。
--[no]show_loading_progress 預設值:「true」
如果啟用,Bazel 就會顯示「Loading package:」訊息。

測試選項

繼承「build」的所有選項。

這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
代碼: loading_and_analysis
影響記錄詳細程度、格式或位置的選項:
--[no]print_relative_test_log_paths 預設值:「false」
如果為 true,在列印測試記錄路徑時,請使用使用「testlogs」捷徑連結的相對路徑。注意:後續以不同設定呼叫「build」/「test」/等,可能會導致此符號連結的目標變更,使先前顯示的路徑不再實用。
標記: affects_outputs
--[no]test_verbose_timeout_warnings 預設值:「false」
如果為 true,當實際測試執行時間與測試定義的逾時時間 (無論是隱含或明確) 不符時,就會顯示其他警告。
標記: affects_outputs
--[no]verbose_test_summary 預設值:「true」
如果為 true,則會在測試摘要中列印其他資訊 (時間、失敗執行次數等)。
標記: affects_outputs

供應商選項

繼承 test 的所有選項。

控制建構執行作業的選項:
--[no]keep_going [-k] 預設值:「false」
盡可能在發生錯誤後繼續執行。雖然無法分析失敗的目標和依附於該目標的其他目標,但可以分析這些目標的其他必要條件。
標記: eagerness_to_exit
--loading_phase_threads=<an integer, or a keyword ("auto", "HOST_CPUS", "HOST_RAM"), optionally followed by an operation ([-|*]<float>) eg. "auto", "HOST_CPUS*.5"> 預設值:「auto」
在載入/分析階段要使用的平行執行緒數量。可接受整數或關鍵字 (「auto」、「HOST_CPUS」、「HOST_RAM」),並可選擇加上運算符號 ([-|*]<float>),例如 「auto」、「HOST_CPUS*.5」等。「auto」會根據主機資源設定合理的預設值。不得小於 1。
標記: bazel_internal_configuration
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_config_setting_private_default_visibility 預設值:「false」
如果 incompatible_enforce_config_setting_visibility=false,則此方法不會執行任何操作。否則,如果這個標記為 false,則任何沒有明確顯示屬性的 config_setting 都是 //visibility:public。如果這個標記設為 True,config_setting 就會遵循與所有其他規則相同的瀏覽權限邏輯。請參閱 https://github.com/bazelbuild/bazel/issues/12933。
標記: loading_and_analysisincompatible_change
--[no]incompatible_enforce_config_setting_visibility 預設值:「true」
如果設為 true,系統就會強制執行 config_setting 曝光度限制。如果為 false,則每個目標都能看到每個 config_setting。請參閱 https://github.com/bazelbuild/bazel/issues/12932。
標記: loading_and_analysisincompatible_change
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
標記: loading_and_analysis
與 Bzlmod 輸出內容和語義相關的選項:
--repo=<a string> 累積多次使用
僅供應指定的存放區,可以是 `@apparent_repo_name` 或 `@@canonical_repo_name`。這個選項可以設定多次
標記: changes_inputs
其他未分類的選項:
--deleted_packages=<comma-separated list of package names> 累積多次使用
以半形逗號分隔的套件名稱清單,即使這些套件名稱在套件路徑的某處可見,建構系統仍會視為不存在。刪除現有套件「x」的子套件「x/y」時,請使用這個選項。舉例來說,在刪除用戶端中的 x/y/BUILD 後,如果建構系統遇到標籤「//x:y/z」,但該標籤仍由另一個 package_path 項目提供,系統可能會發出錯誤訊息。指定 --deleted_packages x/y 即可避免這個問題。
--[no]fetch 預設值:「true」
允許指令擷取外部依附元件。如果設為 false,指令會使用任何快取的依附元件版本,如果沒有任何版本,指令就會失敗。
--package_path=<colon-separated list of options> 預設值:「%workspace%」
以冒號分隔的清單,列出尋找套件的來源。以「%workspace%」開頭的元素是相對於包含工作區的元素。如果省略或留空,預設值為執行「bazel info default-package-path」的輸出內容。
--[no]show_loading_progress 預設值:「true」
如果啟用,Bazel 就會顯示「Loading package:」訊息。
控制建構執行作業的選項:
是否要直接呼叫檔案系統以建立符號連結樹狀結構,而非委派給輔助程序。
標記: loading_and_analysisexecutionexperimental
--[no]experimental_persistent_aar_extractor 預設值:「false」
使用 worker 啟用持續性 AAR Extractor。
標記: executionexperimental
--[no]experimental_remotable_source_manifests 預設值:「false」
是否要讓來源資訊清單動作可遠端執行
標記: loading_and_analysisexecutionexperimental
--[no]experimental_split_coverage_postprocessing 預設值:「false」
如果為 true,Bazel 就會在新的產生事件中執行測試的涵蓋率後置處理程序。
標記: executionexperimental
--[no]experimental_strict_fileset_output 預設值:「false」
如果啟用這個選項,檔案集會將所有輸出構件視為一般檔案。不會遍歷目錄,也不會對符號連結敏感。
標記: executionexperimental
--[no]incompatible_modify_execution_info_additive 預設值:「false」
啟用後,傳遞多個 --modify_execution_info 標記會相加。停用時,系統只會考量最後一個標記。
標記: executionaffects_outputsloading_and_analysisincompatible_change
--modify_execution_info=<regex=[+-]key,regex=[+-]key,...> 累積多次使用
根據動作助憶法,新增或移除動作執行資訊中的鍵。僅適用於支援執行資訊的動作。許多常見動作都支援執行資訊,例如 Genrule、CppCompile、Javac、StarlarkAction、TestRunner。指定多個值時,順序很重要,因為許多規則運算式可能會套用相同的助憶法。語法:「regex=[+-]key,regex=[+-]key,...」。範例: «.*=+x,.*=-y,.*=+z» 會將「x」和「z」加入所有動作的執行資訊,並移除「y」。'Genrule=+requires-x' 會將 'requires-x' 新增至所有 Genrule 動作的執行資訊。'(?!Genrule).*=-requires-x' 會從所有非 Genrule 動作的執行資訊中移除 'requires-x'。
標記: executionaffects_outputsloading_and_analysis
--persistent_android_dex_desugar
使用工作者啟用持續性的 Android dex 和 desugar 動作。
展開為:
  --internal_persistent_android_dex_desugar
  --strategy=Desugar=worker
  --strategy=DexBuilder=worker

標記: host_machine_resource_optimizationsexecution
--persistent_android_resource_processor
使用 worker 啟用 Android 資源處理器。
展開為:
  --internal_persistent_busybox_tools
  --strategy=AaptPackage=worker
  --strategy=AndroidResourceParser=worker
  --strategy=AndroidResourceValidator=worker
  --strategy=AndroidResourceCompiler=worker
  --strategy=RClassGenerator=worker
  --strategy=AndroidResourceLink=worker
  --strategy=AndroidAapt2=worker
  --strategy=AndroidAssetMerger=worker
  --strategy=AndroidResourceMerger=worker
  --strategy=AndroidCompiledResourceMerger=worker
  --strategy=ManifestMerger=worker
  --strategy=AndroidManifestMerger=worker
  --strategy=Aapt2Optimize=worker
  --strategy=AARGenerator=worker
  --strategy=ProcessDatabinding=worker
  --strategy=GenerateDataBindingBaseClasses=worker

標記: host_machine_resource_optimizationsexecution
--persistent_multiplex_android_dex_desugar
使用 worker 啟用持續性的多重 Android dex 和 desugar 動作。
展開為:
  --persistent_android_dex_desugar
  --internal_persistent_multiplex_android_dex_desugar

標記: host_machine_resource_optimizationsexecution
--persistent_multiplex_android_resource_processor
使用 worker 啟用持續性的多重 Android 資源處理器。
展開為:
  --persistent_android_resource_processor
  --modify_execution_info=AaptPackage=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceParser=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceValidator=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceCompiler=+supports-multiplex-workers
  --modify_execution_info=RClassGenerator=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceLink=+supports-multiplex-workers
  --modify_execution_info=AndroidAapt2=+supports-multiplex-workers
  --modify_execution_info=AndroidAssetMerger=+supports-multiplex-workers
  --modify_execution_info=AndroidResourceMerger=+supports-multiplex-workers
  --modify_execution_info=AndroidCompiledResourceMerger=+supports-multiplex-workers
  --modify_execution_info=ManifestMerger=+supports-multiplex-workers
  --modify_execution_info=AndroidManifestMerger=+supports-multiplex-workers
  --modify_execution_info=Aapt2Optimize=+supports-multiplex-workers
  --modify_execution_info=AARGenerator=+supports-multiplex-workers

標記: host_machine_resource_optimizations, execution
--persistent_multiplex_android_tools
啟用持續性和多重化的 Android 工具 (dexing、desugaring、資源處理)。
展開為:
  --internal_persistent_multiplex_busybox_tools
  --persistent_multiplex_android_resource_processor
  --persistent_multiplex_android_dex_desugar

標記: host_machine_resource_optimizationsexecution
--[no]use_target_platform_for_tests 預設值:「false」
如果為 true,Bazel 會使用目標平台執行測試,而不是使用測試執行群組。
代碼: execution
設定用於執行動作的工具鍊的選項:
--android_compiler=<a string> 預設值:請參閱說明
Android 目標編譯器。
標記: affects_outputsloading_and_analysisloses_incremental_state
--android_manifest_merger=<legacy, android or force_android> 預設值:「android」
選取要用於 android_binary 規則的資訊清單合併工具。旗標,可協助從舊版合併工具轉換至 Android 資訊清單合併工具。
標記: affects_outputsloading_and_analysisloses_incremental_state
--android_platforms=<a build target label> 預設值:""
設定 android_binary 目標使用的平台。如果指定多個平台,則二進位檔會是笨重的 APK,其中包含每個指定目標平台的原生二進位檔。
標記: changes_inputsloading_and_analysisloses_incremental_state
--apple_crosstool_top=<a build target label> 預設值:"@bazel_tools//tools/cpp:toolchain"
在 Apple 和 Objc 規則及其依附元件中使用的 crosstool 套件標籤。
標記: loses_incremental_statechanges_inputs
--cc_output_directory_tag=<a string> 預設值:""
指定要新增至設定目錄的後置字串。
標記: affects_outputs
--compiler=<a string> 預設值:請參閱說明
用於編譯目標的 C++ 編譯器。
標記: loading_and_analysisexecution
--coverage_output_generator=<a build target label> 預設值:"@bazel_tools//tools/test:lcov_merger"
用於後處理原始涵蓋率報表的二進位檔位置。這個檔案群組目前必須包含單一檔案 (二進位檔)。預設值為 '//tools/test:lcov_merger'。
標記: changes_inputsaffects_outputsloading_and_analysis
--coverage_report_generator=<a build target label> 預設值:"@bazel_tools//tools/test:coverage_report_generator"
用於產生涵蓋率報表的二進位檔位置。這個檔案群組目前必須包含單一檔案 (二進位檔)。預設值為 '//tools/test:coverage_report_generator'。
標記: changes_inputsaffects_outputsloading_and_analysis
--coverage_support=<a build target label> 預設值:"@bazel_tools//tools/test:coverage_support"
收集程式碼涵蓋率的每個測試動作輸入項目所需的支援檔案位置。預設值為 '//tools/test:coverage_support'。
標記: changes_inputsaffects_outputsloading_and_analysis
--custom_malloc=<a build target label> 預設值:請參閱說明
指定自訂 malloc 實作項目。這項設定會覆寫建構規則中的 malloc 屬性。
標記: changes_inputsaffects_outputs
--experimental_add_exec_constraints_to_targets=<a '<RegexFilter>=<label1>[,<label2>,...]' assignment> 累積多次使用
以逗號分隔的規則運算式清單,每個運算式可選擇加上前置字元 - (負值運算式),並將 (=) 指派給以逗號分隔的限制值目標清單。如果目標不符合任何負面運算式,且至少符合一個正面運算式,則會執行工具鍊解析作業,就像宣告限制值為執行限制一樣。範例://demo,-test=@platforms//cpus:x86_64 會將「x86_64」新增至 //demo 下的任何目標,但名稱含有「test」的目標除外。
標記: loading_and_analysis
--[no]experimental_include_xcode_execution_requirements 預設值:「false」
如果已設定,請在每個 Xcode 動作中新增「requires-xcode:{version}」執行需求。如果 Xcode 版本有連字號標籤,請一併新增「requires-xcode-label:{version_label}」執行要求。
標記: loses_incremental_stateloading_and_analysisexecutionexperimental
--[no]experimental_prefer_mutual_xcode 預設值:「true」
如果為 true,請使用在本機和遠端都可用的最新 Xcode。如果為 false,或沒有可用的共同版本,請使用透過 xcode-select 所選的本機 Xcode 版本。
標記: loses_incremental_stateexperimental
--extra_execution_platforms=<comma-separated list of options> 預設值:""
可用於執行動作的執行平台。您可以使用完全比對目標或目標模式指定平台。系統會先考慮這些平台,再考慮由 register_execution_platforms() 在 WORKSPACE 檔案中宣告的平台。這個選項只能設定一次;後續的例項會覆寫先前的標記設定。
標記: execution
--extra_toolchains=<comma-separated list of options> 累積多次使用
在工具鍊解析期間要考量的工具鍊規則。您可以使用確切目標或目標模式指定工具鍊。系統會先考慮這些工具鍊,再考慮 WORKSPACE 檔案中透過 register_toolchains() 宣告的工具鍊。
標記: affects_outputschanges_inputsloading_and_analysis
--grte_top=<a label> 預設值:請參閱說明
已檢查的 libc 程式庫的標籤。預設值是由 crosstool 工具鍊選取,您幾乎不需要覆寫。
標記: action_command_linesaffects_outputs
--host_compiler=<a string> 預設值:請參閱說明
無操作標記。將在日後推出的版本中移除。
標記: loading_and_analysisexecution
--host_grte_top=<a label> 預設值:請參閱說明
如果指定此值,這項設定會覆寫執行設定的 libc 頂層目錄 (--grte_top)。
標記: action_command_linesaffects_outputs
--host_platform=<a build target label> 預設值:"@bazel_tools//tools:host_platform"
平台規則的標籤,用於說明主機系統。
標記: affects_outputschanges_inputsloading_and_analysis
--[no]incompatible_bazel_test_exec_run_under 預設值:「false」
如果啟用,則「bazel test --run_under=//:runner」會在執行設定中建構「//:runner」。如果停用,則會在目標設定中建構「//:runner」。Bazel 會在執行機器上執行測試,因此前者較為正確。這不會影響「bazel run」,因為這項指令會一律在目標設定中建構「--run_under=//foo」。
標記: affects_outputsincompatible_change
--[no]incompatible_dont_enable_host_nonhost_crosstool_features 預設值:「true」
如果設為 true,Bazel 就不會在 c++ 工具鍊中啟用「host」和「nonhost」功能 (詳情請參閱 https://github.com/bazelbuild/bazel/issues/7407)。
標記: loading_and_analysisincompatible_change
--[no]incompatible_enable_apple_toolchain_resolution 預設值:「false」
使用工具鍊解析來選取 Apple 規則的 Apple SDK (Starlark 和原生)
標記: loading_and_analysisincompatible_change
--[no]incompatible_remove_legacy_whole_archive 預設值:「true」
如果為 true,Bazel 預設不會將程式庫依附元件連結為整個封存檔 (如需遷移操作說明,請參閱 https://github.com/bazelbuild/bazel/issues/7362)。
標記: loading_and_analysisincompatible_change
--[no]incompatible_strip_executable_safely 預設值:「false」
如果為 true,可執行檔的剝除動作會使用 -x 標記,不會中斷動態符號解析。
標記: action_command_linesincompatible_change
--[no]interface_shared_objects 預設值:「true」
如果工具鍊支援,請使用介面共用物件。目前所有 ELF 工具鍊都支援這項設定。
標記: loading_and_analysisaffects_outputsaffects_outputs
--ios_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 iOS 應用程式的 iOS SDK 版本。如未指定,系統會使用「xcode_version」的預設 iOS SDK 版本。
標記: loses_incremental_state
--macos_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 macOS 應用程式的 macOS SDK 版本。如未指定,系統會使用「xcode_version」中的預設 macOS SDK 版本。
標記: loses_incremental_state
--minimum_os_version=<a string> 預設值:請參閱說明
編譯目標的最低作業系統版本。
標記: loading_and_analysisaffects_outputs
--platform_mappings=<a main workspace-relative path> 預設值:""
對應檔案的位置,可說明在未設定任何平台時要使用的平台,或在已存在平台時要設定的旗標。必須相對於主要工作區根目錄。預設值為「platform_mappings」(工作區根目錄下方的檔案)。
標記: affects_outputschanges_inputsloading_and_analysisimmutable
--platforms=<a build target label> 預設值:""
平台規則的標籤,說明目前指令的目標平台。
標記: affects_outputschanges_inputsloading_and_analysis
--python_path=<a string> 預設值:請參閱說明
在目標平台上執行 Python 目標時,系統會叫用 Python 解譯器的絕對路徑。已淘汰;已由 --incompatible_use_python_toolchains 停用。
標記: loading_and_analysisaffects_outputs
--python_top=<a build target label> 預設值:請參閱說明
py_runtime 的標籤,代表在目標平台上執行 Python 目標時所叫用的 Python 轉譯器。已淘汰;已由 --incompatible_use_python_toolchains 停用。
標記: loading_and_analysisaffects_outputs
--tvos_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 tvOS 應用程式的 tvOS SDK 版本。如果未指定,系統會使用「xcode_version」中的預設 tvOS SDK 版本。
標記: loses_incremental_state
--watchos_sdk_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定用於建構 watchOS 應用程式的 watchOS SDK 版本。如未指定,系統會使用「xcode_version」的預設 watchOS SDK 版本。
標記: loses_incremental_state
--xcode_version=<a string> 預設值:請參閱說明
如果指定此屬性,系統會使用指定版本的 Xcode 執行相關的建構動作。如未指定,系統會使用執行緒的預設 Xcode 版本。
標記: loses_incremental_state
--xcode_version_config=<a build target label> 預設值:"@bazel_tools//tools/cpp:host_xcodes"
xcode_config 規則的標籤,用於在建構設定中選取 Xcode 版本。
標記: loses_incremental_stateloading_and_analysis
控制指令輸出的選項:
--[no]apple_generate_dsym 預設值:「false」
是否產生偵錯符號 (.dSYM) 檔案。
標記: affects_outputsaction_command_lines
如果為 true,則為所有目標建構 runfiles 符號連結森林。如果為 false,則只有在本機動作、測試或執行指令要求時,才會寫入。
標記: affects_outputs
--[no]build_runfile_manifests 預設值:「true」
如果為 true,則為所有目標寫入 runfiles 資訊清單。如果為 false,則省略這些項目。如果為 false,本機測試就會無法執行。
標記: affects_outputs
--[no]build_test_dwp 預設值:「false」
如果啟用此選項,在使用 Fission 靜態建構 C++ 測試時,系統也會自動建構測試二進位檔的 .dwp 檔案。
標記: loading_and_analysisaffects_outputs
--cc_proto_library_header_suffixes=<comma-separated set of options> 預設值:".pb.h"
設定 cc_proto_library 建立的標頭檔案後置字串。
標記: affects_outputsloading_and_analysis
--cc_proto_library_source_suffixes=<comma-separated set of options> 預設值:「.pb.cc」
設定 cc_proto_library 建立的來源檔案後置字串。
標記: affects_outputsloading_and_analysis
--[no]experimental_proto_descriptor_sets_include_source_info 預設值:「false」
針對 proto_library 中的其他 Java API 版本執行額外動作。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_save_feature_state 預設值:「false」
將已啟用和要求的功能的狀態儲存為編譯的輸出內容。
標記: affects_outputsexperimental
--fission=<a set of compilation modes> 預設值:「no」
指定哪些編譯模式會在 C++ 編譯和連結時使用分裂。可為 {'fastbuild', 'dbg', 'opt'} 或特殊值的任意組合,其中 'yes'可啟用所有模式,'no'可停用所有模式。
標記: loading_and_analysisaction_command_linesaffects_outputs
--[no]incompatible_always_include_files_in_data 預設值:「true」
如果為 true,原生規則會將資料依附元件的 <code>DefaultInfo.files</code> 新增至其執行檔,這與 Starlark 規則的建議行為相符 (https://bazel.build/extending/rules#runfiles_features_to_avoid)。
標記: affects_outputsincompatible_change
--[no]legacy_external_runfiles 預設值:「false」
如果為 true,則會為 .runfiles/wsname/external/repo 下的外部存放區 (除了 .runfiles/repo) 建構執行檔案符號連結森林。
標記: affects_outputs
--[no]objc_generate_linkmap 預設值:「false」
指定是否要產生連結圖檔案。
標記: affects_outputs
--[no]save_temps 預設值:「false」
如果設定,系統會儲存來自 gcc 的臨時輸出內容。包括 .s 檔案 (組譯器程式碼)、.i 檔案 (預處理的 C) 和 .ii 檔案 (預處理的 C++)。
標記: affects_outputs
選項可讓使用者設定預期的輸出內容,影響其值,而非其存在:
--action_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定可供含有目標設定的動作使用的一組環境變數。變數可以透過名稱指定,在這種情況下,系統會從叫用環境取得值;也可以透過名稱=值組合指定,在這種情況下,系統會設定不受叫用環境影響的值。這個選項可以重複使用;如果是針對同一個變數提供的選項,則以最新的選項為準;如果是針對不同變數提供的選項,則會累加。
標記: action_command_lines
--allowed_cpu_values=<comma-separated set of options> 預設值:""
--cpu 標記的有效值。
標記: changes_inputsaffects_outputs
--[no]android_databinding_use_androidx 預設值:「true」
產生與 AndroidX 相容的資料繫結檔案。這個屬性僅適用於資料繫結 v2。這個標記不會執行任何操作。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]android_databinding_use_v3_4_args 預設值:「true」
使用 Android Databinding v2 和 3.4.0 引數。這個標記不會執行任何操作。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--android_dynamic_mode=<off, default or fully> 預設值:「off」
決定在 cc_binary 未明確建立共用程式庫時,是否要動態連結 Android 規則的 C++ 依附元件。「預設」表示 Bazel 會選擇是否要動態連結。「fully」表示所有程式庫都會動態連結。「off」表示所有程式庫都會以靜態模式連結。
標記: affects_outputsloading_and_analysis
--android_manifest_merger_order=<alphabetical, alphabetical_by_configuration or dependency> 預設值:「alphabetical」
設定傳遞至 Android 二進位檔資訊清單合併工具的資訊清單順序。ALPHABETICAL 表示資訊清單會依據相對於執行根目錄的路徑排序。ALPHABETICAL_BY_CONFIGURATION 表示資訊清單會依據輸出目錄中相對於設定目錄的路徑排序。DEPENDENCY 表示資訊清單會依序排列,每個程式庫的資訊清單會排在其依附元件的資訊清單之前。
標記: action_command_linesexecution
--[no]android_resource_shrinking 預設值:「false」
為使用 ProGuard 的 android_binary APK 啟用資源縮減功能。
標記: affects_outputsloading_and_analysis
--[no]build_python_zip 預設值:「auto」
建構 Python 可執行的 zip 檔案;在 Windows 上開啟,在其他平台上關閉
標記: affects_outputs
--catalyst_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的清單,列出要用來建構 Apple Catalyst 二進位檔的架構。
標記: loses_incremental_stateloading_and_analysis
--[no]collect_code_coverage 預設值:「false」
如果指定此選項,Bazel 會檢測程式碼 (盡可能使用離線檢測),並在測試期間收集涵蓋率資訊。只有符合 --instrumentation_filter 的目標才會受到影響。通常不應直接指定這個選項,而應改用「bazel coverage」指令。
標記: affects_outputs
--compilation_mode=<fastbuild, dbg or opt> [-c] 預設值:「fastbuild」
指定要建構二進位檔的模式。值:'fastbuild'、'dbg'、'opt'。
標記: affects_outputsaction_command_lines
--conlyopt=<a string> 累積多次使用
編譯 C 來源檔案時,要傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--copt=<a string> 累積多次使用
傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--cpu=<a string> 預設值:""
目標 CPU。
標記: changes_inputsaffects_outputs
--cs_fdo_absolute_path=<a string> 預設值:請參閱說明
使用 CSFDO 設定檔資訊來最佳化編譯作業。指定內含設定檔檔案的 ZIP 檔案的絕對路徑名稱,也就是原始或索引 LLVM 設定檔檔案。
標記: affects_outputs
--cs_fdo_instrument=<a string> 預設值:請參閱說明
使用情境敏感的 FDO 檢測功能產生二進位檔。使用 Clang/LLVM 編譯器時,它也會接受目錄名稱,以便在執行階段轉儲原始設定檔檔案。
標記: affects_outputs
--cs_fdo_profile=<a build target label> 預設值:請參閱說明
cs_fdo_profile 代表要用於最佳化的內容敏感設定檔。
標記: affects_outputs
--cxxopt=<a string> 累積多次使用
編譯 C++ 來源檔案時,要傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--define=<a 'name=value' assignment> 累積多次使用
每個 --define 選項都會指定建構變數的值。如果變數有多個值,則最後一個值會勝出。
標記: changes_inputsaffects_outputs
--dynamic_mode=<off, default or fully> 預設值:"default"
決定是否要動態連結 C++ 二進位檔。「預設」表示 Bazel 會選擇是否要動態連結。「fully」表示所有程式庫都會動態連結。「off」表示所有程式庫都會以靜態模式連結。
標記: loading_and_analysisaffects_outputs
--[no]enable_propeller_optimize_absolute_paths 預設值:「true」
如果設為此值,任何使用 propeller optimize 的絕對路徑都會發生錯誤。
標記: affects_outputs
--[no]enable_remaining_fdo_absolute_paths 預設值:「true」
如果設為此值,任何使用 FDO 的絕對路徑都會發生錯誤。
標記: affects_outputs
--[no]enable_runfiles 預設值:「auto」
啟用 runfiles 符號連結樹狀結構;預設情況下,Windows 和其他平台都會關閉。
標記: affects_outputs
--experimental_action_listener=<a build target label> 累積多次使用
已淘汰,改用切面。使用 action_listener 將 extra_action 附加至現有的建構動作。
標記: executionexperimental
--[no]experimental_android_compress_java_resources 預設值:「false」
壓縮 APK 中的 Java 資源
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_android_databinding_v2 預設值:「true」
使用 Android Databinding v2。這個標記不會執行任何操作。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]experimental_android_resource_shrinking 預設值:「false」
為使用 ProGuard 的 android_binary APK 啟用資源縮減功能。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_android_rewrite_dexes_with_rex 預設值:「false」
使用 rex 工具重寫 dex 檔案
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]experimental_collect_code_coverage_for_generated_files 預設值:「false」
如果指定,Bazel 也會為產生的檔案產生收集涵蓋率資訊。
標記: affects_outputsexperimental
--experimental_objc_fastbuild_options=<comma-separated list of options> 預設值:"-O0,-DDEBUG=1"
使用這些字串做為 objc fastbuild 編譯器選項。
標記: action_command_lines
--[no]experimental_omitfp 預設值:「false」
如果設為 True,請使用 libunwind 進行堆疊解開作業,並使用 -fomit-frame-pointer 和 -fasynchronous-unwind-tables 進行編譯。
標記: action_command_linesaffects_outputsexperimental
--experimental_output_paths=<off, content or strip> 預設值:「off」
在輸出樹狀結構規則寫入輸出內容時,應使用哪個模型,特別適用於多平台 / 多設定版本。這項功能仍在實驗階段,詳情請參閱 https://github.com/bazelbuild/bazel/issues/6526。Starlark 動作可以選擇啟用路徑對應功能,方法是將「supports-path-mapping」鍵新增至「execution_requirements」字典。
標記: loses_incremental_statebazel_internal_configurationaffects_outputsexecution
--experimental_override_name_platform_in_output_dir=<a 'label=value' assignment> 累積多次使用
每個項目都應採用 label=value 的格式,其中 label 是指平台,而 value 是輸出路徑中要使用的所需簡稱。僅在 --experimental_platform_in_output_dir 為 true 時使用。具有最高的命名優先順序。
標記: affects_outputsexperimental
--[no]experimental_platform_in_output_dir 預設值:「false」
如果為 true,輸出目錄名稱會使用目標平台的短名稱,而非 CPU。具體的配置為實驗性質,可能會變更:首先,在極少數情況下,如果 --platforms 選項不含確切的一個值,系統會使用 platforms 選項的雜湊值。接著,如果目前平台的任何簡稱都已透過 --experimental_override_name_platform_in_output_dir 註冊,系統就會使用該簡稱。接著,如果已設定 --experimental_use_platforms_in_output_dir_legacy_heuristic,請使用目前平台標籤的短名稱。最後,平台選項的雜湊值會用於最後的手段。
標記: affects_outputsexperimental
--[no]experimental_py_binaries_include_label 預設值:「false」
即使停用沖壓功能,py_binary 目標也會包含標籤。
標記: affects_outputsexperimental
--[no]experimental_use_llvm_covmap 預設值:「false」
如果指定此選項,在啟用 collect_code_coverage 時,Bazel 會產生 llvm-cov 涵蓋範圍對應資訊,而非 gcov。
標記: changes_inputsaffects_outputsloading_and_analysisexperimental
--[no]experimental_use_platforms_in_output_dir_legacy_heuristic 預設值:「true」
請僅在建議的遷移或測試策略中使用這個標記。請注意,啟發式搜尋有已知的缺陷,建議您改為只使用 --experimental_override_name_platform_in_output_dir。
標記: affects_outputsexperimental
--fdo_instrument=<a string> 預設值:請參閱說明
使用 FDO 檢測功能產生二進位檔。使用 Clang/LLVM 編譯器時,它也會接受目錄名稱,以便在執行階段轉儲原始設定檔檔案。
標記: affects_outputs
--fdo_optimize=<a string> 預設值:請參閱說明
使用 FDO 設定檔資訊來最佳化編譯作業。指定內含 .gcda 檔案樹狀結構的 ZIP 檔案名稱、內含自動設定檔的 afdo 檔案,或 LLVM 設定檔檔案。這個旗標也接受指定為標籤的檔案 (例如 `//foo/bar:file.afdo` - 您可能需要在對應的套件中新增 `exports_files` 指示),以及指向 `fdo_profile` 目標的標籤。這項標記將由 `fdo_profile` 規則取代。
標記: affects_outputs
--fdo_prefetch_hints=<a build target label> 預設值:請參閱說明
使用快取預先擷取提示。
標記: affects_outputs
--fdo_profile=<a build target label> 預設值:請參閱說明
fdo_profile 代表用於最佳化的設定檔。
標記: affects_outputs
--features=<a string> 累積多次使用
對於在目標設定中建構的目標,系統會預設啟用或停用指定功能。指定 -<feature> 會停用該功能。負面特徵一律會覆寫正面特徵。另請參閱 --host_features
標記: changes_inputsaffects_outputs
--[no]force_pic 預設值:「false」
如果啟用,所有 C++ 編譯作業都會產生位置無關的程式碼 ("-fPIC"),連結會優先使用 PIC 預先建構的程式庫,而非非 PIC 程式庫,且連結會產生位置無關的可執行檔 ("-pie")。
標記: loading_and_analysisaffects_outputs
--host_action_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定執行作業設定可用的環境變數組合。變數可以透過名稱指定,在這種情況下,系統會從叫用環境取得值;也可以透過名稱=值組合指定,在這種情況下,系統會設定不受叫用環境影響的值。這個選項可以重複使用;如果是針對同一個變數提供的選項,則以最新的選項為準;如果是針對不同變數提供的選項,則會累加。
標記: action_command_lines
--host_compilation_mode=<fastbuild, dbg or opt> 預設值:「opt」
指定在建構期間使用的工具將以何種模式建構。值:'fastbuild'、'dbg'、'opt'。
標記: affects_outputsaction_command_lines
--host_conlyopt=<a string> 累積多次使用
在執行設定中編譯 C (但非 C++) 來源檔案時,要傳遞至 C 編譯器的其他選項。
標記: action_command_linesaffects_outputs
--host_copt=<a string> 累積多次使用
為執行設定中建構的工具,傳遞至 C 編譯器的其他選項。
標記: action_command_linesaffects_outputs
--host_cpu=<a string> 預設值:""
主機 CPU。
標記: changes_inputsaffects_outputs
--host_cxxopt=<a string> 累積多次使用
針對在執行設定中建構的工具,傳遞至 C++ 編譯器的其他選項。
標記: action_command_linesaffects_outputs
--host_features=<a string> 累積多次使用
對於在執行設定中建構的目標,系統會依預設啟用或停用指定功能。指定 -<feature> 會停用該功能。負面特徵一律會覆寫正面特徵。
標記: changes_inputsaffects_outputs
--host_force_python=<PY2 or PY3> 預設值:請參閱說明
覆寫執行設定的 Python 版本。可以是「PY2」或「PY3」。
標記: loading_and_analysisaffects_outputs
--host_linkopt=<a string> 累積多次使用
在執行設定中連結工具時,要傳遞至連結器的其他選項。
標記: action_command_linesaffects_outputs
--host_macos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
主機目標的最低相容 macOS 版本。如果未指定,系統會使用「macos_sdk_version」。
標記: loses_incremental_state
--host_per_file_copt=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths followed by an @ and a comma separated list of options> 累積多次使用
在執行設定中編譯特定檔案時,可選擇傳遞至 C/C++ 編譯器的其他選項。這個選項可以多次傳遞。語法:regex_filter@選項_1,選項_2,...,選項_n。其中 regex_filter 代表包含和排除的規則運算式模式清單 (另請參閱 --instrumentation_filter)。option_1 到 option_n 代表任意指令列選項。如果選項包含半形逗號,則必須在半形逗號前後加上反斜線。選項可以包含 @。只有第一個 @ 會用來分割字串。範例:--host_per_file_copt=//foo/.*\.cc,-//foo/bar\.cc@-O0 會將 -O0 指令列選項新增至 //foo/ 中所有 cc 檔案 (除了 bar.cc) 的 gcc 指令列。
標記: action_command_linesaffects_outputs
--[no]incompatible_auto_exec_groups 預設值:「false」
啟用後,系統會為規則使用的每個工具鍊自動建立執行群組。為使這項規則運作,您需要在其動作中指定「toolchain」參數。如需更多資訊,請參閱 https://github.com/bazelbuild/bazel/issues/17134。
標記: affects_outputsincompatible_change
--[no]incompatible_merge_genfiles_directory 預設值:「true」
如果設為 true,系統會將 genfiles 目錄折疊至 bin 目錄。
標記: affects_outputsincompatible_change
--[no]instrument_test_targets 預設值:「false」
啟用涵蓋率時,指定是否要考慮檢測測試規則。設定後,--instrumentation_filter 所包含的測試規則就會進行檢測。否則,測試規則一律會從涵蓋率檢測工具中排除。
標記: affects_outputs
--instrumentation_filter=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths> 預設值:「-/javatests[/:],-/test/java[/:]」
啟用涵蓋率後,系統只會檢測名稱包含指定規則運算式篩選器的規則。系統會排除開頭為「-」的規則。請注意,除非啟用 --instrument_test_targets,否則只會檢測非測試規則。
標記: affects_outputs
--ios_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定模擬器和裝置的最低相容 iOS 版本。如果未指定,系統會使用「ios_sdk_version」。
標記: loses_incremental_state
--ios_multi_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的架構清單,用於建構 ios_application。結果會是包含所有指定架構的通用二進位檔。
標記: loses_incremental_stateloading_and_analysis
--[no]legacy_whole_archive 預設值:「true」
已淘汰,已由 --incompatible_remove_legacy_whole_archive 取代 (詳情請參閱 https://github.com/bazelbuild/bazel/issues/7362)。開啟後,請針對 cc_binary 規則使用 --whole-archive,該規則的 linkshared 為 True,且 linkopts 中為 linkstatic=True 或 '-static'。這項設定僅適用於回溯相容性。更好的做法是在需要時使用 alwayslink=1。
標記: action_command_linesaffects_outputsdeprecated
--linkopt=<a string> 累積多次使用
連結時傳遞至 gcc 的其他選項。
標記: action_command_linesaffects_outputs
--ltobackendopt=<a string> 累積多次使用
傳遞至 LTO 後端步驟的其他選項 (在 --features=thin_lto 下方)。
標記: action_command_linesaffects_outputs
--ltoindexopt=<a string> 累積多次使用
傳遞至 LTO 索引步驟的其他選項 (在 --features=thin_lto 下方)。
標記: action_command_linesaffects_outputs
--macos_cpus=<comma-separated list of options> 累積多次使用
以逗號分隔的架構清單,用於建構 Apple macOS 二進位檔。
標記: loses_incremental_stateloading_and_analysis
--macos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
目標的最低相容 macOS 版本。如果未指定,系統會使用「macos_sdk_version」。
標記: loses_incremental_state
--memprof_profile=<a build target label> 預設值:請參閱說明
使用 memprof 設定檔。
標記: affects_outputs
--[no]objc_debug_with_GLIBCXX 預設值:「false」
如果已設定,且編譯模式設為「dbg」,請定義 GLIBCXX_DEBUG、GLIBCXX_DEBUG_PEDANTIC 和 GLIBCPP_CONCEPT_CHECKS。
標記: action_command_lines
--[no]objc_enable_binary_stripping 預設值:「false」
是否要在已連結的二進位檔上執行符號和無效程式碼去除作業。如果同時指定這個旗標和 --compilation_mode=opt,系統就會執行二進位碼去除作業。
標記: action_command_lines
--objccopt=<a string> 累積多次使用
編譯 Objective-C/C++ 來源檔案時,要傳遞至 gcc 的其他選項。
標記: action_command_lines
--per_file_copt=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths followed by an @ and a comma separated list of options> 累積多次使用
在編譯特定檔案時,可選擇傳遞至 gcc 的其他選項。這個選項可以多次傳遞。語法:regex_filter@選項_1,選項_2,...,選項_n。其中 regex_filter 代表包含和排除的規則運算式模式清單 (另請參閱 --instrumentation_filter)。option_1 到 option_n 代表任意指令列選項。如果選項包含半形逗號,則必須在半形逗號前後加上反斜線。選項可以包含 @。只有第一個 @ 會用來分割字串。範例:--per_file_copt=//foo/.*\.cc,-//foo/bar\.cc@-O0 會將 -O0 指令列選項新增至 //foo/ 中所有 cc 檔案 (除了 bar.cc) 的 gcc 指令列。
標記: action_command_linesaffects_outputs
--per_file_ltobackendopt=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths followed by an @ and a comma separated list of options> 累積多次使用
編譯特定後端物件時,可選擇將哪些選項傳遞至 LTO 後端 (在 --features=thin_lto 下) 的其他選項。這個選項可以多次傳遞。語法:regex_filter@選項_1,選項_2,...,選項_n。其中 regex_filter 代表包含和排除規則運算式的清單。option_1 到 option_n 代表任意指令列選項。如果選項包含半形逗號,則必須在半形逗號前後加上反斜線。選項可以包含 @。只有第一個 @ 會用來分割字串。範例:--per_file_ltobackendopt=//foo/.*\.o,-//foo/bar\.o@-O0 會將 -O0 指令列選項新增至 //foo/ 中所有 o 檔案 (除了 bar.o) 的 LTO 後端指令列。
標記: action_command_linesaffects_outputs
--platform_suffix=<a string> 預設值:請參閱說明
指定要新增至設定目錄的後置字串。
標記: loses_incremental_stateaffects_outputsloading_and_analysis
--propeller_optimize=<a build target label> 預設值:請參閱說明
使用 Propeller 設定檔資訊來改善建構目標。Propeller 設定檔至少必須包含以下兩個檔案之一:cc 設定檔和 ld 設定檔。這個標記可接受建構標籤,但該標籤必須參照螺旋槳設定檔輸入檔案。舉例來說,定義標籤的 BUILD 檔案,在 a/b/BUILD:propeller_optimize( name = "propeller_profile", cc_profile = "propeller_cc_profile.txt", ld_profile = "propeller_ld_profile.txt",) 中,您可能必須在對應的套件中加入 exports_files 指示詞,才能讓 Bazel 看到這些檔案。這個選項必須以以下方式使用:--propeller_optimize=//a/b:propeller_profile
標記: action_command_linesaffects_outputs
--propeller_optimize_absolute_cc_profile=<a string> 預設值:請參閱說明
Propeller 最佳化版本的 cc_profile 檔案絕對路徑名稱。
標記: affects_outputs
--propeller_optimize_absolute_ld_profile=<a string> 預設值:請參閱說明
Propeller 最佳化版本的 ld_profile 檔案絕對路徑名稱。
標記: affects_outputs
--run_under=<a prefix in front of command> 預設值:請參閱說明
在「test」和「run」指令的可執行檔前插入前置字串。如果值為「foo -bar」,執行指令列為「test_binary -baz」,則最終指令列為「foo -bar test_binary -baz」。這也可以是可執行目標的標籤。以下是一些範例:'valgrind'、'strace'、'strace -c'、'valgrind --quiet --num-callers=20'、'//package:target'、'//package:target --options'。
標記: action_command_lines
--[no]share_native_deps 預設值:「true」
如果為 true,含有相同功能的原生程式庫會在不同目標之間共用
標記: loading_and_analysisaffects_outputs
--[no]stamp 預設值:「false」
在二進位檔上蓋上日期、使用者名稱、主機名稱、工作區資訊等資訊。
標記: affects_outputs
--strip=<always, sometimes or never> 預設值:「sometimes」
用於指定是否要移除二進位檔和共用程式庫 (使用「-Wl,--strip-debug」)。預設值為「sometimes」表示如果 --compilation_mode=fastbuild,則會移除。
標記: affects_outputs
--stripopt=<a string> 累積多次使用
產生 '<name>.stripped'二進位檔時,要傳遞至 strip 的其他選項。
標記: action_command_linesaffects_outputs
--tvos_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的架構清單,用於建構 Apple tvOS 二進位檔。
標記: loses_incremental_stateloading_and_analysis
--tvos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定模擬器和裝置的最低相容 tvOS 版本。如果未指定,系統會使用「tvos_sdk_version」。
標記: loses_incremental_state
--visionos_cpus=<comma-separated list of options> 累積多次使用
以逗號分隔的清單,列出要為其建構 Apple visionOS 二進位檔的架構。
標記: loses_incremental_stateloading_and_analysis
--watchos_cpus=<comma-separated list of options> 累積多次使用
以半形逗號分隔的架構清單,用於建構 Apple watchOS 二進位檔。
標記: loses_incremental_stateloading_and_analysis
--watchos_minimum_os=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
指定模擬器和裝置的最低相容 watchOS 版本。如果未指定,系統會使用「watchos_sdk_version」。
標記: loses_incremental_state
--xbinary_fdo=<a build target label> 預設值:請參閱說明
使用 XbinaryFDO 設定檔資訊來最佳化編譯作業。指定預設交叉二進位設定檔的名稱。當此選項與 --fdo_instrument/--fdo_optimize/--fdo_profile 一起使用時,這些選項一律會優先採用,就好像從未指定 xbinary_fdo 一樣。
標記: affects_outputs
影響 Bazel 如何嚴格執行有效建構輸入內容 (規則定義、標記組合等) 的選項:
--[no]check_licenses 預設值:「false」
請確認依附套件施加的授權限制,不會與建構目標的發布模式衝突。根據預設,系統不會檢查授權。
標記: build_file_semantics
--[no]check_visibility 預設值:「true」
如果停用,目標依附元件中的顯示錯誤會降級為警告。
標記: build_file_semantics
--[no]desugar_for_android 預設值:「true」
是否要在解碼前脫糖 Java 8 位元組碼。
標記: affects_outputsloading_and_analysisloses_incremental_state
--[no]desugar_java8_libs 預設值:「false」
是否要在舊版裝置的應用程式中加入支援的 Java 8 程式庫。
標記: affects_outputsloading_and_analysisloses_incremental_stateexperimental
--[no]enforce_constraints 預設值:「true」
檢查每個目標的相容環境,如果任何目標的依附元件不支援相同的環境,就會回報錯誤
標記: build_file_semantics
--[no]experimental_check_desugar_deps 預設值:「true」
是否要再次檢查 Android 二進位檔層級的正確去糖化。
標記: eagerness_to_exitloading_and_analysisexperimental
--experimental_import_deps_checking=<a string> 預設值:請參閱說明
無操作,僅保留用於回溯相容性
標記: loading_and_analysis
--experimental_one_version_enforcement=<off, warning or error> 預設值:「OFF」
啟用後,系統會強制規定 java_binary 規則在 classpath 中不得包含同一個類別檔案的多個版本。這項強制執行措施可能會導致建構作業中斷,或只會產生警告。
標記: loading_and_analysis
--experimental_strict_java_deps=<off, warn, error, strict or default> 預設值:"default"
如果為 true,系統會檢查 Java 目標是否明確將所有直接使用的目標宣告為依附元件。
標記: build_file_semanticseagerness_to_exit
--[no]incompatible_check_testonly_for_output_files 預設值:「false」
如果啟用,請查詢產生規則的 testonly,檢查 testonly 是否為輸出檔案的必要條件目標。這項設定與可見度檢查相符。
標記: build_file_semanticsincompatible_change
--[no]incompatible_check_visibility_for_toolchains 預設值:「false」
如果已啟用,可視性檢查也會套用至工具鍊實作。
標記: build_file_semanticsincompatible_change
--[no]incompatible_disable_native_android_rules 預設值:「false」
如果啟用,系統就會停用原生 Android 規則的直接用法。請使用 https://github.com/bazelbuild/rules_android 中的 Starlark Android 規則
標記: eagerness_to_exitincompatible_change
--[no]incompatible_disable_native_apple_binary_rule 預設值:「false」
無操作。為回溯相容性而保留。
標記: eagerness_to_exitincompatible_change
--[no]incompatible_python_disable_py2 預設值:「true」
如果設為 True,使用 Python 2 設定會導致錯誤。包括 python_version=PY2、srcs_version=PY2 和 srcs_version=PY2ONLY。詳情請參閱 https://github.com/bazelbuild/bazel/issues/15684。
標記: loading_and_analysisincompatible_change
--[no]one_version_enforcement_on_java_tests 預設值:「true」
啟用此選項後,如果 experimental_one_version_enforcement 設為非 NONE 值,系統就會在 java_test 目標上強制執行一個版本。您可以停用這個標記,以便提升增量測試效能,但可能會錯過某個版本的違規項目。
標記: loading_and_analysis
--python_native_rules_allowlist=<a build target label> 預設值:請參閱說明
在強制執行 --incompatible_python_disallow_native_rules 時,要使用的許可清單 (package_group 目標)。
標記: loading_and_analysis
--[no]strict_filesets 預設值:「false」
如果啟用這個選項,系統會將跨越套件邊界的檔案集回報為錯誤。
標記: build_file_semanticseagerness_to_exit
--strict_proto_deps=<off, warn, error, strict or default> 預設值:「error」
除非設為 OFF,否則會檢查 proto_library 目標是否明確將所有直接使用的目標宣告為依附元件。
標記: build_file_semanticseagerness_to_exitincompatible_change
--strict_public_imports=<off, warn, error, strict or default> 預設值:「off」
除非設為 OFF,否則會檢查 proto_library 目標是否明確宣告在「import public」中使用的所有目標為匯出目標。
標記: build_file_semanticseagerness_to_exitincompatible_change
--[no]strict_system_includes 預設值:「false」
如果設為 true,則系統會透過系統包含路徑 (-isystem) 找到的標頭,也必須宣告。
標記: loading_and_analysiseagerness_to_exit
--target_environment=<a build target label> 累積多次使用
宣告此版本的目標環境。必須是「環境」規則的標籤參照。如果指定了這個環境,則所有頂層目標都必須與這個環境相容。
標記: changes_inputs
影響建構簽署輸出內容的選項:
--apk_signing_method=<v1, v2, v1_v2 or v4> 預設值:「v1_v2」
用於簽署 APK 的實作方式
標記: action_command_linesaffects_outputsloading_and_analysis
--[no]device_debug_entitlements 預設值:「true」
如果已設定,且編譯模式不是「opt」,則 objc 應用程式會在簽署時加入偵錯授權。
標記: changes_inputs
--ios_signing_cert_name=<a string> 預設值:請參閱說明
用於 iOS 簽署的憑證名稱。如果未設定,系統會改用佈建設定檔。根據 codesign 的 man 頁面 (SIGNING IDENTITIES),可能為憑證的鑰匙圈身分偏好設定或憑證的常用名稱 (子字串)。
標記: action_command_lines
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_disallow_legacy_py_provider 預設值:「true」
無操作,即將移除。
標記: loading_and_analysisincompatible_change
--[no]incompatible_disallow_sdk_frameworks_attributes 預設值:「false」
如果設為 true,就禁止在 objc_library 和 objc_import 中使用 sdk_frameworks 和 weak_sdk_frameworks 屬性。
標記: build_file_semanticsincompatible_change
如果為 true,請將 objc_library 和 objc_import 中的 alwayslink 屬性預設值設為 true。
標記: build_file_semanticsincompatible_change
--[no]incompatible_python_disallow_native_rules 預設值:「false」
如果為 True,使用內建的 py_* 規則時會發生錯誤;應改用 rule_python 規則。詳情請參閱 https://github.com/bazelbuild/bazel/issues/17773 瞭解遷移操作說明。
標記: loading_and_analysisincompatible_change
用於控管測試環境或測試執行工具行為的選項:
--[no]allow_analysis_failures 預設值:「false」
如果設為 true,規則目標的分析失敗會導致目標傳播包含錯誤說明的 AnalysisFailureInfo 例項,而不會導致建構失敗。
標記: loading_and_analysisexperimental
--analysis_testing_deps_limit=<an integer> 預設值:「2000」
透過規則屬性和 for_analysis_testing 設定轉換,設定遞移依附元件的數量上限。若超出這項限制,就會導致規則錯誤。
標記: loading_and_analysis
--[no]break_build_on_parallel_dex2oat_failure 預設值:「false」
如果為 true,則 dex2oat 動作失敗會導致建構作業中斷,而不會在測試執行階段執行 dex2oat。
標記: loading_and_analysisexperimental
--default_test_resources=<a resource name followed by equal and 1 float or 4 float, e.g memory=10,30,60,100> 累積多次使用
覆寫測試的預設資源量。預期格式為 <resource>=<value>。如果指定單一正整數做為 <value>,則會覆寫所有測試大小的預設資源。如果指定 4 個以逗號分隔的數字,這些數字會分別覆寫小、中、大、特大測試大小的資源數量。值也可以是 HOST_RAM/HOST_CPU,並可選擇加上 [-|*]<浮點> (例如 memory=HOST_RAM*.1,HOST_RAM*.2,HOST_RAM*.3,HOST_RAM*.4)。這個旗標指定的預設測試資源,會遭到標記中明確指定的資源覆寫。
--[no]experimental_android_use_parallel_dex2oat 預設值:「false」
並行使用 dex2oat,可能可加快 android_test 的速度。
標記: loading_and_analysishost_machine_resource_optimizationsexperimental
--[no]ios_memleaks 預設值:「false」
啟用 ios_test 目標的記憶體外洩檢查功能。
標記: action_command_lines
--ios_simulator_device=<a string> 預設值:請參閱說明
在模擬器中執行 iOS 應用程式時要模擬的裝置,例如「iPhone 6」。您可以在要執行模擬器的電腦上執行「xcrun simctl list devicetypes」取得裝置清單。
標記: test_runner
--ios_simulator_version=<a dotted version (for example '2.3' or '3.3alpha2.4')> 預設值:請參閱說明
在執行或測試時,要在模擬器上執行的 iOS 版本。如果規則中指定了目標裝置,系統會忽略 ios_test 規則。
標記: test_runner
--runs_per_test=<a positive integer or test_regex@runs. This flag may be passed more than once> 累積多次使用
指定執行每項測試的次數。如果任何嘗試因任何原因失敗,整個測試就會視為失敗。通常指定的值只是整數。範例:--runs_per_test=3 會執行所有測試 3 次。其他語法:regex_filter@runs_per_test。其中 runs_per_test 代表整數值,而 regex_filter 代表包含和排除的規則運算式清單 (另請參閱 --instrumentation_filter)。範例:--runs_per_test=//foo/.*,-//foo/bar/.*@3 會執行 //foo/ 中的所有測試 (foo/bar 下的測試除外),共三次。這個選項可以多次傳遞。系統會優先採用最近傳遞且相符的引數。如果沒有任何相符項目,則只會執行一次測試。
--test_env=<a 'name=value' assignment with an optional value part> 累積多次使用
指定要插入測試執行器環境的其他環境變數。變數可以透過名稱指定,在這種情況下,系統會從 Bazel 用戶端環境讀取其值,也可以透過名稱=值組合指定。您可以多次使用此選項指定多個變數。僅供「bazel test」指令使用。
標記: test_runner
--test_timeout=<a single integer or comma-separated list of 4 integers> 預設值:「-1」
覆寫測試逾時的預設逾時值 (以秒為單位)。如果指定單一正整數值,系統會覆寫所有類別。如果指定 4 個以逗號分隔的整數,系統會覆寫短、中、長和永久 (依序) 的逾時時間。無論是哪種表單,如果值為 -1,blaze 就會使用該類別的預設逾時時間。
--[no]zip_undeclared_test_outputs 預設值:「false」
如果設為 true,系統會將未宣告的測試輸出內容封存為 ZIP 檔案。
標記: test_runner
觸發建構時間最佳化功能的選項:
--[no]experimental_filter_library_jar_with_program_jar 預設值:「false」
篩選 ProGuard ProgramJar,移除 LibraryJar 中也存在的任何類別。
標記: action_command_linesexperimental
--[no]experimental_inmemory_dotd_files 預設值:「true」
如果啟用此選項,C++ .d 檔案會直接從遠端建構節點傳遞至記憶體,而不會寫入磁碟。
標記: loading_and_analysisexecutionaffects_outputsexperimental
--[no]experimental_inmemory_jdeps_files 預設值:「true」
如果啟用此選項,系統會直接從遠端建構節點,透過記憶體傳遞從 Java 編譯產生的依附元件檔案 (.jdeps),而不會寫入磁碟。
標記: loading_and_analysisexecutionaffects_outputsexperimental
--[no]experimental_retain_test_configuration_across_testonly 預設值:「false」
啟用後,--trim_test_configuration 就不會為標示為 testonly=1 的規則裁減測試設定。這項功能旨在減少非測試規則依賴 cc_test 規則時的動作衝突問題。如果 --trim_test_configuration 為 false,就不會產生任何影響。
標記: loading_and_analysisloses_incremental_stateexperimental
--[no]experimental_starlark_cc_import 預設值:「false」
如果啟用,即可使用 Starlark 版本的 cc_import。
標記: loading_and_analysisexperimental
--[no]experimental_unsupported_and_brittle_include_scanning 預設值:「false」
是否要透過剖析輸入檔案中的 #include 行,將輸入內容縮減為 C/C++ 編譯。這可縮減編譯輸入樹狀結構的大小,進而提升效能和增量。不過,由於包含掃描器未完全實作 C 預處理器語意,因此也可能會導致建構作業中斷。具體來說,它無法瞭解動態 #include 指示,並會忽略預處理器條件邏輯。您必須自行承擔使用風險。我們會關閉與這個標記相關的所有已提交問題。
標記: loading_and_analysisexecutionchanges_inputsexperimental
--[no]incremental_dexing 預設值:「true」
針對每個 Jar 檔案分別執行大部分的解析工作。
標記: affects_outputsloading_and_analysisloses_incremental_state
--[no]objc_use_dotd_pruning 預設值:「true」
如果設定,系統會使用 Clang 產生的 .d 檔案,來修剪傳遞至 objc 編譯作業的輸入集合。
標記: changes_inputsloading_and_analysis
--[no]process_headers_in_dependencies 預設值:「false」
建構目標 //a:a 時,請處理 //a:a 依附的所有目標中的標頭 (如果工具鍊啟用了標頭處理功能)。
標記: execution
--[no]trim_test_configuration 預設值:「true」
啟用後,系統會清除版本頂層以下的測試相關選項。啟用此標記後,測試就無法建構為非測試規則的依附元件,但變更測試相關選項不會導致非測試規則重新分析。
標記: loading_and_analysisloses_incremental_state
影響記錄詳細程度、格式或位置的選項:
--toolchain_resolution_debug=<a comma-separated list of regex expressions with prefix '-' specifying excluded paths> 預設值:「-.*」
在工具鍊解析期間列印偵錯資訊。這個標記會採用規則運算式,並根據工具鍊類型和特定目標進行檢查,以便查看要偵錯的目標。您可以使用逗號分隔多個規則運算式,然後分別檢查每個規則運算式。注意:這個標記的輸出內容非常複雜,可能只有工具鍊解析專家才會覺得實用。
標記: terminal_output
選項可指定或變更 Bazel 指令的一般輸入內容,而該輸入內容不屬於其他類別:
--flag_alias=<a 'name=value' flag alias> 累積多次使用
設定 Starlark 標記的簡寫名稱。它會將單一鍵/值組合 (格式為「<鍵>=<值>」) 做為引數。
標記: changes_inputs
--[no]incompatible_default_to_explicit_init_py 預設值:「false」
這個標記會變更預設行為,讓 __init__.py 檔案不再自動建立在 Python 目標的執行檔案中。具體來說,如果 py_binary 或 py_test 目標將 legacy_create_init 設為「auto」(預設值),則只有在設定此標記時,才會視為 false。請參閱 https://github.com/bazelbuild/bazel/issues/10076。
標記: affects_outputsincompatible_change
--[no]incompatible_py2_outputs_are_suffixed 預設值:「true」
如果設為 true,在 Python 2 設定中建構的目標會顯示在包含「-py2」字尾的輸出根目錄下,而為 Python 3 建構的目標則會顯示在沒有 Python 相關字尾的根目錄中。也就是說,`bazel-bin` 方便捷符號會指向 Python 3 目標,而非 Python 2。如果您啟用這個選項,建議也啟用 `--incompatible_py3_is_default`。
標記: affects_outputsincompatible_change
--[no]incompatible_py3_is_default 預設值:「true」
如果為 true,則未設定 `python_version` (或 `default_python_version`) 屬性的 `py_binary` 和 `py_test` 目標,預設會使用 PY3 而非 PY2。如果您設定這個旗標,建議也設定 `--incompatible_py2_outputs_are_suffixed`。
標記: loading_and_analysisaffects_outputsincompatible_change
--[no]incompatible_use_python_toolchains 預設值:「true」
如果設為 true,可執行的原生 Python 規則會使用 Python 工具鍊指定的 Python 執行階段,而非由 --python_top 等舊版標記提供的執行階段。
標記: loading_and_analysisincompatible_change
--python_version=<PY2 or PY3> 預設值:請參閱說明
Python 主要版本模式,可選為 `PY2` 或 `PY3`。請注意,這會由 `py_binary` 和 `py_test` 目標覆寫 (即使未明確指定版本),因此通常沒有提供這個旗標的必要。
標記: loading_and_analysisaffects_outputs
其他選項,不屬於其他類別:
--[no]cache_test_results [-t] 預設值:「auto」
如果設為「auto」,Bazel 只會在下列情況下重新執行測試:(1) Bazel 偵測到測試或其依附元件的變更、(2) 測試標示為外部、(3) 使用 --runs_per_test 要求執行多個測試,或(4) 測試先前失敗。如果設為「是」,Bazel 會快取所有測試結果,但標示為外部的測試除外。如果設為「no」,Bazel 就不會快取任何測試結果。
--[no]experimental_cancel_concurrent_tests 預設值:「false」
如果為 true,Blaze 會在第一次成功執行時取消同時執行的測試。只有在搭配 --runs_per_test_detects_flakes 時才有用。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_fetch_all_coverage_outputs 預設值:「false」
如果為 true,Bazel 就會在執行涵蓋率時,為每項測試擷取整個涵蓋率資料目錄。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_generate_llvm_lcov 預設值:「false」
如果設為 True,clang 的涵蓋率就會產生 LCOV 報表。
標記: affects_outputsloading_and_analysisexperimental
--[no]experimental_j2objc_header_map 預設值:「true」
是否要在 J2ObjC 轉譯時並行產生 J2ObjC 標頭對應項目。
標記: experimental
--[no]experimental_j2objc_shorter_header_path 預設值:「false」
是否要使用較短的標頭路徑產生 (使用「_ios」而非「_j2objc」)。
標記: affects_outputsexperimental
--experimental_java_classpath=<off, javabuilder or bazel> 預設值:「javabuilder」
啟用 Java 編譯作業的縮減路徑集。
--[no]experimental_limit_android_lint_to_android_constrained_java 預設值:「false」
無操作,僅保留用於向後相容性
標記: affects_outputsexperimental
--[no]experimental_run_android_lint_on_java_rules 預設值:「false」
是否要驗證 java_* 來源。
標記: affects_outputsexperimental
--[no]explicit_java_test_deps 預設值:「false」
在 java_test 中明確指定對 JUnit 或 Hamcrest 的依附元件,而不是意外從 TestRunner 的 deps 取得。目前僅適用於 Bazel。
--host_java_launcher=<a build target label> 預設值:請參閱說明
在建構期間執行的工具所使用的 Java 啟動器。
--host_javacopt=<a string> 累積多次使用
建構在建構期間執行的工具時,要傳遞至 javac 的其他選項。
--host_jvmopt=<a string> 累積多次使用
建構期間執行的工具在建構時,傳遞至 Java VM 的其他選項。這些選項會新增至每個 java_binary 目標的 VM 啟動選項。
--[no]incompatible_check_sharding_support 預設值:「true」
如果為 true,如果測試執行程式未透過觸碰 TEST_SHARD_STATUS_FILE 路徑中的檔案,表示不支援分割,則 Bazel 會失敗執行分割測試。如果為 false,則不支援分割的測試執行程式會導致所有測試在每個分割區中執行。
標記: incompatible_change
--[no]incompatible_exclusive_test_sandboxed 預設值:「true」
如果為 true,系統會使用沙箱策略執行專屬測試。新增「local」標記,強制在本機上執行專屬測試
標記: incompatible_change
--[no]incompatible_strict_action_env 預設值:「false」
如果為 True,Bazel 會使用 PATH 的靜態值環境,且不會繼承 LD_LIBRARY_PATH。如果您想從用戶端繼承特定環境變數,請使用 --action_env=ENV_VARIABLE,但請注意,如果使用共用快取,這麼做可能會導致跨使用者快取無法使用。
標記: loading_and_analysisincompatible_change
--j2objc_translation_flags=<comma-separated list of options> 累積多次使用
傳遞至 J2ObjC 工具的其他選項。
--java_debug
讓 Java 測試的 Java 虛擬機器在開始測試前,等待符合 JDWP 標準的偵錯工具 (例如 jdb) 連線。暗示 -test_output=streamed。
展開為:
  --test_arg=--wrapper_script_flag=--debug
  --test_output=streamed
  --test_strategy=exclusive
  --test_timeout=9999
  --nocache_test_results
--[no]java_deps 預設值:「true」
針對每個 Java 目標產生依附元件資訊 (目前為編譯時間的類別路徑)。
--[no]java_header_compilation 預設值:「true」
直接從來源編譯 ijar。
--java_language_version=<a string> 預設值:""
Java 語言版本
--java_launcher=<a build target label> 預設值:請參閱說明
建構 Java 二進位檔時要使用的 Java 啟動器。如果這個標記設為空字串,系統就會使用 JDK 啟動器。「launcher」屬性會覆寫這個旗標。
--java_runtime_version=<a string> 預設值:「local_jdk」
Java 執行階段版本
--javacopt=<a string> 累積多次使用
傳遞至 javac 的其他選項。
--jvmopt=<a string> 累積多次使用
傳遞至 Java VM 的其他選項。這些選項會新增至每個 java_binary 目標的 VM 啟動選項。
--legacy_main_dex_list_generator=<a build target label> 預設值:請參閱說明
指定要使用的二進位檔,用於產生編譯舊版 Multidex 時,必須位於主 DEX 中的類別清單。
--optimizing_dexer=<a build target label> 預設值:請參閱說明
指定用於在不分割的情況下執行解析的二進位檔。
--plugin=<a build target label> 累積多次使用
在建構中使用的外掛程式。目前支援 java_plugin。
--proguard_top=<a build target label> 預設值:請參閱說明
指定建構 Java 二進位檔時,要使用哪個版本的 ProGuard 來移除程式碼。
--proto_compiler=<a build target label> 預設值:"@bazel_tools//tools/proto:protoc"
Proto 編譯器的標籤。
標記: affects_outputsloading_and_analysis
--[no]proto_profile 預設值:「true」
是否將 profile_path 傳遞至 proto 編譯器。
標記: affects_outputsloading_and_analysis
--proto_profile_path=<a build target label> 預設值:請參閱說明
要以 profile_path 形式傳遞至 Proto 編譯器的設定檔。如果未設定,但 --proto_profile 為 true (預設值),系統會從 --fdo_optimize 推斷路徑。
標記: affects_outputsloading_and_analysis
--proto_toolchain_for_cc=<a build target label> 預設值:"@bazel_tools//tools/proto:cc_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 C++ 原型檔
標記: affects_outputsloading_and_analysis
--proto_toolchain_for_j2objc=<a build target label> 預設值:"@bazel_tools//tools/j2objc:j2objc_proto_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 j2objc 原型檔
標籤: affects_outputsloading_and_analysis
--proto_toolchain_for_java=<a build target label> 預設值:"@bazel_tools//tools/proto:java_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 Java 原型檔
標記: affects_outputsloading_and_analysis
--proto_toolchain_for_javalite=<a build target label> 預設值:"@bazel_tools//tools/proto:javalite_toolchain"
proto_lang_toolchain() 的標籤,說明如何編譯 JavaLite 原型檔
標記: affects_outputsloading_and_analysis
--protocopt=<a string> 累積多次使用
傳遞至 protobuf 編譯器的其他選項。
標記: affects_outputs
--[no]runs_per_test_detects_flakes 預設值:「false」
如果為 true,則任何具有至少一個成功執行/嘗試,以及至少一個失敗執行/嘗試的區塊,都會獲得「不穩定」狀態。
--shell_executable=<a path> 預設值:請參閱說明
Shell 可執行檔的絕對路徑,供 Bazel 使用。如果未設定此值,但在第一次呼叫 Bazel (啟動 Bazel 伺服器) 時已設定 BAZEL_SH 環境變數,Bazel 就會使用該值。如果未設定這兩者,Bazel 會根據執行的作業系統使用硬式編碼的預設路徑 (Windows:c:/msys64/usr/bin/bash.exe、FreeBSD:/usr/local/bin/bash、其他所有作業系統:/bin/bash)。請注意,使用與 bash 不相容的殼層,可能會導致產生的二進位檔發生建構失敗或執行階段失敗。
標記: loading_and_analysis
--test_arg=<a string> 累積多次使用
指定應傳遞至測試可執行檔的其他選項和引數。可多次使用,用於指定多個引數。如果執行多項測試,每項測試都會收到相同的引數。僅供「bazel test」指令使用。
--test_filter=<a string> 預設值:請參閱說明
指定要轉送至測試架構的篩選器。用於限制執行的測試。請注意,這不會影響要建構的目標。
--test_result_expiration=<an integer> 預設值:「-1」
這個選項已淘汰,不會產生任何作用。
--[no]test_runner_fail_fast 預設值:「false」
將快速失敗選項轉送至測試執行程式。測試執行程式應在第一次失敗時停止執行。
--test_sharding_strategy=<explicit, disabled or forced=k where k is the number of shards to enforce> 預設值:「explicit」
指定測試區塊劃分策略:如果有 'shard_count' BUILD 屬性,則只使用區塊劃分策略。如要一律不使用測試分割,請選擇「disabled」。使用「forced=k」強制執行「k」分片進行測試,無論「shard_count」BUILD 屬性為何都一樣。
--tool_java_language_version=<a string> 預設值:""
用於執行建構期間所需工具的 Java 語言版本
--tool_java_runtime_version=<a string> 預設值:「remotejdk_11」
在建構期間用來執行工具的 Java 執行階段版本
--[no]use_ijars 預設值:「true」
如果啟用此選項,Java 編譯作業就會使用介面 JAR 檔案。這會加快增量編譯作業,但錯誤訊息可能會有所不同。

版本選項

讓使用者設定所需輸出內容的選項,影響其值而非其存在狀態:
--[no]gnu_format 預設值:「false」
如果設為此值,則會使用 GNU 標準中所述的慣例,將版本寫入 stdout。
標記: affects_outputsexecution
這個選項會影響 Starlark 語言的語意,或 BUILD 檔案、.bzl 檔案或 WORKSPACE 檔案可存取的建構 API:
--[no]incompatible_use_plus_in_repo_names 預設值:「true」
無操作。
代碼: loading_and_analysis

選項效果標記

unknown 這個選項的效果不明確或未記錄。
no_op 這個選項實際上沒有任何效果。
loses_incremental_state 變更這個選項的值可能會導致大量的增量狀態遺失,進而減緩建構作業。狀態可能會因為伺服器重新啟動或大量依附元件圖表失效而遺失。
changes_inputs 這個選項會主動變更 Bazel 在建構時考量的輸入內容,例如檔案系統限制、存放區版本或其他選項。
affects_outputs 這個選項會影響 bazel 的輸出內容。這個標記是故意設計為廣泛,可包含間接影響,且不會指定影響的輸出內容類型。
build_file_semantics 這個選項會影響 BUILD 或 .bzl 檔案的語意。
bazel_internal_configuration 這個選項會影響 Bazel 內部機制的設定。這個標記本身並不會表示建構構件受到影響。
loading_and_analysis 這個選項會影響依附元件的載入和分析作業,以及依附元件圖表的建構作業。
execution 這個選項會影響執行階段,例如沙箱或遠端執行相關選項。
host_machine_resource_optimizations 這個選項會觸發可能與機器相關的最佳化程序,且不保證可在所有機器上運作。最佳化可能會與其他效能方面 (例如記憶體或 CPU 成本) 產生權衡。
eagerness_to_exit 此選項會變更 Bazel 在失敗時退出的方式,在這種情況下,您可以選擇繼續執行或結束呼叫。
bazel_monitoring 這個選項可用來監控 bazel 的行為和效能。
terminal_output 這個選項會影響 Bazel 的終端機輸出內容。
action_command_lines 這個選項會變更一或多個建構動作的指令列引數。
test_runner 這個選項會變更建構的測試執行程式環境。

選項中繼資料標記

experimental 這個選項會觸發實驗功能,但無法保證功能正常運作。
incompatible_change 這個選項會觸發破壞性變更。使用這個選項測試遷移就緒性,或搶先體驗新功能
deprecated 這個選項已淘汰,這可能是因為影響的功能已淘汰,或是您偏好使用其他方法提供資訊。
immutable 這個選項在轉場中無法變更。