PROJECT STATUS: Technology preview, bug bounty not active.
Solidity Template — Your Smart Contract Starting Point
This project is sponsored by: XXXX XXXX XXXX, your name here. Contact Will for details.
If you are using these contracts, click at top to WATCH this repository for updates and security fixes, and click SPONSOR above to ensure updates and fixes keep coming.
How to use this
-
Click USE THIS TEMPLATE above to make your own repository based on this template.
-
Install project and run all tests
# Install Node 14+ (or nvm install 14 && nvm use 14) yarn install yarn test
-
Add your own application code inside the Contracts folder and tests inside the Tests folder.
-
Delete stuff you don't need.
-
Make sure tests still pass.
-
Deploy and make a GitHub release showing your deployed address.
Introduction
This repository is a starting point for anybody developing their own Solidity smart contracts. It is opinionated. You should use this as your starting point for all your projects.
Reusable utilities
See the contracts/Utilities folder.
Implementations
See the contracts folder. In here are the contracts you would use to deploy your contract and other implementation-specific details.
Run test suite
Run this each time you change contracts or test scripts:
yarn run prepare
yarn run lint # note, we do not use Prettier style for Solidity
FORCE_COLOR=1 ENABLE_GAS_REPORT=true yarn run test
yarn run test:inheritance
yarn run coverageSmooth sailing
-
Install VS Code
-
Install VS Code Remote - Containers extension
-
Install a container system
- Install podman (maybe
brew install podman?) podman machine initpodman machine start- Set VS Code setting Remote > Containers > Docker Path to
podman
- Install podman (maybe
-
Install VS Code extension Mocha Test Explorer (recommended by Hardhat)
// todo: get mocha running inside container https://marketplace.visualstudio.com/items?itemName=hbenl.vscode-mocha-test-adapter
Contributing
This repository is supported by William Entriken. We are accepting contributions of new features to the repository but have not defined yet which new feaures are welcome (!).
Please send pull requests to improve documentation and test cases. Please send issues for anything that might be improved.
Idioms
- The zero address (0x00...00) is no more special than the one address (0x00...01). If your application treats them differently, document it.
- Log things that people might reasonably want to look up or index.
References
- Uses best practices for developing Solidity projects
- Great implementation examples for setting up automated testing are maintained in the OpenZeppelin Contracts project
- Hardhat is preferred for building / see also Foundry as a competitive offering
- A good review of setting up your editor to use tools here is provided by Yarn
- Set up VS Code
- Style
- Follow automated test cases and Solidity style guide, especially use NatSpec everywhere
- Use underbar prefix for and only for private variables/functions, see OpenZeppelin/openzeppelin-contracts#2798
- Use the contract name in every revert message
- Use a container for all work
Style guide
- Use the Solidity style guide for Solidity code https://docs.soliditylang.org/en/latest/
- 120 hard limit line length
- Function parameters start with an underscore (_)
- NatSpec
- Align whitespace for tags
- Align whitespace for
@params @param(and state variable@dev) are sentence case without capitalization for the first letter- Events
@noticesentence case in past-simple tense without a period like "Tokens were transferred"
- Functions
@noticesentence case in present-simple tense without a period like "Finish a sale"@devsentence case with a period at end
- State variables
@notice(same as@return)
- Follow Solidity Style Guide where it makes sense
- When comparing things, prefer to compare what we have versus the requirement, like
msg.sender == ownerrather than the reverse order. - Every require must have a message and start with the name of the contract/library
- Always use NatSpec with the
///flavor (because Solidity documentation uses that one first, we can assume it is preferred). https://docs.soliditylang.org/en/latest/natspec-format.html - Wrap Solidity to 120 columns
- Prefix private/internal functions & variables with underscore (_)
- File names and headings are sentence case. Except the name of this project is title case.