Skip to content

A library for encoding blobs into a 2D square of evenly sized chunks designed for sampling and reconstruction

License

Notifications You must be signed in to change notification settings

pollyiop/go-square

 
 

Repository files navigation

go-square

Go Reference

go-square is a Go module that provides data structures and utilities for interacting with data squares in the Celestia network. The data square is a special form of block serialization in the Celestia blockchain. This repo deals with the original data square which is distinct from the extended data square. Operations on the extended data square are handled by rsmt2d.

Package Description
blob Package blob provides types and functions for working with blobs, blob transactions, and index wrapper transactions.
inclusion Package inclusion contains functions to generate the blob share commitment from a given blob.
merkle Package merkle computes a deterministic minimal height Merkle tree hash.
namespace Package namespace contains the Namespace data structure.
shares Package shares contains the Share data structure.
square Package square implements the logic to construct the original data square based on a list of transactions.

Installation

To use go-square as a dependency in your Go project, you can use go get:

go get github.com/celestiaorg/go-square

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

This repo attempts to conform to conventional commits so PR titles should ideally start with fix:, feat:, build:, chore:, ci:, docs:, style:, refactor:, perf:, or test: because this helps with semantic versioning and changelog generation. It is especially important to include an ! (e.g. feat!:) if the PR includes a breaking change.

Tools

  1. Install Go 1.21.5
  2. Install golangci-lint
  3. Fork this repo
  4. Make your changes
  5. Submit a pull request

Helpful Commands

# Display all available make commands
make help

# Run tests
make test

# Run linter
make lint

# Perform benchmarking
make bench

About

A library for encoding blobs into a 2D square of evenly sized chunks designed for sampling and reconstruction

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 99.6%
  • Makefile 0.4%