1# JerryScript with mbed OS 5 2 3TL;DR? jump straight to [quickstart](#quick-start) 4 5## Introduction 6 7This directory contains the necessary code to build JerryScript for devices 8capable of running mbed OS 5. It has been tested with the following boards 9so far: 10 11- [Nordic Semiconductor NRF52 Development Kit](https://developer.mbed.org/platforms/Nordic-nRF52-DK/) 12- [NXP Freedom K64F](https://developer.mbed.org/platforms/FRDM-K64F/) 13- [STM NUCLEO F401RE](https://developer.mbed.org/platforms/ST-Nucleo-F401RE/) 14- [Silicon Labs EFM32 Giant Gecko](https://developer.mbed.org/platforms/EFM32-Giant-Gecko/) 15 16## Features 17 18### Peripheral Drivers 19 20Peripheral Drivers are intended as a 1-to-1 mapping to mbed C++ APIs, with a few 21differences (due to differences between JavaScript and C++ like lack of operator 22overloading). 23 24- [DigitalOut](https://docs.mbed.com/docs/mbed-os-api-reference/en/5.1/APIs/io/DigitalOut/) 25- [InterruptIn](https://docs.mbed.com/docs/mbed-os-api-reference/en/5.1/APIs/io/InterruptIn/) 26- [I2C](https://docs.mbed.com/docs/mbed-os-api-reference/en/5.1/APIs/interfaces/digital/I2C/) 27- setInterval and setTimeout using [mbed-event](https://github.com/ARMmbed/mbed-events) 28 29## Dependencies 30 31### mbed CLI 32 33mbed CLI is used as the build tool for mbed OS 5. You can find out how to install 34it in the [official documentation](https://docs.mbed.com/docs/mbed-os-handbook/en/5.1/dev_tools/cli/#installing-mbed-cli). 35 36### arm-none-eabi-gcc 37 38arm-none-eabi-gcc is the only currently tested compiler for jerryscript on mbed, 39and instructions for building can be found as part of the mbed-cli installation 40instructions above. 41 42### make 43 44make is used to automate the process of fetching dependencies, and making sure that 45mbed-cli is called with the correct arguments. 46 47### nodejs 48 49npm is used to install the dependencies in the local node_modules folder. 50 51### gulp 52 53gulp is used to automate tasks, like cloning repositories or generate source files. 54If you create an own project, for more info see [mbed-js-gulp](https://github.com/ARMmbed/mbed-js-gulp). 55 56### (optional) jshint 57 58jshint is used to statically check your JavaScript code, as part of the build process. 59This ensures that pins you are using in your code are available on your chosen target 60platform. 61 62## Quick Start 63 64Once you have all of your dependencies installed, you can build the example project as follows: 65 66```bash 67git clone https://github.com/ARMmbed/mbed-js-example 68cd mbed-js-example 69npm install 70gulp --target=YOUR_TARGET_NAME 71``` 72 73The produced file (in build/out/YOUR_TARGET_NAME) can then be uploaded to your board, and will 74run when you press reset. 75