Metadata-Version: 2.4
Name: bounce_desktop
Version: 0.1.2
Summary: Hardware-accelerated Linux virtual desktops.
License-Expression: MIT
Author: William Henning
Author-email: wchenningwchenning@gmail.com
Requires-Python: >=3.11
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Programming Language :: Python :: 3.14
Requires-Dist: numpy (>=2.3.3,<3.0.0)
Description-Content-Type: text/markdown

# Bounce Desktop

Bounce Desktop is a cpp library and python package for starting and interacting
with lightweight hardware-accelerated virtual desktops. It does this by running
VNC-backed Weston sessions and then connecting to them with a VNC client.

I've written Bounce Desktop to serve as a desktop platform for my RL with Games
framework: [BounceRL](https://github.com/Whenning42/bounce-rl).

# Dependencies

poetry, libvncserver (optional), gmock, gtest, libgvnc (from gtk-vnc)

# Getting started

If you want just want the python package, you'll first need to install the system
dependencies listed above. Then you can run this pip command:

```shell
pip install bounce_desktop
```

# Usage

I don't have docs or clear examples handy, but for starter pointers, see:
[src/desktop/client.h](src/desktop/client.h),
[bounce_desktop/bounce_desk_test.py](bounce_desktop/bounce_desk_test.py), and
[src/bindings/client_exe.h](src/bindings/client_ext.h).

# Roadmap 

This project's being developed to support [BounceRL](https://github.com/Whenning42/bounce-rl),
so I'll be focusing development toward that project's needs. With that said, I
do think there's value in having a lightweight virtual desktop library available, and
I do think one could develop this project toward that goal if they're interested.

I also think this project should be close to feature complete at this point, I may at
some point integrate the prototyped, but unused, subprocess reaper into the desktop
class, so that callers can get guaranteed process clean-up, but we'll see if or when
I need that feature.

# Contributing

I don't plan on accepting pull requests in the near term, but I'll take a look at any
issues or feature requests you open.


