No description
Find a file
2020-07-08 16:49:04 -04:00
.github/workflows build.yml: add black formatting check 2020-04-07 16:03:14 -05:00
adafruit_bus_device Ran black, updated to pylint 2.x 2020-03-16 16:45:42 -04:00
docs Black reformatting with Python 3 target. 2020-04-09 17:25:12 -04:00
examples Ran black, updated to pylint 2.x 2020-03-16 16:45:42 -04:00
.gitignore Moved from Travis to GitHub Actions 2019-12-02 15:21:05 -05:00
.pylintrc Ran black, updated to pylint 2.x 2020-03-16 16:45:42 -04:00
.readthedocs.yml updated .travis & .readthedocs yml 2018-03-05 17:39:42 -06:00
CODE_OF_CONDUCT.md update code of coduct: discord moderation contact section 2020-03-15 18:30:44 -05:00
LICENSE First version of I2CDevice 2016-12-01 18:34:46 -08:00
README.rst Fixed discord invite link 2020-07-08 16:49:04 -04:00
requirements.txt Revert "Add Adafruit-Blinka to requirements.txt" 2019-02-25 14:35:29 -08:00
setup.py Ran black, updated to pylint 2.x 2020-03-16 16:45:42 -04:00

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

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

.. image :: https://img.shields.io/discord/327254708534116352.svg
    :target: https://adafru.it/discord
    :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>`_.