mirror of
https://github.com/hyprwm/hyprland-wiki.git
synced 2024-11-26 06:25:59 +01:00
Fix Getting Started section
Fix links, simplify grammar, remove redundant text.
This commit is contained in:
parent
7d7b2ab26c
commit
04bf3f24f9
2 changed files with 72 additions and 56 deletions
|
@ -1,12 +1,15 @@
|
||||||
# Foreword
|
# Foreword
|
||||||
|
|
||||||
Nvidia GPUs are widely known as... yeah. If you want to try Hyprland on Nvidia regardless (many people have reported successes), follow the [Nvidia page](https://github.com/hyprwm/Hyprland/wiki/Nvidia) after installing Hyprland.
|
Nvidia GPUs are widely known as... yeah. If you want to try Hyprland on Nvidia
|
||||||
|
regardless (many people have reported successes), follow the
|
||||||
|
[Nvidia page](https://github.com/hyprwm/Hyprland/wiki/Nvidia) after installing
|
||||||
|
Hyprland.
|
||||||
|
|
||||||
### Distros
|
### Distros
|
||||||
|
|
||||||
Arch and NixOS are very supported. For any other distro (not based on Arch/Nix)
|
Arch and NixOS are very supported. For any other distro (not based on Arch/Nix)
|
||||||
you might have varying amounts of success. However, since Hyprland is extremely
|
you might have varying amounts of success. However, since Hyprland is extremely
|
||||||
bleeding-edge, distros like Pop!_OS, Ubuntu, etc. etc. might have **major**
|
bleeding-edge, distros like Pop!\_OS, Ubuntu, etc. might have **major**
|
||||||
issues running Hyprland.
|
issues running Hyprland.
|
||||||
|
|
||||||
# Installation
|
# Installation
|
||||||
|
@ -14,34 +17,33 @@ issues running Hyprland.
|
||||||
Installing Hyprland is very easy. Either you install it from your local package
|
Installing Hyprland is very easy. Either you install it from your local package
|
||||||
provider (if they provide pkgs for Hyprland) or you install/build it yourself.
|
provider (if they provide pkgs for Hyprland) or you install/build it yourself.
|
||||||
|
|
||||||
**Notice:** Given this project is under development and constantly changing, if
|
{{< hint title=Note >}}
|
||||||
|
This project is under development and is constantly changing. If
|
||||||
you want to keep up to date with the latest commits, please consider updating
|
you want to keep up to date with the latest commits, please consider updating
|
||||||
your packages with `yay -Syu --devel`, or your other preferred package manager.
|
your packages with `yay -Syu --devel`, or your other preferred package manager.
|
||||||
|
{{< /hint >}}
|
||||||
|
|
||||||
## Packages
|
## Packages
|
||||||
|
|
||||||
**WARNING:** I do not maintain any packages. If they are broken, try building
|
**WARNING:** I do not maintain any packages. If they are broken, try building
|
||||||
from source first.
|
from source first.
|
||||||
|
|
||||||
## Arch Linux
|
{{< tabs "uniqueid" >}}
|
||||||
|
|
||||||
*AUR:*
|
{{< tab "Arch Linux" >}}
|
||||||
|
*If you're on Arch Linux, I* ***heavily*** *recommend you use the AUR.*
|
||||||
|
|
||||||
```
|
```plain
|
||||||
hyprland-git - compiles from latest source
|
hyprland-git - compiles from latest source
|
||||||
hyprland - compiles from latest release source
|
hyprland - compiles from latest release source
|
||||||
hyprland-bin - compiled latest release
|
hyprland-bin - compiled latest release
|
||||||
```
|
```
|
||||||
|
{{< /tab >}}
|
||||||
|
|
||||||
*If you're on Arch Linux, I* ***heavily*** *recommend you use the AUR.*
|
{{< tab "Nix" >}}Read the [Nix page](https://github.com/hyprwm/Hyprland/wiki/Nix).{{< /tab >}}
|
||||||
|
{{< tab "Fedora" >}}<https://github.com/hyprwm/Hyprland/discussions/284>{{< /tab >}}
|
||||||
|
{{< /tabs >}}
|
||||||
|
|
||||||
## Nix
|
|
||||||
|
|
||||||
Read the [Nix page](https://github.com/hyprwm/Hyprland/wiki/Nix).
|
|
||||||
|
|
||||||
## Fedora
|
|
||||||
|
|
||||||
[https://github.com/hyprwm/Hyprland/discussions/284](https://github.com/hyprwm/Hyprland/discussions/284)
|
|
||||||
|
|
||||||
## Manual (Releases)
|
## Manual (Releases)
|
||||||
|
|
||||||
|
@ -65,7 +67,9 @@ libwlroots), you don't need to update anything else.
|
||||||
|
|
||||||
*Arch dependencies*:
|
*Arch dependencies*:
|
||||||
|
|
||||||
`yay -S gdb ninja gcc cmake libxcb xcb-proto xcb-util xcb-util-keysyms libxfixes libx11 libxcomposite xorg-xinput libxrender pixman wayland-protocols cairo pango`
|
```plain
|
||||||
|
yay -S gdb ninja gcc cmake libxcb xcb-proto xcb-util xcb-util-keysyms libxfixes libx11 libxcomposite xorg-xinput libxrender pixman wayland-protocols cairo pango
|
||||||
|
```
|
||||||
|
|
||||||
(If any are missing hmu)
|
(If any are missing hmu)
|
||||||
|
|
||||||
|
@ -78,9 +82,7 @@ that (`gcc>=12.1.0` or `clang>=15`)
|
||||||
|
|
||||||
### CMake (recommended)
|
### CMake (recommended)
|
||||||
|
|
||||||
then...
|
```Plain
|
||||||
|
|
||||||
```
|
|
||||||
git clone --recursive https://github.com/hyprwm/Hyprland
|
git clone --recursive https://github.com/hyprwm/Hyprland
|
||||||
cd Hyprland
|
cd Hyprland
|
||||||
sudo make install
|
sudo make install
|
||||||
|
@ -88,33 +90,31 @@ sudo make install
|
||||||
|
|
||||||
### Meson
|
### Meson
|
||||||
|
|
||||||
then...
|
```plain
|
||||||
|
|
||||||
```
|
|
||||||
meson _build
|
meson _build
|
||||||
ninja -C _build
|
ninja -C _build
|
||||||
ninja -C _build install
|
ninja -C _build install
|
||||||
```
|
```
|
||||||
|
|
||||||
Refer to Debugging to see how to build & debug.
|
Refer to [Debugging](../../Contributing-and-Debugging) to see how to build & debug.
|
||||||
|
|
||||||
## Crashes at launch
|
## Crash on launch
|
||||||
|
|
||||||
See the log, `cat /tmp/hypr/[INSTANCE_SIGNATURE]/hyprland.log`
|
See the log, `cat /tmp/hypr/[INSTANCE_SIGNATURE]/hyprland.log`
|
||||||
|
|
||||||
*If you are unsure of the signature, grab the one thats the most recently
|
*If you are unsure of the signature, grab the one that's the most recently
|
||||||
modified.*
|
modified.*
|
||||||
|
|
||||||
Diagnose the issue by what is in the log:
|
Diagnose the issue by what is in the log:
|
||||||
|
|
||||||
- `sWLRBackend was NULL!` -> launch in the TTY and refer to the wlr logs in RED.
|
- `sWLRBackend was NULL!` -> launch in the TTY and refer to the wlr logs in RED.
|
||||||
- `Monitor X has NO PREFERRED MODE, and an INVALID one was requested` -> your
|
- `Monitor X has NO PREFERRED MODE, and an INVALID one was requested` -> your
|
||||||
monitor is bork.
|
monitor is borked.
|
||||||
- Other -> see the coredump. Use `coredumpctl`, find the latest one's PID and do
|
- Other -> see the coredump. Use `coredumpctl`, find the latest one's PID and do
|
||||||
`coredumpctl info PID`.
|
`coredumpctl info PID`.
|
||||||
- failing on a driver (e.g. `radeon`) -> try compiling with
|
- failing on a driver (e.g. `radeon`) -> try compiling with
|
||||||
`make legacyrenderer`, if that doesn't help, report an issue.
|
`make legacyrenderer`. If that doesn't help, report an issue.
|
||||||
- failing on `wlr-xxx` -> try compiling with `make legacyrenderer`, if that
|
- failing on `wlr-xxx` -> try compiling with `make legacyrenderer`. If that
|
||||||
doesn't help, report an issue, and also refer to the TTY wlr logs in RED like
|
doesn't help, report an issue, and also refer to the TTY wlr logs in RED like
|
||||||
in the first point.
|
in the first point.
|
||||||
- failing on `Hyprland` -> report an issue.
|
- failing on `Hyprland` -> report an issue.
|
||||||
|
@ -125,7 +125,7 @@ cd into the hyprland repo.
|
||||||
|
|
||||||
for legacy renderer:
|
for legacy renderer:
|
||||||
|
|
||||||
```
|
```plain
|
||||||
sudo make clear && sudo make config && make legacyrenderer && sudo cp ./build/Hyprland /usr/bin && sudo cp ./example/hyprland.desktop /usr/share/wayland-sessions
|
sudo make clear && sudo make config && make legacyrenderer && sudo cp ./build/Hyprland /usr/bin && sudo cp ./example/hyprland.desktop /usr/share/wayland-sessions
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -133,7 +133,7 @@ _please note the legacy renderer may not support some graphical features._
|
||||||
<br/><br/> Any other config: (replace \[PRESET\] with your preset, `release`
|
<br/><br/> Any other config: (replace \[PRESET\] with your preset, `release`
|
||||||
`debug` `legacyrenderer` `legacyrendererdebug`)
|
`debug` `legacyrenderer` `legacyrendererdebug`)
|
||||||
|
|
||||||
```
|
```plain
|
||||||
sudo make clear && sudo make config && make [PRESET] && sudo cp ./build/Hyprland /usr/bin && sudo cp ./example/hyprland.desktop /usr/share/wayland-sessions
|
sudo make clear && sudo make config && make [PRESET] && sudo cp ./build/Hyprland /usr/bin && sudo cp ./example/hyprland.desktop /usr/share/wayland-sessions
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -143,7 +143,7 @@ To apply custom build flags, you'll have to ditch make.
|
||||||
|
|
||||||
Supported custom build flags:
|
Supported custom build flags:
|
||||||
|
|
||||||
```
|
```plain
|
||||||
NO_XWAYLAND - Removes XWayland support
|
NO_XWAYLAND - Removes XWayland support
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -153,13 +153,13 @@ Go to the root repo.
|
||||||
|
|
||||||
Clean before everything and config the root:
|
Clean before everything and config the root:
|
||||||
|
|
||||||
```
|
```plain
|
||||||
make clear && sudo make config
|
make clear && sudo make config
|
||||||
```
|
```
|
||||||
|
|
||||||
Then, configure CMake:
|
Then, configure CMake:
|
||||||
|
|
||||||
```
|
```plain
|
||||||
mkdir -p build && cmake --no-warn-unused-cli -DCMAKE_BUILD_TYPE:STRING=Release -D<YOUR_FLAG>:STRING=true -H./ -B./build -G Ninja
|
mkdir -p build && cmake --no-warn-unused-cli -DCMAKE_BUILD_TYPE:STRING=Release -D<YOUR_FLAG>:STRING=true -H./ -B./build -G Ninja
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -170,7 +170,7 @@ You can of course also change the `BUILD_TYPE` to `Debug`.
|
||||||
|
|
||||||
Now, build:
|
Now, build:
|
||||||
|
|
||||||
```
|
```plain
|
||||||
cmake --build ./build --config Release --target all -j 10
|
cmake --build ./build --config Release --target all -j 10
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -178,7 +178,7 @@ If you configured in `Debug`, change the `--config` to `Debug` as well.
|
||||||
|
|
||||||
Now, of course, install manually.
|
Now, of course, install manually.
|
||||||
|
|
||||||
```
|
```plain
|
||||||
sudo cp ./build/Hyprland /usr/bin && sudo cp ./example/hyprland.desktop /usr/share/wayland-sessions
|
sudo cp ./build/Hyprland /usr/bin && sudo cp ./example/hyprland.desktop /usr/share/wayland-sessions
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
|
@ -4,18 +4,26 @@ After you've installed Hyprland, you can either launch it from a TTY with
|
||||||
supported, I recommend `SDDM`, as it's been working flawlessly with wayland
|
supported, I recommend `SDDM`, as it's been working flawlessly with wayland
|
||||||
compositors.
|
compositors.
|
||||||
|
|
||||||
It is recommended you have `kitty` for terminal access, (example and autogenerated configs have it bound to SUPER+Q) or for you to manually change it in the config before launching hyprland.
|
It is recommended you have `kitty` for terminal access, (example and
|
||||||
|
autogenerated configs have it bound to <kbd>SUPER</kbd> + <kbd>Q</kbd>).
|
||||||
|
Alternatively, manually change it in the config before launching Hyprland.
|
||||||
|
|
||||||
If you have an Nvidia card, please also take a look at [The nvidia page](https://github.com/hyprwm/Hyprland/wiki/Nvidia) before launching. You should **first** make a wrapper, as described in the section below, then follow the instructions from the Nvidia page, and then continue on with sections below.
|
If you have an Nvidia card, please also take a look at
|
||||||
|
[The Nvidia page](../../Nvidia) before
|
||||||
|
launching. You should **first** make a wrapper, as described in the section
|
||||||
|
below, then follow the instructions from the Nvidia page, and then continue
|
||||||
|
on with sections below.
|
||||||
|
|
||||||
## Wrapping the launcher (recommended)
|
## Wrapping the launcher (recommended)
|
||||||
With Xorg, you get the `.xinitrc`. With Hyprland, you can create your own... kind of.
|
With Xorg, you get the `.xinitrc`. With Hyprland, you can create your own...
|
||||||
|
kind of.
|
||||||
|
|
||||||
Make an executable file somewhere in your `PATH`, for example `~/.local/bin/`, called (for example) `wrappedHl`
|
Make an executable file somewhere in your `PATH`, for example `~/.local/bin/`,
|
||||||
|
called (for example) `wrappedhl`
|
||||||
|
|
||||||
In it, put:
|
In it, put:
|
||||||
```
|
```bash
|
||||||
#!/bin/bash
|
#!/bin/sh
|
||||||
|
|
||||||
cd ~
|
cd ~
|
||||||
|
|
||||||
|
@ -25,9 +33,13 @@ export XCURSOR_SIZE=24
|
||||||
exec Hyprland
|
exec Hyprland
|
||||||
```
|
```
|
||||||
|
|
||||||
you can add as many exported envvars as you need (nvidia users might need a lot), but I recommend to have *at least* the shown two. You can also change the shell you launch this with, although it shouldn't matter.
|
You can add as many exported envvars as you need (Nvidia users might need a
|
||||||
|
lot), but I recommend having *at least* the shown two.
|
||||||
|
|
||||||
You should now launch Hyprland with `wrappedHl` instead of `Hyprland`. Make sure to edit your .desktop file in `/usr/share/wayland-sessions/` if you use a login manager! (You might need to put the full path in it, as login managers are usually not ran through the user account)
|
You should now launch Hyprland with `wrappedhl` instead of `Hyprland`. Make
|
||||||
|
sure to edit your `.desktop` file in `/usr/share/wayland-sessions/` if you use
|
||||||
|
a login manager! You might need to put the full path in it, as login managers
|
||||||
|
are usually not ran through the user account.
|
||||||
|
|
||||||
## Immediate
|
## Immediate
|
||||||
|
|
||||||
|
@ -49,36 +61,40 @@ Use `hyprctl monitors` to list available outputs.
|
||||||
|
|
||||||
Then, you can configure your outputs with
|
Then, you can configure your outputs with
|
||||||
|
|
||||||
```
|
```bash
|
||||||
hyprctl keyword monitor NAME,RES@HZ,OFFSET,SCALE
|
hyprctl keyword monitor NAME,RES@HZ,OFFSET,SCALE
|
||||||
```
|
```
|
||||||
|
|
||||||
`NAME` is the name of the display, e.g. `DP-1`, can be empty for a global rule.
|
`NAME` is the name of the display, e.g. `DP-1`. Can be empty for a global rule.
|
||||||
|
|
||||||
`RES@HZ` is the resolution and refresh rate, e.g. `1920x1080@144`
|
`RES@HZ` is the resolution and refresh rate, e.g. `1920x1080@144`. Can be
|
||||||
|
`preferred` for auto-detection.
|
||||||
|
|
||||||
`OFFSET` is the position of the monitor, e.g. `0x0`
|
`OFFSET` is the position of the monitor, e.g. `0x0`. Can be `auto` to
|
||||||
|
automatically add it to the right of the viewport.
|
||||||
|
|
||||||
`SCALE` is the display scale, e.g. `1`
|
`SCALE` is the display scale, e.g. `1`
|
||||||
|
|
||||||
example command:
|
example command:
|
||||||
|
|
||||||
```
|
```plain
|
||||||
hyprctl keyword monitor DP-3,1920x1080@240,1920x0,1
|
hyprctl keyword monitor DP-3,1920x1080@240,1920x0,1
|
||||||
```
|
```
|
||||||
|
|
||||||
**Warning!** These changes are **not** permanent! If you want to make those
|
{{< hint type=important >}}
|
||||||
|
These changes are **not** permanent! If you want to make those
|
||||||
changes persist, configure your outputs in the config!
|
changes persist, configure your outputs in the config!
|
||||||
|
{{< /hint >}}
|
||||||
|
|
||||||
# Proper configuring
|
# Proper configuring
|
||||||
|
|
||||||
Head onto the
|
Head onto the
|
||||||
[Master Configuring Wiki Page](https://github.com/hyprwm/Hyprland/wiki/Configuring-Hyprland)
|
[Configuring Hyprland page](../../Configuring/Configuring-Hyprland)
|
||||||
to learn all about configuring Hyprland to your likings.
|
to learn all about configuring Hyprland to your likings.
|
||||||
|
|
||||||
# Apps / X11 replacements
|
# Apps / X11 replacements
|
||||||
|
|
||||||
See the [Useful Utilities Page](https://github.com/hyprwm/Hyprland/wiki/Useful-utilities) and the
|
See the [Useful Utilities page](../../Useful-Utilities) and the
|
||||||
[Sway wiki page](https://github.com/swaywm/sway/wiki/Useful-add-ons-for-sway)
|
[Sway wiki page](https://github.com/swaywm/sway/wiki/Useful-add-ons-for-sway)
|
||||||
just about that.
|
just about that.
|
||||||
|
|
||||||
|
@ -94,11 +110,11 @@ Exit hyprland, and then:
|
||||||
- `cat /tmp/hypr/$(ls -t /tmp/hypr | head -n 1)/hyprland.log | grep monitor`
|
- `cat /tmp/hypr/$(ls -t /tmp/hypr | head -n 1)/hyprland.log | grep monitor`
|
||||||
will give you a bunch of logs about the connected monitors. Names like `DP-x`
|
will give you a bunch of logs about the connected monitors. Names like `DP-x`
|
||||||
or `HDMI-x` etc are your monitor names.
|
or `HDMI-x` etc are your monitor names.
|
||||||
- edit (with your favorite text editor) `~/.config/hypr/hyprland.conf`
|
- edit `~/.config/hypr/hyprland.conf`
|
||||||
- replace the `monitor=` line with `monitor=NAME,RES@Hz,OFFSET,SCALE`, for
|
- replace the `monitor=` line with `monitor=NAME,RES@Hz,OFFSET,SCALE`, for
|
||||||
example `monitor=DP-1,1920x1080@60,0x0,1` (See the above section titled
|
example `monitor=DP-1,1920x1080@60,0x0,1` (See [Monitors](#monitors) for
|
||||||
Monitors for more info about the values) You can also add multiple of those
|
more info about the values). You can also add multiple of those
|
||||||
for multi-mon setups.
|
for multi-montor setups.
|
||||||
|
|
||||||
After this, upon launching Hyprland again, provided you set an appropriate mode
|
After this, upon launching Hyprland again, everything should be fine,
|
||||||
for your monitors, everything should be fine.
|
provided you set an appropriate mode for your monitors.
|
||||||
|
|
Loading…
Reference in a new issue