infrastructure-upgrade/lib/solmate/README.md
T-Hax 735546619e
init
Signed-off-by: T-Hax <>
2023-04-08 18:46:18 +00:00

70 lines
2.9 KiB
Markdown

# solmate
**Modern**, **opinionated**, and **gas optimized** building blocks for **smart contract development**.
## Contracts
```ml
auth
├─ Owned "Simple single owner authorization"
├─ Auth "Flexible and updatable auth pattern"
├─ authorities
├─ RolesAuthority "Role based Authority that supports up to 256 roles"
├─ MultiRolesAuthority "Flexible and target agnostic role based Authority"
mixins
├─ ERC4626 "Minimal ERC4626 tokenized Vault implementation"
tokens
├─ WETH "Minimalist and modern Wrapped Ether implementation"
├─ ERC20 "Modern and gas efficient ERC20 + EIP-2612 implementation"
├─ ERC721 "Modern, minimalist, and gas efficient ERC721 implementation"
├─ ERC1155 "Minimalist and gas efficient standard ERC1155 implementation"
utils
├─ SSTORE2 "Library for cheaper reads and writes to persistent storage"
├─ CREATE3 "Deploy to deterministic addresses without an initcode factor"
├─ LibString "Library for creating string representations of uint values"
├─ SafeCastLib "Safe unsigned integer casting lib that reverts on overflow"
├─ SignedWadMath "Signed integer 18 decimal fixed point arithmetic library"
├─ MerkleProofLib "Efficient merkle tree inclusion proof verification library"
├─ ReentrancyGuard "Gas optimized reentrancy protection for smart contracts"
├─ FixedPointMathLib "Arithmetic library with operations for fixed-point numbers"
├─ Bytes32AddressLib "Library for converting between addresses and bytes32 values"
├─ SafeTransferLib "Safe ERC20/ETH transfer lib that handles missing return values"
```
## Safety
This is **experimental software** and is provided on an "as is" and "as available" basis.
While each [major release has been audited](audits), these contracts are **not designed with user safety** in mind:
- There are implicit invariants these contracts expect to hold.
- **You can easily shoot yourself in the foot if you're not careful.**
- You should thoroughly read each contract you plan to use top to bottom.
We **do not give any warranties** and **will not be liable for any loss** incurred through any use of this codebase.
## Installation
To install with [**Foundry**](https://github.com/gakonst/foundry):
```sh
forge install transmissions11/solmate
```
To install with [**Hardhat**](https://github.com/nomiclabs/hardhat) or [**Truffle**](https://github.com/trufflesuite/truffle):
```sh
npm install solmate
```
## Acknowledgements
These contracts were inspired by or directly modified from many sources, primarily:
- [Gnosis](https://github.com/gnosis/gp-v2-contracts)
- [Uniswap](https://github.com/Uniswap/uniswap-lib)
- [Dappsys](https://github.com/dapphub/dappsys)
- [Dappsys V2](https://github.com/dapp-org/dappsys-v2)
- [0xSequence](https://github.com/0xSequence)
- [OpenZeppelin](https://github.com/OpenZeppelin/openzeppelin-contracts)