No description
Find a file
2019-12-22 15:11:47 -05:00
.github/workflows Changed build.yml and release.yml 2019-12-22 15:11:47 -05:00
adafruit_bus_device Whitespace change to make pylint happy 2019-11-25 22:07:14 -05:00
docs rename expample files: include simpletest on name 2019-10-02 22:44:40 +07:00
examples rename expample files: include simpletest on name 2019-10-02 22:44:40 +07:00
.gitignore Moved from Travis to GitHub Actions 2019-12-02 15:21:05 -05:00
.pylintrc ignore the board module imports in .pylintrc 2018-08-25 14:06:47 +00:00
.readthedocs.yml updated .travis & .readthedocs yml 2018-03-05 17:39:42 -06:00
CODE_OF_CONDUCT.md updated CoC 2018-08-01 04:32:18 +00:00
LICENSE First version of I2CDevice 2016-12-01 18:34:46 -08:00
README.rst Fix GitHub Actions badge 2019-12-03 20:06:49 -05:00
requirements.txt Revert "Add Adafruit-Blinka to requirements.txt" 2019-02-25 14:35:29 -08:00
setup.py Update setup.py so it can be used in CPython on RPi 2018-06-28 13:03:18 -07:00

Adafruit CircuitPython BusDevice
================================

.. image:: https://readthedocs.org/projects/adafruit-circuitpython-busdevice/badge/?version=latest
    :target: https://circuitpython.readthedocs.io/projects/bus_device/en/latest/
    :alt: Documentation Status

.. image :: https://img.shields.io/discord/327254708534116352.svg
    :target: https://discord.gg/nBQh6qu
    :alt: Discord

.. image:: https://github.com/adafruit/Adafruit_CircuitPython_BusDevice/workflows/Build%20CI/badge.svg
    :target: https://github.com/adafruit/Adafruit_CircuitPython_BusDevice/actions/
    :alt: Build Status

The ``I2CDevice`` and ``SPIDevice`` helper classes make managing transaction state
on a bus easy. For example, they manage locking the bus to prevent other
concurrent access. For SPI devices, it manages the chip select and protocol
changes such as mode. For I2C, it manages the device address.

.. _bus_device_installation:

On supported GNU/Linux systems like the Raspberry Pi, you can install the driver locally `from
PyPI <https://pypi.org/project/adafruit-circuitpython-busdevice/>`_. To install for current user:

.. code-block:: shell
    
    pip3 install adafruit-circuitpython-busdevice
    
To install system-wide (this may be required in some cases):

.. code-block:: shell
    
    sudo pip3 install adafruit-circuitpython-busdevice
   
To install in a virtual environment in your current project:

.. code-block:: shell

    mkdir project-name && cd project-name
    python3 -m venv .env
    source .env/bin/activate
    pip3 install adafruit-circuitpython-busdevice
    
Usage Example
=============

See examples/read_register_i2c.py and examples/read_register_spi.py for examples of the module's usage.

Contributing
============

Contributions are welcome! Please read our `Code of Conduct
<https://github.com/adafruit/Adafruit_CircuitPython_BusDevice/blob/master/CODE_OF_CONDUCT.md>`_
before contributing to help this project stay welcoming.

Documentation
=============

For information on building library documentation, please check out `this guide <https://learn.adafruit.com/creating-and-sharing-a-circuitpython-library/sharing-our-docs-on-readthedocs#sphinx-5-1>`_.