ShareManagerLibrary
This library helps pack multiple boolean flags and lockup durations into a compact uint256 bitmask. It enables efficient storage and quick access to share manager configuration in vault systems.
Designed for the ShareManager component to control:
Whether minting, burning, or transfers are paused
Whether deposit/transfer whitelists are active
How long global or user-specific lockups last
All data is packed into a single uint256 using bit-level encoding for optimal storage and gas efficiency.
Bitmask Layout
[0]
hasMintPause (bool)
[1]
hasBurnPause (bool)
[2]
hasTransferPause (bool)
[3]
hasWhitelist (bool)
[4]
hasTransferWhitelist (bool)
[5..36]
globalLockup (uint32)
[37..68]
targetedLockup (uint32)
Functions
hasMintPause(uint256 mask) β bool
hasMintPause(uint256 mask) β boolReturns true if minting is paused (bit 0 is set).
hasBurnPause(uint256 mask) β bool
hasBurnPause(uint256 mask) β boolReturns true if burning is paused (bit 1 is set).
hasTransferPause(uint256 mask) β bool
hasTransferPause(uint256 mask) β boolReturns true if transfers are paused (bit 2 is set).
hasWhitelist(uint256 mask) β bool
hasWhitelist(uint256 mask) β boolReturns true if a deposit whitelist is enabled (bit 3 is set).
hasTransferWhitelist(uint256 mask) β bool
hasTransferWhitelist(uint256 mask) β boolReturns true if a transfer whitelist is enabled (bit 4 is set).
getGlobalLockup(uint256 mask) β uint32
getGlobalLockup(uint256 mask) β uint32Returns the global lockup duration in seconds (timestamp), encoded in bits [5..36].
getTargetedLockup(uint256 mask) β uint32
getTargetedLockup(uint256 mask) β uint32Returns the targeted lockup duration in seconds, encoded in bits [37..68].
createMask(IShareManager.Flags calldata f) β uint256
createMask(IShareManager.Flags calldata f) β uint256Encodes the values in a Flags struct into a single bitmask: