執行環境資訊

回報問題 查看原始碼 Nightly · 7.4 . 7.3 · 7.2 · 7.1 · 7.0 · 6.5

可透過可執行規則傳回的提供者,以控制執行其執行檔的環境。

成員

環境

dict RunEnvironmentInfo.environment

字串鍵和值的對應項目,用於代表環境變數及其值。當傳回這個供應器的目標執行時,不論是以測試還是執行指令,都能提供這些元件。

inherited_environment

List RunEnvironmentInfo.inherited_environment

環境變數名稱序列。當您以測試或透過執行指令執行傳回此提供者的目標時,系統會從殼層環境取得這些變數的目前值,並提供這些變數。如果 environmentinherited_environment 中都含有變數,系統會優先採用從殼層環境沿用的值。

to_json

string RunEnvironmentInfo.to_json()

已淘汰。這個 API 已淘汰,並將在近期內移除。請勿依賴這項功能。---incompatible_struct_has_no_methods停用。使用這個標記,驗證您的程式碼是否與即將移除的標記相容。
透過 struct 參數建立 JSON 字串。只有在所有結構體元素 (遞迴) 都是字串、整數、布林值、其他結構體、這些類型的清單,或是含有這些類型字串鍵和值的字典時,這個方法才有效。字串中的引號和換行符號會逸出。範例:
struct(key=123).to_json()
# {"key":123}

struct(key=True).to_json()
# {"key":true}

struct(key=[1, 2, 3]).to_json()
# {"key":[1,2,3]}

struct(key='text').to_json()
# {"key":"text"}

struct(key=struct(inner_key='text')).to_json()
# {"key":{"inner_key":"text"}}

struct(key=[struct(inner_key=1), struct(inner_key=2)]).to_json()
# {"key":[{"inner_key":1},{"inner_key":2}]}

struct(key=struct(inner_key=struct(inner_inner_key='text'))).to_json()
# {"key":{"inner_key":{"inner_inner_key":"text"}}}

已淘汰:請改用 json.encode(x) 或 json.encode_indent(x,這適用於 struct 以外的值,而且不會汙染 struct 欄位命名空間。

to_proto

string RunEnvironmentInfo.to_proto()

已淘汰。這個 API 已淘汰,並將在近期移除。請勿仰賴這項功能。---incompatible_struct_has_no_methods停用。使用這個標記,驗證您的程式碼是否與即將移除的標記相容。
使用 struct 參數建立文字訊息。只有在所有結構體元素 (遞迴) 都是字串、整數、布林值、其他結構體或字典或這些類型的清單時,這個方法才會運作。系統會將字串中的引號和換行符號逸出。結構鍵會按照排序順序疊代。範例:
struct(key=123).to_proto()
# key: 123

struct(key=True).to_proto()
# key: true

struct(key=[1, 2, 3]).to_proto()
# key: 1
# key: 2
# key: 3

struct(key='text').to_proto()
# key: "text"

struct(key=struct(inner_key='text')).to_proto()
# key {
#   inner_key: "text"
# }

struct(key=[struct(inner_key=1), struct(inner_key=2)]).to_proto()
# key {
#   inner_key: 1
# }
# key {
#   inner_key: 2
# }

struct(key=struct(inner_key=struct(inner_inner_key='text'))).to_proto()
# key {
#    inner_key {
#     inner_inner_key: "text"
#   }
# }

struct(foo={4: 3, 2: 1}).to_proto()
# foo: {
#   key: 4
#   value: 3
# }
# foo: {
#   key: 2
#   value: 1
# }

已淘汰:請改用 proto.encode_text(x)。