Merge pull request #257 from pimoroni/badger2040-builtin-override

Badger2040: Allow builtin demos to be replaced
This commit is contained in:
Philip Howard 2022-03-03 12:17:10 +00:00 committed by GitHub
commit d1954f50b9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 17 additions and 28 deletions

View File

@ -45,7 +45,7 @@ jobs:
- name: Copy modules & examples - name: Copy modules & examples
run: | run: |
cp -r pimoroni-pico-${GITHUB_SHA}/micropython/badger2040_modules_py/* micropython/ports/rp2/modules/ cp -r pimoroni-pico-${GITHUB_SHA}/micropython/badger2040_modules_py/* micropython/ports/rp2/modules/
cp pimoroni-pico-${GITHUB_SHA}/micropython/examples/badger2040/launcher.py micropython/ports/rp2/modules/ cp pimoroni-pico-${GITHUB_SHA}/micropython/examples/badger2040/launcher.py micropython/ports/rp2/modules/_launcher.py
cp pimoroni-pico-${GITHUB_SHA}/micropython/examples/badger2040/clock.py micropython/ports/rp2/modules/_clock.py cp pimoroni-pico-${GITHUB_SHA}/micropython/examples/badger2040/clock.py micropython/ports/rp2/modules/_clock.py
cp pimoroni-pico-${GITHUB_SHA}/micropython/examples/badger2040/fonts.py micropython/ports/rp2/modules/_fonts.py cp pimoroni-pico-${GITHUB_SHA}/micropython/examples/badger2040/fonts.py micropython/ports/rp2/modules/_fonts.py
cp pimoroni-pico-${GITHUB_SHA}/micropython/examples/badger2040/e-reader.py micropython/ports/rp2/modules/_ebook.py cp pimoroni-pico-${GITHUB_SHA}/micropython/examples/badger2040/e-reader.py micropython/ports/rp2/modules/_ebook.py

View File

@ -1,19 +1,6 @@
#import gc
#import machine
#
#a = machine.Pin(12, machine.Pin.IN, machine.Pin.PULL_DOWN)
#b = machine.Pin(13, machine.Pin.IN, machine.Pin.PULL_DOWN)
#c = machine.Pin(14, machine.Pin.IN, machine.Pin.PULL_DOWN)
#
#if a.value() or b.value() or c.value():
# for k in locals().keys():
# if k not in ("gc"):
# del locals()[k]
# gc.collect()
# __import__("launcher.py")
try: try:
open("main.py", "r") open("main.py", "r")
except OSError: except OSError:
with open("main.py", "w") as f: with open("main.py", "w") as f:
f.write("import launcher") f.write("import _launcher")
f.flush() f.flush()

View File

@ -1,6 +1,5 @@
import gc import gc
import os import os
import sys
import time import time
import math import math
import machine import machine
@ -19,14 +18,14 @@ inverted = False
icons = bytearray(launchericons.data()) icons = bytearray(launchericons.data())
examples = [ examples = [
("_clock.py", 0), ("_clock", 0),
("_fonts.py", 1), ("_fonts", 1),
("_ebook.py", 2), ("_ebook", 2),
("_image.py", 3), ("_image", 3),
("_list.py", 4), ("_list", 4),
("_badge.py", 5), ("_badge", 5),
("_info.py", 6), ("_info", 6),
("_help.py", 7) ("_help", 7)
] ]
font_sizes = (0.5, 0.7, 0.9) font_sizes = (0.5, 0.7, 0.9)
@ -140,7 +139,7 @@ def render():
for i in range(max_icons): for i in range(max_icons):
x = centers[i] x = centers[i]
label, icon = examples[i + (page * 3)] label, icon = examples[i + (page * 3)]
label = label[1:-3] label = label[1:]
display.pen(0) display.pen(0)
display.icon(icons, icon, 512, 64, x - 32, 24) display.icon(icons, icon, 512, 64, x - 32, 24)
w = display.measure_text(label, font_sizes[font_size]) w = display.measure_text(label, font_sizes[font_size])
@ -168,11 +167,14 @@ def render():
def launch(file): def launch(file):
for k in locals().keys(): for k in locals().keys():
if k not in ("gc", "file"): if k not in ("gc", "file", "machine"):
del locals()[k] del locals()[k]
gc.collect() gc.collect()
__import__(file) try:
sys.exit(0) __import__(file[1:]) # Try to import _[file] (drop underscore prefix)
except ImportError:
__import__(file) # Failover to importing [_file]
machine.reset() # Exit back to launcher
def launch_example(index): def launch_example(index):