The official language of TON Blockchain is Tolk, and all other languages are deemed legacy. They are not necessarily outdated or deprecated, so you can still use them and contribute to their development, tooling, or documentation.
Features
The most prominent and distinctive features of Tact are:- Familiar and user-friendly TypeScript-like syntax.
- Strong static type system with built-in Structs, Messages, and maps, among others.
- First-class maps support, with many methods and a convenient foreachstatement for traversing.
- Automatic (de)serialization of incoming messages and data structures.
- Automatic routing of internal, external, and bounced messages.
- Automatic handling of message types, including binary, text, and fallback slices.
- No boilerplate functions for sending messages and deploying child contracts.
- Reusable behaviors through traits.
- Support for low-level programming with asmfunctions.
- Generation of single-file TypeScript wrappers for convenient interactions with compiled contracts, which include:
- Type definitions for Structs and Messages are observable in the compilation report.
- Corresponding storeStructureName()andloadStructureName()functions for (de)serialization.
- All global and contract-level constants.
- Bi-directional records of exit codes: from their names to numbers and vice versa.
- Opcodes of all Messages.
- A contract wrapper class with various helper functions for initialization, deployment, and message exchange.
 
- Rich standard library.
- Extensive documentation.
- Robust tooling.
- …and there’s much more to come!
Security
Tact in production
Some selected software and applications based on contracts written in Tact, deployed in production, and consumed by end users:Open source or source available
- Proof-of-capital - proof-of-capital is a market-making smart contract that protects the interests of all holders.
- See the security audit report by Nowarp.
 
Closed source
- Tradoor - Fast and social DEX on TON.
- See the security audit report by TonBit.
 
- PixelSwap - First modular and upgradeable DEX on TON.
- See the security audit report by Trail of Bits.
 
- GasPump - TON memecoin launchpad and trading platform.
Installation
Compiler
The Tact compiler is distributed as an NPM package bundled with the Tact standard library. The recommended Node.js version is 22 or higher, while the minimum version is 18. Use your favorite package manager to install it into a Node.js project:tact compiler available on your PATH, as well as:
- a convenient unbocdisassembler of a contract’s code compiled into a bag of cells.bocformat.
- a formatter tact-fmt, which can format or check the formatting of individual Tact files and directories.
Tooling
Extensions and plugins
- VS Code extension - powerful and feature-rich extension for Visual Studio Code (VSCode) and VSCode-based editors like VSCodium, Cursor, Windsurf, and others.
- Get it on the Visual Studio Marketplace.
- Get it on the Open VSX Registry.
- Or install from the .vsixfiles in nightly releases.
 
- JetBrains IDEs plugin - provides syntax highlighting, code navigation, and more.
- Language Server (LSP Server) - supports Sublime Text, (Neo)Vim, Helix, and other editors with LSP support.
- tact.vim - Vim 8+ plugin.
- tact-sublime - Sublime Text 4 package.
- Get it on the Package Control.
 
Security
- Misti - Static smart contract analyzer.
- TON Symbolic Analyzer (TSA) - Static smart contract analysis tool based on symbolic execution.
Utility
- Formatter (tact-fmt) — The official formatter. It ships with the Tact Language Server, VS Code extension, and as a standalone binary with the compiler. You can invoke it by runningnpx tact-fmtin your Tact projects.
- BoC Disassembler (unboc) — Disassembler for.bocfiles. Ships as a standalone binary with the compiler. You can invoke it by runningnpx unbocin your Tact projects.
Getting started
For a quick start, read the “Let’s start!” mini-guide in the Tact documentation. It uses the Blueprint development environment for writing, testing, and deploying smart contracts on TON Blockchain. If you want more manual control, use tact-template. It’s a ready-to-use template with the development environment set up, including the Tact compiler with TypeScript + Jest, a local TON emulator, AI-based editor support, and examples of how to run tests.Community
If you can’t find the answer in the docs, or you’ve tried to do some local testing and it still didn’t help, don’t hesitate to reach out to Tact’s flourishing community:- @tactlangon Telegram - Main community chat and discussion group.
- @tactlang_ruon Telegram (Russian)
- @tact_kitchenon Telegram - Channel with updates from the team.
- @tact_languageon X/Twitter
- tact-langorganization on GitHub
- @ton_studioon Telegram
- @thetonstudioon X/Twitter
Contributing
Contributions are welcome! To help develop the compiler, see the contributing guide.Footnotes
- The “unique code” means that each contract in the data sample has at least one TVM instruction that differs from the other contracts, excluding many preprocessed wallets with everything inlined — even seqno and a public key for signature verification! ↩