2019-04-16 16:40:16 -07:00
|
|
|
CircuitPython
|
|
|
|
=============
|
2018-02-20 17:34:59 -08:00
|
|
|
|
2019-04-16 16:40:16 -07:00
|
|
|
.. image:: https://s3.amazonaws.com/adafruit-circuit-python/CircuitPython_Repo_header_logo.png
|
2018-12-28 13:43:14 -06:00
|
|
|
|
2020-05-16 17:58:08 -05:00
|
|
|
|Build Status| |Doc Status| |License| |Discord| |Weblate|
|
2018-02-20 17:34:59 -08:00
|
|
|
|
2019-05-04 16:14:43 -04:00
|
|
|
`circuitpython.org <https://circuitpython.org>`__ \| `Get CircuitPython <#get-circuitpython>`__ \|
|
2019-04-16 16:40:16 -07:00
|
|
|
`Documentation <#documentation>`__ \| `Contributing <#contributing>`__ \|
|
|
|
|
`Branding <#branding>`__ \| `Differences from Micropython <#differences-from-micropython>`__ \|
|
|
|
|
`Project Structure <#project-structure>`__
|
2018-02-20 17:34:59 -08:00
|
|
|
|
2019-04-17 10:48:11 -07:00
|
|
|
**CircuitPython** is a *beginner friendly*, open source version of Python for tiny, inexpensive
|
2019-04-16 16:40:16 -07:00
|
|
|
computers called microcontrollers. Microcontrollers are the brains of many electronics including a
|
|
|
|
wide variety of development boards used to build hobby projects and prototypes. CircuitPython in
|
|
|
|
electronics is one of the best ways to learn to code because it connects code to reality. Simply
|
|
|
|
install CircuitPython on a supported board via drag and drop and then edit a ``code.py`` file on
|
|
|
|
the CIRCUITPY drive. The code will automatically reload. No software installs are needed besides a
|
|
|
|
text editor (we recommend `Mu <https://codewith.mu/>`_ for beginners.)
|
2018-02-20 17:34:59 -08:00
|
|
|
|
2019-04-16 16:40:16 -07:00
|
|
|
CircuitPython features unified Python core APIs and a growing list of 150+ device libraries and
|
|
|
|
drivers that work with it. These libraries also work on single board computers with regular
|
|
|
|
Python via the `Adafruit Blinka Library <https://github.com/adafruit/Adafruit_Blinka>`_.
|
2018-02-20 17:34:59 -08:00
|
|
|
|
2019-04-17 10:48:11 -07:00
|
|
|
CircuitPython is based on `MicroPython <https://micropython.org>`_. See
|
|
|
|
`below <#differences-from-micropython>`_ for differences. CircuitPython development is sponsored by
|
|
|
|
`Adafruit <https://adafruit.com>`_ and is available on their educational development boards. Please
|
|
|
|
support both MicroPython and Adafruit.
|
2018-02-20 17:34:59 -08:00
|
|
|
|
2019-04-16 16:40:16 -07:00
|
|
|
Get CircuitPython
|
|
|
|
------------------
|
2018-02-20 17:34:59 -08:00
|
|
|
|
2019-04-16 16:40:16 -07:00
|
|
|
Official binaries for all supported boards are available through
|
2019-04-16 17:33:13 -07:00
|
|
|
`circuitpython.org/downloads <https://circuitpython.org/downloads>`_. The site includes stable, unstable and
|
|
|
|
continuous builds. Full release notes and assets are available through
|
2019-04-16 16:40:16 -07:00
|
|
|
`GitHub releases <https://github.com/adafruit/circuitpython/releases>`_ as well.
|
2018-02-20 17:34:59 -08:00
|
|
|
|
|
|
|
Documentation
|
|
|
|
-------------
|
|
|
|
|
|
|
|
Guides and videos are available through the `Adafruit Learning
|
|
|
|
System <https://learn.adafruit.com/>`__ under the `CircuitPython
|
2019-04-16 16:40:16 -07:00
|
|
|
category <https://learn.adafruit.com/category/circuitpython>`__. An API
|
2018-05-14 13:50:06 -04:00
|
|
|
reference is also available on `Read the Docs
|
|
|
|
<http://circuitpython.readthedocs.io/en/latest/?>`__. A collection of awesome
|
|
|
|
resources can be found at `Awesome CircuitPython <https://github.com/adafruit/awesome-circuitpython>`__.
|
|
|
|
|
|
|
|
Specifically useful documentation when starting out:
|
|
|
|
|
|
|
|
- `Welcome to CircuitPython <https://learn.adafruit.com/welcome-to-circuitpython>`__
|
|
|
|
- `CircuitPython Essentials <https://learn.adafruit.com/circuitpython-essentials>`__
|
|
|
|
- `Example Code <https://github.com/adafruit/Adafruit_Learning_System_Guides/tree/master/CircuitPython_Essentials>`__
|
2018-02-20 17:34:59 -08:00
|
|
|
|
|
|
|
Contributing
|
|
|
|
------------
|
|
|
|
|
|
|
|
See
|
2020-06-14 14:25:58 -05:00
|
|
|
`CONTRIBUTING.md <https://github.com/adafruit/circuitpython/blob/main/CONTRIBUTING.md>`__
|
2018-02-20 17:34:59 -08:00
|
|
|
for full guidelines but please be aware that by contributing to this
|
|
|
|
project you are agreeing to the `Code of
|
2020-06-14 14:25:58 -05:00
|
|
|
Conduct <https://github.com/adafruit/circuitpython/blob/main/CODE_OF_CONDUCT.md>`__.
|
2018-02-20 17:34:59 -08:00
|
|
|
Contributors who follow the `Code of
|
2020-06-14 14:25:58 -05:00
|
|
|
Conduct <https://github.com/adafruit/circuitpython/blob/main/CODE_OF_CONDUCT.md>`__
|
2018-02-20 17:34:59 -08:00
|
|
|
are welcome to submit pull requests and they will be promptly reviewed
|
2018-03-21 21:11:24 -05:00
|
|
|
by project admins. Please join the
|
2019-05-09 09:53:31 -07:00
|
|
|
`Discord <https://adafru.it/discord>`__ too.
|
2018-02-20 17:34:59 -08:00
|
|
|
|
2019-04-16 16:40:16 -07:00
|
|
|
Branding
|
|
|
|
------------
|
|
|
|
|
|
|
|
While we are happy to see CircuitPython forked and modified, we'd appreciate it if forked releases
|
|
|
|
not use the name "CircuitPython" or the Blinka logo. "CircuitPython" means something special to
|
|
|
|
us and those who learn about it. As a result, we'd like to make sure products referring to it meet a
|
|
|
|
common set of requirements.
|
|
|
|
|
|
|
|
If you'd like to use the term "CircuitPython" and Blinka for your product here is what we ask:
|
|
|
|
|
|
|
|
* Your product is supported by the primary
|
|
|
|
`"adafruit/circuitpython" <https://github.com/adafruit/circuitpython>`_ repo. This way we can
|
|
|
|
update any custom code as we update the CircuitPython internals.
|
2019-09-16 12:35:46 -07:00
|
|
|
* Your product is listed on `circuitpython.org <https://circuitpython.org>`__ (source
|
2019-04-16 17:33:13 -07:00
|
|
|
`here <https://github.com/adafruit/circuitpython-org/>`_). This is to ensure that a user of your
|
|
|
|
product can always download the latest version of CircuitPython from the standard place.
|
2019-04-16 16:40:16 -07:00
|
|
|
* Your product has a user accessible USB plug which appears as a CIRCUITPY drive when plugged in.
|
|
|
|
|
|
|
|
If you choose not to meet these requirements, then we ask you call your version of CircuitPython
|
|
|
|
something else (for example, SuperDuperPython) and not use the Blinka logo. You can say it is
|
|
|
|
"CircuitPython-compatible" if most CircuitPython drivers will work with it.
|
|
|
|
|
2018-02-20 17:34:59 -08:00
|
|
|
--------------
|
|
|
|
|
|
|
|
Differences from `MicroPython <https://github.com/micropython/micropython>`__
|
|
|
|
-----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
CircuitPython:
|
|
|
|
|
2020-01-22 19:26:01 +01:00
|
|
|
- Supports native USB on all boards, allowing file editing without special tools.
|
|
|
|
- Floats (aka decimals) are enabled for all builds.
|
|
|
|
- Error messages are translated into 10+ languages.
|
|
|
|
- Does not support concurrency within Python (including interrupts and threading). Some concurrency
|
2019-04-16 17:33:13 -07:00
|
|
|
is achieved with native modules for tasks that require it such as audio file playback.
|
2018-02-20 17:34:59 -08:00
|
|
|
|
|
|
|
Behavior
|
|
|
|
~~~~~~~~
|
|
|
|
|
|
|
|
- The order that files are run and the state that is shared between
|
|
|
|
them. CircuitPython's goal is to clarify the role of each file and
|
|
|
|
make each file independent from each other.
|
|
|
|
- ``boot.py`` (or ``settings.py``) runs only once on start up before
|
|
|
|
USB is initialized. This lays the ground work for configuring USB at
|
|
|
|
startup rather than it being fixed. Since serial is not available,
|
|
|
|
output is written to ``boot_out.txt``.
|
|
|
|
- ``code.py`` (or ``main.py``) is run after every reload until it
|
|
|
|
finishes or is interrupted. After it is done running, the vm and
|
2019-05-15 21:34:14 -04:00
|
|
|
hardware is reinitialized. **This means you cannot read state from**
|
2021-03-07 09:19:49 +02:00
|
|
|
``code.py`` **in the REPL anymore, as the REPL is a fresh vm.** CircuitPython's goal for this
|
2020-11-27 12:07:49 -05:00
|
|
|
change includes reducing confusion about pins and memory being used.
|
2021-03-07 09:19:49 +02:00
|
|
|
- After the main code is finished the REPL can be entered by pressing any key.
|
2018-02-20 17:34:59 -08:00
|
|
|
- Autoreload state will be maintained across reload.
|
|
|
|
- Adds a safe mode that does not run user code after a hard crash or
|
|
|
|
brown out. The hope is that this will make it easier to fix code that
|
|
|
|
causes nasty crashes by making it available through mass storage
|
2020-11-27 12:07:49 -05:00
|
|
|
after the crash. A reset (the button) is needed after it's fixed to
|
2018-02-20 17:34:59 -08:00
|
|
|
get back into normal mode.
|
2019-04-16 17:33:13 -07:00
|
|
|
- RGB status LED indicating CircuitPython state, and errors through a sequence of colored flashes.
|
2019-04-17 10:48:11 -07:00
|
|
|
- Re-runs ``code.py`` or other main file after file system writes over USB mass storage. (Disable with
|
2021-01-25 23:20:37 -05:00
|
|
|
``supervisor.disable_autoreload()``)
|
2021-03-07 09:19:49 +02:00
|
|
|
- Autoreload is disabled while the REPL is active.
|
2019-05-15 21:22:40 -04:00
|
|
|
- Main is one of these: ``code.txt``, ``code.py``, ``main.py``,
|
2019-04-16 16:40:16 -07:00
|
|
|
``main.txt``
|
2019-05-15 21:22:40 -04:00
|
|
|
- Boot is one of these: ``settings.txt``, ``settings.py``, ``boot.py``,
|
2019-04-16 16:40:16 -07:00
|
|
|
``boot.txt``
|
2018-02-20 17:34:59 -08:00
|
|
|
|
|
|
|
API
|
|
|
|
~~~
|
|
|
|
|
2020-10-17 02:22:15 +05:30
|
|
|
- Unified hardware APIs. Documented on
|
|
|
|
`ReadTheDocs <https://circuitpython.readthedocs.io/en/latest/shared-bindings/index.html>`_.
|
2019-04-16 16:40:16 -07:00
|
|
|
- API docs are rST within the C files in ``shared-bindings``.
|
|
|
|
- No ``machine`` API.
|
2018-02-20 17:34:59 -08:00
|
|
|
|
|
|
|
Modules
|
|
|
|
~~~~~~~
|
|
|
|
|
|
|
|
- No module aliasing. (``uos`` and ``utime`` are not available as
|
|
|
|
``os`` and ``time`` respectively.) Instead ``os``, ``time``, and
|
|
|
|
``random`` are CPython compatible.
|
|
|
|
- New ``storage`` module which manages file system mounts.
|
|
|
|
(Functionality from ``uos`` in MicroPython.)
|
|
|
|
- Modules with a CPython counterpart, such as ``time``, ``os`` and
|
|
|
|
``random``, are strict
|
|
|
|
`subsets <https://circuitpython.readthedocs.io/en/latest/shared-bindings/time/__init__.html>`__
|
|
|
|
of their `CPython
|
|
|
|
version <https://docs.python.org/3.4/library/time.html?highlight=time#module-time>`__.
|
|
|
|
Therefore, code from CircuitPython is runnable on CPython but not
|
|
|
|
necessarily the reverse.
|
|
|
|
- tick count is available as
|
2018-02-20 18:06:42 -08:00
|
|
|
`time.monotonic() <https://circuitpython.readthedocs.io/en/latest/shared-bindings/time/__init__.html#time.monotonic>`__
|
2018-02-20 17:34:59 -08:00
|
|
|
|
|
|
|
--------------
|
|
|
|
|
|
|
|
Project Structure
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
Here is an overview of the top-level source code directories.
|
|
|
|
|
|
|
|
Core
|
|
|
|
~~~~
|
|
|
|
|
|
|
|
The core code of
|
|
|
|
`MicroPython <https://github.com/micropython/micropython>`__ is shared
|
|
|
|
amongst ports including CircuitPython:
|
|
|
|
|
|
|
|
- ``docs`` High level user documentation in Sphinx reStructuredText
|
|
|
|
format.
|
|
|
|
- ``drivers`` External device drivers written in Python.
|
|
|
|
- ``examples`` A few example Python scripts.
|
|
|
|
- ``extmod`` Shared C code used in multiple ports' modules.
|
|
|
|
- ``lib`` Shared core C code including externally developed libraries
|
|
|
|
such as FATFS.
|
2018-12-12 08:51:16 -05:00
|
|
|
- ``logo`` The CircuitPython logo.
|
2018-02-20 17:34:59 -08:00
|
|
|
- ``mpy-cross`` A cross compiler that converts Python files to byte
|
|
|
|
code prior to being run in MicroPython. Useful for reducing library
|
|
|
|
size.
|
|
|
|
- ``py`` Core Python implementation, including compiler, runtime, and
|
|
|
|
core library.
|
|
|
|
- ``shared-bindings`` Shared definition of Python modules, their docs
|
|
|
|
and backing C APIs. Ports must implement the C API to support the
|
|
|
|
corresponding module.
|
|
|
|
- ``shared-module`` Shared implementation of Python modules that may be
|
|
|
|
based on ``common-hal``.
|
|
|
|
- ``tests`` Test framework and test scripts.
|
|
|
|
- ``tools`` Various tools, including the pyboard.py module.
|
|
|
|
|
|
|
|
Ports
|
|
|
|
~~~~~
|
|
|
|
|
|
|
|
Ports include the code unique to a microcontroller line and also
|
|
|
|
variations based on the board.
|
|
|
|
|
2020-10-17 02:22:15 +05:30
|
|
|
================ ============================================================
|
|
|
|
Supported Support status
|
|
|
|
================ ============================================================
|
|
|
|
atmel-samd ``SAMD21`` stable | ``SAMD51`` stable
|
|
|
|
cxd56 stable
|
|
|
|
esp32s2 beta
|
|
|
|
litex alpha
|
|
|
|
mimxrt10xx alpha
|
|
|
|
nrf stable
|
|
|
|
stm ``F4`` stable | ``others`` beta
|
|
|
|
unix alpha
|
|
|
|
================ ============================================================
|
|
|
|
|
|
|
|
- ``stable`` Highly unlikely to have bugs or missing functionality.
|
|
|
|
- ``beta`` Being actively improved but may be missing functionality and have bugs.
|
|
|
|
- ``alpha`` Will have bugs and missing functionality.
|
2019-04-16 16:40:16 -07:00
|
|
|
|
2019-04-16 17:33:13 -07:00
|
|
|
The remaining port directories not listed above are in the repo to maintain compatibility with the
|
2019-04-16 16:40:16 -07:00
|
|
|
`MicroPython <https://github.com/micropython/micropython>`__ parent project.
|
2018-02-20 17:34:59 -08:00
|
|
|
|
2020-10-17 02:22:15 +05:30
|
|
|
`Back to Top <#circuitpython>`__
|
2018-02-20 17:34:59 -08:00
|
|
|
|
2020-06-14 16:58:22 -05:00
|
|
|
.. |Build Status| image:: https://github.com/adafruit/circuitpython/workflows/Build%20CI/badge.svg
|
|
|
|
:target: https://github.com/adafruit/circuitpython/actions?query=branch%3Amain
|
2018-02-20 17:34:59 -08:00
|
|
|
.. |Doc Status| image:: https://readthedocs.org/projects/circuitpython/badge/?version=latest
|
|
|
|
:target: http://circuitpython.readthedocs.io/
|
|
|
|
.. |Discord| image:: https://img.shields.io/discord/327254708534116352.svg
|
2019-01-31 19:03:13 -08:00
|
|
|
:target: https://adafru.it/discord
|
2019-04-16 16:40:16 -07:00
|
|
|
.. |License| image:: https://img.shields.io/badge/License-MIT-brightgreen.svg
|
|
|
|
:target: https://choosealicense.com/licenses/mit/
|
2020-05-16 17:58:08 -05:00
|
|
|
.. |Weblate| image:: https://hosted.weblate.org/widgets/circuitpython/-/svg-badge.svg
|
|
|
|
:target: https://hosted.weblate.org/engage/circuitpython/?utm_source=widget
|