Solidity

This page is a reduced version of the Solidity docs site that is adapted to Viction network to avoid overwhelming information.

About

Solidity is a contract-oriented, high-level language for implementing smart contracts. It was influenced by Python and JavaScript and is designed to target the Ethereum Virtual Machine (EVM) both Ethereum and Viction.

Solidity is statically typed, supports inheritance, libraries and complex user-defined types among other features.

Solidity in Viction

Viction support Solidity compiler version <=0.8.17, which targets London hardfork in Ethereum. However, due the fee mechanism in Viction, BASEFEE opcode is unused and not supported by the runtime.

For Solidity compiler version >=0.8.18, you may still compile and deploy to Viction. However, use it at your own risk.

The table below describes all the opcodes that isn't available in Viction:

Example

As you will see, it is possible to create contracts for voting, crowdfunding, blind auctions, multi-signature wallets and more.

The best way to try out Solidity right now is using Remix (it can take a while to load, please be patient). Remix is a web browser-based IDE that allows you to write Solidity smart contracts, then deploy and run the smart contracts.

Once you're strong enough, on the next pages, we will first see a simple smart contract written in Solidity followed by the basics about blockchains and the Ethereum Virtual Machine.

The next section will explain several features of Solidity by giving useful example contracts. Remember that you can always try out the contracts in your browser!

The last and most extensive section will cover all aspects of Solidity in depth.

If you still have questions, you can try searching or asking on the Ethereum Stackexchange site, or come to our Gitter channel. Ideas for improving Solidity or this documentation are always welcome! the world:

hello.sh
# Ain't no code for that yet, sorry
echo 'You got to trust me on this, I saved the world'

Last updated