dbus-fast 2.42.0__tar.gz → 2.44.0__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of dbus-fast might be problematic. Click here for more details.

Files changed (44) hide show
  1. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/PKG-INFO +1 -1
  2. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/pyproject.toml +3 -3
  3. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/setup.py +1 -1
  4. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/__version__.py +1 -1
  5. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/_private/unmarshaller.py +3 -4
  6. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/signature.pxd +2 -0
  7. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/signature.py +26 -5
  8. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/LICENSE +0 -0
  9. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/README.md +0 -0
  10. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/build_ext.py +0 -0
  11. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/__init__.py +0 -0
  12. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/_private/__init__.py +0 -0
  13. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/_private/_cython_compat.py +0 -0
  14. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/_private/address.pxd +0 -0
  15. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/_private/address.py +0 -0
  16. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/_private/constants.py +0 -0
  17. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/_private/marshaller.pxd +0 -0
  18. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/_private/marshaller.py +0 -0
  19. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/_private/unmarshaller.pxd +0 -0
  20. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/_private/util.py +0 -0
  21. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/aio/__init__.py +0 -0
  22. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/aio/message_bus.py +0 -0
  23. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/aio/message_reader.pxd +0 -0
  24. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/aio/message_reader.py +0 -0
  25. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/aio/proxy_object.py +0 -0
  26. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/auth.py +0 -0
  27. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/constants.py +0 -0
  28. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/errors.py +0 -0
  29. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/glib/__init__.py +0 -0
  30. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/glib/message_bus.py +0 -0
  31. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/glib/proxy_object.py +0 -0
  32. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/introspection.py +0 -0
  33. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/message.pxd +0 -0
  34. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/message.py +0 -0
  35. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/message_bus.pxd +0 -0
  36. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/message_bus.py +0 -0
  37. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/proxy_object.py +0 -0
  38. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/py.typed +0 -0
  39. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/send_reply.py +0 -0
  40. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/service.pxd +0 -0
  41. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/service.py +0 -0
  42. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/unpack.pxd +0 -0
  43. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/unpack.py +0 -0
  44. {dbus_fast-2.42.0 → dbus_fast-2.44.0}/src/dbus_fast/validators.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: dbus-fast
3
- Version: 2.42.0
3
+ Version: 2.44.0
4
4
  Summary: A faster version of dbus-next
5
5
  License: MIT
6
6
  Author: Bluetooth Devices Authors
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "dbus-fast"
3
- version = "2.42.0"
3
+ version = "2.44.0"
4
4
  description = "A faster version of dbus-next"
5
5
  authors = ["Bluetooth Devices Authors <bluetooth@koston.org>"]
6
6
  license = "MIT"
@@ -47,11 +47,11 @@ sphinxcontrib-fulltoc = "^1.2.0"
47
47
  [tool.poetry.group.dev.dependencies]
48
48
  pytest = ">=7,<9"
49
49
  pytest-cov = ">=3,<7"
50
- pytest-asyncio = ">=0.19,<0.26"
50
+ pytest-asyncio = ">=0.19,<0.27"
51
51
  pycairo = "^1.21.0"
52
52
  PyGObject = {version = ">=3.50,<3.51", python = "<4"}
53
53
  Cython = ">=3,<3.1.0"
54
- setuptools = ">=65.4.1,<77.0.0"
54
+ setuptools = ">=65.4.1,<79.0.0"
55
55
  pytest-timeout = "^2.1.0"
56
56
  pytest-codspeed = "^3.1.1"
57
57
  covdefaults = "^2.3.0"
@@ -12,7 +12,7 @@ package_data = \
12
12
 
13
13
  setup_kwargs = {
14
14
  'name': 'dbus-fast',
15
- 'version': '2.42.0',
15
+ 'version': '2.44.0',
16
16
  'description': 'A faster version of dbus-next',
17
17
  'long_description': '# dbus-fast\n\n<p align="center">\n <a href="https://github.com/bluetooth-devices/dbus-fast/actions?query=workflow%3ACI">\n <img src="https://img.shields.io/github/workflow/status/bluetooth-devices/dbus-fast/CI/main?label=CI&logo=github&style=flat-square" alt="CI Status" >\n </a>\n <a href="https://dbus-fast.readthedocs.io">\n <img src="https://img.shields.io/readthedocs/dbus-fast.svg?logo=read-the-docs&logoColor=fff&style=flat-square" alt="Documentation Status">\n </a>\n <a href="https://codecov.io/gh/bluetooth-devices/dbus-fast">\n <img src="https://img.shields.io/codecov/c/github/bluetooth-devices/dbus-fast.svg?logo=codecov&logoColor=fff&style=flat-square" alt="Test coverage percentage">\n </a>\n</p>\n<p align="center">\n <a href="https://python-poetry.org/">\n <img src="https://img.shields.io/badge/packaging-poetry-299bd7?style=flat-square&logo=" alt="Poetry">\n </a>\n <a href="https://github.com/astral-sh/ruff">\n <img src="https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json" alt="Ruff">\n </a>\n <a href="https://github.com/pre-commit/pre-commit">\n <img src="https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white&style=flat-square" alt="pre-commit">\n </a>\n <a href="https://codspeed.io/Bluetooth-Devices/dbus-fast"><img src="https://img.shields.io/endpoint?url=https://codspeed.io/badge.json" alt="CodSpeed Badge"/></a>\n</p>\n<p align="center">\n <a href="https://pypi.org/project/dbus-fast/">\n <img src="https://img.shields.io/pypi/v/dbus-fast.svg?logo=python&logoColor=fff&style=flat-square" alt="PyPI Version">\n </a>\n <img src="https://img.shields.io/pypi/pyversions/dbus-fast.svg?style=flat-square&logo=python&amp;logoColor=fff" alt="Supported Python versions">\n <img src="https://img.shields.io/pypi/l/dbus-fast.svg?style=flat-square" alt="License">\n</p>\n\nA faster version of dbus-next originally from the [great DBus next library](https://github.com/altdesktop/python-dbus-next) ❤️\n\n## Installation\n\nInstall this via pip (or your favourite package manager):\n\n`pip install dbus-fast`\n\n[Documentation](https://dbus-fast.readthedocs.io/en/latest/)\n\ndbus-fast is a Python library for DBus that aims to be a performant fully featured high level library primarily geared towards integration of applications into Linux desktop and mobile environments.\n\nDesktop application developers can use this library for integrating their applications into desktop environments by implementing common DBus standard interfaces or creating custom plugin interfaces.\n\nDesktop users can use this library to create their own scripts and utilities to interact with those interfaces for customization of their desktop environment.\n\ndbus-fast plans to improve over other DBus libraries for Python in the following ways:\n\n- Zero dependencies and pure Python 3\n- An optional cython extension is available to speed up (un)marshalling\n- Focus on performance\n- Support for multiple IO backends including asyncio and the GLib main loop.\n- Nonblocking IO suitable for GUI development.\n- Target the latest language features of Python for beautiful services and clients.\n- Complete implementation of the DBus type system without ever guessing types.\n- Integration tests for all features of the library.\n- Completely documented public API.\n\n## Installing\n\nThis library is available on PyPi as [dbus-fast](https://pypi.org/project/dbus-fast/).\n\n```\npip3 install dbus-fast\n```\n\n## The Client Interface\n\nTo use a service on the bus, the library constructs a proxy object you can use to call methods, get and set properties, and listen to signals.\n\nFor more information, see the [overview for the high-level client](https://dbus-fast.readthedocs.io/en/latest/high-level-client/index.html).\n\nThis example connects to a media player and controls it with the [MPRIS](https://specifications.freedesktop.org/mpris-spec/latest/) DBus interface.\n\n```python\nfrom dbus_fast.aio import MessageBus\n\nimport asyncio\n\n\nasync def main():\n bus = await MessageBus().connect()\n # the introspection xml would normally be included in your project, but\n # this is convenient for development\n introspection = await bus.introspect(\'org.mpris.MediaPlayer2.vlc\', \'/org/mpris/MediaPlayer2\')\n\n obj = bus.get_proxy_object(\'org.mpris.MediaPlayer2.vlc\', \'/org/mpris/MediaPlayer2\', introspection)\n player = obj.get_interface(\'org.mpris.MediaPlayer2.Player\')\n properties = obj.get_interface(\'org.freedesktop.DBus.Properties\')\n\n # call methods on the interface (this causes the media player to play)\n await player.call_play()\n\n volume = await player.get_volume()\n print(f\'current volume: {volume}, setting to 0.5\')\n\n await player.set_volume(0.5)\n\n # listen to signals\n def on_properties_changed(interface_name, changed_properties, invalidated_properties):\n for changed, variant in changed_properties.items():\n print(f\'property changed: {changed} - {variant.value}\')\n\n properties.on_properties_changed(on_properties_changed)\n\n await asyncio.Event().wait()\n\nasyncio.run(main())\n```\n\n## The Service Interface\n\nTo define a service on the bus, use the `ServiceInterface` class and decorate class methods to specify DBus methods, properties, and signals with their type signatures.\n\nFor more information, see the [overview for the high-level service](https://python-dbus-fast.readthedocs.io/en/latest/high-level-service/index.html).\n\n```python\nfrom dbus_fast.service import ServiceInterface, method, dbus_property, signal, Variant\nfrom dbus_fast.aio MessageBus\n\nimport asyncio\n\nclass ExampleInterface(ServiceInterface):\n def __init__(self, name):\n super().__init__(name)\n self._string_prop = \'kevin\'\n\n @method()\n def Echo(self, what: \'s\') -> \'s\':\n return what\n\n @method()\n def GetVariantDict() -> \'a{sv}\':\n return {\n \'foo\': Variant(\'s\', \'bar\'),\n \'bat\': Variant(\'x\', -55),\n \'a_list\': Variant(\'as\', [\'hello\', \'world\'])\n }\n\n @dbus_property()\n def string_prop(self) -> \'s\':\n return self._string_prop\n\n @string_prop.setter\n def string_prop_setter(self, val: \'s\'):\n self._string_prop = val\n\n @signal()\n def signal_simple(self) -> \'s\':\n return \'hello\'\n\nasync def main():\n bus = await MessageBus().connect()\n interface = ExampleInterface(\'test.interface\')\n bus.export(\'/test/path\', interface)\n # now that we are ready to handle requests, we can request name from D-Bus\n await bus.request_name(\'test.name\')\n # wait indefinitely\n await asyncio.Event().wait()\n\nasyncio.run(main())\n```\n\n## The Low-Level Interface\n\nThe low-level interface works with DBus messages directly.\n\nFor more information, see the [overview for the low-level interface](https://python-dbus-fast.readthedocs.io/en/latest/low-level-interface/index.html).\n\n```python\nfrom dbus_fast.message import Message, MessageType\nfrom dbus_fast.aio import MessageBus\n\nimport asyncio\nimport json\n\n\nasync def main():\n bus = await MessageBus().connect()\n\n reply = await bus.call(\n Message(destination=\'org.freedesktop.DBus\',\n path=\'/org/freedesktop/DBus\',\n interface=\'org.freedesktop.DBus\',\n member=\'ListNames\'))\n\n if reply.message_type == MessageType.ERROR:\n raise Exception(reply.body[0])\n\n print(json.dumps(reply.body[0], indent=2))\n\n\nasyncio.run(main())\n```\n\n## Projects that use python-dbus-fast\n\n- [Bluetooth Adapters](https://github.com/bluetooth-devices/bluetooth-adapters)\n\n## Contributing\n\nContributions are welcome. Development happens on [Github](https://github.com/Bluetooth-Devices/dbus-fast).\n\nBefore you commit, run `pre-commit run --all-files` to run the linter, code formatter, and the test suite.\n\n## Copyright\n\nYou can use this code under an MIT license (see LICENSE).\n\n- © 2019, Tony Crisci\n- © 2022, Bluetooth Devices authors\n\n## Contributors ✨\n\nThanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):\n\n<!-- prettier-ignore-start -->\n<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section -->\n<!-- markdownlint-disable -->\n<!-- markdownlint-enable -->\n<!-- ALL-CONTRIBUTORS-LIST:END -->\n<!-- prettier-ignore-end -->\n\nThis project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!\n\n## Credits\n\nThis package was created with\n[Cookiecutter](https://github.com/audreyr/cookiecutter) and the\n[browniebroke/cookiecutter-pypackage](https://github.com/browniebroke/cookiecutter-pypackage)\nproject template.\n',
18
18
  'author': 'Bluetooth Devices Authors',
@@ -3,7 +3,7 @@ __description__ = (
3
3
  "A performant zero-dependency DBus library for Python with asyncio support"
4
4
  )
5
5
  __url__ = "https://github.com/bluetooth-devices/dbus-fast"
6
- __version__ = "2.42.0"
6
+ __version__ = "2.44.0"
7
7
  __author__ = "Bluetooth Devices authors, Tony Crisci"
8
8
  __author_email__ = "bluetooth@koston.org"
9
9
  __license__ = "MIT"
@@ -607,7 +607,7 @@ class Unmarshaller:
607
607
  )
608
608
  else:
609
609
  array_length = self._uint32_unpack(self._buf, self._pos - UINT32_SIZE)[0]
610
- child_type: SignatureType = type_.children[0]
610
+ child_type = type_._child_0
611
611
  token_as_int = child_type.token_as_int
612
612
 
613
613
  if token_as_int in {
@@ -631,9 +631,8 @@ class Unmarshaller:
631
631
  result_dict: dict[Any, Any] = {}
632
632
  key: str | int
633
633
  beginning_pos = self._pos
634
- children = child_type.children
635
- child_0 = children[0]
636
- child_1 = children[1]
634
+ child_0 = child_type._child_0
635
+ child_1 = child_type._child_1
637
636
  child_0_token_as_int = child_0.token_as_int
638
637
  child_1_token_as_int = child_1.token_as_int
639
638
  # Strings with variant values are the most common case
@@ -9,6 +9,8 @@ cdef class SignatureType:
9
9
  cdef public unsigned int token_as_int
10
10
  cdef public list children
11
11
  cdef str _signature
12
+ cdef public SignatureType _child_0
13
+ cdef public SignatureType _child_1
12
14
 
13
15
 
14
16
  cdef class SignatureTree:
@@ -21,13 +21,22 @@ class SignatureType:
21
21
  """
22
22
 
23
23
  _tokens = "ybnqiuxtdsogavh({"
24
- __slots__ = ("_signature", "children", "token", "token_as_int")
24
+ __slots__ = (
25
+ "_child_0",
26
+ "_child_1",
27
+ "_signature",
28
+ "children",
29
+ "token",
30
+ "token_as_int",
31
+ )
25
32
 
26
33
  def __init__(self, token: str) -> None:
27
34
  """Init a new SignatureType."""
28
35
  self.token: str = token
29
36
  self.token_as_int = ord(token)
30
37
  self.children: list[SignatureType] = []
38
+ self._child_0: Optional[SignatureType] = None
39
+ self._child_1: Optional[SignatureType] = None
31
40
  self._signature: Optional[str] = None
32
41
 
33
42
  def __eq__(self, other: object) -> bool:
@@ -60,6 +69,18 @@ class SignatureType:
60
69
  self._signature = self._collapse()
61
70
  return self._signature
62
71
 
72
+ def _add_child(self, child: "SignatureType") -> None:
73
+ """Add a child type to this type.
74
+
75
+ :param child: The child type to add.
76
+ :type child: :class:`SignatureType`
77
+ """
78
+ if self._child_0 is None:
79
+ self._child_0 = child
80
+ elif self._child_1 is None:
81
+ self._child_1 = child
82
+ self.children.append(child)
83
+
63
84
  @staticmethod
64
85
  def _parse_next(signature: str) -> tuple["SignatureType", str]:
65
86
  if not signature:
@@ -76,7 +97,7 @@ class SignatureType:
76
97
  (child, signature) = SignatureType._parse_next(signature[1:])
77
98
  if not child:
78
99
  raise InvalidSignatureError("missing type for array")
79
- self.children.append(child)
100
+ self._add_child(child)
80
101
  return (self, signature)
81
102
  if token == "(":
82
103
  self = SignatureType("(")
@@ -85,7 +106,7 @@ class SignatureType:
85
106
  (child, signature) = SignatureType._parse_next(signature)
86
107
  if not signature:
87
108
  raise InvalidSignatureError('missing closing ")" for struct')
88
- self.children.append(child)
109
+ self._add_child(child)
89
110
  if signature[0] == ")":
90
111
  return (self, signature[1:])
91
112
  elif token == "{":
@@ -94,13 +115,13 @@ class SignatureType:
94
115
  (key_child, signature) = SignatureType._parse_next(signature)
95
116
  if not key_child or len(key_child.children):
96
117
  raise InvalidSignatureError("expected a simple type for dict entry key")
97
- self.children.append(key_child)
118
+ self._add_child(key_child)
98
119
  (value_child, signature) = SignatureType._parse_next(signature)
99
120
  if not value_child:
100
121
  raise InvalidSignatureError("expected a value for dict entry")
101
122
  if not signature or signature[0] != "}":
102
123
  raise InvalidSignatureError('missing closing "}" for dict entry')
103
- self.children.append(value_child)
124
+ self._add_child(value_child)
104
125
  return (self, signature[1:])
105
126
 
106
127
  # basic type
File without changes
File without changes
File without changes