Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/micro-os-plus/devices-cortexm-xpack

A source xPack with µOS++ Cortex-M device definitions
https://github.com/micro-os-plus/devices-cortexm-xpack

Last synced: about 2 months ago
JSON representation

A source xPack with µOS++ Cortex-M device definitions

Awesome Lists containing this project

README

        

[![license](https://img.shields.io/github/license/micro-os-plus/devices-cortexm-xpack)](https://github.com/micro-os-plus/devices-cortexm-xpack/blob/xpack/LICENSE)
[![CI on Push](https://github.com/micro-os-plus/devices-cortexm-xpack/workflows/CI%20on%20Push/badge.svg)](https://github.com/micro-os-plus/devices-cortexm-xpack/actions?query=workflow%3A%22CI+on+Push%22)
[![GitHub issues](https://img.shields.io/github/issues/micro-os-plus/devices-cortexm-xpack.svg)](https://github.com/micro-os-plus/devices-cortexm-xpack/issues/)
[![GitHub pulls](https://img.shields.io/github/issues-pr/micro-os-plus/devices-cortexm-xpack.svg)](https://github.com/micro-os-plus/devices-cortexm-xpack/pulls)

# Maintainer info

## Prerequisites

A recent [xpm](https://xpack.github.io/xpm/), which is a portable
[Node.js](https://nodejs.org/) command line application.

It is recommended to update to the latest version with:

```sh
npm install --global xpm@latest
```

## Project repository

The project is hosted on GitHub as:

-

To clone the stable branch (`xpack`), run the following commands in a
terminal (on Windows use the _Git Bash_ console):

```sh
rm -rf ~/Work/devices-cortexm-xpack.git && \
mkdir -p ~/Work && \
git clone \
https://github.com/micro-os-plus/devices-cortexm-xpack.git \
~/Work/devices-cortexm-xpack.git
```

For development purposes, clone the `xpack-develop` branch:

```sh
rm -rf ~/Work/devices-cortexm-xpack.git && \
mkdir -p ~/Work && \
git clone \
--branch xpack-develop \
https://github.com/micro-os-plus/devices-cortexm-xpack.git \
~/Work/devices-cortexm-xpack.git
```

## Development setup

### Remove previous packages

In this early development phase, package versions are not properly set, and
if you have older versions of the xPack installed, sometimes updates may fail
to get the latest version. To fix this remove all global packages by using

```sh
cd ~/Work/devices-cortexm-xpack.git
xpm run rm-global-deps
```

and repeat the steps from `xpm install`.

### Install dependencies

With a clean slate, install dependencies:

```sh
cd ~/Work/devices-cortexm-xpack.git
xpm run install-all
```

## Run tests

The project includes unit tests.

To perform the tests, run the usual xpm sequence:

```sh
cd ~/Work/devices-cortexm-xpack.git
xpm run test-all
```

### Clone writeable dependencies

The above procedure will allow to develop the project itself, but the
dependencies will be read-only; to be able to contribute to them,
also clone the `xpack-develop` branches of all µOS++ source xPacks
into a folder of your choice and link them to the central xPacks
folder by running `xpack link` in each folder.

To automate this, there is a helper script to clone these repos into
`${HOME}/Work/micro-os-plus-xpack-repos`:

```sh
curl -L https://raw.githubusercontent.com/micro-os-plus/helper-scripts/main/clone-and-link-all-git-repos.sh | bash -
```

Note: If you prefer a different location, start the script with a first
argument as the destination folder path.

After cloning all Git repos, link this project to the development packages,
by running the `link-deps` actions:

```sh
cd devices-cortexm-xpack.git
xpm run link-deps
```

## Continuous Integration

The CI tests are performed on GitHub Actions, as the
[CI on Push](https://github.com/micro-os-plus/devices-cortexm-xpack/actions?query=workflow%3A%22CI+on+Push%22)
workflow.

## Code formatting

Code formatting is done using `clang-format --style=file`, either manually
from a script, or automatically from Visual Studio Code, or the Eclipse
CppStyle plug-in.

## How to publish

### Prepare a new blog post

In the `micro-os-plus/web-jekyll` GitHub repo:

- select the `develop` branch
- add a new file to `_posts/devices-cortexm/releases`
- name the file like `2020-12-19-devices-cortexm-v0-1-0-released.md`
- name the post like: **µOS++ devices-cortexm v4.1.0 released**
- update the `date:` field with the current date
- update the GitHub Actions URLs using the actual test pages

If any, refer to closed
[issues](https://github.com/micro-os-plus/devices-cortexm-xpack/issues/)
as:

- **[Issue:\[#1\]\(...\)]**.

### Publish on the npmjs.com server

- select the `xpack-develop` branch
- commit all changes
- update versions in `README.md` and `README-MAINTAINER.md`
- update `CHANGELOG.md`
- commit with a message like _prepare v4.1.0_
- `npm pack` and check the content of the archive, which should list
only `package.json`, `README.md`, `LICENSE`, `CHANGELOG.md`,
the sources and CMake/meson files;
possibly adjust `.npmignore`
- `npm version patch`, `npm version minor`, `npm version major`
- push the `xpack-develop` branch to GitHub
- the `postversion` npm script should also update tags via `git push origin --tags`
- wait for the CI job to complete
()
- `npm publish --tag next` (use `npm publish --access public` when
publishing for the first time)

The version is visible at:

-

## Update the repo

When the package is considered stable:

- with a Git client (VS Code is fine)
- merge `xpack-develop` into `xpack`
- push to GitHub
- select `xpack-develop`

## Tag the npm package as `latest`

When the release is considered stable, promote it as `latest`:

- `npm dist-tag ls @micro-os-plus/devices-cortexm`
- `npm dist-tag add @micro-os-plus/[email protected] latest`
- `npm dist-tag ls @micro-os-plus/devices-cortexm`

## Share on Twitter

- in a separate browser windows, open [TweetDeck](https://tweetdeck.twitter.com/)
- using the `@micro_os_plus` account
- paste the release name like **µOS++ devices-cortexm v4.1.0 released**
- paste the link to the Web page release
- click the **Tweet** button