envOr
签名
function envOr(string calldata key, bool defaultValue) external returns (bool value);
function envOr(string calldata key, uint256 defaultValue) external returns (uint256 value);
function envOr(string calldata key, int256 defaultValue) external returns (int256 value);
function envOr(string calldata key, address defaultValue) external returns (address value);
function envOr(string calldata key, bytes32 defaultValue) external returns (bytes32 value);
function envOr(string calldata key, string calldata defaultValue) external returns (string memory value);
function envOr(string calldata key, bytes calldata defaultValue) external returns (bytes memory value);
function envOr(string calldata key, string calldata delimiter, bool[] calldata defaultValue) external returns (bool[] memory value);
function envOr(string calldata key, string calldata delimiter, uint256[] calldata defaultValue) external returns (uint256[] memory value);
function envOr(string calldata key, string calldata delimiter, int256[] calldata defaultValue) external returns (int256[] memory value);
function envOr(string calldata key, string calldata delimiter, address[] calldata defaultValue) external returns (address[] memory value);
function envOr(string calldata key, string calldata delimiter, bytes32[] calldata defaultValue) external returns (bytes32[] memory value);
function envOr(string calldata key, string calldata delimiter, string[] calldata defaultValue) external returns (string[] memory value);
function envOr(string calldata key, string calldata delimiter, bytes[] calldata defaultValue) external returns (bytes[] memory value);
描述
envOr()
是一种非失败的方法,用于读取任何类型的环境变量:如果请求的环境键不存在,envOr()
将返回默认值,而不是回滚(也适用于数组)。
返回的类型由传递的 defaultValue
参数的类型确定。
提示
- 使用
envOr(key, defaultValue)
来读取单个值 - 使用
envOr(key, delimiter, defaultValue[])
来使用分隔符读取数组 - 环境变量的解析将根据
defaultValue
的类型进行(例如,如果默认值类型为uint
,则环境变量也将被解析为uint
) - 对于字面量,使用显式转换来指定默认变量的类型:
uint(69)
将返回uint
,但int(69)
将返回int
- 同样适用于:
string("")
和bytes("")
- 这些将分别返回string
和bytes
- 在提供默认值时,请使用动态数组(
bool[]
)而不是固定大小数组(bool[4]
)(仅支持动态数组)
例子
单个值
如果环境变量 FORK
未设置,你可以将其默认设置为 false
:
bool fork = vm.envOr("FORK", false);
或者
address owner;
function setUp() {
owner = vm.envOr("OWNER", address(this));
}
数组
如果环境变量 BAD_TOKENS
未设置,你可以将默认值指定为空数组:
address[] badTokens;
function envBadTokens() public {
badTokens = vm.envOr("BAD_TOKENS", ",", badTokens);
}
或者
function envBadTokens() public {
address[] memory defaultBadTokens = new address[](0);
address[] memory badTokens = vm.envOr("BAD_TOKENS", ",", defaultBadTokens);
}