Compare commits
155 commits
py310-comp
...
master
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
4ca170f09a | ||
|
|
078f453be3 | ||
|
|
32f60f499e | ||
|
|
04727ed0d4 | ||
|
|
d827a91a24 | ||
|
|
c9945ba55e | ||
|
|
324b4f8f3a | ||
|
|
eb96289980 | ||
|
|
e659722956 | ||
|
|
a1cd2c9e46 | ||
|
|
092a5ecfbd | ||
|
|
373f0c0c22 | ||
|
|
3fc602ef7a | ||
|
|
4e812d285c | ||
|
|
7283e8e87e | ||
|
|
28dc122a5c | ||
|
|
23118ee09d | ||
|
|
dd58a69a9e | ||
|
|
a05792c0d7 | ||
|
|
1e54f73313 | ||
|
|
24542df558 | ||
|
|
f08b762a34 | ||
|
|
319b6613e4 | ||
|
|
4d09c4abe4 | ||
|
|
fa2c172a12 | ||
|
|
3907bae549 | ||
|
|
c173d84c6d | ||
|
|
6ba1af1dfe | ||
|
|
6c55535367 | ||
|
|
8dda6941f5 | ||
|
|
42f4803327 | ||
|
|
8639df4c99 | ||
|
|
bf8812dd55 | ||
|
|
6b10fd6eb6 | ||
|
|
febfc922c4 | ||
|
|
ca4de93cc4 | ||
|
|
2c53c9bda1 | ||
|
|
6a67a1dec1 | ||
|
|
b64a59cec8 | ||
|
|
1b72ada926 | ||
|
|
b6e95ad50d | ||
|
|
696be13876 | ||
|
|
2602c52184 | ||
|
|
d0893ffd9f | ||
|
|
b8d1a1315b | ||
|
|
764f427a25 | ||
|
|
efd44cee4d | ||
|
|
4eff8b6c4b | ||
|
|
22bd6d6cc4 | ||
|
|
aa7b9800a1 | ||
|
|
eb515470b7 | ||
|
|
49a97f0acc | ||
|
|
76b0b0fbfe | ||
|
|
777e49e47f | ||
|
|
7840ec8a9f | ||
|
|
5172372545 | ||
|
|
e4760ab70e | ||
|
|
5bd604c966 | ||
|
|
fa90162410 | ||
|
|
888253b2de | ||
|
|
af388556f0 | ||
|
|
cd2c49a796 | ||
|
|
1f3a9aea38 | ||
|
|
ba452bb270 | ||
|
|
22307baa0e | ||
|
|
3640064284 | ||
|
|
efc9ca81ec | ||
|
|
1841e5b121 | ||
|
|
d16676c9c7 | ||
|
|
b863a6b594 | ||
|
|
adaa941584 | ||
|
|
dee8376c41 | ||
|
|
3127711e16 | ||
|
|
90fac687a1 | ||
|
|
fc374d68bb | ||
|
|
a47bd2ea9a | ||
|
|
18d7089513 | ||
|
|
5851559e4d | ||
|
|
1d634ea903 | ||
|
|
4c593787b4 | ||
|
|
0c7fa0126f | ||
|
|
4b002375e7 | ||
|
|
363a50de81 | ||
|
|
c31ee4dea9 | ||
|
|
f452154470 | ||
|
|
2c389af214 | ||
|
|
67feedfeee | ||
|
|
88b746ff77 | ||
|
|
9a8728c380 | ||
|
|
1fcc2329ee | ||
|
|
a6a0e86502 | ||
|
|
9c244d68ed | ||
|
|
7351a8957b | ||
|
|
f1a8355781 | ||
|
|
63b7c7e7e1 | ||
|
|
6b3d2e3b2b | ||
|
|
00bc76f9c9 | ||
|
|
26112fa943 | ||
|
|
4f21970e59 | ||
|
|
144a80dd3a | ||
|
|
22b835bfb2 | ||
|
|
74610a110d | ||
|
|
9b8cd9511d | ||
|
|
9ad307d36f | ||
|
|
8617e71e7d | ||
|
|
acaa4b761c | ||
|
|
4434e2cc44 | ||
|
|
ddcbcde7a1 | ||
|
|
31fe9f5f64 | ||
|
|
3a7e6065aa | ||
|
|
71bef419dc | ||
|
|
27df6130e3 | ||
|
|
23f3180f36 | ||
|
|
81aa9cb758 | ||
|
|
6ff9f7096a | ||
|
|
e8902ddae1 | ||
|
|
4e069bd16b | ||
|
|
f49b8e3e6e | ||
|
|
40a78a0aba | ||
|
|
97fc171114 | ||
|
|
a688e13e7c | ||
|
|
7d0c6a18eb | ||
|
|
bf2d23f5ff | ||
|
|
771ad04e80 | ||
|
|
200a3c0bf4 | ||
|
|
291765dca0 | ||
|
|
65a4580800 | ||
|
|
20cfc49f70 | ||
|
|
b6466e2092 | ||
|
|
37f36870c4 | ||
|
|
a3f77586be | ||
|
|
e60cb85683 | ||
|
|
b731f8a295 | ||
|
|
58d99c4da1 | ||
|
|
de6ad7a3f6 | ||
|
|
31575a9335 | ||
|
|
2deeba4613 | ||
|
|
9b0a17ddea | ||
|
|
9c83e4de86 | ||
|
|
de76725537 | ||
|
|
441382d135 | ||
|
|
83b8102c73 | ||
|
|
f21ee38196 | ||
|
|
893fcd5730 | ||
|
|
ecf8ecea5d | ||
|
|
4fbe599cac | ||
|
|
4fb9820b2d | ||
|
|
39087b3b5b | ||
|
|
0362af3856 | ||
|
|
26d7b20482 | ||
|
|
939d3f0f18 | ||
|
|
6f36123a95 | ||
|
|
338302c9da | ||
|
|
86a998bdd4 | ||
|
|
ebe9f6fcc7 |
7 changed files with 272 additions and 103 deletions
2
.github/workflows/githubci.yml
vendored
2
.github/workflows/githubci.yml
vendored
|
|
@ -16,5 +16,5 @@ jobs:
|
||||||
run: bash ./actions_install.sh
|
run: bash ./actions_install.sh
|
||||||
- name: test platforms
|
- name: test platforms
|
||||||
run: |
|
run: |
|
||||||
python3 build_platform.py uno leonardo mega2560 zero esp8266 esp32
|
python3 build_platform.py uno leonardo mega2560 zero esp8266 esp32 pico_rp2040
|
||||||
|
|
||||||
|
|
|
||||||
12
.travis.yml
12
.travis.yml
|
|
@ -1,19 +1,15 @@
|
||||||
language: c
|
language: python
|
||||||
sudo: false
|
|
||||||
|
dist: focal
|
||||||
|
|
||||||
cache:
|
cache:
|
||||||
directories:
|
directories:
|
||||||
- ~/arduino_ide
|
- ~/arduino_ide
|
||||||
- ~/.arduino15/packages/
|
|
||||||
|
|
||||||
git:
|
git:
|
||||||
depth: false
|
depth: false
|
||||||
quiet: true
|
quiet: true
|
||||||
|
|
||||||
addons:
|
|
||||||
apt:
|
|
||||||
packages:
|
|
||||||
- python3
|
|
||||||
- python3-pip
|
|
||||||
|
|
||||||
before_install:
|
before_install:
|
||||||
- source $TRAVIS_BUILD_DIR/install.sh
|
- source $TRAVIS_BUILD_DIR/install.sh
|
||||||
|
|
|
||||||
|
|
@ -1,9 +1,9 @@
|
||||||
# Travis CI Arduino Init Script [](https://travis-ci.com/adafruit/travis-ci-arduino)
|
# Travis CI Arduino Init Script [](https://travis-ci.com/adafruit/travis-ci-arduino)
|
||||||
|
|
||||||
The purpose of this repo is to create a centrally managed dependency
|
The purpose of this repo is to create a centrally managed dependency
|
||||||
install script for all Adafruit Arduino Library Travis CI configs.
|
install script for all Adafruit Arduino Library Travis CI and Github Actions configs.
|
||||||
This will allow us to easily update the install steps without
|
This will allow us to easily update the install steps without
|
||||||
having to manually or programatically update 100+ `.travis.yml` files.
|
having to manually or programmatically update 100+ `.travis.yml` files.
|
||||||
|
|
||||||
We have a guide that you can use to follow along to install both TravisCI and Doxygen generation here https://learn.adafruit.com/the-well-automated-arduino-library/
|
We have a guide that you can use to follow along to install both TravisCI and Doxygen generation here https://learn.adafruit.com/the-well-automated-arduino-library/
|
||||||
|
|
||||||
|
|
@ -17,7 +17,7 @@ source <(curl -SLs https://raw.githubusercontent.com/adafruit/travis-ci-arduino/
|
||||||
```
|
```
|
||||||
|
|
||||||
If you only want to install and build on certain platforms, you can set the
|
If you only want to install and build on certain platforms, you can set the
|
||||||
`INSTALL_PLATFORMS` envionrment variable to a comma-seperated list of platforms.
|
`INSTALL_PLATFORMS` environment variable to a comma-separated list of platforms.
|
||||||
|
|
||||||
**Example `.travis.yml`:**
|
**Example `.travis.yml`:**
|
||||||
```yaml
|
```yaml
|
||||||
|
|
@ -181,7 +181,7 @@ deploy:
|
||||||
```
|
```
|
||||||
6. Still in the top-level directory of the library you'll be testing, copy the current library to Adafruit_Test_Library
|
6. Still in the top-level directory of the library you'll be testing, copy the current library to Adafruit_Test_Library
|
||||||
```bash
|
```bash
|
||||||
adafruit@adafruit:~/Adafruit_BMP183_Library$ cp * ~/Arduino/libraryes/Adafruit_Test_Library/
|
adafruit@adafruit:~/Adafruit_BMP183_Library$ cp * ~/Arduino/libraries/Adafruit_Test_Library/
|
||||||
```
|
```
|
||||||
7. Grep for build_platform.py in githubci.yml to find out what boards to test.
|
7. Grep for build_platform.py in githubci.yml to find out what boards to test.
|
||||||
```bash
|
```bash
|
||||||
|
|
|
||||||
|
|
@ -4,7 +4,7 @@ set -e
|
||||||
|
|
||||||
pip3 install clint pyserial setuptools adafruit-nrfutil
|
pip3 install clint pyserial setuptools adafruit-nrfutil
|
||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install -y --allow-downgrades libllvm8=1:8-3~ubuntu18.04.2 -V
|
sudo apt-get install -y libllvm8 -V
|
||||||
sudo apt install -fy cppcheck clang-format-8
|
sudo apt install -fy cppcheck clang-format-8
|
||||||
if [ ! -f /usr/bin/clang-format ]; then
|
if [ ! -f /usr/bin/clang-format ]; then
|
||||||
sudo ln -s /usr/bin/clang-format-8 /usr/bin/clang-format
|
sudo ln -s /usr/bin/clang-format-8 /usr/bin/clang-format
|
||||||
|
|
@ -18,6 +18,6 @@ mkdir ${HOME}/Arduino/libraries
|
||||||
|
|
||||||
# install arduino IDE
|
# install arduino IDE
|
||||||
export PATH=$PATH:$GITHUB_WORKSPACE/bin
|
export PATH=$PATH:$GITHUB_WORKSPACE/bin
|
||||||
curl -fsSL https://raw.githubusercontent.com/arduino/arduino-cli/master/install.sh | sh -s 0.11.0 2>&1
|
curl -fsSL https://raw.githubusercontent.com/arduino/arduino-cli/master/install.sh | sh
|
||||||
arduino-cli config init > /dev/null
|
arduino-cli config init > /dev/null
|
||||||
arduino-cli core update-index > /dev/null
|
arduino-cli core update-index > /dev/null
|
||||||
|
|
|
||||||
|
|
@ -2,20 +2,36 @@ import sys
|
||||||
import glob
|
import glob
|
||||||
import time
|
import time
|
||||||
import os
|
import os
|
||||||
|
import shutil
|
||||||
|
from distutils.dir_util import copy_tree
|
||||||
import subprocess
|
import subprocess
|
||||||
import collections
|
import collections
|
||||||
|
|
||||||
|
# optional wall option cause build failed if has warnings
|
||||||
|
BUILD_WALL = False
|
||||||
|
BUILD_WARN = True
|
||||||
|
if "--wall" in sys.argv:
|
||||||
|
BUILD_WALL = True
|
||||||
|
sys.argv.remove("--wall")
|
||||||
|
|
||||||
|
if "--no_warn" in sys.argv:
|
||||||
|
BUILD_WARN = False
|
||||||
|
sys.argv.remove("--no_warn")
|
||||||
|
|
||||||
# add user bin to path!
|
# add user bin to path!
|
||||||
BUILD_DIR = ''
|
BUILD_DIR = ''
|
||||||
# add user bin to path!
|
# add user bin to path!
|
||||||
try:
|
try:
|
||||||
BUILD_DIR = os.environ["TRAVIS_BUILD_DIR"]
|
# If we're on actions
|
||||||
except KeyError:
|
|
||||||
pass # ok maybe we're on actions?
|
|
||||||
try:
|
|
||||||
BUILD_DIR = os.environ["GITHUB_WORKSPACE"]
|
BUILD_DIR = os.environ["GITHUB_WORKSPACE"]
|
||||||
except KeyError:
|
except KeyError:
|
||||||
pass # ok maybe we're on travis?
|
try:
|
||||||
|
# If we're on travis
|
||||||
|
BUILD_DIR = os.environ["TRAVIS_BUILD_DIR"]
|
||||||
|
except KeyError:
|
||||||
|
# If we're running on local machine
|
||||||
|
BUILD_DIR = os.path.abspath(".")
|
||||||
|
pass
|
||||||
|
|
||||||
os.environ["PATH"] += os.pathsep + BUILD_DIR + "/bin"
|
os.environ["PATH"] += os.pathsep + BUILD_DIR + "/bin"
|
||||||
print("build dir:", BUILD_DIR)
|
print("build dir:", BUILD_DIR)
|
||||||
|
|
@ -24,6 +40,11 @@ IS_LEARNING_SYS = False
|
||||||
if "Adafruit_Learning_System_Guides" in BUILD_DIR:
|
if "Adafruit_Learning_System_Guides" in BUILD_DIR:
|
||||||
print("Found learning system repo")
|
print("Found learning system repo")
|
||||||
IS_LEARNING_SYS = True
|
IS_LEARNING_SYS = True
|
||||||
|
os.remove(BUILD_DIR + "/ci/examples/Blink/Blink.ino")
|
||||||
|
os.rmdir(BUILD_DIR + "/ci/examples/Blink")
|
||||||
|
elif "METROX-Examples-and-Project-Sketches" in BUILD_DIR:
|
||||||
|
print("Found MetroX Examples Repo")
|
||||||
|
IS_LEARNING_SYS = True
|
||||||
|
|
||||||
#os.system('pwd')
|
#os.system('pwd')
|
||||||
#os.system('ls -lA')
|
#os.system('ls -lA')
|
||||||
|
|
@ -33,60 +54,106 @@ CHECK = u'\N{check mark}'
|
||||||
|
|
||||||
ALL_PLATFORMS={
|
ALL_PLATFORMS={
|
||||||
# classic Arduino AVR
|
# classic Arduino AVR
|
||||||
"uno" : "arduino:avr:uno",
|
"uno" : ["arduino:avr:uno", None],
|
||||||
"leonardo" : "arduino:avr:leonardo",
|
"leonardo" : ["arduino:avr:leonardo", None],
|
||||||
"mega2560" : "arduino:avr:mega:cpu=atmega2560",
|
"mega2560" : ["arduino:avr:mega:cpu=atmega2560", None],
|
||||||
# Arduino SAMD
|
# Arduino SAMD
|
||||||
"zero" : "arduino:samd:arduino_zero_native",
|
"zero" : ["arduino:samd:arduino_zero_native", "0x68ed2b88"],
|
||||||
"cpx" : "arduino:samd:adafruit_circuitplayground_m0",
|
"cpx" : ["arduino:samd:adafruit_circuitplayground_m0", "0x68ed2b88"],
|
||||||
# Espressif
|
# Espressif
|
||||||
"esp8266" : "esp8266:esp8266:huzzah:eesz=4M3M,xtal=80",
|
"esp8266" : ["esp8266:esp8266:huzzah:eesz=4M3M,xtal=80", None],
|
||||||
"esp32" : "esp32:esp32:featheresp32:FlashFreq=80",
|
"esp32" : ["esp32:esp32:featheresp32:FlashFreq=80", None],
|
||||||
|
"magtag" : ["esp32:esp32:adafruit_magtag29_esp32s2", "0xbfdd4eee"],
|
||||||
|
"funhouse" : ["esp32:esp32:adafruit_funhouse_esp32s2", "0xbfdd4eee"],
|
||||||
|
"metroesp32s2" : ["esp32:esp32:adafruit_metro_esp32s2", "0xbfdd4eee"],
|
||||||
|
"qtpy_esp32s2" : ["esp32:esp32:adafruit_qtpy_esp32s2", "0xbfdd4eee"],
|
||||||
|
"feather_esp32s2" : ["esp32:esp32:adafruit_feather_esp32s2", "0xbfdd4eee"],
|
||||||
|
"feather_esp32s2_tft" : ["esp32:esp32:adafruit_feather_esp32s2_tft", "0xbfdd4eee"],
|
||||||
# Adafruit AVR
|
# Adafruit AVR
|
||||||
"trinket_3v" : "adafruit:avr:trinket3",
|
"trinket_3v" : ["adafruit:avr:trinket3", None],
|
||||||
"trinket_5v" : "adafruit:avr:trinket5",
|
"trinket_5v" : ["adafruit:avr:trinket5", None],
|
||||||
"protrinket_3v" : "adafruit:avr:protrinket3",
|
"protrinket_3v" : ["adafruit:avr:protrinket3", None],
|
||||||
"protrinket_5v" : "adafruit:avr:protrinket5",
|
"protrinket_5v" : ["adafruit:avr:protrinket5", None],
|
||||||
"gemma" : "adafruit:avr:gemma",
|
"gemma" : ["adafruit:avr:gemma", None],
|
||||||
"flora" : "adafruit:avr:flora8",
|
"flora" : ["adafruit:avr:flora8", None],
|
||||||
"feather32u4" : "adafruit:avr:feather32u4",
|
"feather32u4" : ["adafruit:avr:feather32u4", None],
|
||||||
"cpc" : "arduino:avr:circuitplay32u4cat",
|
"cpc" : ["arduino:avr:circuitplay32u4cat", None],
|
||||||
# Adafruit SAMD
|
# Adafruit SAMD
|
||||||
"gemma_m0" : "adafruit:samd:adafruit_gemma_m0",
|
"gemma_m0" : ["adafruit:samd:adafruit_gemma_m0", "0x68ed2b88"],
|
||||||
"trinket_m0" : "adafruit:samd:adafruit_trinket_m0",
|
"trinket_m0" : ["adafruit:samd:adafruit_trinket_m0", "0x68ed2b88"],
|
||||||
"feather_m0_express" : "adafruit:samd:adafruit_feather_m0_express",
|
"feather_m0_express" : ["adafruit:samd:adafruit_feather_m0_express", "0x68ed2b88"],
|
||||||
"metro_m0" : "adafruit:samd:adafruit_metro_m0",
|
"feather_m4_express" : ["adafruit:samd:adafruit_feather_m4:speed=120", "0x68ed2b88"],
|
||||||
"metro_m0_tinyusb" : "adafruit:samd:adafruit_metro_m0:usbstack=tinyusb",
|
"feather_m4_express_tinyusb" : ["adafruit:samd:adafruit_feather_m4:speed=120,usbstack=tinyusb", "0x68ed2b88"],
|
||||||
"metro_m4" : "adafruit:samd:adafruit_metro_m4:speed=120",
|
"feather_m4_can" : ["adafruit:samd:adafruit_feather_m4_can:speed=120", "0x68ed2b88"],
|
||||||
"metro_m4_tinyusb" : "adafruit:samd:adafruit_metro_m4:speed=120,usbstack=tinyusb",
|
"feather_m4_can_tinyusb" : ["adafruit:samd:adafruit_feather_m4_can:speed=120,usbstack=tinyusb", "0x68ed2b88"],
|
||||||
"metro_m4_airliftlite" : "adafruit:samd:adafruit_metro_m4_airliftlite:speed=120",
|
"metro_m0" : ["adafruit:samd:adafruit_metro_m0", "0x68ed2b88"],
|
||||||
"pybadge" : "adafruit:samd:adafruit_pybadge_m4:speed=120",
|
"metro_m0_tinyusb" : ["adafruit:samd:adafruit_metro_m0:usbstack=tinyusb", "0x68ed2b88"],
|
||||||
"pybadge_tinyusb" : "adafruit:samd:adafruit_pybadge_m4:speed=120,usbstack=tinyusb",
|
"metro_m4" : ["adafruit:samd:adafruit_metro_m4:speed=120", "0x55114460"],
|
||||||
"pygamer" : "adafruit:samd:adafruit_pygamer_m4:speed=120",
|
"metro_m4_tinyusb" : ["adafruit:samd:adafruit_metro_m4:speed=120,usbstack=tinyusb", "0x55114460"],
|
||||||
"hallowing_m0" : "adafruit:samd:adafruit_hallowing",
|
"metro_m4_airliftlite" : ["adafruit:samd:adafruit_metro_m4_airliftlite:speed=120", "0x55114460"],
|
||||||
"hallowing_m4" : "adafruit:samd:adafruit_hallowing_m4:speed=120,usbstack=tinyusb",
|
"metro_m4_airliftlite_tinyusb" : ["adafruit:samd:adafruit_metro_m4_airliftlite:speed=120,usbstack=tinyusb", "0x55114460"],
|
||||||
"neotrellis_m4" : "adafruit:samd:adafruit_trellis_m4:speed=120",
|
"pybadge" : ["adafruit:samd:adafruit_pybadge_m4:speed=120", "0x55114460"],
|
||||||
"monster_m4sk" : "adafruit:samd:adafruit_monster_m4sk:speed=120,usbstack=tinyusb",
|
"pybadge_tinyusb" : ["adafruit:samd:adafruit_pybadge_m4:speed=120,usbstack=tinyusb", "0x55114460"],
|
||||||
"pyportal" : "adafruit:samd:adafruit_pyportal_m4:speed=120,usbstack=tinyusb",
|
"pygamer" : ["adafruit:samd:adafruit_pygamer_m4:speed=120", "0x55114460"],
|
||||||
"pyportal_titano" : "adafruit:samd:adafruit_pyportal_m4_titano:speed=120,usbstack=tinyusb",
|
"pygamer_tinyusb" : ["adafruit:samd:adafruit_pygamer_m4:speed=120,usbstack=tinyusb", "0x55114460"],
|
||||||
"cpx_ada" : "adafruit:samd:adafruit_circuitplayground_m0",
|
"hallowing_m0" : ["adafruit:samd:adafruit_hallowing", "0x68ed2b88"],
|
||||||
"grand_central" : "adafruit:samd:adafruit_grandcentral_m4:speed=120,usbstack=tinyusb",
|
"hallowing_m4" : ["adafruit:samd:adafruit_hallowing_m4:speed=120", "0x55114460"],
|
||||||
"matrixportal" : "adafruit:samd:adafruit_matrixportal_m4:speed=120,usbstack=tinyusb",
|
"hallowing_m4_tinyusb" : ["adafruit:samd:adafruit_hallowing_m4:speed=120,usbstack=tinyusb", "0x55114460"],
|
||||||
|
"neotrellis_m4" : ["adafruit:samd:adafruit_trellis_m4:speed=120", "0x55114460"],
|
||||||
|
"monster_m4sk" : ["adafruit:samd:adafruit_monster_m4sk:speed=120", "0x55114460"],
|
||||||
|
"monster_m4sk_tinyusb" : ["adafruit:samd:adafruit_monster_m4sk:speed=120,usbstack=tinyusb", "0x55114460"],
|
||||||
|
"pyportal" : ["adafruit:samd:adafruit_pyportal_m4:speed=120", "0x55114460"],
|
||||||
|
"pyportal_tinyusb" : ["adafruit:samd:adafruit_pyportal_m4:speed=120,usbstack=tinyusb", "0x55114460"],
|
||||||
|
"pyportal_titano" : ["adafruit:samd:adafruit_pyportal_m4_titano:speed=120", "0x55114460"],
|
||||||
|
"pyportal_titano_tinyusb" : ["adafruit:samd:adafruit_pyportal_m4_titano:speed=120,usbstack=tinyusb", "0x55114460"],
|
||||||
|
"cpx_ada" : ["adafruit:samd:adafruit_circuitplayground_m0", "0x68ed2b88"],
|
||||||
|
"grand_central" : ["adafruit:samd:adafruit_grandcentral_m4:speed=120", "0x55114460"],
|
||||||
|
"grand_central_tinyusb" : ["adafruit:samd:adafruit_grandcentral_m4:speed=120,usbstack=tinyusb", "0x55114460"],
|
||||||
|
"matrixportal" : ["adafruit:samd:adafruit_matrixportal_m4:speed=120", "0x55114460"],
|
||||||
|
"matrixportal_tinyusb" : ["adafruit:samd:adafruit_matrixportal_m4:speed=120,usbstack=tinyusb", "0x55114460"],
|
||||||
|
"neotrinkey_m0" : ["adafruit:samd:adafruit_neotrinkey_m0", "0x68ed2b88"],
|
||||||
|
"rotarytrinkey_m0" : ["adafruit:samd:adafruit_rotarytrinkey_m0", "0x68ed2b88"],
|
||||||
|
"neokeytrinkey_m0" : ["adafruit:samd:adafruit_neokeytrinkey_m0", "0x68ed2b88"],
|
||||||
|
"slidetrinkey_m0" : ["adafruit:samd:adafruit_slidetrinkey_m0", "0x68ed2b88"],
|
||||||
|
"proxlighttrinkey_m0" : ["adafruit:samd:adafruit_proxlighttrinkey_m0", "0x68ed2b88"],
|
||||||
|
"qtpy_m0" : ["adafruit:samd:adafruit_qtpy_m0", "0x68ed2b88"],
|
||||||
|
"qtpy_m0_tinyusb" : ["adafruit:samd:adafruit_qtpy_m0:usbstack=tinyusb", "0x68ed2b88"],
|
||||||
# Arduino nRF
|
# Arduino nRF
|
||||||
"microbit" : "sandeepmistry:nRF5:BBCmicrobit:softdevice=s130",
|
"microbit" : ["sandeepmistry:nRF5:BBCmicrobit:softdevice=s110", None],
|
||||||
# Adafruit nRF
|
# Adafruit nRF
|
||||||
"nrf52832" : "adafruit:nrf52:feather52832:softdevice=s132v6,debug=l0",
|
"nrf52832" : ["adafruit:nrf52:feather52832:softdevice=s132v6,debug=l0", None],
|
||||||
"nrf52840" : "adafruit:nrf52:feather52840:softdevice=s140v6,debug=l0",
|
"nrf52840" : ["adafruit:nrf52:feather52840:softdevice=s140v6,debug=l0", "0xada52840"],
|
||||||
"cpb" : "adafruit:nrf52:cplaynrf52840:softdevice=s140v6,debug=l0",
|
"cpb" : ["adafruit:nrf52:cplaynrf52840:softdevice=s140v6,debug=l0", "0xada52840"],
|
||||||
"clue" : "adafruit:nrf52:cluenrf52840:softdevice=s140v6,debug=l0",
|
"clue" : ["adafruit:nrf52:cluenrf52840:softdevice=s140v6,debug=l0", "0xada52840"],
|
||||||
|
"ledglasses_nrf52840" : ["adafruit:nrf52:ledglasses_nrf52840:softdevice=s140v6,debug=l0", "0xada52840"],
|
||||||
|
# RP2040 (Philhower)
|
||||||
|
"pico_rp2040" : ["rp2040:rp2040:rpipico:freq=125,flash=2097152_0", "0xe48bff56"],
|
||||||
|
"pico_rp2040_tinyusb" : ["rp2040:rp2040:rpipico:flash=2097152_0,freq=125,dbgport=Disabled,dbglvl=None,usbstack=tinyusb", "0xe48bff56"],
|
||||||
|
"feather_rp2040" : ["rp2040:rp2040:adafruit_feather:freq=125,flash=8388608_0", "0xe48bff56"],
|
||||||
|
"feather_rp2040_tinyusb" : ["rp2040:rp2040:adafruit_feather:flash=8388608_0,freq=125,dbgport=Disabled,dbglvl=None,usbstack=tinyusb", "0xe48bff56"],
|
||||||
|
"qt2040_trinkey" : ["rp2040:rp2040:adafruit_trinkeyrp2040qt:freq=125,flash=8388608_0", "0xe48bff56"],
|
||||||
|
"qt2040_trinkey_tinyusb" : ["rp2040:rp2040:adafruit_trinkeyrp2040qt:flash=8388608_0,freq=125,dbgport=Disabled,dbglvl=None,usbstack=tinyusb", "0xe48bff56"],
|
||||||
|
# Attiny8xy, 16xy, 32xy (SpenceKonde)
|
||||||
|
"attiny3217" : ["megaTinyCore:megaavr:atxy7:chip=3217", None],
|
||||||
|
"attiny3216" : ["megaTinyCore:megaavr:atxy6:chip=3216", None],
|
||||||
|
"attiny1617" : ["megaTinyCore:megaavr:atxy7:chip=1617", None],
|
||||||
|
"attiny1616" : ["megaTinyCore:megaavr:atxy6:chip=1616", None],
|
||||||
|
"attiny1607" : ["megaTinyCore:megaavr:atxy7:chip=1607", None],
|
||||||
|
"attiny1606" : ["megaTinyCore:megaavr:atxy6:chip=1606", None],
|
||||||
|
"attiny817" : ["megaTinyCore:megaavr:atxy7:chip=817", None],
|
||||||
|
"attiny816" : ["megaTinyCore:megaavr:atxy6:chip=816", None],
|
||||||
|
"attiny807" : ["megaTinyCore:megaavr:atxy7:chip=807", None],
|
||||||
|
"attiny806" : ["megaTinyCore:megaavr:atxy6:chip=806", None],
|
||||||
# groupings
|
# groupings
|
||||||
"main_platforms" : ("uno", "leonardo", "mega2560", "zero",
|
"main_platforms" : ("uno", "leonardo", "mega2560", "zero", "qtpy_m0",
|
||||||
"esp8266", "esp32", "metro_m4"),
|
"esp8266", "esp32", "metro_m4", "trinket_m0"),
|
||||||
"arcada_platforms" : ("pybadge", "pygamer", "hallowing_m4",
|
"arcada_platforms" : ("pybadge", "pygamer", "hallowing_m4",
|
||||||
"cpb", "cpx_ada")
|
"cpb", "cpx_ada"),
|
||||||
|
"wippersnapper_platforms" : ("metro_m4_airliftlite_tinyusb", "pyportal_tinyusb"),
|
||||||
|
"rp2040_platforms" : ("pico_rp2040", "feather_rp2040")
|
||||||
}
|
}
|
||||||
|
|
||||||
BSP_URLS = "https://adafruit.github.io/arduino-board-index/package_adafruit_index.json,http://arduino.esp8266.com/stable/package_esp8266com_index.json,https://dl.espressif.com/dl/package_esp32_index.json,https://sandeepmistry.github.io/arduino-nRF5/package_nRF5_boards_index.json"
|
BSP_URLS = "https://adafruit.github.io/arduino-board-index/package_adafruit_index.json,http://arduino.esp8266.com/stable/package_esp8266com_index.json,https://raw.githubusercontent.com/espressif/arduino-esp32/gh-pages/package_esp32_dev_index.json,https://sandeepmistry.github.io/arduino-nRF5/package_nRF5_boards_index.json,https://github.com/earlephilhower/arduino-pico/releases/download/global/package_rp2040_index.json,http://drazzy.com/package_drazzy.com_index.json"
|
||||||
|
|
||||||
class ColorPrint:
|
class ColorPrint:
|
||||||
|
|
||||||
|
|
@ -119,12 +186,20 @@ def install_platform(platform):
|
||||||
ColorPrint.print_fail("FAILED to install "+platform)
|
ColorPrint.print_fail("FAILED to install "+platform)
|
||||||
exit(-1)
|
exit(-1)
|
||||||
ColorPrint.print_pass(CHECK)
|
ColorPrint.print_pass(CHECK)
|
||||||
|
# print installed core version
|
||||||
|
print(os.popen('arduino-cli core list | grep {}'.format(platform)).read(), end='')
|
||||||
|
|
||||||
def run_or_die(cmd, error):
|
def run_or_die(cmd, error):
|
||||||
print(cmd)
|
print(cmd)
|
||||||
if os.system(cmd) != 0:
|
attempt = 0
|
||||||
ColorPrint.print_fail(error)
|
while attempt < 3:
|
||||||
exit(-1)
|
if os.system(cmd) == 0:
|
||||||
|
return
|
||||||
|
attempt += 1
|
||||||
|
print('attempt {} failed, {} retry left'.format(attempt, 3-attempt))
|
||||||
|
time.sleep(5)
|
||||||
|
ColorPrint.print_fail(error)
|
||||||
|
exit(-1)
|
||||||
|
|
||||||
################################ Install Arduino IDE
|
################################ Install Arduino IDE
|
||||||
print()
|
print()
|
||||||
|
|
@ -133,17 +208,10 @@ print("INSTALLING ARDUINO BOARDS")
|
||||||
ColorPrint.print_info('#'*40)
|
ColorPrint.print_info('#'*40)
|
||||||
|
|
||||||
run_or_die("arduino-cli core update-index --additional-urls "+BSP_URLS+
|
run_or_die("arduino-cli core update-index --additional-urls "+BSP_URLS+
|
||||||
" > /dev/null", "FAILED to update core indecies")
|
" > /dev/null", "FAILED to update core indices")
|
||||||
print()
|
print()
|
||||||
|
|
||||||
# link test library folder to the arduino libraries folder
|
################################ Install dependencies
|
||||||
if not IS_LEARNING_SYS:
|
|
||||||
try:
|
|
||||||
os.symlink(BUILD_DIR, os.environ['HOME']+'/Arduino/libraries/Adafruit_Test_Library')
|
|
||||||
except FileExistsError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
################################ Install dependancies
|
|
||||||
our_name=None
|
our_name=None
|
||||||
try:
|
try:
|
||||||
if IS_LEARNING_SYS:
|
if IS_LEARNING_SYS:
|
||||||
|
|
@ -159,18 +227,74 @@ try:
|
||||||
dep = dep.strip()
|
dep = dep.strip()
|
||||||
print("Installing "+dep)
|
print("Installing "+dep)
|
||||||
run_or_die('arduino-cli lib install "'+dep+'" > /dev/null',
|
run_or_die('arduino-cli lib install "'+dep+'" > /dev/null',
|
||||||
"FAILED to install dependancy "+dep)
|
"FAILED to install dependency "+dep)
|
||||||
except OSError:
|
except OSError:
|
||||||
print("No library dep or properties found!")
|
print("No library dep or properties found!")
|
||||||
pass # no library properties
|
pass # no library properties
|
||||||
|
|
||||||
# Delete the existing library if we somehow downloaded
|
# Delete the existing library if we somehow downloaded
|
||||||
# due to dependancies
|
# due to dependencies
|
||||||
if our_name:
|
if our_name:
|
||||||
run_or_die("arduino-cli lib uninstall \""+our_name+"\"", "Could not uninstall")
|
run_or_die("arduino-cli lib uninstall \""+our_name+"\"", "Could not uninstall")
|
||||||
|
|
||||||
print("Libraries installed: ", glob.glob(os.environ['HOME']+'/Arduino/libraries/*'))
|
print("Libraries installed: ", glob.glob(os.environ['HOME']+'/Arduino/libraries/*'))
|
||||||
|
|
||||||
|
# link our library folder to the arduino libraries folder
|
||||||
|
if not IS_LEARNING_SYS:
|
||||||
|
try:
|
||||||
|
os.symlink(BUILD_DIR, os.environ['HOME']+'/Arduino/libraries/' + os.path.basename(BUILD_DIR))
|
||||||
|
except FileExistsError:
|
||||||
|
pass
|
||||||
|
|
||||||
|
################################ UF2 Utils.
|
||||||
|
|
||||||
|
def glob1(pattern):
|
||||||
|
result = glob.glob(pattern)
|
||||||
|
if len(result) != 1:
|
||||||
|
raise RuntimeError(f"Required pattern {pattern} to match exactly 1 file, got {result}")
|
||||||
|
return result[0]
|
||||||
|
|
||||||
|
def download_uf2_utils():
|
||||||
|
"""Downloads uf2conv tools if we don't already have them
|
||||||
|
"""
|
||||||
|
cmd = "wget -nc --no-check-certificate http://raw.githubusercontent.com/microsoft/uf2/master/utils/uf2families.json https://raw.githubusercontent.com/microsoft/uf2/master/utils/uf2conv.py"
|
||||||
|
proc = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, shell=True)
|
||||||
|
r = proc.wait(timeout=60)
|
||||||
|
out = proc.stdout.read()
|
||||||
|
err = proc.stderr.read()
|
||||||
|
if r != 0:
|
||||||
|
ColorPrint.print_fail("Failed to download UF2 Utils!")
|
||||||
|
ColorPrint.print_fail(out.decode("utf-8"))
|
||||||
|
ColorPrint.print_fail(err.decode("utf-8"))
|
||||||
|
return False
|
||||||
|
return True
|
||||||
|
|
||||||
|
def generate_uf2(example_path):
|
||||||
|
"""Generates a .uf2 file from a .bin or .hex file.
|
||||||
|
:param str example_path: A path to the compiled .bin or .hex file.
|
||||||
|
|
||||||
|
"""
|
||||||
|
if not download_uf2_utils():
|
||||||
|
return None
|
||||||
|
cli_build_path = "build/*.*." + fqbn.split(':')[2] + "/*.hex"
|
||||||
|
input_file = glob1(os.path.join(example_path, cli_build_path))
|
||||||
|
output_file = os.path.splitext(input_file)[0] + ".uf2"
|
||||||
|
family_id = ALL_PLATFORMS[platform][1]
|
||||||
|
cmd = ['python3', 'uf2conv.py', input_file, '-c', '-f', family_id, '-o', output_file]
|
||||||
|
proc = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
|
||||||
|
r = proc.wait(timeout=60)
|
||||||
|
out = proc.stdout.read()
|
||||||
|
err = proc.stderr.read()
|
||||||
|
if r == 0 and not err:
|
||||||
|
ColorPrint.print_pass(CHECK)
|
||||||
|
ColorPrint.print_info(out.decode("utf-8"))
|
||||||
|
else:
|
||||||
|
ColorPrint.print_fail(CROSS)
|
||||||
|
ColorPrint.print_fail(out.decode("utf-8"))
|
||||||
|
ColorPrint.print_fail(err.decode("utf-8"))
|
||||||
|
return None
|
||||||
|
return output_file
|
||||||
|
|
||||||
################################ Test platforms
|
################################ Test platforms
|
||||||
platforms = []
|
platforms = []
|
||||||
success = 0
|
success = 0
|
||||||
|
|
@ -178,9 +302,9 @@ success = 0
|
||||||
# expand groups:
|
# expand groups:
|
||||||
for arg in sys.argv[1:]:
|
for arg in sys.argv[1:]:
|
||||||
platform = ALL_PLATFORMS.get(arg, None)
|
platform = ALL_PLATFORMS.get(arg, None)
|
||||||
if isinstance(platform, str):
|
if isinstance(platform, list):
|
||||||
platforms.append(arg)
|
platforms.append(arg)
|
||||||
elif isinstance(platform, collections.Iterable):
|
elif isinstance(platform, tuple):
|
||||||
for p in platform:
|
for p in platform:
|
||||||
platforms.append(p)
|
platforms.append(p)
|
||||||
else:
|
else:
|
||||||
|
|
@ -201,21 +325,62 @@ def test_examples_in_folder(folderpath):
|
||||||
# check if we should SKIP
|
# check if we should SKIP
|
||||||
skipfilename = folderpath+"/."+platform+".test.skip"
|
skipfilename = folderpath+"/."+platform+".test.skip"
|
||||||
onlyfilename = folderpath+"/."+platform+".test.only"
|
onlyfilename = folderpath+"/."+platform+".test.only"
|
||||||
|
# check if we should GENERATE UF2
|
||||||
|
gen_file_name = folderpath+"/."+platform+".generate"
|
||||||
if os.path.exists(skipfilename):
|
if os.path.exists(skipfilename):
|
||||||
ColorPrint.print_warn("skipping")
|
ColorPrint.print_warn("skipping")
|
||||||
continue
|
continue
|
||||||
if glob.glob(folderpath+"/.*.test.only") and not os.path.exists(onlyfilename):
|
if glob.glob(folderpath+"/.*.test.only"):
|
||||||
ColorPrint.print_warn("skipping")
|
platformname = glob.glob(folderpath+"/.*.test.only")[0].split('.')[1]
|
||||||
continue
|
if platformname != "none" and not platformname in ALL_PLATFORMS:
|
||||||
|
# uh oh, this isnt a valid testonly!
|
||||||
|
ColorPrint.print_fail(CROSS)
|
||||||
|
ColorPrint.print_fail("This example does not have a valid .platform.test.only file")
|
||||||
|
success = 1
|
||||||
|
continue
|
||||||
|
if not os.path.exists(onlyfilename):
|
||||||
|
ColorPrint.print_warn("skipping")
|
||||||
|
continue
|
||||||
|
if os.path.exists(gen_file_name):
|
||||||
|
ColorPrint.print_info("generating")
|
||||||
|
|
||||||
|
if BUILD_WARN:
|
||||||
|
if os.path.exists(gen_file_name):
|
||||||
|
cmd = ['arduino-cli', 'compile', '--warnings', 'all', '--fqbn', fqbn, '-e', folderpath]
|
||||||
|
else:
|
||||||
|
cmd = ['arduino-cli', 'compile', '--warnings', 'all', '--fqbn', fqbn, folderpath]
|
||||||
|
else:
|
||||||
|
cmd = ['arduino-cli', 'compile', '--warnings', 'none', '--export-binaries', '--fqbn', fqbn, folderpath]
|
||||||
|
|
||||||
cmd = ['arduino-cli', 'compile', '--fqbn', fqbn, examplepath]
|
|
||||||
proc = subprocess.Popen(cmd, stdout=subprocess.PIPE,
|
proc = subprocess.Popen(cmd, stdout=subprocess.PIPE,
|
||||||
stderr=subprocess.PIPE)
|
stderr=subprocess.PIPE)
|
||||||
r = proc.wait()
|
try:
|
||||||
out = proc.stdout.read()
|
out, err = proc.communicate(timeout=60)
|
||||||
err = proc.stderr.read()
|
r = proc.returncode
|
||||||
if r == 0:
|
except:
|
||||||
|
proc.kill()
|
||||||
|
out, err = proc.communicate()
|
||||||
|
r = 1
|
||||||
|
|
||||||
|
if r == 0 and not (err and BUILD_WALL == True):
|
||||||
ColorPrint.print_pass(CHECK)
|
ColorPrint.print_pass(CHECK)
|
||||||
|
if err:
|
||||||
|
# also print out warning message
|
||||||
|
ColorPrint.print_fail(err.decode("utf-8"))
|
||||||
|
if os.path.exists(gen_file_name):
|
||||||
|
if ALL_PLATFORMS[platform][1] == None:
|
||||||
|
ColorPrint.print_info("Platform does not support UF2 files, skipping...")
|
||||||
|
else:
|
||||||
|
ColorPrint.print_info("Generating UF2...")
|
||||||
|
filename = generate_uf2(folderpath)
|
||||||
|
if filename is None:
|
||||||
|
success = 1 # failure
|
||||||
|
if IS_LEARNING_SYS:
|
||||||
|
fqbnpath, uf2file = filename.split("/")[-2:]
|
||||||
|
os.makedirs(BUILD_DIR+"/build", exist_ok=True)
|
||||||
|
os.makedirs(BUILD_DIR+"/build/"+fqbnpath, exist_ok=True)
|
||||||
|
shutil.copy(filename, BUILD_DIR+"/build/"+fqbnpath+"-"+uf2file)
|
||||||
|
os.system("ls -lR "+BUILD_DIR+"/build")
|
||||||
else:
|
else:
|
||||||
ColorPrint.print_fail(CROSS)
|
ColorPrint.print_fail(CROSS)
|
||||||
ColorPrint.print_fail(out.decode("utf-8"))
|
ColorPrint.print_fail(out.decode("utf-8"))
|
||||||
|
|
@ -231,8 +396,8 @@ def test_examples_in_learningrepo(folderpath):
|
||||||
continue
|
continue
|
||||||
if not projectpath.endswith(".ino"):
|
if not projectpath.endswith(".ino"):
|
||||||
continue
|
continue
|
||||||
# found an INO!
|
# found an INO!
|
||||||
print('\t'+projectpath, end=' ')
|
print('\t'+projectpath, end=' ', flush=True)
|
||||||
# check if we should SKIP
|
# check if we should SKIP
|
||||||
skipfilename = folderpath+"/."+platform+".test.skip"
|
skipfilename = folderpath+"/."+platform+".test.skip"
|
||||||
onlyfilename = folderpath+"/."+platform+".test.only"
|
onlyfilename = folderpath+"/."+platform+".test.only"
|
||||||
|
|
@ -242,8 +407,8 @@ def test_examples_in_learningrepo(folderpath):
|
||||||
elif glob.glob(folderpath+"/.*.test.only") and not os.path.exists(onlyfilename):
|
elif glob.glob(folderpath+"/.*.test.only") and not os.path.exists(onlyfilename):
|
||||||
ColorPrint.print_warn("skipping")
|
ColorPrint.print_warn("skipping")
|
||||||
continue
|
continue
|
||||||
|
|
||||||
cmd = ['arduino-cli', 'compile', '--fqbn', fqbn, projectpath]
|
cmd = ['arduino-cli', 'compile', '--warnings', 'all', '--fqbn', fqbn, projectpath]
|
||||||
proc = subprocess.Popen(cmd, stdout=subprocess.PIPE,
|
proc = subprocess.Popen(cmd, stdout=subprocess.PIPE,
|
||||||
stderr=subprocess.PIPE)
|
stderr=subprocess.PIPE)
|
||||||
r = proc.wait()
|
r = proc.wait()
|
||||||
|
|
@ -251,6 +416,9 @@ def test_examples_in_learningrepo(folderpath):
|
||||||
err = proc.stderr.read()
|
err = proc.stderr.read()
|
||||||
if r == 0:
|
if r == 0:
|
||||||
ColorPrint.print_pass(CHECK)
|
ColorPrint.print_pass(CHECK)
|
||||||
|
if err:
|
||||||
|
# also print out warning message
|
||||||
|
ColorPrint.print_fail(err.decode("utf-8"))
|
||||||
else:
|
else:
|
||||||
ColorPrint.print_fail(CROSS)
|
ColorPrint.print_fail(CROSS)
|
||||||
ColorPrint.print_fail(out.decode("utf-8"))
|
ColorPrint.print_fail(out.decode("utf-8"))
|
||||||
|
|
@ -259,7 +427,7 @@ def test_examples_in_learningrepo(folderpath):
|
||||||
|
|
||||||
|
|
||||||
for platform in platforms:
|
for platform in platforms:
|
||||||
fqbn = ALL_PLATFORMS[platform]
|
fqbn = ALL_PLATFORMS[platform][0]
|
||||||
print('#'*80)
|
print('#'*80)
|
||||||
ColorPrint.print_info("SWITCHING TO "+fqbn)
|
ColorPrint.print_info("SWITCHING TO "+fqbn)
|
||||||
install_platform(":".join(fqbn.split(':', 2)[0:2])) # take only first two elements
|
install_platform(":".join(fqbn.split(':', 2)[0:2])) # take only first two elements
|
||||||
|
|
|
||||||
|
|
@ -44,6 +44,8 @@ if [[ -z "${TRAVIS_BUILD_DIR}" ]]; then
|
||||||
export BUILD_DIR=${GITHUB_WORKSPACE}
|
export BUILD_DIR=${GITHUB_WORKSPACE}
|
||||||
export AUTH=${GITHUB_ACTOR}:${GH_REPO_TOKEN}
|
export AUTH=${GITHUB_ACTOR}:${GH_REPO_TOKEN}
|
||||||
export REPO_SLUG=${GITHUB_REPOSITORY}
|
export REPO_SLUG=${GITHUB_REPOSITORY}
|
||||||
|
export COMMIT_SHA1=${GITHUB_SHA}
|
||||||
|
export BUILD_ID="GitHub Actions run: ${GITHUB_RUN_ID}"
|
||||||
if [ "$GITHUB_EVENT_NAME" == "pull_request" ]; then
|
if [ "$GITHUB_EVENT_NAME" == "pull_request" ]; then
|
||||||
export IS_PULL=1
|
export IS_PULL=1
|
||||||
fi
|
fi
|
||||||
|
|
@ -51,6 +53,8 @@ else
|
||||||
export BUILD_DIR=${TRAVIS_BUILD_DIR}
|
export BUILD_DIR=${TRAVIS_BUILD_DIR}
|
||||||
export AUTH=${GH_REPO_TOKEN}
|
export AUTH=${GH_REPO_TOKEN}
|
||||||
export REPO_SLUG=${TRAVIS_REPO_SLUG}
|
export REPO_SLUG=${TRAVIS_REPO_SLUG}
|
||||||
|
export COMMIT_SHA1=${TRAVIS_COMMIT}
|
||||||
|
export BUILD_ID="Travis build: ${TRAVIS_BUILD_NUMBER}"
|
||||||
if [ "${TRAVIS_PULL_REQUEST}" != "false" ]; then
|
if [ "${TRAVIS_PULL_REQUEST}" != "false" ]; then
|
||||||
export IS_PULL=1
|
export IS_PULL=1
|
||||||
fi
|
fi
|
||||||
|
|
@ -78,7 +82,7 @@ cd ${REPO_NAME}
|
||||||
git config --global push.default simple
|
git config --global push.default simple
|
||||||
# Pretend to be an user called Doxygen CI.
|
# Pretend to be an user called Doxygen CI.
|
||||||
git config user.name "Doxygen CI"
|
git config user.name "Doxygen CI"
|
||||||
git config user.email "travis@travis-ci.org"
|
git config user.email "ci-arduino@invalid"
|
||||||
|
|
||||||
# Remove everything currently in the gh-pages branch.
|
# Remove everything currently in the gh-pages branch.
|
||||||
# GitHub is smart enough to know which files have changed and which files have
|
# GitHub is smart enough to know which files have changed and which files have
|
||||||
|
|
@ -171,10 +175,12 @@ if [ -d "html" ] && [ -f "html/index.html" ]; then
|
||||||
# Commit the added files with a title and description containing the Travis CI
|
# Commit the added files with a title and description containing the Travis CI
|
||||||
# build number and the GitHub commit reference that issued this build.
|
# build number and the GitHub commit reference that issued this build.
|
||||||
echo 'Git committing'
|
echo 'Git committing'
|
||||||
git commit -m "Deploy code docs to GitHub Pages Travis build: ${TRAVIS_BUILD_NUMBER}" -m "Commit: ${TRAVIS_COMMIT}"
|
git commit \
|
||||||
|
-m "Deploy docs to GitHub Pages from commit ${COMMIT_SHA1:0:10}" \
|
||||||
|
-m "Commit: ${COMMIT_SHA1}"$'\n'"${BUILD_ID}"
|
||||||
|
|
||||||
# Force push to the remote gh-pages branch.
|
# Force push to the remote gh-pages branch.
|
||||||
# The ouput is redirected to /dev/null to hide any sensitive credential data
|
# The output is redirected to /dev/null to hide any sensitive credential data
|
||||||
# that might otherwise be exposed.
|
# that might otherwise be exposed.
|
||||||
echo 'Git pushing'
|
echo 'Git pushing'
|
||||||
git push --force "https://${AUTH}@github.com/${REPO_SLUG}.git" > /dev/null 2>&1
|
git push --force "https://${AUTH}@github.com/${REPO_SLUG}.git" > /dev/null 2>&1
|
||||||
|
|
|
||||||
13
install.sh
13
install.sh
|
|
@ -109,6 +109,7 @@ INSTALL_NRF52=$([[ $INSTALL_PLATFORMS == *"nrf52"* || -z "$INSTALL_PLATFORMS" ]]
|
||||||
|
|
||||||
if [[ $INSTALL_ESP32 == 1 ]]; then
|
if [[ $INSTALL_ESP32 == 1 ]]; then
|
||||||
echo -n "ESP32: "
|
echo -n "ESP32: "
|
||||||
|
pip install pyserial
|
||||||
DEPENDENCY_OUTPUT=$(arduino --install-boards esp32:esp32 2>&1)
|
DEPENDENCY_OUTPUT=$(arduino --install-boards esp32:esp32 2>&1)
|
||||||
if [ $? -ne 0 ]; then echo -e "\xe2\x9c\x96 OR CACHED"; else echo -e """$GREEN""\xe2\x9c\x93"; fi
|
if [ $? -ne 0 ]; then echo -e "\xe2\x9c\x96 OR CACHED"; else echo -e """$GREEN""\xe2\x9c\x93"; fi
|
||||||
fi
|
fi
|
||||||
|
|
@ -139,12 +140,10 @@ fi
|
||||||
|
|
||||||
if [[ $INSTALL_NRF52 == 1 ]]; then
|
if [[ $INSTALL_NRF52 == 1 ]]; then
|
||||||
echo -n "ADAFRUIT NRF5X: "
|
echo -n "ADAFRUIT NRF5X: "
|
||||||
pip3 install --user setuptools
|
pip install wheel
|
||||||
pip3 install --user adafruit-nrfutil
|
pip install setuptools
|
||||||
pip3 install --user pyserial
|
pip install adafruit-nrfutil
|
||||||
sudo pip3 install setuptools
|
pip install pyserial
|
||||||
sudo pip3 install adafruit-nrfutil
|
|
||||||
sudo pip3 install pyserial
|
|
||||||
DEPENDENCY_OUTPUT=$(arduino --install-boards adafruit:nrf52 2>&1)
|
DEPENDENCY_OUTPUT=$(arduino --install-boards adafruit:nrf52 2>&1)
|
||||||
if [ $? -ne 0 ]; then echo -e "\xe2\x9c\x96 OR CACHED"; else echo -e """$GREEN""\xe2\x9c\x93"; fi
|
if [ $? -ne 0 ]; then echo -e "\xe2\x9c\x96 OR CACHED"; else echo -e """$GREEN""\xe2\x9c\x93"; fi
|
||||||
fi
|
fi
|
||||||
|
|
@ -169,7 +168,7 @@ export SKIP_COUNT=0
|
||||||
export FAIL_COUNT=0
|
export FAIL_COUNT=0
|
||||||
export PDE_COUNT=0
|
export PDE_COUNT=0
|
||||||
# close if [[ $# -eq 0 ]] ; then
|
# close if [[ $# -eq 0 ]] ; then
|
||||||
fi
|
fi
|
||||||
# build all of the examples for the passed platform
|
# build all of the examples for the passed platform
|
||||||
#Sourcing and defining functions
|
#Sourcing and defining functions
|
||||||
function build_platform()
|
function build_platform()
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue