Setup
Moddable Platform Setup
This command downloads the Moddable developer tooling for the current OS (Windows support coming soon).
After installing the CLI, call the setup
command:
This process mostly automates the instructions provided by Moddable’s “Getting Started” documentation with a few exceptions.
On macOS:
Homebrew is assumed to be installed.
XZ utils are required to install the CLI due to a dependency for decompressing the ARM toolchain used for nrf52 development. It can be installed with homebrew:
The Xcode Command Line tools are required; setup
will check for their existence before continuing.
A symlink for xsbug.app
is created in /Applications
for easy access through Launchpad.
On Unix environments:
The moddable
git repo is cloned into ~/.local/share
instead of a new/existing ~/Projects
directory.
Environment config:
This command will create (and update) an environment configuration file called ~/.local/share/xs-dev-export.sh
(on Mac & Linux) or Moddable.bat
(on Windows). This file will be sourced by xs-dev
when running commands (on Mac & Linux) or through the custom command prompt (on Windows), to set environment variables and call other “exports” files for embedded tooling.
Interactive Input
By default, this command may prompt during the setup process. To override this behavior, use the --noInteractive
flag.
If there is a environment variable called CI
set to true
, then this command will be non-interactive and automatically accept all prompts.
Tagged Release
The default behavior of this command for Moddable developer tooling pulls the latest release tooling and source code for the associated tagged branch. This provides a known-working state for the SDK and avoids needing to build the tooling on the local machine.
To override this behavior, use the --release
flag to select a tagged release version; this fetches the pre-compiled release assets and latest commit off that tag.
When combined with the --source-repo
flag, it’s possible to get the SDK from another source instead of the default GitHub repo.
This will only work for the mac
, windows
, and linux
device options, which are the respective defaults for the operating system on which the command is run.
Target Branch
The default behavior of this command for Moddable developer tooling pulls the latest release tooling and source code for the associated tagged branch. This provides a known-working state for the SDK and avoids needing to build the tooling on the local machine.
To override this behavior, use the --branch
flag to select public
; this fetches the latest commit off that main branch and runs the build to generate the associated tools. This can be set to any branch name, however public
is the main public branch for the Moddable-OpenSource repo.
When combined with the --source-repo
flag, it’s possible to get the SDK repo from another source instead of the default GitHub repo.
This will only work for the mac
, windows
, and linux
device options, which are the respective defaults for the operating system on which the command is run.
Device Setup
While the setup
command provides the Moddable SDK for the dev environment, the --device
flag selects another platform target SDK to set up. It ensures the Moddable SDK has been installed first.
Use the --list-devices
flag to get a prompt for supported device tooling to install.
Additional related tooling
There are some utilities that are not included in the Moddable SDK or other platform tooling but can be helpful with some common development tasks. The --tool
flag allows for installing one of these related tools, which may not be easily done from a typical package manager.
Supported tools:
ejectfix
: not a downloadable tool, rather a environment preference to disable the DISK NOT EJECTED PROPERLY
notification while working with the nrf52 on MacOS. This will automate the process described by the Adafruit blog: