Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/juanfranblanco/vscode-solidity
Visual Studio Code language support extension for Solidity smart contracts in Ethereum https://marketplace.visualstudio.com/items?itemName=JuanBlanco.solidity
https://github.com/juanfranblanco/vscode-solidity
ethereum solidity solidity-contracts visual-studio
Last synced: 3 days ago
JSON representation
Visual Studio Code language support extension for Solidity smart contracts in Ethereum https://marketplace.visualstudio.com/items?itemName=JuanBlanco.solidity
- Host: GitHub
- URL: https://github.com/juanfranblanco/vscode-solidity
- Owner: juanfranblanco
- License: mit
- Created: 2015-11-19T07:03:05.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2024-10-10T10:03:50.000Z (3 months ago)
- Last Synced: 2025-01-02T00:06:39.493Z (11 days ago)
- Topics: ethereum, solidity, solidity-contracts, visual-studio
- Language: TypeScript
- Homepage:
- Size: 330 MB
- Stars: 904
- Watchers: 23
- Forks: 193
- Open Issues: 148
-
Metadata Files:
- Readme: README-DEVELOP.md
- License: License.txt
Awesome Lists containing this project
- awesome-solidity - vscode-solidity - Visual Studio Code language support extension. (Editor Plugins)
- awesome-solidity - vscode-solidity - Visual Studio Code language support extension. (Editor Plugins)
- awesome-solidity - vscode-solidity - Visual Studio Code language support extension. (Editor Plugins)
README
**Table of Contents**
- [Prerequisites...](#prerequisites)
- [How to run code in this github repository](#how-to-run-code-in-this-github-repository)
- [Running](#running)
- [Debugging](#debugging)
- [See also:](#see-also)Perhaps you want to help work on this awesome project? Or run from the github repository?
# Prerequisites...
You need to have installed
* VSCode (duh). Download [here](https://code.visualstudio.com/download).
* [nodejs](https://nodejs.org/en/)
* [npm](https://www.npmjs.com/get-npm)There are a number of nodejs packages are needed, like [typescript](https://www.typescriptlang.org/), but you can get those via `npm`,
which is described in a below [section](#how-to-run-code-in-this-github-repository).# How to run code in this github repository
Clone the repository:
```console
$ git clone https://github.com/juanfranblanco/vscode-solidity
Cloning into 'vscode-solidity'...
remote: Enumerating objects: 169, done.
...
$ cd vscode-solidity
$
```Install dependent npm packages:
```console
$ npm install
```Now just run from inside the `vscode-solidity` folder
```
$ code .
```## Running
If you just want to run the code, on the top there is a "Debug" menu item and under that, the second item is "Start Without Debugging", which is also bound the key sequence `Ctrl`-`F5`.
After that, the VSCode window should turn from blue to orange and another window will pop up. In this window you will have the vscode extension installed and enabled.
If you edit a solidity file, which is a file ending in `.sol` and looks like this:
```solidity
/*
* @source: http://blockchain.unica.it/projects/ethereum-survey/attacks.html#simpledao
* @author: Atzei N., Bartoletti M., Cimoli T
* Modified by Josselin Feist
*/
pragma solidity 0.4.25;contract SimpleDAO {
mapping (address => uint) public credit;function donate(address to) payable public{
credit[to] += msg.value;
}function withdraw(uint amount) public{
if (credit[msg.sender]>= amount) {
require(msg.sender.call.value(amount)());
credit[msg.sender]-=amount;
}
}function queryCredit(address to) view public returns(uint){
return credit[to];
}
}
```This when rendered inside be colorized, for example the tokens "pragma", "solidity" and "0.4.25" may appear in a different color. If the all appear in the same color then the language extension mechanism is not working and there is probably something wrong in the extension. Look in the other VSCode window with the orange frame for what might be wrong.
But if everything is good, enter `Ctrl`-`Shift`-`P` and a list of commands will pop up. If you type "Solidity", you should see those specific to this extension.
## Debugging
You may want to extend this code of may find a problem and want to debug what is going wrong. For this, you start off from the "Debug" menu using the first item on the list "Start Debugging" which is also bound to the function key `F5`. As before the window will go orange a popup menu bar will appear at the top.
__NOTE__: It may happen that after the window goes orange, another and VSCode window with the blue, the "play button" may go from a the parallel bars to "pause" back to "play". When that happens you may also be stopped in `bootstrap-fork.js` at some nonsensical like like line 9 which has no code on it. If this happens (and it may happen several times for each solidity file loaded) just hit the play button to make sure it goes back to the parallel bars. You have 10 seconds from the time this button goes from "Pause" to "Play" to hit the "Play" button. Otherwise in the other VSCode you will get a popup message that reads:
> Extension host did not start in 10 seconds, it might be stopped on the first line and needs a debugger to continue.
# See also:
* [Extension API](https://code.visualstudio.com/api)
* [Your First Extension](https://code.visualstudio.com/api/get-started/your-first-extension)