Computers, like people, communicate in a variety of languages. Solidity and Vyper are two notable languages in the Ethereum blockchain realm. We introduced Vyper, an Ethereum smart contract programming language, and compared it to Solidity in the lesson 1. In this section instead, we will go deeper into Vyper’s syntax, which is strikingly similar to Python’s. One of Vyper’s goals is to make smart contract coding easier while retaining good security. Its syntax is intended to be as simple and straightforward as possible. You’ll feel perfectly at home if you’re a Python coder. Even if you aren’t, Vyper’s Python-like syntax is simple to learn. Let’s look at Vyper’s main syntactic components.
Python
# This is a comment in Vyper
@external
def greet(name: string[10]) -> string[30]:
    return concat("Hello, ", name, "!")
Data types are the building blocks of any programming language. They define what kind of data can be stored and manipulated within a program. Let’s go over some basic data types that Vyper offers:
flag: bool = Trueint128. Example: count: int128 = 10price: decimal = 123.45name: string[20] = 'Alice'numbers: int128[5] = [1, 2, 3, 4, 5]To recap, some values available in Vyper:
boolint128uint256decimalsaddressbytes32BytesStringPython
# @version ^0.3.7
b: public(bool)
i: public(int128)  # -2 ** 127 to (2 ** 127 - 1)
u: public(uint256)  # 0 to 2 ** 256 - 1
dec: public(decimal)  # -2 ** 127 to (2 ** 127 - 1), 10 decimal places
addr: public(address)
b32: public(bytes32)
bs: public(Bytes[100])
s: public(String[100])
@external
def __init__():
    self.b = False
    self.i = -1
    self.u = 123
    self.dec = 3.14
    self.addr = 0x704534A22F03Ea46f76A07a195568D115E2e6d52
    self.b32 = 0xada1b75f8ae9a65dcc16f95678ac203030505c6b465c8206e26ae84b525cdacb
    self.bs = b"\x01"
    self.s = "Hello Vyper"
Functions in Vyper, just like in many other languages, are blocks of reusable code that perform a specific task. They provide better modularity for your application and allow for code reusability.
In Vyper, you can define a function using the def keyword, just like in Python. Functions also have a list of parameters and a return type. Here’s a simple Vyper function:
Python
@external
def add(a: int128, b: int128) -> int128:
    return a + b
The @externaldecorator makes this function callable from outside the contract (by a transaction or another contract). Without this decorator, the function would only be callable within the contract where it’s defined.
@internal functions can only be called inside the contract.
@external functions can only be called from outside the contract.
Example:
Python
# @version ^0.3.7
# Internal functions can only be called inside this contract
@internal
@pure
def _add(x: uint256, y: uint256) -> uint256:
    return x + y
@external
@view
def extFunc() -> bool:
    return True
# External functions can only be called from outside this contract
@external
@view
def avg(x: uint256, y: uint256) -> uint256:
    # cannot call other external function
    # self.extFunc()
    # can call internal functions
    z: uint256 = self._add(x, y)
    return (x + y) / 2
@internal
@pure
def _sqr(x: uint256) -> uint256:
    return x * x
@external
@view
def sumOfSquares(x: uint256, y: uint256) -> uint256:
    return self._sqr(x) + self._sqr(y)
Control structures are used to perform different actions based on different decisions. Vyper offers several control structures including if, for loop, and while loop.
The if statement is the most basic control structure. It executes a block of code only if a specified condition is true.
Python
@external
def is_greater_than_ten(a: int128) -> bool:
    if a > 10:
        return True
    else:
        return False
The for loop in Vyper has the same syntax as in Python. You can execute a set of statements, once for each item in a list, tuple, set etc.
Python
numbers: int128[5] = [1, 2, 3, 4, 5]
@external
def sum_numbers() -> int128:
    sum: int128 = 0
    for i in range(5):
        sum += self.numbers[i]
    return sum
The while loop in Vyper repeatedly executes a target statement as long as a given condition is true.
Python
@external
def count_to_ten() -> int128:
    count: int128 = 0
    while count < 10:
        count += 1
    return count
In programming, error handling is crucial to deal with runtime errors and provide meaningful error messages to the user. Vyper uses the assert statement to handle errors.
Python
@external
def divide(a: decimal, b: decimal) -> decimal:
    assert b != 0, "Cannot divide by zero"
    return a / b
In the above code, if b is zero, an error message “Cannot divide by zero” will be thrown, and the transaction will be reverted. Otherwise, it will proceed to the division operation.
Vyper also provides the revert statement which can be used to stop the execution of the current call and revert state changes, while also providing an error message.
That’s a quick rundown of Vyper’s syntax and fundamental principles. The key to mastering Vyper, as with any programming language, is practise. I advocate using these techniques to write simple applications. In the following session, we’ll go through how to use Vyper to construct and maintain smart contracts. Keep an eye out!
Congratulations on successfully completing Lesson 2! You’ve made tremendous progress in grasping Vyper syntax and fundamental constructs. We’ve gone over an introduction to Vyper syntax, basic data types, and functions, control structures, and error handling in Vyper. Recall that each of these components is the foundation of any Vyper programme. It is critical to have a firm understanding of these core components, and the best way to do so is to practise and explore. Create simple programmes that incorporate what you’ve learned today. There is no alternative for hands-on experience when it comes to coding.
Prepare to go deeper into the world of Ethereum smart contracts with Vyper in the future. In Lesson 3, we’ll look at more sophisticated Vyper principles. We’ll take a more hands-on approach, concentrating on designing, implementing, and interacting with smart contracts on the Ethereum network. Understand that the world of blockchain technology is wide and constantly changing. As a blockchain engineer, your journey of discovery and learning never truly ends. You are on the road to mastery, and every step forward, no matter how tiny, is a stride ahead. Continue your excellent effort, and I’ll see you in Lesson 3!