[![License](https://img.shields.io/badge/License-EPL%202.0-blue)](https://choosealicense.com/licenses/epl-2.0/)
[![License](https://img.shields.io/badge/License-EDL%201.0-blue)](https://choosealicense.com/licenses/edl-1.0/)
[![Website](https://img.shields.io/badge/web-cyclonedds.io-blue)](https://cyclonedds.io)
[![PyPI - Python Version](https://img.shields.io/pypi/pyversions/cyclonedds)](https://pypi.org/project/cyclonedds/)
[![PyPI](https://img.shields.io/pypi/v/cyclonedds)](https://pypi.org/project/cyclonedds/)
[![Community](https://img.shields.io/badge/discord-join%20community-5865f2)](https://discord.gg/BkRYQPpZVV)
# Python binding for Eclipse Cyclone DDS
A Python binding for [Eclipse Cyclone DDS][1].
# Getting Started
Eclipse CycloneDDS Python requires Python version 3.7 or higher. You can install [with included Cyclone DDS binaries](#installing-with-pre-built-binaries) or leveraging an existing Cyclone DDS installation by [installing from source](#installing-from-source) via PyPi.
Documentation can be found on the [cyclonedds.io](https://cyclonedds.io/docs/) website: [Python API docs][3]
<!----><a name="installing-with-pre-built-binaries"></a>
## Installing with pre-built Cyclone DDS binaries
This is the most straightforward method to install Cyclone DDS Python, but there are a couple of caveats. The pre-built package:
* has no support for DDS Security,
* has no support for shared memory via Iceoryx,
* comes with generic Cyclone DDS binaries that are not optimized per-platform.
If these are of concern, proceed with an [installation from source](#installing-from-source). If not, running this installation is as simple as:
```bash
$ pip install cyclonedds
```
You can also use the nightly build stream instead, which is built from the `master` branches of `cyclonedds` and `cyclonedds-python`. This will always get you the latest and greatest, but less stable version that might contain API breaks.
```bash
$ pip install cyclonedds-nightly
```
<!----><a name="installing-from-source"></a>
## Installing from source
When installing from source you can make use of the full list of features offered by [Cyclone DDS][1]. First install [Cyclone DDS][1] as normal. Make sure that [Cyclone DDS][1] is built with the ENABLE_TYPELIB option set to `ON` (the default for this option). Then continue by setting the `CYCLONEDDS_HOME` environment variable to the installation location of [Cyclone DDS][1], which is the same as what was used for `CMAKE_INSTALL_PREFIX`. You will have to have this variable active any time you run Python code that depends on `cyclonedds` so adding it to `.bashrc` on Linux, `~/bash_profile` on MacOS or the System Variables in Windows can be helpful. This also allows you to switch, move or update [Cyclone DDS][1] without recompiling the Python package.
You'll need the Python development headers to complete the install. If using `apt`, try `sudo apt install python3-dev`. For other distributions, see [this comment](https://stackoverflow.com/a/21530768).
<!----><a name="installing-from-source-via-pypi"></a>
### via PyPi
You can install the source from the latest release from [Pypi](https://pypi.org/project/cyclonedds/), or use a tag to get a specific version. A full example (for linux) is shown below
```bash
$ git clone https://github.com/eclipse-cyclonedds/cyclonedds
$ cd cyclonedds && mkdir build install && cd build
$ cmake .. -DCMAKE_INSTALL_PREFIX=../install
$ cmake --build . --config RelWithDebInfo --target install
$ cd ..
$ export CYCLONEDDS_HOME="$(pwd)/install"
$ pip3 install cyclonedds --no-binary cyclonedds
```
<!----><a name="installing-from-source-via-git"></a>
### via git
A full example installation of the quickest way to get started via git is shown below:
```bash
$ git clone https://github.com/eclipse-cyclonedds/cyclonedds
$ cd cyclonedds && mkdir build install && cd build
$ cmake .. -DCMAKE_INSTALL_PREFIX=../install
$ cmake --build . --config RelWithDebInfo --target install
$ cd ..
$ export CYCLONEDDS_HOME="$(pwd)/install"
$ pip3 install git+https://github.com/eclipse-cyclonedds/cyclonedds-python
```
# Command line tooling
The Python package contains a suite of command line tools, all nested under the main entrypoint `cyclonedds`. The main help screen shows the commands available:
![`cyclonedds --help`](docs/manual/static/images/cyclonedds-help.svg)
## `cyclonedds ls`
![`cyclonedds ls --help`](docs/manual/static/images/cyclonedds-ls-help.svg)
The `ls` subcommand shows you the entities in your DDS system and their QoS settings. For example, here is the output when running the `Vehicle` example from this repo in the background:
![`cyclonedds ls --suppress-progress-bar --force-color-mode`](docs/manual/static/images/cyclonedds-ls-demo.svg)
## `cyclonedds ps`
![`cyclonedds ps --help`](docs/manual/static/images/cyclonedds-ps-help.svg)
The `ps` subcommand shows you the applications in your DDS system. Note that this depends on so called 'Participant Properties', tactfully named QoS properties in DDS participants. These were merged into CycloneDDS for version 0.10.0. Here is an example of the output when running the `Vehicle` example from this repo in the background on a single host:
![`cyclonedds ps --suppress-progress-bar --force-color-mode`](docs/manual/static/images/cyclonedds-ps-demo.svg)
## `cyclonedds typeof`
![`cyclonedds typeof --help`](docs/manual/static/images/cyclonedds-typeof-help.svg)
The `typeof` subcommand shows you the type(s) of a topic in your system. With XTypes it can happen that more than one type for each topic exists and that they are still compatible. The types are represented in IDL. Here is an example of the output when running the `Vehicle` example:
![`cyclonedds typeof Vehicle --suppress-progress-bar --force-color-mode`](docs/manual/static/images/cyclonedds-typeof-demo.svg)
## `cyclonedds subscribe`
![`cyclonedds subscribe --help`](docs/manual/static/images/cyclonedds-subscribe-help.svg)
The `subscribe` subcommand dynamically subscribes to a topic and shows you the data as it arrives. The type is discovered in a similar manner as `typeof`. Here is an example of the output when running the `Vehicle` example:
![`timeout -s INT 10s cyclonedds subscribe Vehicle --suppress-progress-bar --force-color-mode`](docs/manual/static/images/cyclonedds-subscribe-demo.svg)
## `cyclonedds publish`
![`cyclonedds publish --help`](docs/manual/static/images/cyclonedds-publish-help.svg)
The `publish` subcommand dynamically builds a REPL with datatypes and a writer for a topic and shows you the data as it arrives. The type is discovered in a similar manner as `typeof`.
## `cyclonedds performance`
![`cyclonedds performance --help`](docs/manual/static/images/cyclonedds-performance-help.svg)
The `performance` subcommand is a nicer frontend to `ddsperf` with four modes: `publish`, `subscribe`, `ping` and `pong`. The below performance run example is the `cyclonedds performance subscribe` mode rendered with `cyclonedds performance publish` running in the background.
![`cyclonedds performance --duration 21s --render-output-once-on-exit --force-color-mode subscribe --triggering-mode waitset`](docs/manual/static/images/cyclonedds-performance-subscribe-demo.svg)
# Contributing
We very much welcome all contributions to the project, whether that is questions, examples, bug
fixes, enhancements or improvements to the documentation, or anything else really.
When considering contributing code, it might be good to know that build configurations for Azure pipelines are present in the repository and that there is a test suite using pytest, along with flake8 code linting, and documentation built with sphinx. Be sure to install with the [Extra dependencies](#extra-dependencies) if you're going to run tests, lints or build the docs.
You can run the test suite and linting using the [local-ci.py](local-ci.py) script in this repo.
```bash
$ python local-ci.py
```
Or lint a single file/directory (as the whole repo can be a little noisey) using:
```bash
$ python -m flake8 path/to/some_file.py
```
You can build and serve the documentation (at http://localhost:8000/) using:
```bash
cd docs
python -m sphinx source/ _build/
# Serve the HTML files to view at localhost:8000
python -m http.server -d _build
```
# Extra dependencies
The `cyclonedds` package defines two sets of optional dependencies, `dev` and `docs`, used for developing `cyclonedds` and building the documentation, respectively. If you want to install with development tools add the component to your installation, for example:
```bash
$ pip3 install --user "cyclonedds[dev] @ git+https://github.com/eclipse-cyclonedds/cyclonedds-python"
```
Or when installing from a local git clone, which is recommended when developing or building the docs:
```bash
$ cd /path/to/git/clone
# for development:
$ pip3 install --user ".[dev]"
# for documentation generation
$ pip3 install --user ".[docs]"
# or for both
$ pip3 install --user ".[dev,docs]"
```
For more information see [the packaging guide information on optional dependencies][2].
[1]: https://github.com/eclipse-cyclonedds/cyclonedds/#eclipse-cyclone-dds
[2]: https://setuptools.pypa.io/en/latest/userguide/dependency_management.html#optional-dependencies
[3]: https://cyclonedds.io/docs/cyclonedds-python/latest/
# PyOxidizer build
You can build a self-contained binary of the `cyclonedds` CLI tool using PyOxidizer. It should be as simple as:
```bash
$ cd /path/to/git/clone
$ pip3 install --user pyoxidizer
$ pyoxidizer build
```
Raw data
{
"_id": null,
"home_page": "https://cyclonedds.io",
"name": "cyclonedds-nightly",
"maintainer": "Thijs Miedema",
"docs_url": null,
"requires_python": ">=3.7",
"maintainer_email": "thijs.miedema@zettascale.tech",
"keywords": "eclipse, cyclone, dds, pub, sub, pubsub, iot, cyclonedds, cdr, omg, idl, middleware, ros",
"author": "Eclipse Cyclone DDS Committers",
"author_email": null,
"download_url": "https://files.pythonhosted.org/packages/56/93/58d4ea9d010cf44c995b02c0c38de948a159374f730d43eb47dfa36e2587/cyclonedds-nightly-2024.10.12.tar.gz",
"platform": "Windows",
"description": "[![License](https://img.shields.io/badge/License-EPL%202.0-blue)](https://choosealicense.com/licenses/epl-2.0/)\n[![License](https://img.shields.io/badge/License-EDL%201.0-blue)](https://choosealicense.com/licenses/edl-1.0/)\n[![Website](https://img.shields.io/badge/web-cyclonedds.io-blue)](https://cyclonedds.io)\n[![PyPI - Python Version](https://img.shields.io/pypi/pyversions/cyclonedds)](https://pypi.org/project/cyclonedds/)\n[![PyPI](https://img.shields.io/pypi/v/cyclonedds)](https://pypi.org/project/cyclonedds/)\n[![Community](https://img.shields.io/badge/discord-join%20community-5865f2)](https://discord.gg/BkRYQPpZVV)\n\n# Python binding for Eclipse Cyclone DDS\n\nA Python binding for [Eclipse Cyclone DDS][1].\n\n# Getting Started\n\nEclipse CycloneDDS Python requires Python version 3.7 or higher. You can install [with included Cyclone DDS binaries](#installing-with-pre-built-binaries) or leveraging an existing Cyclone DDS installation by [installing from source](#installing-from-source) via PyPi.\n\nDocumentation can be found on the [cyclonedds.io](https://cyclonedds.io/docs/) website: [Python API docs][3]\n\n<!----><a name=\"installing-with-pre-built-binaries\"></a>\n## Installing with pre-built Cyclone DDS binaries\n\nThis is the most straightforward method to install Cyclone DDS Python, but there are a couple of caveats. The pre-built package:\n * has no support for DDS Security,\n * has no support for shared memory via Iceoryx,\n * comes with generic Cyclone DDS binaries that are not optimized per-platform.\n\nIf these are of concern, proceed with an [installation from source](#installing-from-source). If not, running this installation is as simple as:\n\n```bash\n $ pip install cyclonedds\n```\n\nYou can also use the nightly build stream instead, which is built from the `master` branches of `cyclonedds` and `cyclonedds-python`. This will always get you the latest and greatest, but less stable version that might contain API breaks.\n\n```bash\n $ pip install cyclonedds-nightly\n```\n\n<!----><a name=\"installing-from-source\"></a>\n## Installing from source\n\nWhen installing from source you can make use of the full list of features offered by [Cyclone DDS][1]. First install [Cyclone DDS][1] as normal. Make sure that [Cyclone DDS][1] is built with the ENABLE_TYPELIB option set to `ON` (the default for this option). Then continue by setting the `CYCLONEDDS_HOME` environment variable to the installation location of [Cyclone DDS][1], which is the same as what was used for `CMAKE_INSTALL_PREFIX`. You will have to have this variable active any time you run Python code that depends on `cyclonedds` so adding it to `.bashrc` on Linux, `~/bash_profile` on MacOS or the System Variables in Windows can be helpful. This also allows you to switch, move or update [Cyclone DDS][1] without recompiling the Python package.\n\nYou'll need the Python development headers to complete the install. If using `apt`, try `sudo apt install python3-dev`. For other distributions, see [this comment](https://stackoverflow.com/a/21530768).\n\n<!----><a name=\"installing-from-source-via-pypi\"></a>\n### via PyPi\n\nYou can install the source from the latest release from [Pypi](https://pypi.org/project/cyclonedds/), or use a tag to get a specific version. A full example (for linux) is shown below\n\n```bash\n$ git clone https://github.com/eclipse-cyclonedds/cyclonedds\n$ cd cyclonedds && mkdir build install && cd build\n$ cmake .. -DCMAKE_INSTALL_PREFIX=../install\n$ cmake --build . --config RelWithDebInfo --target install\n$ cd ..\n$ export CYCLONEDDS_HOME=\"$(pwd)/install\"\n$ pip3 install cyclonedds --no-binary cyclonedds\n```\n\n<!----><a name=\"installing-from-source-via-git\"></a>\n### via git\n\nA full example installation of the quickest way to get started via git is shown below:\n\n```bash\n$ git clone https://github.com/eclipse-cyclonedds/cyclonedds\n$ cd cyclonedds && mkdir build install && cd build\n$ cmake .. -DCMAKE_INSTALL_PREFIX=../install\n$ cmake --build . --config RelWithDebInfo --target install\n$ cd ..\n$ export CYCLONEDDS_HOME=\"$(pwd)/install\"\n$ pip3 install git+https://github.com/eclipse-cyclonedds/cyclonedds-python\n```\n\n# Command line tooling\n\nThe Python package contains a suite of command line tools, all nested under the main entrypoint `cyclonedds`. The main help screen shows the commands available:\n\n![`cyclonedds --help`](docs/manual/static/images/cyclonedds-help.svg)\n\n## `cyclonedds ls`\n\n![`cyclonedds ls --help`](docs/manual/static/images/cyclonedds-ls-help.svg)\n\nThe `ls` subcommand shows you the entities in your DDS system and their QoS settings. For example, here is the output when running the `Vehicle` example from this repo in the background:\n\n![`cyclonedds ls --suppress-progress-bar --force-color-mode`](docs/manual/static/images/cyclonedds-ls-demo.svg)\n\n## `cyclonedds ps`\n\n![`cyclonedds ps --help`](docs/manual/static/images/cyclonedds-ps-help.svg)\n\nThe `ps` subcommand shows you the applications in your DDS system. Note that this depends on so called 'Participant Properties', tactfully named QoS properties in DDS participants. These were merged into CycloneDDS for version 0.10.0. Here is an example of the output when running the `Vehicle` example from this repo in the background on a single host:\n\n![`cyclonedds ps --suppress-progress-bar --force-color-mode`](docs/manual/static/images/cyclonedds-ps-demo.svg)\n\n## `cyclonedds typeof`\n\n![`cyclonedds typeof --help`](docs/manual/static/images/cyclonedds-typeof-help.svg)\n\nThe `typeof` subcommand shows you the type(s) of a topic in your system. With XTypes it can happen that more than one type for each topic exists and that they are still compatible. The types are represented in IDL. Here is an example of the output when running the `Vehicle` example:\n\n![`cyclonedds typeof Vehicle --suppress-progress-bar --force-color-mode`](docs/manual/static/images/cyclonedds-typeof-demo.svg)\n\n## `cyclonedds subscribe`\n\n![`cyclonedds subscribe --help`](docs/manual/static/images/cyclonedds-subscribe-help.svg)\n\nThe `subscribe` subcommand dynamically subscribes to a topic and shows you the data as it arrives. The type is discovered in a similar manner as `typeof`. Here is an example of the output when running the `Vehicle` example:\n\n![`timeout -s INT 10s cyclonedds subscribe Vehicle --suppress-progress-bar --force-color-mode`](docs/manual/static/images/cyclonedds-subscribe-demo.svg)\n\n## `cyclonedds publish`\n\n![`cyclonedds publish --help`](docs/manual/static/images/cyclonedds-publish-help.svg)\n\nThe `publish` subcommand dynamically builds a REPL with datatypes and a writer for a topic and shows you the data as it arrives. The type is discovered in a similar manner as `typeof`.\n\n## `cyclonedds performance`\n\n![`cyclonedds performance --help`](docs/manual/static/images/cyclonedds-performance-help.svg)\n\nThe `performance` subcommand is a nicer frontend to `ddsperf` with four modes: `publish`, `subscribe`, `ping` and `pong`. The below performance run example is the `cyclonedds performance subscribe` mode rendered with `cyclonedds performance publish` running in the background.\n\n![`cyclonedds performance --duration 21s --render-output-once-on-exit --force-color-mode subscribe --triggering-mode waitset`](docs/manual/static/images/cyclonedds-performance-subscribe-demo.svg)\n\n# Contributing\n\nWe very much welcome all contributions to the project, whether that is questions, examples, bug\nfixes, enhancements or improvements to the documentation, or anything else really.\nWhen considering contributing code, it might be good to know that build configurations for Azure pipelines are present in the repository and that there is a test suite using pytest, along with flake8 code linting, and documentation built with sphinx. Be sure to install with the [Extra dependencies](#extra-dependencies) if you're going to run tests, lints or build the docs.\n\nYou can run the test suite and linting using the [local-ci.py](local-ci.py) script in this repo.\n```bash\n$ python local-ci.py\n```\n\nOr lint a single file/directory (as the whole repo can be a little noisey) using:\n```bash\n$ python -m flake8 path/to/some_file.py\n```\n\nYou can build and serve the documentation (at http://localhost:8000/) using:\n```bash\ncd docs\npython -m sphinx source/ _build/\n# Serve the HTML files to view at localhost:8000\npython -m http.server -d _build\n```\n\n# Extra dependencies\n\nThe `cyclonedds` package defines two sets of optional dependencies, `dev` and `docs`, used for developing `cyclonedds` and building the documentation, respectively. If you want to install with development tools add the component to your installation, for example:\n\n```bash\n$ pip3 install --user \"cyclonedds[dev] @ git+https://github.com/eclipse-cyclonedds/cyclonedds-python\"\n```\n\nOr when installing from a local git clone, which is recommended when developing or building the docs:\n\n```bash\n$ cd /path/to/git/clone\n# for development:\n$ pip3 install --user \".[dev]\"\n# for documentation generation\n$ pip3 install --user \".[docs]\"\n# or for both\n$ pip3 install --user \".[dev,docs]\"\n```\n\nFor more information see [the packaging guide information on optional dependencies][2].\n\n[1]: https://github.com/eclipse-cyclonedds/cyclonedds/#eclipse-cyclone-dds\n[2]: https://setuptools.pypa.io/en/latest/userguide/dependency_management.html#optional-dependencies\n[3]: https://cyclonedds.io/docs/cyclonedds-python/latest/\n\n# PyOxidizer build\n\nYou can build a self-contained binary of the `cyclonedds` CLI tool using PyOxidizer. It should be as simple as:\n\n```bash\n$ cd /path/to/git/clone\n$ pip3 install --user pyoxidizer\n$ pyoxidizer build\n```\n\n\n",
"bugtrack_url": null,
"license": "EPL-2.0, BSD-3-Clause",
"summary": "Eclipse Cyclone DDS Python binding",
"version": "2024.10.12",
"project_urls": {
"Bug Tracker": "https://github.com/eclipse-cyclonedds/cyclonedds-python/issues",
"Documentation": "https://cyclonedds.io/docs",
"Homepage": "https://cyclonedds.io",
"Source Code": "https://github.com/eclipse-cyclonedds/cyclonedds-python"
},
"split_keywords": [
"eclipse",
" cyclone",
" dds",
" pub",
" sub",
" pubsub",
" iot",
" cyclonedds",
" cdr",
" omg",
" idl",
" middleware",
" ros"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "84561cfa77fc07bf1f5da14ad01b4a735b3d93713997019a7ea081c58a2b5f47",
"md5": "250732a76e2346fc07d1b3e6a8dd0fe3",
"sha256": "beedb6e3198a295340204639b3a73a8e318efe1fcc8a562bd552946bfa20b5ec"
},
"downloads": -1,
"filename": "cyclonedds_nightly-2024.10.12-cp310-cp310-macosx_10_9_x86_64.whl",
"has_sig": false,
"md5_digest": "250732a76e2346fc07d1b3e6a8dd0fe3",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": ">=3.7",
"size": 892244,
"upload_time": "2024-10-12T00:29:14",
"upload_time_iso_8601": "2024-10-12T00:29:14.788215Z",
"url": "https://files.pythonhosted.org/packages/84/56/1cfa77fc07bf1f5da14ad01b4a735b3d93713997019a7ea081c58a2b5f47/cyclonedds_nightly-2024.10.12-cp310-cp310-macosx_10_9_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "6816072ee0dcedadcb072647cccccec4634fd30768c9e81985c59666c16f428b",
"md5": "bfbbf8c8ae76c12c4bdd1613bbfdd84c",
"sha256": "08abfa1d6b599e6580a193bb6fa95078fa6d223a1ce4a086819c5cda2d4771eb"
},
"downloads": -1,
"filename": "cyclonedds_nightly-2024.10.12-cp310-cp310-macosx_11_0_arm64.whl",
"has_sig": false,
"md5_digest": "bfbbf8c8ae76c12c4bdd1613bbfdd84c",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": ">=3.7",
"size": 820173,
"upload_time": "2024-10-12T00:29:16",
"upload_time_iso_8601": "2024-10-12T00:29:16.386968Z",
"url": "https://files.pythonhosted.org/packages/68/16/072ee0dcedadcb072647cccccec4634fd30768c9e81985c59666c16f428b/cyclonedds_nightly-2024.10.12-cp310-cp310-macosx_11_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "3d4b9df2938339e804ea643fcf6e6aa4ecedba6ce00f3d3b398417ce899e6c79",
"md5": "fc8a36850e7e3f1384b9b59180449872",
"sha256": "57978363504a42361500c761f55fe385e6b66625113c1ef0ffcc327d42e721d4"
},
"downloads": -1,
"filename": "cyclonedds_nightly-2024.10.12-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "fc8a36850e7e3f1384b9b59180449872",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": ">=3.7",
"size": 7293731,
"upload_time": "2024-10-12T00:29:18",
"upload_time_iso_8601": "2024-10-12T00:29:18.311860Z",
"url": "https://files.pythonhosted.org/packages/3d/4b/9df2938339e804ea643fcf6e6aa4ecedba6ce00f3d3b398417ce899e6c79/cyclonedds_nightly-2024.10.12-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "a3e10bb77c5fbc190c0538d2b28cad836f0bec3c0f4a2b4342ecdb9aa501b479",
"md5": "d0a0214b8d5f3658300eafbfff6c74b7",
"sha256": "00200de5ea63e1ee5156e7e66db244f30e635c87f659e4901b4aaf716c31fd37"
},
"downloads": -1,
"filename": "cyclonedds_nightly-2024.10.12-cp310-cp310-win_amd64.whl",
"has_sig": false,
"md5_digest": "d0a0214b8d5f3658300eafbfff6c74b7",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": ">=3.7",
"size": 1288326,
"upload_time": "2024-10-12T00:29:20",
"upload_time_iso_8601": "2024-10-12T00:29:20.916423Z",
"url": "https://files.pythonhosted.org/packages/a3/e1/0bb77c5fbc190c0538d2b28cad836f0bec3c0f4a2b4342ecdb9aa501b479/cyclonedds_nightly-2024.10.12-cp310-cp310-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "211ea8a0dafaf2dc03ff632af6681350f57c801b45a178336f5e9c666ffdb7ec",
"md5": "8211c202e398f70b28e50460fad82ee6",
"sha256": "0d3e8633846b5555bffaa2719545699d0dcb8a9d675b33e4879d99239a8b21fa"
},
"downloads": -1,
"filename": "cyclonedds_nightly-2024.10.12-cp37-cp37m-macosx_10_9_x86_64.whl",
"has_sig": false,
"md5_digest": "8211c202e398f70b28e50460fad82ee6",
"packagetype": "bdist_wheel",
"python_version": "cp37",
"requires_python": ">=3.7",
"size": 892251,
"upload_time": "2024-10-12T00:29:22",
"upload_time_iso_8601": "2024-10-12T00:29:22.850175Z",
"url": "https://files.pythonhosted.org/packages/21/1e/a8a0dafaf2dc03ff632af6681350f57c801b45a178336f5e9c666ffdb7ec/cyclonedds_nightly-2024.10.12-cp37-cp37m-macosx_10_9_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "68d130d1a1e0e0b716ff36975f6457113fdab76fd9396dae89e8b414bcb8e39e",
"md5": "706c5ec289d7f50492cd744b98b0f893",
"sha256": "c72e6c531011ef85fa1d1921396a957bfb333f983495f387ae8a62dd178ddbd2"
},
"downloads": -1,
"filename": "cyclonedds_nightly-2024.10.12-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "706c5ec289d7f50492cd744b98b0f893",
"packagetype": "bdist_wheel",
"python_version": "cp37",
"requires_python": ">=3.7",
"size": 7294269,
"upload_time": "2024-10-12T00:29:25",
"upload_time_iso_8601": "2024-10-12T00:29:25.034719Z",
"url": "https://files.pythonhosted.org/packages/68/d1/30d1a1e0e0b716ff36975f6457113fdab76fd9396dae89e8b414bcb8e39e/cyclonedds_nightly-2024.10.12-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "efb8b3963a1f2a17a7d15df94f57798082dcacb64ce71a5b3ad5b32820a95045",
"md5": "ea4d2c2bb184b61d5049d2e287e1ee3b",
"sha256": "74f5bc5728e7e4219260a36bfd4841412600646932bb5319b8a15563dac29fcd"
},
"downloads": -1,
"filename": "cyclonedds_nightly-2024.10.12-cp37-cp37m-win_amd64.whl",
"has_sig": false,
"md5_digest": "ea4d2c2bb184b61d5049d2e287e1ee3b",
"packagetype": "bdist_wheel",
"python_version": "cp37",
"requires_python": ">=3.7",
"size": 1288389,
"upload_time": "2024-10-12T00:29:26",
"upload_time_iso_8601": "2024-10-12T00:29:26.662575Z",
"url": "https://files.pythonhosted.org/packages/ef/b8/b3963a1f2a17a7d15df94f57798082dcacb64ce71a5b3ad5b32820a95045/cyclonedds_nightly-2024.10.12-cp37-cp37m-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "1e41969cc0a97c27aaf00b7792e021f32c0e281b93952f70b0ccb4b5644ec4a5",
"md5": "9972a1744ecc652f1cb6ff4972152dc0",
"sha256": "8811106f5515107f928d56683b50417857e7518f6963253c660e42ac8de9cea9"
},
"downloads": -1,
"filename": "cyclonedds_nightly-2024.10.12-cp38-cp38-macosx_10_9_x86_64.whl",
"has_sig": false,
"md5_digest": "9972a1744ecc652f1cb6ff4972152dc0",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": ">=3.7",
"size": 892252,
"upload_time": "2024-10-12T00:29:28",
"upload_time_iso_8601": "2024-10-12T00:29:28.519804Z",
"url": "https://files.pythonhosted.org/packages/1e/41/969cc0a97c27aaf00b7792e021f32c0e281b93952f70b0ccb4b5644ec4a5/cyclonedds_nightly-2024.10.12-cp38-cp38-macosx_10_9_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "8861de2191c2238c6fe45389dbbfcee073f7281001c0362acbd78f7b9f43eaba",
"md5": "9c6de09dc20de12da8fcab4b4b59c523",
"sha256": "75dbf914c128848778890df3d21a0fbbec35cfcb4e1cff0bf2b3decfa2b58fbf"
},
"downloads": -1,
"filename": "cyclonedds_nightly-2024.10.12-cp38-cp38-macosx_11_0_arm64.whl",
"has_sig": false,
"md5_digest": "9c6de09dc20de12da8fcab4b4b59c523",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": ">=3.7",
"size": 820190,
"upload_time": "2024-10-12T00:29:29",
"upload_time_iso_8601": "2024-10-12T00:29:29.920116Z",
"url": "https://files.pythonhosted.org/packages/88/61/de2191c2238c6fe45389dbbfcee073f7281001c0362acbd78f7b9f43eaba/cyclonedds_nightly-2024.10.12-cp38-cp38-macosx_11_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "764f4e466e67507e56732e36658c23b6a77d6a5690d01122074f057a3771470a",
"md5": "a96d9fbdeca3911deb06666723cff60d",
"sha256": "0affa8d162eacdf384632361d2d45f1ca8d6b5e9d9e272efe5fbbc3827e96fac"
},
"downloads": -1,
"filename": "cyclonedds_nightly-2024.10.12-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "a96d9fbdeca3911deb06666723cff60d",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": ">=3.7",
"size": 7295014,
"upload_time": "2024-10-12T00:29:31",
"upload_time_iso_8601": "2024-10-12T00:29:31.707186Z",
"url": "https://files.pythonhosted.org/packages/76/4f/4e466e67507e56732e36658c23b6a77d6a5690d01122074f057a3771470a/cyclonedds_nightly-2024.10.12-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "da29b33b58a09443dce65ad771dd3896660bccf142c2687e6d88bbccfbe744de",
"md5": "b61644226de0012121646183dbfb1e93",
"sha256": "4974e065d109aaf00f6e6c440a4b83c706834ef7df632f9469da729a5e43c96a"
},
"downloads": -1,
"filename": "cyclonedds_nightly-2024.10.12-cp38-cp38-win_amd64.whl",
"has_sig": false,
"md5_digest": "b61644226de0012121646183dbfb1e93",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": ">=3.7",
"size": 1288324,
"upload_time": "2024-10-12T00:29:33",
"upload_time_iso_8601": "2024-10-12T00:29:33.631725Z",
"url": "https://files.pythonhosted.org/packages/da/29/b33b58a09443dce65ad771dd3896660bccf142c2687e6d88bbccfbe744de/cyclonedds_nightly-2024.10.12-cp38-cp38-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "c4078284ff2801835ea496a2228701fae90b90634124f25d10027ad700929867",
"md5": "fe02648eafd25a6831a7182e6bf04bf3",
"sha256": "143b045f2e380fdbff88ec06f3c3760e42f864e9009d1b298453daab5ce0f5f1"
},
"downloads": -1,
"filename": "cyclonedds_nightly-2024.10.12-cp39-cp39-macosx_10_9_x86_64.whl",
"has_sig": false,
"md5_digest": "fe02648eafd25a6831a7182e6bf04bf3",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.7",
"size": 892261,
"upload_time": "2024-10-12T00:29:36",
"upload_time_iso_8601": "2024-10-12T00:29:36.074733Z",
"url": "https://files.pythonhosted.org/packages/c4/07/8284ff2801835ea496a2228701fae90b90634124f25d10027ad700929867/cyclonedds_nightly-2024.10.12-cp39-cp39-macosx_10_9_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "9ed706f8730fc6ef75cc5938847e764e8757f3d7ce341e80f8edc97360c7cab9",
"md5": "e837ecb5798d8b523305d438ed93f54e",
"sha256": "d2173d6439e8282ef801de4ad1bc7e8ad0797835e552887d0dbea3a944283f72"
},
"downloads": -1,
"filename": "cyclonedds_nightly-2024.10.12-cp39-cp39-macosx_11_0_arm64.whl",
"has_sig": false,
"md5_digest": "e837ecb5798d8b523305d438ed93f54e",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.7",
"size": 820214,
"upload_time": "2024-10-12T00:29:37",
"upload_time_iso_8601": "2024-10-12T00:29:37.599613Z",
"url": "https://files.pythonhosted.org/packages/9e/d7/06f8730fc6ef75cc5938847e764e8757f3d7ce341e80f8edc97360c7cab9/cyclonedds_nightly-2024.10.12-cp39-cp39-macosx_11_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "b012c2b2b1553f685e9d3588e129cc994cc64a2382c089019683d93cc140d1f2",
"md5": "f89aeb0b3c5187c8e2f3f5c2bd89ac98",
"sha256": "8b94a6cd7e85dc6570315e0afba563620a121b6ac4f9c56ea32d45e2a7cb8137"
},
"downloads": -1,
"filename": "cyclonedds_nightly-2024.10.12-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "f89aeb0b3c5187c8e2f3f5c2bd89ac98",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.7",
"size": 7293540,
"upload_time": "2024-10-12T00:29:39",
"upload_time_iso_8601": "2024-10-12T00:29:39.321565Z",
"url": "https://files.pythonhosted.org/packages/b0/12/c2b2b1553f685e9d3588e129cc994cc64a2382c089019683d93cc140d1f2/cyclonedds_nightly-2024.10.12-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "73b2e35e22557115b05ce0e55f196d2fdd5a56c34f71182ddc362127075661d5",
"md5": "a60b7316184bc61c934dc504e1aed307",
"sha256": "2aeadb104fe61990bbc592985b12466fa0dd2ee4a1f6aa338971125d8e9277dc"
},
"downloads": -1,
"filename": "cyclonedds_nightly-2024.10.12-cp39-cp39-win_amd64.whl",
"has_sig": false,
"md5_digest": "a60b7316184bc61c934dc504e1aed307",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.7",
"size": 1288324,
"upload_time": "2024-10-12T00:29:41",
"upload_time_iso_8601": "2024-10-12T00:29:41.039826Z",
"url": "https://files.pythonhosted.org/packages/73/b2/e35e22557115b05ce0e55f196d2fdd5a56c34f71182ddc362127075661d5/cyclonedds_nightly-2024.10.12-cp39-cp39-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "569358d4ea9d010cf44c995b02c0c38de948a159374f730d43eb47dfa36e2587",
"md5": "0f72a9e835704b0bf222f641cb0c6b97",
"sha256": "9e63c26a049e90f4b9d998097c81770bddf930824d81d24d1f82ae7c307da583"
},
"downloads": -1,
"filename": "cyclonedds-nightly-2024.10.12.tar.gz",
"has_sig": false,
"md5_digest": "0f72a9e835704b0bf222f641cb0c6b97",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.7",
"size": 161495,
"upload_time": "2024-10-12T00:29:11",
"upload_time_iso_8601": "2024-10-12T00:29:11.001996Z",
"url": "https://files.pythonhosted.org/packages/56/93/58d4ea9d010cf44c995b02c0c38de948a159374f730d43eb47dfa36e2587/cyclonedds-nightly-2024.10.12.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-10-12 00:29:11",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "eclipse-cyclonedds",
"github_project": "cyclonedds-python",
"travis_ci": false,
"coveralls": true,
"github_actions": false,
"lcname": "cyclonedds-nightly"
}