diff options
Diffstat (limited to 'gui-wm/hyprland')
-rw-r--r-- | gui-wm/hyprland/Manifest | 6 | ||||
-rw-r--r-- | gui-wm/hyprland/files/hyprland-0.30.0-3400-fix-build.patch | 49 | ||||
-rw-r--r-- | gui-wm/hyprland/files/hyprland-0.30.0-no-wlroots-automagic-r1.patch | 18 | ||||
-rw-r--r-- | gui-wm/hyprland/hyprland-0.30.0.ebuild (renamed from gui-wm/hyprland/hyprland-0.28.0-r1.ebuild) | 29 |
4 files changed, 85 insertions, 17 deletions
diff --git a/gui-wm/hyprland/Manifest b/gui-wm/hyprland/Manifest index af5f2f0f190e..4be187989797 100644 --- a/gui-wm/hyprland/Manifest +++ b/gui-wm/hyprland/Manifest @@ -1,6 +1,8 @@ AUX hyprland-0.28.0-no-wlroots-automagic-r1.patch 880 BLAKE2B eecb42897483a41040442e2dc8a14a3ca22276a8625a15f2b43a180db5f2cdd509e186dc30271d2c2c679844082ccbb6af4d73b7a2b08eb890f1e87dcfc0f323 SHA512 5f629a3e755bf513e17f6b814001677e9c6ea0ec249030ca652dd3661180fa7ed3b85340b62c5ee7f08df29c0d0678d185c3949d1df1bbc950128028163e7a88 -DIST hyprland-0.28.0.gh.tar.gz 14060441 BLAKE2B 25059b74b67df222867e84f5f1d44219302e7e454ec68110b70d6e915e95913bfdc8c6112bc8725e9be61f10a44603a96ba70980a9835d4b7757363825b93326 SHA512 c0802f2b061d5c9265c7767fae6ddaf00c1bbf6dc620f75593ba1538f94105a9ebe1517b7be444a1e70b81fd3a4205afd8154ba9ad02b3d610b00a9440ee6a63 +AUX hyprland-0.30.0-3400-fix-build.patch 1923 BLAKE2B 57bd8c8ad0dbb308c4cc49ecebb584fb6516997d7af8e064dd5a153d5dd321d2739d9bb39cd104ef551faad307d4bd29b4446f186170fc9c6bab8039f9553f2a SHA512 8d1dd21104103ef95c6585b246eb9abd239eea20be7bea64bb9fc5b81547d910b7490df0083de9e92735b02b7995e880f1c9be0aeaf18972f515e04e6966dd97 +AUX hyprland-0.30.0-no-wlroots-automagic-r1.patch 760 BLAKE2B 386b70de5c525fb1f1258565cb6dccc7edb1561190c261885ee6603640e81f866887adbd22caf765c3c9dd5a94d03b104136f48c93be3cbcad8da0206e73dc35 SHA512 e6915957153fba06b00dcd3401e3febacca0b9976ff9ac73611732b632d55348b153132554026ebecefea63834d006c9bd57e4ecb55ecddde8add5f376364900 DIST hyprland-0.29.1.gh.tar.gz 14056843 BLAKE2B 9e9f1b15d354cf5e391b1add5dc5ce8cf2e4b206853465028a6170e613c7c5435e9a6e3318cd1006d3c2874d885128b95495bba08444fade0185b2a69d9ab950 SHA512 abbfd244b7473ec521a639b0d424e2873193ab9ef0d24e6272e15b79da9ade8ee56ea4cffdc328713f99600c1d320384839d32eb223034945659b015125e98b1 -EBUILD hyprland-0.28.0-r1.ebuild 2800 BLAKE2B 12bea435a4863101d32bdbde0bd588a0c295b6ef7b92d5511dcccc37a42ef264945f37db43861f9b53de813703eae128f0d50d7ac48aa30d4183770a32db7382 SHA512 e382b0819c2d4484d421ce69c682305b2176b1c2125dce57b6431335018b8521006c86b6d89ae9d16294cad8942222dcb5788596418f21ee6aa941ca4899f201 +DIST hyprland-0.30.0.gh.tar.gz 14064946 BLAKE2B 188328ed08ca8a9db97ae94b77159f9ebe5361a050a177ec586f376b168dab4c9dcd6b6d71d3314e9470f46b57f0610a92cdfe73ff1704b9f55f21399895e69f SHA512 f8053c19460e7768aa00944d1fc624d85ff9e042d0750a74d28e08147fe50e45262bdb1c259642bb7241746a8fb967344841e58fa598213f8c333f15246f9c94 EBUILD hyprland-0.29.1.ebuild 2576 BLAKE2B eabbf6255c19a2a200efc8c2ef77d55e1c995448af3c859a0c734f03704a1a1ff2ebacdba124e6187bc39ec283d6c86e282ccea75d3d3a600734a418d7efd30c SHA512 fa64b70fb0914beaffdc16bd50ab40c7c96f4e2f8c30b8b2cf3ed258343df8e053c844a7e4df7d6ab1801d39ad2b5e836cf421b2d8e40d90cecfced5b6592b59 +EBUILD hyprland-0.30.0.ebuild 2774 BLAKE2B b74b342882ca178e338b03d76f92296f3aa2dc2df4ea48da9aa71cfb4cea90b495301d2bc4ee963a80cc765f631f5a493202d280f37763661d43cb7d37c625ed SHA512 8e582ef86485186a8675db8fdb6e8192cbcc04b994d1334504ccb61bbe9ca0fcbb2e297f23768caf88469006b8896b9c82798874d923ba072ac2a9e4abec2111 MISC metadata.xml 716 BLAKE2B fc5248c809b9b5bf1002e3d82ff80f595b8e613d09e5541f1a0151c3ea2c117376d25fa5a40c85d254533708d9eff5339bd329b42118e87ca49e22e55c0c5d7b SHA512 31252ced2546f3686f17259aabfe9273af14f7efaf3fa0bfb446c65c6d9478be3a23c531e0ac463f27fe1d50842f6f126f32e47a8a03a345306297e182952e98 diff --git a/gui-wm/hyprland/files/hyprland-0.30.0-3400-fix-build.patch b/gui-wm/hyprland/files/hyprland-0.30.0-3400-fix-build.patch new file mode 100644 index 000000000000..3ee5ca710015 --- /dev/null +++ b/gui-wm/hyprland/files/hyprland-0.30.0-3400-fix-build.patch @@ -0,0 +1,49 @@ +From 8637bfb1b79d7778447d93349f14b86dea41d2a4 Mon Sep 17 00:00:00 2001 +From: Jan Beich <jbeich@FreeBSD.org> +Date: Sat, 23 Sep 2023 12:31:37 +0000 +Subject: [PATCH] build: Unbreak build without precompiled headers (#3400) + +* helpers: add missing header after 2e34548aea5b + +src/helpers/VarList.cpp: In constructor 'CVarList::CVarList(const std::string&, size_t, char, bool)': +src/helpers/VarList.cpp:19:34: error: 'removeBeginEndSpacesTabs' was not declared in this scope + 19 | m_vArgs.emplace_back(removeBeginEndSpacesTabs(in.substr(pos))); + | ^~~~~~~~~~~~~~~~~~~~~~~~ +src/helpers/VarList.cpp:23:30: error: 'removeBeginEndSpacesTabs' was not declared in this scope + 23 | m_vArgs.emplace_back(removeBeginEndSpacesTabs(std::string_view{s}.data())); + | ^~~~~~~~~~~~~~~~~~~~~~~~ + +* helpers: add missing C linkage after 0dbd99700319 + +ld.lld: error: undefined symbol: wlr_region_scale(pixman_region32*, pixman_region32 const*, float) +>>> referenced by Region.cpp +>>> src/Hyprland.p/helpers_Region.cpp.o:(CRegion::scale(float)) +>>> did you mean: extern "C" wlr_region_scale +>>> defined in: /usr/lib/libwlroots.so.12032 +--- + src/helpers/Region.cpp | 2 ++ + src/helpers/VarList.cpp | 1 + + 2 files changed, 3 insertions(+) + +diff --git a/src/helpers/Region.cpp b/src/helpers/Region.cpp +index e2db466438..5515e71e7e 100644 +--- a/src/helpers/Region.cpp ++++ b/src/helpers/Region.cpp +@@ -1,6 +1,8 @@ + #include "Region.hpp" ++extern "C" { + #include <wlr/util/box.h> + #include <wlr/util/region.h> ++} + + CRegion::CRegion() { + pixman_region32_init(&m_rRegion); +diff --git a/src/helpers/VarList.cpp b/src/helpers/VarList.cpp +index c29a1e9641..780ea9a045 100644 +--- a/src/helpers/VarList.cpp ++++ b/src/helpers/VarList.cpp +@@ -1,3 +1,4 @@ ++#include "MiscFunctions.hpp" + #include "VarList.hpp" + #include <ranges> + #include <algorithm> diff --git a/gui-wm/hyprland/files/hyprland-0.30.0-no-wlroots-automagic-r1.patch b/gui-wm/hyprland/files/hyprland-0.30.0-no-wlroots-automagic-r1.patch new file mode 100644 index 000000000000..452c1cc80f5e --- /dev/null +++ b/gui-wm/hyprland/files/hyprland-0.30.0-no-wlroots-automagic-r1.patch @@ -0,0 +1,18 @@ +diff --git a/meson.build b/meson.build +index d515621e..08993f8a 100644 +--- a/meson.build ++++ b/meson.build +@@ -39,7 +39,12 @@ add_project_arguments( + ], + language: 'cpp') + +-wlroots = subproject('wlroots', default_options: ['examples=false', 'renderers=gles2']) ++if get_option('xwayland').enabled() ++ wlroots = subproject('wlroots', default_options: ['backends=drm,libinput,x11','examples=false','renderers=gles2','xcb-errors=disabled','xwayland=enabled']) ++else ++ wlroots = subproject('wlroots', default_options: ['backends=drm,libinput','examples=false','renderers=gles2','xcb-errors=disabled','xwayland=disabled']) ++endif ++ + have_xwlr = wlroots.get_variable('features').get('xwayland') + xcb_dep = dependency('xcb', required: get_option('xwayland')) + diff --git a/gui-wm/hyprland/hyprland-0.28.0-r1.ebuild b/gui-wm/hyprland/hyprland-0.30.0.ebuild index 1da193f4e218..46dcb4002906 100644 --- a/gui-wm/hyprland/hyprland-0.28.0-r1.ebuild +++ b/gui-wm/hyprland/hyprland-0.30.0.ebuild @@ -70,6 +70,7 @@ DEPEND=" " BDEPEND=" ${WLROOTS_BDEPEND} + || ( >=sys-devel/gcc-13:* >=sys-devel/clang-16:* ) app-misc/jq dev-util/cmake dev-util/wayland-scanner @@ -77,18 +78,22 @@ BDEPEND=" virtual/pkgconfig " +PATCHES=( + "${FILESDIR}/hyprland-0.30.0-no-wlroots-automagic-r1.patch" + "${FILESDIR}/hyprland-0.30.0-3400-fix-build.patch" +) + pkg_setup() { [[ ${MERGE_TYPE} == binary ]] && return - if tc-is-gcc; then - STDLIBVER=$(echo '#include <string>' | $(tc-getCXX) -x c++ -dM -E - | \ - grep GLIBCXX_RELEASE | sed 's/.*\([1-9][0-9]\)/\1/') - - if ! [[ ${STDLIBVER} -ge 12 ]]; then - die "Hyprland requires >=sys-devel/gcc-12.1.0 to build" - fi - elif [[ $(clang-major-version) -lt 16 ]]; then - die "Hyprland requires >=sys-devel/clang-16.0.3 to build"; + if tc-is-gcc && ver_test $(gcc-version) -lt 13 ; then + eerror "Hyprland requires >=sys-devel/gcc-13 to build" + eerror "Please upgrade GCC: emerge -v1 sys-devel/gcc" + die "GCC version is too old to compile Hyprland!" + elif tc-is-clang && ver_test $(clang-version) -lt 16 ; then + eerror "Hyprland requires >=sys-devel/clang-16 to build" + eerror "Please upgrade Clang: emerge -v1 sys-devel/clang" + die "Clang version is too old to compile Hyprland!" fi } @@ -96,15 +101,9 @@ src_prepare() { if use video_cards_nvidia; then cd "${S}/subprojects/wlroots" || die eapply "${S}/nix/patches/wlroots-nvidia.patch" - # https://bugs.gentoo.org/911597 - # https://github.com/hyprwm/Hyprland/pull/2874 - # https://github.com/hyprwm/Hyprland/blob/main/nix/wlroots.nix#L54 - sed -i -e 's/glFlush();/glFinish();/' render/gles2/renderer.c || die cd "${S}" || die fi - eapply "${FILESDIR}/hyprland-0.28.0-no-wlroots-automagic-r1.patch" - default } |