A toolkit for Solidity Smart Contracts development.
git clone https://github.com/noncept/solidity-toolkit.git
npm install
npm run compile
npm test
npm run coverage
Check Solidity files.
npm run lint:sol
Check JS/TS files.
npm run lint:js
Fix JS and Solidity files.
npm run lint:fix
npm run docs
By default, it takes contracts compiled with Truffle using the following command.
npm run truffle:compile
To use Hardhat compiled contracts adjust ./build/contracts
with ./artifacts
files in bs-config.json
.
npm run dev
Read how to interact with your Smart Contracts here.
This allows to flatten the code into a single file.
Edit scripts/flat.sh
to add your contracts.
npm run flat
Important
It is better to analyze the flattened code to have a bigger overview on the entire codebase. So run the flattener first.
The describe
command shows a summary of the contracts and methods in the files provided
surya describe dist/SampleContract.dist.sol
The dependencies
command outputs the c3-linearization of a given contract's inheirtance graph. Contracts will be listed starting with most-derived, ie. if the same function is defined in more than one contract, the solidity compiler will use the definition in whichever contract is listed first.
surya dependencies SampleContract dist/SampleContract.dist.sol
Edit scripts/analyze.sh
to add your contracts
npm run analyze
The inheritance
command outputs a DOT-formatted graph of the inheritance tree.
The graph
command outputs a DOT-formatted graph of the control flow.
The mdreport
command creates a markdown description report with tables comprising information about the system's files, contracts and their functions.
The sol2uml
generates UML class diagram from Solidity contracts.
Code released under the MIT License.