mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
Merge pull request #20957 from AnnsAnns/examples/readme
Examples: Add proper Table of Contents
This commit is contained in:
commit
03b6122ada
2
dist/tools/ci/static_tests.sh
vendored
2
dist/tools/ci/static_tests.sh
vendored
@ -129,6 +129,8 @@ run ./dist/tools/feature_resolution/check.sh
|
||||
run ./dist/tools/boards_supported/check.sh
|
||||
run ./dist/tools/codespell/check.sh
|
||||
run ./dist/tools/cargo-checks/check.sh
|
||||
run ./dist/tools/examples_check/check_has_readme.sh
|
||||
run ./dist/tools/examples_check/check_in_readme.sh
|
||||
if [ -z "${GITHUB_RUN_ID}" ]; then
|
||||
run ./dist/tools/uncrustify/uncrustify.sh --check
|
||||
else
|
||||
|
27
dist/tools/examples_check/check_has_readme.sh
vendored
Executable file
27
dist/tools/examples_check/check_has_readme.sh
vendored
Executable file
@ -0,0 +1,27 @@
|
||||
#!/bin/bash
|
||||
|
||||
# Path to the examples directory
|
||||
EXAMPLES_DIR="$(dirname "$0")/../../../examples"
|
||||
|
||||
# Get a list of all directories in the examples directory
|
||||
directories=$(find "$EXAMPLES_DIR" -maxdepth 1 -mindepth 1 -type d -exec basename {} \;)
|
||||
|
||||
# Check each directory
|
||||
missing_entries=()
|
||||
for dir in $directories; do
|
||||
if [ ! -f "$EXAMPLES_DIR/$dir/README.md" ]; then
|
||||
missing_entries+=("$dir")
|
||||
fi
|
||||
done
|
||||
|
||||
# Report missing entries
|
||||
if [ ${#missing_entries[@]} -eq 0 ]; then
|
||||
echo "All examples have a README"
|
||||
exit 0
|
||||
else
|
||||
echo "The following directories are missing a README:"
|
||||
for entry in "${missing_entries[@]}"; do
|
||||
echo "- $entry"
|
||||
done
|
||||
exit 1
|
||||
fi
|
30
dist/tools/examples_check/check_in_readme.sh
vendored
Executable file
30
dist/tools/examples_check/check_in_readme.sh
vendored
Executable file
@ -0,0 +1,30 @@
|
||||
#!/bin/bash
|
||||
|
||||
# Path to the examples directory
|
||||
EXAMPLES_DIR="$(dirname "$0")/../../../examples"
|
||||
|
||||
# Path to the README.md file
|
||||
README_FILE="$EXAMPLES_DIR/README.md"
|
||||
|
||||
# Get a list of all directories in the examples directory
|
||||
directories=$(find "$EXAMPLES_DIR" -maxdepth 1 -mindepth 1 -type d -exec basename {} \;)
|
||||
|
||||
# Check each directory
|
||||
missing_entries=()
|
||||
for dir in $directories; do
|
||||
if ! grep -q "$dir" "$README_FILE"; then
|
||||
missing_entries+=("$dir")
|
||||
fi
|
||||
done
|
||||
|
||||
# Report missing entries
|
||||
if [ ${#missing_entries[@]} -eq 0 ]; then
|
||||
echo "All directories are listed in the README.md file."
|
||||
exit 0
|
||||
else
|
||||
echo "The following directories are missing in the README.md file:"
|
||||
for entry in "${missing_entries[@]}"; do
|
||||
echo "- $entry"
|
||||
done
|
||||
exit 1
|
||||
fi
|
144
examples/README.md
Normal file
144
examples/README.md
Normal file
@ -0,0 +1,144 @@
|
||||
# Examples
|
||||
|
||||
RIOT provides a wide range of examples to demonstrate the capabilities of the OS and its modules.
|
||||
|
||||
Each example contains a `README.md` that provides information and instructions how to run it.
|
||||
|
||||
Here is a quick overview of the examples available in the RIOT:
|
||||
|
||||
## The Essentials
|
||||
|
||||
| Example | Description |
|
||||
|---------|-------------|
|
||||
| [default](./default/README.md) | This application is a showcase for RIOT's hardware support. Using it for your board, you should be able to interactively use any hardware that is supported. |
|
||||
| [hello-world](./hello-world/README.md) | A simple "Hello World" that shows the basic structure of a RIOT application. |
|
||||
| [blinky](./blinky/README.md) | The classic "Hello World" example for embedded systems: blinking an LED (or printing "Blink!" via stdio when none are available). |
|
||||
| [leds_shell](./leds_shell/README.md) | The application `leds_shell` is a basic example, which allows easy, interactive control of internal board LEDs, and basic GPIO for externally connected simple devices (for e.g. additional LEDs, relay, motors - via dedicated drivers, etc.) via the shell. |
|
||||
| [saul](./saul/README.md) | This example demonstrates the usage of the SAUL (Sensor Actuator Uber Layer) module. |
|
||||
| [timer_periodic_wakeup](./timer_periodic_wakeup/README.md) | How to set up a periodic wakeup timer using the RIOT operating system. |
|
||||
| [ipc_pingpong](./ipc_pingpong/README.md) | This example is to illustrate the usage of RIOTs IPC messaging system. |
|
||||
| [filesystem](./filesystem/README.md) | This example showcases ways to interact/manage the filesystem in RIOT. |
|
||||
| [subfolders](./subfolders/README.md) | This example demonstrates how to use subfolders in RIOT applications. |
|
||||
|
||||
### RIOT Language Bindings
|
||||
|
||||
#### Officially Supported/Targeted
|
||||
|
||||
##### _Rust_
|
||||
|
||||
| Example | Description |
|
||||
|---------|-------------|
|
||||
| [rust-hello-world](./rust-hello-world/README.md) | This example demonstrates how to write a simple RIOT application in Rust. |
|
||||
| [rust-gcoap](./rust-gcoap/README.md) | This example demonstrates how to write a coap server application in Rust using the RIOTs gcoap module. |
|
||||
| [rust-async](./rust-async/README.md) | This example demonstrates how to use Rusts async/await syntax in a RIOT application. |
|
||||
|
||||
##### _C++_
|
||||
|
||||
| Example | Description |
|
||||
|---------|-------------|
|
||||
| [riot_and_cpp](./riot_and_cpp/README.md) | Example of using C++ in RIOT applications. |
|
||||
|
||||
#### Community Supported
|
||||
|
||||
| Example | Description |
|
||||
|---------|-------------|
|
||||
| [javascript](./javascript/README.md) | How to write IoT applications using javascript using JerryScript. |
|
||||
| [lua_basic](./lua_basic/README.md) | How to write IoT applications using Lua. |
|
||||
| [lua_REPL](./lua_REPL/README.md) | This example demonstrates how to use the Lua Read-Eval-Print Loop (REPL) in RIOT. |
|
||||
| [micropython](./micropython/README.md) | How to use the MicroPython port for RIOT. |
|
||||
| [wasm](./wasm/README.md) | How to use WebAssembly in RIOT. |
|
||||
| [arduino_hello-world](./arduino_hello-world/README.md) | This application demonstrates the usage of Arduino sketches in RIOT. |
|
||||
|
||||
## Networking
|
||||
|
||||
### Constraint Application Protocol (CoAP)
|
||||
|
||||
| Example | Description |
|
||||
|---------|-------------|
|
||||
| [gcoap](./gcoap/README.md) | This example demonstrates the usage of the `gcoap` module, a high-level API for CoAP (Constrained Application Protocol) messaging. |
|
||||
| [gcoap_block_server](./gcoap_block_server/README.md) | CoAP server handling for Block requests, build with gcoap using nanocoap block handling functions. |
|
||||
| [gcoap_fileserver](./gcoap_fileserver/README.md) | This example demonstrates the usage of the `gcoap` module to serve files over CoAP. |
|
||||
| [gcoap_dtls](./gcoap_dtls/README.md) | This example demonstrates the usage of the `gcoap` module with DTLS. |
|
||||
| [nanocoap_server](./nanocoap_server/README.md) | This example demonstrates the usage of the `nanocoap` module, a high-level API for CoAP (Constrained Application Protocol) messaging. |
|
||||
|
||||
### Bluetooth Low Energy (BLE)
|
||||
|
||||
#### NimBLE
|
||||
|
||||
| Example | Description |
|
||||
|---------|-------------|
|
||||
| [nimble_scanner](./nimble_scanner/README.md) | This example showcases the usage of the `NimBLE` BLE stack as a scanner. |
|
||||
| [nimble_gatt](./nimble_gatt/README.md) | This example application configures and runs the NimBLE BLE stack as simple GATT server. |
|
||||
| [nimble_heart_rate_sensor](./nimble_heart_rate_sensor/README.md) | This example demonstrates how to implement asynchronous data transfer using GATT notifications by implementing a mock-up BLE heart rate sensor. |
|
||||
|
||||
#### Misc BLE Examples
|
||||
|
||||
| Example | Description |
|
||||
|---------|-------------|
|
||||
| [skald_eddystone](./skald_eddystone/README.md) | This example demonstrates the usage of `Skald` for creating an Google `Eddystone` beacon. |
|
||||
| [skald_ibeacon](./skald_ibeacon/README.md) | This example demonstrates the usage of `Skald` for creating an Apple `iBeacon`. |
|
||||
|
||||
### MQTT
|
||||
|
||||
| Example | Description |
|
||||
|---------|-------------|
|
||||
| [asymcute_mqttsn](./asymcute_mqttsn/README.md) | This application demonstrates the usage of the Asymcute (MQTT-SN) module in RIOT. |
|
||||
| [emcute_mqttsn](./emcute_mqttsn/README.md) | This application demonstrates the usage of the emCute (MQTT-SN) module in RIOT. |
|
||||
| [paho-mqtt](./paho-mqtt/README.md) | This example demonstrates the usage of the Paho MQTT client library in RIOT. |
|
||||
|
||||
### CoRE Resource Directory
|
||||
|
||||
| Example | Description |
|
||||
|---------|-------------|
|
||||
| [cord_ep](./cord_ep/README.md) | Example of RIOT's Resource Directory (RD) endpoint module, called `cord_ep` |
|
||||
| [cord_lc](./cord_lc/README.md) | Example of RIOT's Resource Directory (RD) lookup module, called `cord_lc` |
|
||||
| [cord_epsim](./cord_epsim/README.md) | This example shows how a node can register with a CoRE resource directory |
|
||||
|
||||
### GNRC Networking
|
||||
|
||||
| Example | Description |
|
||||
|---------|-------------|
|
||||
| [gnrc_minimal](./gnrc_minimal/README.md) | This is a minimalistic example for RIOT's gnrc network stack. |
|
||||
| [gnrc_networking](./gnrc_networking/README.md) | This example demonstrates the usage of the GNRC network stack in RIOT. |
|
||||
| [gnrc_networking_subnets](./gnrc_networking_subnets/README.md) | This example demonstrates IPv6 subnet auto-configuration for networks on a tree topology. |
|
||||
| [gnrc_border_router](./gnrc_border_router/README.md) | Example of `gnrc_border_router` using automatic configuration |
|
||||
| [gnrc_lorawan](./gnrc_lorawan/README.md) | Send and receive LoRaWAN packets and perform basic LoRaWAN commands |
|
||||
| [gnrc_networking_mac](./gnrc_networking_mac/README.md) | This example shows you how to try out communications between RIOT instances with duty-cycled MAC layer protocols |
|
||||
|
||||
### DTLS
|
||||
|
||||
| Example | Description |
|
||||
|---------|-------------|
|
||||
| [dtls-sock](./dtls-sock/README.md) | This example shows how to use DTLS sock `sock_dtls_t` |
|
||||
| [dtls-echo](./dtls-echo/README.md) | This example shows how to use TinyDTLS with sock_udp. |
|
||||
| [dtls-wolfssl](./dtls-wolfssl/README.md) | This example demonstrates the usage of the DTLS module with the wolfSSL library. |
|
||||
|
||||
### Misc
|
||||
|
||||
| Example | Description |
|
||||
|---------|-------------|
|
||||
| [lorawan](./lorawan/README.md) | This application shows a basic LoRaWAN use-case with RIOT. |
|
||||
| [openthread](./openthread/README.md) | This example demonstrates the usage of the OpenThread stack in RIOT. |
|
||||
| [lwm2m](./lwm2m/README.md) | Example of a LWM2M client on RIOT |
|
||||
| [ccn-lite-relay](./ccn-lite-relay/README.md) | This application demonstrates how to use the Content-Centric Networking stack from [CCN-Lite](http://www.ccn-lite.net/) on RIOT |
|
||||
| [telnet_server](./telnet_server/README.md) | Simple telnet server that listens on port 23 over IPv6. |
|
||||
| [posix_sockets](./posix_sockets/README.md) | Showcase for RIOT's POSIX socket support |
|
||||
| [spectrum-scanner](./spectrum-scanner/README.md) | This example demonstrates how to monitor energy levels on all available wireless channels |
|
||||
| [sniffer](./sniffer/README.md) | This application is built to run together with the script `./tools/sniffer.py` as a sniffer for (wireless) data traffic. |
|
||||
| [benckmark_udp](./benchmark_udp/README.md) | This example uses the `benchmark_udp` module to create a stress-test for the RIOT network stack. |
|
||||
| [sock_tcp_echo](./sock_tcp_echo/README.md) | This is a simple TCP echo server / client that uses the SOCK API. |
|
||||
|
||||
## Advanced Examples
|
||||
|
||||
| Example | Description |
|
||||
|---------|-------------|
|
||||
| [bindist](./bindist/README.md) | RIOT allows for creating a "binary distribution", which can be used to ship proprietary, compiled objects in a way that makes it possible to re-link them against a freshly compiled RIOT. This application serves as a simple example. |
|
||||
| [usbus_minimal](./usbus_minimal/README.md) | This is a minimalistic example for RIOT's USB stack. |
|
||||
| [suit_update](./suit_update/README.md) | This example shows how to integrate SUIT-compliant firmware updates into a RIOT application. |
|
||||
| [thread_duel](./thread_duel/README.md) | This is a thread duel application to show RIOTs abilities to run multiple-threads concurrently, even if they are neither cooperative nor dividable into different scheduler priorities, by using the optional round-robin scheduler module. |
|
||||
| [posix_select](./posix_select/README.md) | This example is a showcase for RIOT's POSIX select support |
|
||||
| [psa_crypto](./psa_crypto) | Basic functions of the PSA Crypto API |
|
||||
| [pio_blink](./pio_blink/README.md) | How to use the PIO peripheral on the RaspberryPi Pico to blink an LED. |
|
||||
| [twr_aloha](./twr_aloha/README.md) | This example allows testing different two-way ranging algorithms between two boards supporting a dw1000 device. This makes use of the uwb-core pkg. |
|
||||
| [senml_saul](./senml_saul/README.md) | This example demonstrates the usage of the SAUL (Sensor Actuator Uber Layer) module with the SenML (Sensor Measurement Lists) format. |
|
||||
| [opendsme](./opendsme/README.md) | This example demonstrates the usage of the OpenDSME module in RIOT. |
|
3
examples/gcoap_fileserver/README.md
Normal file
3
examples/gcoap_fileserver/README.md
Normal file
@ -0,0 +1,3 @@
|
||||
# GCoAP Fileserver
|
||||
|
||||
This example demonstrates how to create a CoAP server that serves files from the filesystem.
|
3
examples/pio_blink/README.md
Normal file
3
examples/pio_blink/README.md
Normal file
@ -0,0 +1,3 @@
|
||||
# RaspberryPi Pico PIO Blink
|
||||
|
||||
This example demonstrates how to use the PIO peripheral on the RaspberryPi Pico to blink an LED. The PIO peripheral is a programmable I/O block that can be used to implement custom digital interfaces that work at extremely high speeds.
|
3
examples/senml_saul/README.md
Normal file
3
examples/senml_saul/README.md
Normal file
@ -0,0 +1,3 @@
|
||||
# senml_saul
|
||||
|
||||
This example demonstrates the usage of the SAUL (Sensor Actuator Uber Layer) module with the SenML (Sensor Measurement Lists) format.
|
5
examples/telnet_server/README.md
Normal file
5
examples/telnet_server/README.md
Normal file
@ -0,0 +1,5 @@
|
||||
# Telnet Example
|
||||
|
||||
Example application for demonstrating the RIOT telnet server.
|
||||
|
||||
It creates a simple telnet server that listens on port 23 over IPv6.
|
@ -2,8 +2,7 @@ Thread-Duel
|
||||
============
|
||||
|
||||
This is a thread duel application to show RIOTs abilities to run multiple-threads
|
||||
concurrently, even if they are neither cooperative nor dividable into different scheduler priorities,
|
||||
by using the optional round-robin scheduler module.
|
||||
concurrently, even if they are neither cooperative nor dividable into different scheduler priorities, by using the optional round-robin scheduler module.
|
||||
|
||||
Every thread will do some work (busy waiting).
|
||||
After the work is done it counts up by the amount of work it did and then it rests.
|
||||
|
11
examples/timer_periodic_wakeup/README.md
Normal file
11
examples/timer_periodic_wakeup/README.md
Normal file
@ -0,0 +1,11 @@
|
||||
# Periodic Wakeup Timer Example
|
||||
|
||||
This example demonstrates how to set up a periodic wakeup timer using the RIOT operating system.
|
||||
|
||||
## Overview
|
||||
|
||||
The application sets up a timer that periodically wakes up the system and performs a specific task. This is useful for applications that need to perform regular actions, such as sensor readings or data transmissions.
|
||||
|
||||
## Usage
|
||||
|
||||
Once the application is running, you should see periodic messages indicating that the timer has triggered and the system has woken up to perform its task.
|
Loading…
Reference in New Issue
Block a user