54 lines
1.7 KiB
Python
54 lines
1.7 KiB
Python
#!/usr/bin/env python
|
||
# -*- coding: utf-8 -*-
|
||
|
||
"""
|
||
LoRa通信模块的抽象接口定义 (契约)
|
||
|
||
这个文件定义了一个LoRa处理器应该具备哪些功能,
|
||
但不包含任何具体的实现代码。任何具体的LoRa处理器,
|
||
无论是UART的还是SPI的,都必须实现这里定义的所有方法。
|
||
"""
|
||
|
||
# abc (Abstract Base Class) 是Python定义接口的标准方式
|
||
from abc import ABC, abstractmethod
|
||
|
||
class ILoraManager(ABC):
|
||
"""
|
||
LoRa处理器接口。
|
||
它规定了所有LoRa处理器实现类必须提供的功能。
|
||
"""
|
||
|
||
@abstractmethod
|
||
def receive_packet(self):
|
||
"""
|
||
【契约】非阻塞地检查并接收一个数据包。
|
||
|
||
一个符合本接口的实现必须:
|
||
- 检查是否有新的数据包。
|
||
- 如果有,读取、解析并返回负载数据。
|
||
- 如果没有,必须立刻返回None,不得阻塞。
|
||
|
||
Returns:
|
||
bytes: 如果成功接收到一个数据包,返回该数据包的字节。
|
||
None: 如果当前没有可读的数据包。
|
||
"""
|
||
pass
|
||
|
||
@abstractmethod
|
||
def send_packet(self, data_bytes: bytes) -> bool:
|
||
"""
|
||
【契约】发送一个数据包。
|
||
|
||
一个符合本接口的实现必须:
|
||
- 接收一个bytes类型的参数。
|
||
- 将这些数据通过LoRa模块发送出去。
|
||
- 返回一个布尔值表示发送指令是否成功提交。
|
||
|
||
Args:
|
||
data_bytes (bytes): 需要发送的字节数据。
|
||
|
||
Returns:
|
||
bool: True表示发送指令已成功提交,False表示因任何原因失败。
|
||
"""
|
||
pass
|