Links:
- Github: https://github.com/dhrosa/circuitpython-tool
- PyPI: https://pypi.org/project/circuitpython-tool
- Documentation: https://circuitpython-tool.readthedocs.io/
Installation:
pip install circuitpython-tool
circuitpython-tool
is a command-line utility for conveniently using
CircuitPython devices from the terminal. Especially useful
when multiple devices are connected to the same computer.
Benefits:
- No need to manually mount
CIRCUITPY
drives, or even keep track of where its mounted. You can refer to the device by name instead. - No need to figure out the name of the serial terminal (e.g. /dev/ttyACM1). You can refer to the device by name instead.
- No need to find the correct CircuitPython version, reset your device while holding BOOTSEL, or drag-and-drop the
.uf2
file intoRPI-RP2
. You can enter the UF2 bootloader with one command, and automatically download and install CircuitPython with another command.
This tool is designed for a workflow where instead of editing files directly on the CircuitPython device, you edit files on your computer and sync the code over to the device.
-
Query:
vendor:model:serial
string that specifies one or more connected CircuitPython devices. Each component string is searched for in the respective attribute. Empty strings are allowed in each component of the query. Example queries:::
matches ANY device.Adafruit::
matches any device whose vendor contains the string "Adafruit":Feather:
matches any device whose model contains the string "Feather"Adafruit:Feather:
matches any device whose vendor contains the string "Adafruit" AND whose model contains the string "Feather"
-
Device: A CircuitPython device connected over USB. The device shows up as a removeable drive labeled
CIRCUITPY
. When the term "device" is referred to in a command-line argument, the device is specified as a query strong as above. An error is thrown if the given query matches multiple connected devices. -
UF2 Device: A device connected over USB that is in its UF2 bootloader. For RP2040-based devices, the device shows up as a removable drive labeled
RPI-RP2
. This is the default state for brand-new RP2040 devices. This is also the state entered when a device is reset with the BOOTSEL butten held down. This state can also be entered via theuf2 enter
command.
List connected CircuitPython devices and their properties:
Open serial terminal to connected Raspberry Pi Pico (without needing to find the correct /dev/ttyACM path!):
circuitpython-tool connect :Pico:
Upload code to connected Raspberry Pi Pico everytime the contents of ~/mycode
changes (without needing to manually mount the device!):
circuitpython-tool upload --dir ~/mycode :Pico:
Or to only upload code once and exit:
circuitpython-tool watch --dir ~/mycode :Pico: --mode=single-shot
Mount Raspberry Pi Pico (if needed) and print the path to the mountpoint:
circuitpython-tool mount :Pico:
Automatically download and install the correct version of CircuitPython onto a connected Raspberry Pi Pico.
If the device isn't already in the UF2 bootloader:
circuitpython-tool uf2 enter :Pico:
Then download and install CircuitPython:
circuitpython-tool install --board raspberry_pi_pico
Wipe out flash memory to bring the device to a factory default state:
circuitpython-tool uf2 nuke
The tool supports shell completion of all parameters, including device queries and board names!
Setup completion for your shell:
eval "$(circuitpython-tool completion)"
Device queries:
Adafruit board names:
CircuitPython locales: