Inspired by the popular Truffle framework and developed in Typescript, Lamington makes smart contract development simple for any level of EOSIO developer.
The Lamington library includes CLI tools and JavaScript utilities to streamline the smart contract building, testing and deployment pipeline.
Lamington requires Docker and NodeJS to be installed before it can be used.
Lamington includes command line tools and JavaScript utilities for EOSIO contract development. We recommend installing the framework as a development dependency within your project. This lets you run commands like lamington test in your project.
$ npm install --save-dev lamingtonFrom there you just need to add node scripts to your package.json file that trigger lamington actions, for example:
{
  ...
  "scripts": {
    "build": "lamington build",
    "start": "lamington start eos",
    "stop": "lamington stop eos",
    "test": "lamington test"
  },
  ...
}If you'd like the convenience of using the lamington command without adding it as a project dependency, you can install it on your system globally, just be mindful that this can create trouble if you use lamington with multiple projects simultaneously and don't have them all ready for the same version.
To install globally, run:
$ npm install -g lamingtonLamington is super simple! Whether you're migrating from Solidity, or a seasoned EOSIO developer deploying a complex decentralized application (dApp) you'll find yourself right at home in no time.
Compiling your smart contracts with Lamington is as simple as;
$ lamington buildLamington automatically searches for all files with the .cpp file extension before batch compiling within a docker container. Compiling within a docker container with locked configuration ensures contracts compile consistently and clean every time.
Not every .cpp file is a contract, so we added an additional exclude to the configuration file .lamingtonrc. This exclude option takes an array of globular patterns as files and patterns you don't want added to your build process. We've added the command line method lamington ignore to generate a .lamingtonrc file with default settings.
If you'd like to run builds on specific contracts, an additional contract identifier can be specified like so;
$ lamington build [identifier]Replace the [identifier] with the relative path to the contract with or without the .cpp extension.
Lamington was built with testing in mind. We considered the most commonly used testing libraries like Mocha when developing the Lamington toolset. Running your test suit is as easy as;
$ lamington testFor a full list of available JavaScript utilities, please visit the documentation here.
Initially setting up a project can be tedious and repetitive, so we've created a simple CLI method to setup a boilerplate EOSIO project with Lamington integration.
$ lamington initThis creates a .lamingtonrc file in your current directory with default Lamington settings.
$ lamington init [PROJECT_NAME]Optionally you can provide and additional PROJECT_NAME to create a project directory and initialize a boilerplate project within.
Lamington ships with a default configuration to make getting started simple and setup free. However, as your project grows, so will your need for additional Lamington configuration. For example, deployment to a testnet or the live network will require environment setup. Additionally, you'll need customize your configuration if you'd like to control Lamington's fine grained settings. Fortunately we've made a simple tool to get you started, simply run lamington init in your project directory to create a default .lamingtonrc configuration file.
The .lamingtonrc file allows you to configure additional settings using JSON syntax. We're working on provide allot more settings, like defining multiple environments for each stage of your pipeline.
{
  ...
  "keepAlive":true,
  ...
}The keepAlive setting prevents Lamington from stopping the EOSIO container between each build, allowing you to develop faster and compile often.
We welcome contributions of all types, even down to typo fixes. All help is very welcome!
If you're not sure where to start, the best resource for you is our Contributing to Lamington guide, and if you're still stuck, please reach out to us on Slack.
You can find more information about the Lamington tool-set and join our growing community of developers by visiting any of the following links;
Core Lamington front end toolset
React context management for LamingtonJS
					This project is proudly supported by Coinage.
				
Generated using TypeDoc