aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorVaxry <[email protected]>2023-10-13 20:00:30 +0100
committerVaxry <[email protected]>2023-10-13 20:00:30 +0100
commit6a5b0f9c1e5604eafd3e7158cab85c1c77b1adcd (patch)
tree74b79b4b82597c8faa7d2357257de8a6b9eec350
parente4bcd2e2da3136fb55886c4f02dd4a01099e687b (diff)
downloadHyprland-6a5b0f9c1e5604eafd3e7158cab85c1c77b1adcd.tar.gz
Hyprland-6a5b0f9c1e5604eafd3e7158cab85c1c77b1adcd.zip
better cmake sutff
-rwxr-xr-x[-rw-r--r--]CMakeLists.txt24
-rw-r--r--Makefile83
-rw-r--r--hyprctl/CMakeLists.txt8
3 files changed, 43 insertions, 72 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt
index b67314bc..55bd495d 100644..100755
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -26,6 +26,27 @@ execute_process(
#
#
+# udis
+add_subdirectory("subprojects/udis86")
+
+# wlroots
+message(STATUS "Setting up wlroots")
+
+include(ExternalProject)
+string(TOLOWER ${CMAKE_BUILD_TYPE} BUILDTYPE_LOWER)
+ExternalProject_Add(
+ wlroots
+ PREFIX ${CMAKE_SOURCE_DIR}/subprojects/wlroots
+ SOURCE_DIR ${CMAKE_SOURCE_DIR}/subprojects/wlroots
+ PATCH_COMMAND sed -E -i -e "s/(soversion = 12)([^032]|$$)/soversion = 12032/g" meson.build
+ CONFIGURE_COMMAND meson setup build --buildtype=${BUILDTYPE_LOWER} -Dwerror=false -Dexamples=false -Drenderers=gles2 $<IF:$<BOOL:${WITH_ASAN}>,-Db_sanitize=address,-Db_sanitize=none> && meson setup build --buildtype=${BUILDTYPE_LOWER} -Dwerror=false -Dexamples=false -Drenderers=gles2 $<IF:$<BOOL:${WITH_ASAN}>,-Db_sanitize=address,-Db_sanitize=none> --reconfigure
+ BUILD_COMMAND ninja -C build
+ BUILD_ALWAYS true
+ BUILD_IN_SOURCE true
+ BUILD_BYPRODUCTS ${CMAKE_SOURCE_DIR}/subprojects/wlroots/build/libwlroots.so.12032
+ INSTALL_COMMAND echo "wlroots: install not needed"
+)
+
find_program(WaylandScanner NAMES wayland-scanner)
message(STATUS "Found WaylandScanner at ${WaylandScanner}")
execute_process(
@@ -201,3 +222,6 @@ protocol("staging/fractional-scale/fractional-scale-v1.xml" "fractional-scale-v1
protocol("staging/tearing-control/tearing-control-v1.xml" "tearing-control-v1" false)
protocol("unstable/text-input/text-input-unstable-v1.xml" "text-input-unstable-v1" false)
protocol("staging/cursor-shape/cursor-shape-v1.xml" "cursor-shape-v1" false)
+
+# hyprctl
+add_subdirectory(hyprctl) \ No newline at end of file
diff --git a/Makefile b/Makefile
index 6a96015c..493554fc 100644
--- a/Makefile
+++ b/Makefile
@@ -23,32 +23,20 @@ debug:
clear:
rm -rf build
rm -f ./protocols/*-protocol.h ./protocols/*-protocol.c
- rm -f ./hyprctl/hyprctl
rm -rf ./subprojects/wlroots/build
all:
+ @if [[ "$EUID" = 0 ]]; then echo -en "Avoid running $(MAKE) all as sudo.\n"; fi
$(MAKE) clear
- $(MAKE) fixwlr
- cd ./subprojects/wlroots && meson setup build/ --buildtype=release && ninja -C build/ && mkdir -p ${PREFIX}/lib/ && cp ./build/libwlroots.so.12032 ${PREFIX}/lib/ || echo "Could not install libwlroots to ${PREFIX}/lib/libwlroots.so.12032"
- cd subprojects/udis86 && cmake --no-warn-unused-cli -DCMAKE_BUILD_TYPE:STRING=Release -S . -B./build -G Ninja && cmake --build ./build --config Release --target all -j`nproc 2>/dev/null || getconf NPROCESSORS_CONF`
$(MAKE) release
- $(MAKE) -C hyprctl all
install:
- $(MAKE) clear
- $(MAKE) fixwlr
- cd ./subprojects/wlroots && meson setup build/ --buildtype=release && ninja -C build/ && mkdir -p ${PREFIX}/lib/ && cp ./build/libwlroots.so.12032 ${PREFIX}/lib/ || echo "Could not install libwlroots to ${PREFIX}/lib/libwlroots.so.12032"
- cd subprojects/udis86 && cmake --no-warn-unused-cli -DCMAKE_BUILD_TYPE:STRING=Release -S . -B./build -G Ninja && cmake --build ./build --config Release --target all -j`nproc 2>/dev/null || getconf NPROCESSORS_CONF` && cd ../..
- chmod -R 777 subprojects/udis86
- chmod -R 777 subprojects/wlroots
- $(MAKE) release
- $(MAKE) -C hyprctl all
- chmod 755 ./hyprctl/hyprctl
+ @if [ ! -d ./build/Hyprland ]; then echo -en "You need to run $(MAKE) all first.\n" && exit 1; fi
mkdir -p ${PREFIX}/share/wayland-sessions
mkdir -p ${PREFIX}/bin
cp -f ./build/Hyprland ${PREFIX}/bin
- cp -f ./hyprctl/hyprctl ${PREFIX}/bin
+ cp -f ./build/hyprctl/hyprctl ${PREFIX}/bin
chmod 755 ${PREFIX}/bin/Hyprland
chmod 755 ${PREFIX}/bin/hyprctl
if [ ! -f ${PREFIX}/share/wayland-sessions/hyprland.desktop ]; then cp ./example/hyprland.desktop ${PREFIX}/share/wayland-sessions; fi
@@ -58,26 +46,10 @@ install:
mkdir -p ${PREFIX}/share/man/man1
install -m644 ./docs/*.1 ${PREFIX}/share/man/man1
- mkdir -p ${PREFIX}/include/hyprland
- mkdir -p ${PREFIX}/include/hyprland/protocols
- mkdir -p ${PREFIX}/include/hyprland/wlroots
- mkdir -p ${PREFIX}/share/pkgconfig
- mkdir -p ${PREFIX}/share/xdg-desktop-portal
-
- find src -name '*.h*' -print0 | cpio --quiet -0dump ${PREFIX}/include/hyprland
- cd subprojects/wlroots/include && find . -name '*.h*' -print0 | cpio --quiet -0dump ${PREFIX}/include/hyprland/wlroots && cd ../../..
- cd subprojects/wlroots/build/include && find . -name '*.h*' -print0 | cpio --quiet -0dump ${PREFIX}/include/hyprland/wlroots && cd ../../../..
- cp ./protocols/*-protocol.h ${PREFIX}/include/hyprland/protocols
- cp ./build/hyprland.pc ${PREFIX}/share/pkgconfig
- cp ./assets/hyprland-portals.conf ${PREFIX}/share/xdg-desktop-portal/
- if [ -d /usr/share/pkgconfig ]; then cp ./build/hyprland.pc /usr/share/pkgconfig 2>/dev/null || true; fi
+ mkdir -p ${PREFIX}/lib/
+ cp ./build/libwlroots.so.12032 ${PREFIX}/lib/
- chmod -R 755 ${PREFIX}/include/hyprland
- chmod 755 ${PREFIX}/share/pkgconfig
-
-cleaninstall:
- echo -en "$(MAKE) cleaninstall has been DEPRECATED, you should avoid using it in the future.\nRunning $(MAKE) install instead...\n"
- $(MAKE) install
+ $(MAKE) installheaders
uninstall:
rm -f ${PREFIX}/share/wayland-sessions/hyprland.desktop
@@ -88,37 +60,12 @@ uninstall:
rm -f ${PREFIX}/share/man/man1/Hyprland.1
rm -f ${PREFIX}/share/man/man1/hyprctl.1
-fixwlr:
- sed -E -i -e 's/(soversion = 12)([^032]|$$)/soversion = 12032/g' subprojects/wlroots/meson.build
-
- rm -rf ./subprojects/wlroots/build
-
-config:
- $(MAKE) fixwlr
-
- meson setup subprojects/wlroots/build subprojects/wlroots --prefix=${PREFIX} --buildtype=release -Dwerror=false -Dexamples=false -Drenderers="gles2"
- ninja -C subprojects/wlroots/build/
-
- ninja -C subprojects/wlroots/build/ install
-
- chmod -R 777 subprojects/wlroots
-
- cd subprojects/udis86 && cmake --no-warn-unused-cli -DCMAKE_BUILD_TYPE:STRING=Release -S . -B ./build -G Ninja && cmake --build ./build --config Release --target all -j`nproc 2>/dev/null || getconf NPROCESSORS_CONF`
-
- chmod -R 777 subprojects/udis86
-
pluginenv:
- cd subprojects/udis86 && cmake --no-warn-unused-cli -DCMAKE_BUILD_TYPE:STRING=Release -S . -B ./build -G Ninja && cmake --build ./build --config Release --target all -j`nproc 2>/dev/null || getconf NPROCESSORS_CONF`
-
- $(MAKE) fixwlr
-
- meson setup subprojects/wlroots/build subprojects/wlroots --prefix=${PREFIX} --buildtype=release -Dwerror=false -Dexamples=false
- ninja -C subprojects/wlroots/build/
-
- chmod -R 777 subprojects/udis86
- chmod -R 777 subprojects/wlroots
-
- cmake --no-warn-unused-cli -DCMAKE_BUILD_TYPE:STRING=Release -S . -B ./build -G Ninja
+ @echo -en "$(MAKE) pluginenv has been deprecated.\nPlease run $(MAKE) all && sudo $(MAKE) installheaders\n"
+ @exit 1
+
+installheaders:
+ @if [ ! -d ./build/Hyprland ]; then echo -en "You need to run $(MAKE) all first.\n" && exit 1; fi
mkdir -p ${PREFIX}/include/hyprland
mkdir -p ${PREFIX}/include/hyprland/protocols
@@ -135,14 +82,6 @@ pluginenv:
chmod -R 755 ${PREFIX}/include/hyprland
chmod 755 ${PREFIX}/share/pkgconfig
-configdebug:
- $(MAKE) fixwlr
-
- meson setup subprojects/wlroots/build subprojects/wlroots --prefix=${PREFIX} --buildtype=debug -Dwerror=false -Dexamples=false -Drenderers="gles2" -Db_sanitize=address
- ninja -C subprojects/wlroots/build/
-
- ninja -C subprojects/wlroots/build/ install
-
man:
pandoc ./docs/Hyprland.1.rst \
--standalone \
diff --git a/hyprctl/CMakeLists.txt b/hyprctl/CMakeLists.txt
new file mode 100644
index 00000000..99964b50
--- /dev/null
+++ b/hyprctl/CMakeLists.txt
@@ -0,0 +1,8 @@
+cmake_minimum_required(VERSION 3.19)
+
+project(
+ hyprctl
+ DESCRIPTION "Control utility for Hyprland"
+)
+
+add_executable(hyprctl "main.cpp") \ No newline at end of file