mirror of
https://github.com/pinnacle-comp/pinnacle.git
synced 2025-01-18 22:26:12 +01:00
Make the README an actual README
This commit is contained in:
parent
6f6a159c3a
commit
1ef57905e1
1 changed files with 117 additions and 7 deletions
124
README.md
124
README.md
|
@ -1,9 +1,119 @@
|
|||
# Pinnacle
|
||||
<div align="center">
|
||||
<font size="50">
|
||||
<strong>
|
||||
Pinnacle
|
||||
</strong>
|
||||
</font>
|
||||
</div>
|
||||
|
||||
<picture>
|
||||
<source media="(prefers-color-scheme: dark)" srcset="/assets/cool_logo_dark_theme.png">
|
||||
<source media="(prefers-color-scheme: light)" srcset="/assets/cool_logo_light_theme.png">
|
||||
<img alt="Cool logo" src="/assets/cool_logo_dark_theme.png">
|
||||
</picture>
|
||||
<div align="center">
|
||||
<picture>
|
||||
<source media="(prefers-color-scheme: dark)" srcset="/assets/cool_logo_dark_theme.png">
|
||||
<source media="(prefers-color-scheme: light)" srcset="/assets/cool_logo_light_theme.png">
|
||||
<img alt="Cool logo" src="/assets/cool_logo_dark_theme.png">
|
||||
</picture>
|
||||
</div>
|
||||
|
||||
A Smithay-based wayland compositor
|
||||
<div align="center">
|
||||
A very, VERY WIP Smithay-based wayland compositor
|
||||
</div>
|
||||
|
||||
## Info
|
||||
### Why Pinnacle?
|
||||
Well, I currently use [Awesome](https://github.com/awesomeWM/awesome). And I really like it! Unfortunately, Awesome doesn't exist for Wayland ([anymore](http://way-cooler.org/blog/2020/01/09/way-cooler-post-mortem.html)). There doesn't seem to be any Wayland compositor out there that has all of the following:
|
||||
- Tags for window management
|
||||
- Configurable in Lua (or any other programming language for that matter)
|
||||
- Has a bunch of batteries included (widget system, systray, etc)
|
||||
|
||||
So, this is my attempt at making an Awesome-esque Wayland compositor.
|
||||
|
||||
## Dependencies
|
||||
You'll need the following packages, as specified by [Smithay](https://github.com/Smithay/smithay):
|
||||
```
|
||||
libwayland
|
||||
libxkbcommon
|
||||
libudev
|
||||
libinput
|
||||
libgdm
|
||||
libseat
|
||||
```
|
||||
Package names will vary across distros. TODO: list those names.
|
||||
|
||||
## Building
|
||||
Build the project with:
|
||||
```
|
||||
cargo build [--release]
|
||||
```
|
||||
|
||||
## Running
|
||||
After building, run the executable located in either:
|
||||
```
|
||||
./target/debug/pinnacle --<backend> // without --release
|
||||
./target/release/pinnacle --<backend> // with --release
|
||||
```
|
||||
|
||||
Or, run the project directly with
|
||||
```
|
||||
cargo run [--release] -- --<backend>
|
||||
```
|
||||
|
||||
`backend` can be one of two values:
|
||||
|
||||
- `winit`: run Pinnacle as a window in your graphical environment
|
||||
- `udev`: run Pinnacle in a tty. NOTE: I tried running udev in Awesome and some things broke so uh, don't do that
|
||||
|
||||
## Configuration
|
||||
Please note: this is VERY WIP and has basically no options yet.
|
||||
|
||||
Pinnacle supports configuration through Lua (and hopefully more languages if I architect it correctly :crab:).
|
||||
|
||||
Run Pinnacle with the `PINNACLE_CONFIG` environment variable set to the path of your config file. If not specified, Pinnacle will look for the following:
|
||||
```
|
||||
$XDG_CONFIG_HOME/pinnacle/init.lua
|
||||
~/.config/pinnacle/init.lua // if XDG_CONFIG_HOME isn't set
|
||||
```
|
||||
The following will use the example config file in [`api/lua`](api/lua):
|
||||
```
|
||||
PINNACLE_CONFIG="./api/lua/example_config.lua" cargo run -- --<backend>
|
||||
```
|
||||
|
||||
### Autocomplete and that cool stuff
|
||||
It is *highly* recommended to use the [Lua language server](https://github.com/LuaLS/lua-language-server) and set it up to have the [`api/lua`](api/lua) directory as a library, as I'll be using its doc comments to provide autocomplete and error checking.
|
||||
|
||||
#### For VS Code:
|
||||
Install the [Lua](https://marketplace.visualstudio.com/items?itemName=sumneko.lua) plugin, then go into its settings and add the absolute(?) path to the [`api/lua`](api/lua) directory to Workspace: Library.
|
||||
|
||||
#### For Neovim:
|
||||
Pass
|
||||
```lua
|
||||
Lua = {
|
||||
workspace = {
|
||||
library = {
|
||||
"/path/to/pinnacle/api/lua"
|
||||
}
|
||||
}
|
||||
}
|
||||
```
|
||||
into your Lua language server settings.
|
||||
|
||||
## Controls
|
||||
The following controls are currently hardcoded:
|
||||
|
||||
- `Esc`: Stop Pinnacle
|
||||
- `Ctrl + Left Mouse`: Move a window
|
||||
- `Ctrl + Right Mouse`: Resize a window
|
||||
- `Shift + L`: Open Alacritty
|
||||
- `Shift + K`: Open Nautilus
|
||||
- `Shift + J`: Open Kitty
|
||||
- `Shift + H`: Open Foot
|
||||
|
||||
The following controls are set in the [`example_config`](api/lua/example_config.lua):
|
||||
- `Ctrl + Alt + C`: Close the currently focused window
|
||||
- `Ctrl + Alt + Space`: Toggle "floating" for the currently focused window
|
||||
|
||||
"Floating" is in quotes because while windows do currently tile themselves, tiled ones can still be moved just like a floating window. Toggling to and from floating will retile all tiled windows.
|
||||
|
||||
The only layout currently is a master stack with the master on the left side.
|
||||
|
||||
## A Small Note
|
||||
This is currently just a summer project I'm working on, but I hope that I can work on it enough that it becomes somewhat usable! If development slows down during the rest of the year, it's because :star:university:star:.
|
||||
|
|
Loading…
Reference in a new issue