pupilometer/.venv/lib/python3.12/site-packages/bleak/backends/__init__.py

76 lines
1.8 KiB
Python

"""
Communicating with Bluetooth hardware requires calling OS-specific APIs. These
are abstracted as "backends" in Bleak.
The backend will be automatically selected based on the operating system Bleak
is running on. In some cases, this may also depend on a specific runtime, like
Pythonista on iOS.
"""
import enum
import os
import platform
import sys
from bleak.exc import BleakError
class BleakBackend(str, enum.Enum):
"""
Identifiers for available built-in Bleak backends.
.. versionadded:: 2.0
"""
P4ANDROID = "p4android"
"""
Python for Android backend.
"""
BLUEZ_DBUS = "bluez_dbus"
"""
BlueZ D-Bus backend for Linux.
"""
PYTHONISTA_CB = "pythonista_cb"
"""
Pythonista CoreBluetooth backend for iOS and macOS.
"""
CORE_BLUETOOTH = "core_bluetooth"
"""
CoreBluetooth backend for macOS.
"""
WIN_RT = "win_rt"
"""
Windows Runtime backend for Windows.
"""
def get_default_backend() -> BleakBackend:
"""
Returns the preferred backend for the current platform/environment.
.. versionadded:: 2.0
"""
if os.environ.get("P4A_BOOTSTRAP") is not None:
return BleakBackend.P4ANDROID
if platform.system() == "Linux":
return BleakBackend.BLUEZ_DBUS
if sys.platform == "ios" and "Pythonista3.app" in sys.executable:
# Must be resolved before checking for "Darwin" (macOS),
# as both the Pythonista app for iOS and macOS
# return "Darwin" from platform.system()
return BleakBackend.PYTHONISTA_CB
if platform.system() == "Darwin":
return BleakBackend.CORE_BLUETOOTH
if platform.system() == "Windows":
return BleakBackend.WIN_RT
raise BleakError(f"Unsupported platform: {platform.system()}")