Skip to content

amilano/pact-5

Repository files navigation

Kadena

 

The Pact Programming Language

Pact is an open-source, Turing-incomplete smart contract language that has been purpose-built with blockchains first in mind. Pact focuses on facilitating transactional logic with the optimal mix of functionality in authorization, data management, and workflow.

Read the whitepaper:

For additional information, press, and development inquiries, please refer to the Kadena website

Important

This repository hosts a rewrite of the Pact language and is not utilized by chainweb-node, serving primarily for local development and testing purposes. We detail the planned transition from Pact to Pact Core in Section Roadmap.

If you are looking for legacy Pact, see github.com/kadena-io/pact.

Table of Contents

Quickstart

  1. Download the latest Pact binary from Github Releases.
  2. Extract the pact binary, make sure that you have the required permissions to execute it.
    chmod +x /path/to/pact
  3. (Optional) Add the path to your $PATH environment variable or adding the line to your shell profile.
    export PATH=$PATH:/path/to/
  4. Execute pact and have fun :-)

Pact Core vs Pact

Pact Core is a redevelopment of the Pact language, focusing on enhancing scalability, maintainability, and performance in response to increasingly complex demands from users and partners.

Pact Core enables sustainable growth of the Pact featureset within the Kadena ecosystem by offering a more modular and maintainable internals, enabling the community to further develop and propose enhancements to the language and components that rely on it.

Pact Core maintains semantic equivalence to Pact, aside from minor differences for security and performance. Existing code will behave the same as code written in (legacy) Pact. Breaking modifications will be communicated using the Kadena Improvement Process (KIP) process.

Roadmap

Note

The current roadmap is being sketched by the Pact Team and will be updated.

Documentation

The Kadena Docs site serves as the primary source of information about Pact. You can find information about how to get started with the Pact language, how to execute already deployed contracts, and follow our step-by-step tutorials.

We recommend that new users start with our beginner`s guide, which provides an understanding of the fundamental concepts and terminology of the language.

Installing Pact Core

To install Pact Core on your infrastructure, you have the option to download a pre-built binary or compile it from the source.

Binary Downloads

You can obtain the latest released version of Pact from our GitHub releases page here. Ensure to download the binary that corresponds to your specific architecture.

Building from Source

Two methods are supported for building Pact Core: using bare Cabal and GHC or employing the Nix package manager.

Using Cabal and GHC

Building is a process comprising four steps:

  1. Install GHCup

  2. Set and ensure the versions specified below are correctly set:

    ghcup install ghc 9.6.3 && ghcup install-cabal
  3. Update Haskell packages:

    cabal update
  4. Build the Pact binary:

    cabal build exe:pact
  5. (Optional) You can either run pact directly:

    cabal run exe:pact

    or, if you prever to make the pact executable available in your $PATH environment, run:

    cabal install exe:pact

Using the Nix Infrastructure

Kadena offers a binary cache for all Nix builds, allowing users to accelerate their build times by utilizing our cache infrastructure. The specifics of setting up the cache depend on various factors and are beyond the scope of this instruction. A good starting point for configuring our cache is the Nix documentation on binary caches, available at: NixOS Wiki on Binary Cache.

The binary cache is typically configured using the nixConfig attribute in our flake definition as follows:

nixConfig = {
    extra-substituters = "https://nixcache.chainweb.com https://cache.iog.io";
    trusted-public-keys = "nixcache.chainweb.com:FVN503ABX9F8x8K0ptnc99XEz5SaA4Sks6kNcZn2pBY= iohk.cachix.org-1:DpRUyj7h7V830dp/i6Nti+NEO2/nhblbov/8MW7Rqoo= cache.nixos.org-1:6NCHdD59X431o0gWypbMrAURkbJ16ZPMQFGspcDShjY=";
  };

Executing nix build within the root directory of this project will create a build under the ./result symbolic link. This will contain the artifact within its bin directory.

Entering the developer shell using nix develop will bring all required dependencies into scope, enabling the use of cabal build to compile the final project.

Editor Integration

We offer built-in integration with Microsoft's Language Server Protocol (LSP). Check your editor's support for the LSP protocol and the specific setup instructions. The server itself can be initiated as follows.

pact --lsp

We currently support the following featureset:

  • Document diagnostics
  • Hover information (Builtins and user specified docs)
  • Jump to definition (Toplevel)

Note

We continue to add specifics on major editors such as Emacs, vim, and VSCode.

License

This code is distributed under the terms of the BSD3 license. See LICENSE for details.

Packages

No packages published

Languages

  • Haskell 86.1%
  • Pact 9.9%
  • C 2.8%
  • Yacc 0.8%
  • Lex 0.2%
  • Nix 0.1%
  • Shell 0.1%