Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ulinja/hyprpy
Python bindings for Hyprland.
https://github.com/ulinja/hyprpy
hyprland hyprland-bindings linux linux-desktop python python-library wayland wayland-compositor
Last synced: 3 months ago
JSON representation
Python bindings for Hyprland.
- Host: GitHub
- URL: https://github.com/ulinja/hyprpy
- Owner: ulinja
- License: mit
- Created: 2023-08-10T01:27:51.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-05-12T14:09:41.000Z (8 months ago)
- Last Synced: 2024-05-13T12:16:37.138Z (8 months ago)
- Topics: hyprland, hyprland-bindings, linux, linux-desktop, python, python-library, wayland, wayland-compositor
- Language: Python
- Homepage: https://hyprpy.lobbes.dev
- Size: 113 KB
- Stars: 14
- Watchers: 2
- Forks: 4
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-hyprland - hyprpy
README
# Hyprpy
[Hyprpy](https://github.com/ulinja/hyprpy) is a library that provides python bindings for the [Hyprland](https://hyprland.org/) wayland compositor.
With Hyprpy you can very easily retrieve information about windows, workspaces and monitors
in a running Hyprland instance.
It also offers an event monitor, allowing you to write your own callback functions which
execute in response to Hyprland events.Hyprpy uses unix sockets to communicate with Hyprland, making it **fast** and **efficient**.
Please [check out the documentation](https://hyprpy.lobbes.dev)!
Hyprpy is fully typed and extensively documented. Happy hacking :sunglasses:## Quickstart
### Installation
```bash
pip install hyprpy
```### Usage examples
```python
from hyprpy import Hyprlandinstance = Hyprland()
# Fetch active window and display information:
window = instance.get_active_window()
print(window.wm_class)
print(window.width)
print(window.position_x)# Print information about the windows on the active workspace
workspace = instance.get_active_workspace()
for window in workspace.windows:
print(f"{window.address}: {window.title} [{window.wm_class}]")# Get the resolution of the first monitor
monitor = instance.get_monitor_by_id(0)
if monitor:
print(f"{monitor.width} x {monitor.height}")# Get all windows currently on the special workspace
special_workspace = instance.get_workspace_by_name("special")
if special_workspace:
special_windows = special_workspace.windows
for window in special_windows:
print(window.title)# Show a desktop notification every time we switch to workspace 6
from hyprpy.utils.shell import run_or_faildef workspace_changed(sender, **kwargs):
current_workspace_id = kwargs.get('active_workspace_id')
if current_workspace_id == 6:
run_or_fail(["notify-send", "We are on workspace 6."])instance.signal_active_workspace_changed.connect(workspace_changed)
instance.watch()
```## Development
Hyprpy is in active development! Please file an issue if you find any bugs or have a feature request.
Your contributions are greatly appreciated.
### Roadmap
- [ ] include [dispatchers in components API](https://github.com/ulinja/hyprpy/issues/11)