OracleFacet Code Style Findings

OracleFacet Code Style Findings

OFT-01C: Redundant Condition Evaluation

Type Severity Location
Gas Optimization OracleFacet.sol:L56-L58

Description:

The updateOracle function validates whether either of the reserves of the pair is zero and if so, yields an equillibrium point for the price between USDC and BEAN.

Example:

protocol/contracts/farm/facets/OracleFacet.sol
53function updateOracle() internal returns (Decimal.D256 memory, Decimal.D256 memory) {
54 (Decimal.D256 memory bean_price, Decimal.D256 memory usdc_price) = updatePrice();
55 (uint112 reserve0, uint112 reserve1,) = IUniswapV2Pair(s.c.pair).getReserves();
56 if (reserve0 == 0 || reserve1 == 0) {
57 return (Decimal.one(),Decimal.one());
58 }
59 return (bean_price, usdc_price);
60}

Recommendation:

This condition only materializes during the very beginning of the contract's launch as it is impossible to empty out the reserves of a Uniswap V2 pair once it has been set up properly. As such, we advise the conditional to be omitted for gas optimization and codebase legibility purposes.

Alleviation:

The conditional has been safely omitted from the codebase thereby optimizing it.

View Fix on GitHub
Navigated to OracleFacet Code Style Findings