Skip to content

Commit bdc4fd7

Browse files
committed
First version of I2CDevice
0 parents  commit bdc4fd7

File tree

5 files changed

+192
-0
lines changed

5 files changed

+192
-0
lines changed

.gitignore

+1
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
*.mpy

CODE_OF_CONDUCT.md

+74
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,74 @@
1+
# Contributor Covenant Code of Conduct
2+
3+
## Our Pledge
4+
5+
In the interest of fostering an open and welcoming environment, we as
6+
contributors and maintainers pledge to making participation in our project and
7+
our community a harassment-free experience for everyone, regardless of age, body
8+
size, disability, ethnicity, gender identity and expression, level of experience,
9+
nationality, personal appearance, race, religion, or sexual identity and
10+
orientation.
11+
12+
## Our Standards
13+
14+
Examples of behavior that contributes to creating a positive environment
15+
include:
16+
17+
* Using welcoming and inclusive language
18+
* Being respectful of differing viewpoints and experiences
19+
* Gracefully accepting constructive criticism
20+
* Focusing on what is best for the community
21+
* Showing empathy towards other community members
22+
23+
Examples of unacceptable behavior by participants include:
24+
25+
* The use of sexualized language or imagery and unwelcome sexual attention or
26+
advances
27+
* Trolling, insulting/derogatory comments, and personal or political attacks
28+
* Public or private harassment
29+
* Publishing others' private information, such as a physical or electronic
30+
address, without explicit permission
31+
* Other conduct which could reasonably be considered inappropriate in a
32+
professional setting
33+
34+
## Our Responsibilities
35+
36+
Project maintainers are responsible for clarifying the standards of acceptable
37+
behavior and are expected to take appropriate and fair corrective action in
38+
response to any instances of unacceptable behavior.
39+
40+
Project maintainers have the right and responsibility to remove, edit, or
41+
reject comments, commits, code, wiki edits, issues, and other contributions
42+
that are not aligned to this Code of Conduct, or to ban temporarily or
43+
permanently any contributor for other behaviors that they deem inappropriate,
44+
threatening, offensive, or harmful.
45+
46+
## Scope
47+
48+
This Code of Conduct applies both within project spaces and in public spaces
49+
when an individual is representing the project or its community. Examples of
50+
representing a project or community include using an official project e-mail
51+
address, posting via an official social media account, or acting as an appointed
52+
representative at an online or offline event. Representation of a project may be
53+
further defined and clarified by project maintainers.
54+
55+
## Enforcement
56+
57+
Instances of abusive, harassing, or otherwise unacceptable behavior may be
58+
reported by contacting the project team at [email protected]. All
59+
complaints will be reviewed and investigated and will result in a response that
60+
is deemed necessary and appropriate to the circumstances. The project team is
61+
obligated to maintain confidentiality with regard to the reporter of an incident.
62+
Further details of specific enforcement policies may be posted separately.
63+
64+
Project maintainers who do not follow or enforce the Code of Conduct in good
65+
faith may face temporary or permanent repercussions as determined by other
66+
members of the project's leadership.
67+
68+
## Attribution
69+
70+
This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4,
71+
available at [http://contributor-covenant.org/version/1/4][version]
72+
73+
[homepage]: http://contributor-covenant.org
74+
[version]: http://contributor-covenant.org/version/1/4/

LICENSE

+21
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
MIT License
2+
3+
Copyright (c) 2016 Adafruit Industries
4+
5+
Permission is hereby granted, free of charge, to any person obtaining a copy
6+
of this software and associated documentation files (the "Software"), to deal
7+
in the Software without restriction, including without limitation the rights
8+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9+
copies of the Software, and to permit persons to whom the Software is
10+
furnished to do so, subject to the following conditions:
11+
12+
The above copyright notice and this permission notice shall be included in all
13+
copies or substantial portions of the Software.
14+
15+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21+
SOFTWARE.

README.md

+6
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,6 @@
1+
# Adafruit MicroPython BusDevice
2+
3+
The `I2CDevice` and `SPIDevice` helper classes make managing transaction state
4+
on a bus easy. For example, they manage locking the bus to prevent other
5+
concurrent access. For SPI devices, it manages the chip select and protocol
6+
changes such as mode. For I2C, it manages the device address.

adafruit_bus_device/i2c_device.py

+90
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,90 @@
1+
# The MIT License (MIT)
2+
#
3+
# Copyright (c) 2016 Scott Shawcroft for Adafruit Industries
4+
#
5+
# Permission is hereby granted, free of charge, to any person obtaining a copy
6+
# of this software and associated documentation files (the "Software"), to deal
7+
# in the Software without restriction, including without limitation the rights
8+
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9+
# copies of the Software, and to permit persons to whom the Software is
10+
# furnished to do so, subject to the following conditions:
11+
#
12+
# The above copyright notice and this permission notice shall be included in
13+
# all copies or substantial portions of the Software.
14+
#
15+
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16+
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17+
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18+
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19+
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20+
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21+
# THE SOFTWARE.
22+
23+
class I2CDevice:
24+
"""
25+
Represents a single I2C device and manages locking the bus and the device
26+
address.
27+
28+
:param I2C i2c: The I2C bus the device is on
29+
:param int device_address: The 7 bit device address
30+
31+
Example::
32+
33+
import nativeio
34+
from board import *
35+
from adafruit_bus_device.i2c_device import I2CDevice
36+
37+
with nativeio.I2C(SCL, SDA) as i2c:
38+
device = I2CDevice(i2c, 0x70)
39+
bytes_read = bytearray(4)
40+
with device:
41+
device.readfrom_into(bytes_read)
42+
# A second transaction
43+
with device:
44+
device.writeto(bytes_read)
45+
"""
46+
def __init__(self, i2c, device_address):
47+
self.i2c = i2c
48+
self.device_address = device_address
49+
50+
def readfrom_into(self, buf, **kwargs):
51+
"""
52+
Read into ``buf`` from the device. The number of bytes read will be the
53+
length of ``buf``.
54+
55+
If ``start`` or ``end`` is provided, then the buffer will be sliced
56+
as if ``buf[start:end]``. This will not cause an allocation like
57+
``buf[start:end]`` will so it saves memory.
58+
59+
:param int address: 7-bit device address
60+
:param bytearray buffer: buffer to write into
61+
:param int start: Index to start writing at
62+
:param int end: Index to write up to but not include
63+
"""
64+
self.i2c.readfrom_into(self.device_address, buf, **kwargs)
65+
66+
def writeto(self, buf, **kwargs):
67+
"""
68+
Write the bytes from ``buffer`` to the device. Transmits a stop bit if
69+
``stop`` is set.
70+
71+
If ``start`` or ``end`` is provided, then the buffer will be sliced
72+
as if ``buffer[start:end]``. This will not cause an allocation like
73+
``buffer[start:end]`` will so it saves memory.
74+
75+
:param bytearray buffer: buffer containing the bytes to write
76+
:param int start: Index to start writing from
77+
:param int end: Index to read up to but not include
78+
:param bool stop: If true, output an I2C stop condition after the
79+
buffer is written
80+
"""
81+
self.i2c.writeto(self.device_address, buf, **kwargs)
82+
83+
def __enter__(self):
84+
while not self.i2c.try_lock():
85+
pass
86+
return self
87+
88+
def __exit__(self, *exc):
89+
self.i2c.unlock()
90+
return False

0 commit comments

Comments
 (0)