# Vyper — Pythonic Smart Contract Language for the EVM > Vyper is a contract-oriented programming language for the Ethereum Virtual Machine that emphasizes simplicity, security, and auditability. Its Python-like syntax deliberately omits features like inheritance, operator overloading, and inline assembly to reduce the attack surface of smart contracts. Vyper is used by teams that prioritize readable and auditable on-chain code. ## Install Save as a script file and run: # Vyper — Pythonic Smart Contract Language for the EVM ## Quick Use ```bash # Install the compiler pip install vyper # Compile a contract vyper contracts/MyToken.vy # Or use with Foundry forge build --use vyper ``` ## Introduction Vyper is a smart contract language for the EVM designed to be simpler and more secure than Solidity. Inspired by Python, it uses indentation-based syntax and intentionally removes complex features that make code harder to audit. Vyper is the second most popular language for Ethereum smart contracts, favored by security-conscious teams. ## What Vyper Does - Compiles Python-like source code to EVM bytecode for deployment on Ethereum and compatible chains - Enforces bounds checking, overflow protection, and reentrancy guards by default - Produces human-readable ABI and deployment bytecode alongside compilation output - Supports built-in interfaces, events, and storage layout declarations - Generates gas estimates for each function at compile time ## Architecture Overview The Vyper compiler is written in Python and processes source files through lexing, parsing, type checking, and code generation stages. It produces EVM bytecode, ABI JSON, and storage layout metadata. The compiler enforces a strict subset of functionality: no class inheritance, no function overloading, no modifiers, and no inline assembly. This restricted design makes it possible to reason about contract behavior by reading the source alone. Vyper integrates with build tools like Hardhat (via plugin) and Foundry. ## Self-Hosting & Configuration - Install with `pip install vyper` or use the Docker image for reproducible builds - Compile individual files with `vyper filename.vy` or use build frameworks - Use the `--output-format` flag to select ABI, bytecode, or source map outputs - Pin the compiler version in your project to ensure deterministic compilation - Integrate with Foundry using `forge build` with Vyper source files in the project ## Key Features - Python-like syntax with strict indentation, making contracts readable for Python developers - No inheritance, overloading, or inline assembly reduces the attack surface for audits - Built-in overflow and bounds checking eliminates common vulnerability classes - Compile-time gas estimation per function helps optimize contract costs - Storage layout is deterministic and exportable for upgrade planning ## Comparison with Similar Tools - **Solidity** — More feature-rich with inheritance and modifiers; Vyper trades flexibility for simplicity and auditability - **Huff** — Low-level EVM assembly language for gas optimization; Vyper is high-level and readable - **Fe** — Rust-inspired EVM language still in early development; Vyper is mature and production-proven - **Yul** — Intermediate representation used by Solidity; Vyper compiles directly to bytecode without an IR ## FAQ **Q: Is Vyper production-ready?** A: Yes. Major protocols including Curve Finance use Vyper in production for billions of dollars in TVL. **Q: Why does Vyper not have inheritance?** A: Inheritance makes it harder to trace code flow during audits. Vyper uses composition and interfaces instead, so reviewers can understand a contract from a single file. **Q: Can I use Vyper with Hardhat or Foundry?** A: Yes. Hardhat has a Vyper plugin (`@nomiclabs/hardhat-vyper`), and Foundry supports Vyper compilation natively. **Q: How does Vyper handle reentrancy?** A: Vyper includes a built-in `@nonreentrant` decorator that prevents reentrant calls to protected functions. ## Sources - https://github.com/vyperlang/vyper - https://docs.vyperlang.org --- Source: https://tokrepo.com/en/workflows/asset-9ed39a34 Author: Script Depot