Skip to content

Aermanio/my-project-name

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Bare mbed Project

Introduction

This repository can be used as a starting template for mbed projects with sane defaults:

  • use mbed-cli
  • write code with VSCode
  • simple directory structure
  • format with .clang-format and .editorconfig

It's the little cousin of Bare Arduino Project

Installation

Before starting, make sure you've read mbed documentation.

1. Install mbed-cli

I recommend the manual install. Make sure to follow the instructions from mbed:

https://os.mbed.com/docs/mbed-os/v5.13/tools/manual-installation.html

If you want to use (at your own risks) Python 3, do the following:

# for the latest stable version
$ pip3 install -U --user mbed-cli

# for HEAD
$ pip3 install -U --user https://github.com/ARMmbed/mbed-cli/archive/master.zip

2. Install arm-none-eabi-gcc

For macOS:

$ brew tap ArmMbed/homebrew-formulae
$ brew install arm-none-eabi-gcc

For Windows & Linux:

You can download the toolchain here:

https://developer.arm.com/tools-and-software/open-source-software/developer-tools/gnu-toolchain/gnu-rm/downloads

3. Import project

Use mbed import to import the project:

$ cd to/where/the/project/should/be
$ mbed import https://github.com/ladislas/Bare-mbed-Project my-project-name

Alternatively, you can use git to do the same with the advantage of making a shallow clone to save space and time:

$ git clone https://github.com/ladislas/Bare-mbed-Project my-project-name
$ cd my-project-name
$ git clone --depth=1 https://github.com/ARMmbed/mbed-os ./lib/mbed-os

4. Publish to Github (optional)

Create a Github repository and push to it:

$ git remote set-url origin https://github.com/{{ GITHUB USERNAME }}/my-project-name
$ git push --set-upstream origin master

Usage

1. Edit .mbed

Don't forget to set your target and favorite toolchain, for example:

MBED_OS_DIR=./lib/mbed-os
TARGET=NUCLEO_WB55RG
TOOLCHAIN=GCC_ARM
ROOT=.

Before running mbed compile.

2. Edit .mbedignore

To speed up compilation time, we've setup a .mbedignore file that removes some files from the compilation process.

If you get error about missing headers when compiling, make sure the header's directory is not set in the .mbedignore file.

Note that it has no impact on binary size after linking (or should not have anyway...).

3. Writing tests

coming soon...

Notes

The templates comes with a simple HelloWorld library that you can use as an example and/or use to make sure your program works.

Bugs & Contributing

Please open an issue or create a PR.

Authors

Made with ❤️ by:

License

Apache 2.0 @ Ladislas de Toldi (Ladislas [at] detoldi dot me)

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published