Important update: The Motoko
baselibrary has been replaced by the officialcorepackage. New projects should usecoreinstead ofbase.
This repository contains the Motoko base library. It is intended to be used with the moc compiler (and tools that wrap it, like dfx).
If you are installing Motoko through the DFINITY SDK releases, then this base library is already included.
If you build your project using the Mops package manager, run the following command to add the base package to your project:
mops add baseIf you build your project using the Vessel package manager your package-set most likely already includes base, but if it doesn't or you want to override its version, add an entry like so to your package-set.dhall:
{
name = "base",
repo = "https://github.com/dfinity/motoko-base",
version = "master",
dependencies = [] : List Text
}
The package name "base" appears when importing its modules in Motoko (e.g., import "mo:base/Nat"). The repo may either be your local clone path, or this public repository url, as above. The version can be any git branch or tag name (such as version = "moc-0.8.4"). There are no dependencies. See the Vessel package manager docs for more details.
Run the following commands to configure your local development branch:
# First-time setup
git clone https://github.com/dfinity/motoko-base
cd motoko-base
npm install
# Run tests
npm test
# Run all tests in wasi mode
npm test -- --mode wasi
# Run formatter
npm run prettier:formatNote:
-
If you are using
npm testto run the tests:- You don't need to install any additional dependencies.
- The test runner will automatically download the
mocandwasmtimeversions specified inmops.tomlin the[toolchain]section.
-
If you are using
Makefileto run the tests:
Run only specific test files:
npm test <filter>For example npm test list will run List.test.mo and AssocList.test.mo test files.
Run tests in watch mode:
npm test -- --watch
# useful to combine with filter when writing tests
npm test array -- --watchThe documentation can be generated in doc/ by running
./make_docs.shwhich creates _out/html/index.html.
The next-moc branch contains changes that make base compatible with the
in-development version of moc. This repository's public CI does not run
on that branch.
External contributions are best made against master.
masterbranch is meant for the newest released version ofmoc- The CI runs on this branch
next-mocbranch is meant for the in-development version ofmoc- This branch is used by the
motokorepository's CI
- This branch is used by the
Both branches are kept in sync with each other by mutual, circular merges:
next-mocis updated automatically on each push tomastervia the sync.yml workflowmasteris updated manually on each release ofmocas part of themotokorelease process
Only normal merges are allowed between master and next-moc, because development is permitted on both branches.
This policy makes every PR (to either branch) visible in the history of both branches.
Please read the Interface Design Guide for Motoko Base Library before making a pull request.