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);
}