Home

Awesome

<img align="right" width="150" height="150" top="100" src="./assets/m-icon.jpg">

VSCode Solidity Inspector • license

An extension for VSCode editor that offers multiple utilities to work with the Solidity smart-contracts.

Note: This extension is not tested across multiple platforms yet. Only the contracts under foundry project are supported for now.


Motivation:

0age 👑 dropped the optimization alpha in his tweet and when I tried it out for the first time I thought it was really a cool trick. The tweet has the configuration only for hardhat projects. But forge helps to do the same thing in a single command. So I thought instead of typing out the command for each contract in the CLI, it would be handy for the buildooors if there's an extension to inspect solidity contracts and generate low-level code for the contracts. The o/p generated is very useful for gas optimizations. Later I started adding more features to this extension.

TL;DR, this is my first VSCode extension, so feel free to provide feedback as I know that there's a plenty of room for improvements, as always^^

Features at a glance:


Requirements

The following will need to be installed in order to use this template. Please follow the links and instructions.


Usage

The usage of this extension is straightforward.


Highlights unused imports:

https://github.com/PraneshASP/vscode-solidity-inspector/assets/42379522/e4906ad3-69e6-4cea-b986-7712ec342fca


Generate foundry deployment report:

https://github.com/PraneshASP/vscode-solidity-inspector/assets/42379522/cfaf987e-ad91-4927-9042-7562bc8684dc


Support for .tree files and test stub generation:

https://github.com/PraneshASP/vscode-solidity-inspector/assets/42379522/2a3d591b-bc80-46cc-88c9-7e4faa0bb043


File import auto-complete suggestions (with forge remappings support):

[!TIP] If you have updated your remappings.txt file, you can press CMD+CTRL+X to refresh remappings.


Inline separator suggestions:


Inline contract size decoration:

[!TIP] This uses the deployedBytecode object from the build file. So it will get updated only after every build. This setting can be also turned on/off via the extension settings.


[!NOTE] For more demos, see ./assets

<!-- CONTRIBUTING -->

Contributing

Contributions are welcomed. Any contributions you make are greatly appreciated.

  1. Fork the Project
  2. Create your Feature Branch (git checkout -b feature/AmazingFeature)
  3. Commit your Changes (git commit -m 'Add some AmazingFeature')
  4. Push to the Branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

Disclaimer

The outputs generated are not always safe for production usage. No guarantee, representation or warranty is being made, express or implied, as to the safety or correctness of the result. They have not been audited and as such there can be no assurance they will work as intended, and users may experience delays, failures, errors, omissions, loss of transmitted information or loss of funds. The creators are not liable for any of the foregoing. Users should proceed with caution and use at their own risk.