forked from Shinonome/dots-hyprland
62 lines
3.3 KiB
Markdown
62 lines
3.3 KiB
Markdown
# Install scripts for Gentoo
|
||
|
||
Note:
|
||
- The scripts here are **not** meant to be executed directly.
|
||
- This folder should reflect the equivalents of `/sdata/dist-arch/` but under Gentoo.
|
||
- **When `/sdata/dist-arch/` is newer than this folder, an update on this folder is very likely needed.**
|
||
- Useful link: [Commit history on sdata/dist-arch/](https://github.com/end-4/dots-hyprland/commits/main/sdata/dist-arch)
|
||
- See also [Install scripts | illogical-impulse](https://ii.clsty.link/en/dev/inst-script/)
|
||
|
||
## Contributors
|
||
- Author: [jwihardi](https://github.com/jwihardi)
|
||
|
||
|
||
## install-deps.sh
|
||
1. Enables localrepo and guru overlays if not already enabled.
|
||
2. Copies _keywords_ to _keywords-user_ and appends the correct unmask keywords for the user's architecture (adm64, arm64, and x86 are supported).
|
||
3. _keywords-user_ and _useflags_ are copies over into the proper portage directories. Quickshell also uses a live ebuild.
|
||
4. Syncs, updates, and depcleans @world.
|
||
5. Copies over the custom live ebuilds (hyprgraphics, hyprland-qt-support, hyprland-qtutils, hyprlang, hyprwayland-scanner) into localrepo and digests them.
|
||
6. Loops through all illogical-impulse ebuilds to digest and emerge them.
|
||
|
||
## install-setup.sh
|
||
1. Creates the _i2c_ group since Gentoo doesn't have this by default, then adds the user to it.
|
||
2. Enables _bluetooth_ and _ydotool_ services (systemd or openrc)
|
||
3. _icons_, _konsole_, _hypr_, and _quickshell_ are are chowned to user since they're emerge in as root by default.
|
||
4. gsettings and kwriteconfig6 are set (same as sdata/dist-arch).
|
||
|
||
## Recommended use flags (useflags)
|
||
- **The recommended useflags are not required, this is a more out of the box experience with these**
|
||
- Pipewire is used, alsa and pulseaudio are disabled (enabling them won't hurt).
|
||
- Init system is not assumed or considered so disabling systemd should be done in make.conf, same with session managers (elogind is recommended).
|
||
|
||
## Making the dot-files work
|
||
- elogind is expected to be installed and run as a service on OpenRC to set ```XDG_RUNTIME_DIR```
|
||
- NOT recommended: seatd will require more manual setup
|
||
- pipewire, pipewire-pulse, and wireplumber must be started after a dbus-session is created and before Hyprland is launched.
|
||
|
||
If you want to start after logging into tty1 you can do something like this.
|
||
```fish
|
||
if status --is-interactive; and [ (tty) = "/dev/tty1" ]
|
||
# Start DBus session if not running
|
||
if not set -q DBUS_SESSION_BUS_ADDRESS
|
||
dbus-launch --sh-syntax | sed 's/^/set -gx /; s/=/ /' | source
|
||
end
|
||
|
||
# Start PipeWire if not running
|
||
pgrep -x pipewire >/dev/null; or pipewire &
|
||
pgrep -x pipewire-pulse >/dev/null; or pipewire-pulse &
|
||
pgrep -x wireplumber >/dev/null; or wireplumber &
|
||
|
||
# Launch Hyprland with DBus session
|
||
exec Hyprland
|
||
end
|
||
```
|
||
|
||
## Known Issues
|
||
- If Hyprland is just blank, rebuild Quickshell (emerge -q gui-apps/quickshell)
|
||
- ```Hyprland: error while loading shared libraries: libhyprgraphics.so.0: cannot open shared object file: No such file or directory```
|
||
- The Hyprland live ebuild sometimes has linkage issues, deleting _Hyprland_ and _hyprland_ from ```/usr/bin/``` and then re-emerging usually fixes this.
|
||
- When emerging Hyprland if you get an issue relating to```undefined reference to `Hyprutils::Math::Vector2D::˜Vector2D()` ```
|
||
- Clear the cache folder (```rm -fr /var/tmp/portage/gui-wm/hyprland*```) then try again
|