Environment Variables
Cargo 設(shè)置,并讀取許多環(huán)境變量,代碼可以檢測或覆蓋這些環(huán)境變量。以下是 Cargo 與它們交互時,組織的變量列表:
Environment variables Cargo reads
Cargo 會讀取的環(huán)境變量
您可以重寫這些環(huán)境變量來更改 Cargo 在系統(tǒng)中的行為:
名(ENV) | 曰 |
---|---|
CARGO_HOME | Cargo 在本地緩存注冊表索引和箱子的 git 版本。默認情況下,這些存儲在$HOME/.cargo ,但是這個變量重寫了這個目錄的位置。一旦箱被緩存,它就不會被清除命令刪除。 |
CARGO_TARGET_DIR | 相對于當前工作目錄,放置所有生成的工件的位置. |
RUSTC | Cargo 不運行rustc ,而執(zhí)行指定的編譯器。 |
RUSTC_WRAPPER | Cargo 將執(zhí)行這個指定的包裝器,而不是簡單地運行rustc 。將 rustc 調(diào)用 作為其命令行參數(shù)傳遞,第一個參數(shù)是 rustc. |
RUSTDOC | Cargo 將執(zhí)行此指定的rustdoc 實例,而不是rustdoc . |
RUSTDOCFLAGS | 空格分隔的自定義標志列表,用來傳遞給 Cargo 執(zhí)行的所有rustdoc 調(diào)用 。與cargo rustdoc 不同,這對于傳遞一個參數(shù)給 全部的 rustdoc 實例是有用的。 |
RUSTFLAGS | 自定義參數(shù)的空格分隔列表,用來傳遞給 Cargo 執(zhí)行的所有編譯器調(diào)用。與cargo rustc 不同,這對于傳遞一個標志 全部的 編譯實例是有用的。 |
CARGO_INCREMENTAL | 如果設(shè)置為 1,則 Cargo 將強制在當前編譯中啟用增量編譯,而當設(shè)置為 0,則強制禁用增量編譯。如果這個 ENV 不存在,否則將使用 Cargo 默認值。 |
CARGO_CACHE_RUSTC_INFO | 如果這個設(shè)置為 0,那么 Cargo 將不嘗試緩存編譯器版本信息. |
注意,Cargo 也會在.cargo/config
配置中讀取環(huán)境變量,如那份文件
Environment variables Cargo sets for crates
Cargo 為 crates 設(shè)置的環(huán)境變量
Cargo 在編譯時,會將這些環(huán)境變量暴露在箱子中。請注意,這也適用于測試二進制文件。要在 RIST 程序中獲得這些變量中的任何一個變量的值,請執(zhí)行以下操作:
let version = env!("CARGO_PKG_VERSION");
version
現(xiàn)在將包含了CARGO_PKG_VERSION
值。
名 | 曰 |
---|---|
CARGO | 執(zhí)行構(gòu)建的二進制cargo 路徑. |
CARGO_MANIFEST_DIR | 包含包的清單的目錄. |
CARGO_PKG_VERSION | 您的包的完整版本. |
CARGO_PKG_VERSION_MAJOR | 你的軟件包的主要版本. |
CARGO_PKG_VERSION_MINOR | 您的包的次要版本. |
CARGO_PKG_VERSION_PATCH | 包的補丁版本. |
CARGO_PKG_VERSION_PRE | 包的預發(fā)布版本. |
CARGO_PKG_AUTHORS | 從程序包的清單中,冒號分隔出作者列表. |
CARGO_PKG_NAME | 你的包的名字. |
CARGO_PKG_DESCRIPTION | 從包的清單中描述. |
CARGO_PKG_HOMEPAGE | 從包的清單中的主頁. |
CARGO_PKG_REPOSITORY | 從包的清單中存儲庫. |
OUT_DIR | 如果包具有構(gòu)建腳本,則將其設(shè)置為,構(gòu)建腳本應該在其中放置其輸出的文件夾。更多信息見下文. |
Environment variables Cargo sets for build scripts
Cargo 為構(gòu)建腳本設(shè)置的環(huán)境變量
當運行構(gòu)建腳本時,Cargo 設(shè)置多個環(huán)境變量.因為編譯生成腳本時還沒有設(shè)置這些變量,所以上面的示例使用env!
無法工作,而是在運行構(gòu)建腳本時需要檢索值:
use std::env;
let out_dir = env::var("OUT_DIR").unwrap();
out_dir
現(xiàn)在將包含的價值OUT_DIR
.
名 | 曰 |
---|---|
CARGO | 執(zhí)行構(gòu)建的二進制cargo 路徑. |
CARGO_MANIFEST_DIR | 包含正在構(gòu)建的包的清單的目錄(包含構(gòu)建腳本的包)。還要注意,這是生成腳本啟動時,當前工作目錄的值. |
CARGO_MANIFEST_LINKS | 清單links 的值. |
CARGO_FEATURE_<name> | 對于正在構(gòu)建的包的每個激活特性,此環(huán)境變量會讓<name> 功能名稱存在,名稱的- 會轉(zhuǎn)換成_ . |
CARGO_CFG_<cfg> | 對正在構(gòu)建包的每個配置選項,此環(huán)境變量將包含配置的值,其中<cfg> 就是配置的名稱,并將- 翻譯成_ . 如果設(shè)置了布爾配置,則存在布爾配置,否則不存在。具有多個值的配置被連接到單個變量,該變量用, 分隔就好。 |
OUT_DIR | 所有輸出都應該放在這個文件夾。此文件夾位于正在構(gòu)建的包的構(gòu)建目錄中,并且對于所討論的包是唯一的。 |
TARGET | 正在編譯的目標三元組。該為這個三元組編譯本機代碼。關(guān)于目標三元組的更多信息在clang 自身文檔中. |
HOST | Rust 編譯器的主機三元組. |
NUM_JOBS | 指定為頂層并行的并行性。這可以傳遞一個-j 參數(shù)到系統(tǒng)(像make ). 注意,在解釋這個環(huán)境變量時應該小心。出于歷史目的,仍然提供此功能,但是例如,最新版本的 Cargo 不需要運行make -j ,因為它會自動。Cargo 自行實現(xiàn)[JooServer],并且允許構(gòu)建腳本繼承這些信息,因此與 GNU 兼容的程序?qū)⑹棺鳂I(yè)服務(wù)器已經(jīng)具有適當配置的并行性。 |
OPT_LEVEL ,DEBUG | 為了分析,當前正在構(gòu)建的相應變量值. |
PROFILE | 發(fā)布版本用release ,而debug 用于其他構(gòu)建. |
DEP_<name>_<key> | 有關(guān)此組環(huán)境變量的更多信息,請參閱links . |
RUSTC ,RUSTDOC | Cargo 已經(jīng)決定使用的編譯器和文檔生成器,傳遞給構(gòu)建腳本,以便構(gòu)建腳本也可以使用它. |
RUSTC_LINKER | 如果指定了,Cargo 為了當前目標,決定使用的鏈接器(二進制文件)的路徑。這個鏈接器可以通過編輯.cargo/config 更改,欲了解更多信息,請參閱有關(guān)文檔Cargo 配置。 |
Environment variables Cargo sets for 3rd party subcommands
Cargo 為 第三方子命令設(shè)置的環(huán)境變量
Cargo 將這個環(huán)境變量公開給第三方子命令(即,名為cargo-foobar
放置在$PATH
):
CARGO
- 執(zhí)行構(gòu)建的二進制cargo
路徑。
更多建議: