diff options
author | Ching Pei Yang <[email protected]> | 2023-04-26 23:59:16 +0200 |
---|---|---|
committer | GitHub <[email protected]> | 2023-04-27 00:59:16 +0300 |
commit | 38bdbdb0f5356c07f077f238c4e27703e3ff4c1b (patch) | |
tree | 47a29c819d327230df1a3aae91529c0c255ca156 /Makefile | |
parent | 622132290f60a3ecc1374d1e06eb8d3ddc96af89 (diff) | |
download | Hyprland-38bdbdb0f5356c07f077f238c4e27703e3ff4c1b.tar.gz Hyprland-38bdbdb0f5356c07f077f238c4e27703e3ff4c1b.zip |
Plugin header overhaul (#2087)
* meson: install headers
* Meson/CMake: add pkg-config file for headers
* makefile: install headers and pkgconfig
* CMake: move protocols to cmake
Co-authored-by: Ching Pei Yang <[email protected]>
---------
Co-authored-by: Mihai Fufezan <[email protected]>
Co-authored-by: vaxerski <[email protected]>
Diffstat (limited to 'Makefile')
-rw-r--r-- | Makefile | 172 |
1 files changed, 9 insertions, 163 deletions
@@ -1,155 +1,4 @@ -include config.mk - -CFLAGS += -I. -DWLR_USE_UNSTABLE -std=c99 - -WAYLAND_PROTOCOLS=$(shell pkg-config --variable=pkgdatadir wayland-protocols) -WAYLAND_SCANNER=$(shell pkg-config --variable=wayland_scanner wayland-scanner) - -PKGS = wlroots wayland-server xcb xkbcommon libinput -CFLAGS += $(foreach p,$(PKGS),$(shell pkg-config --cflags $(p))) -LDLIBS += $(foreach p,$(PKGS),$(shell pkg-config --libs $(p))) - -DATE=$(shell date "+%d %b %Y") - -xdg-shell-protocol.h: - $(WAYLAND_SCANNER) server-header \ - $(WAYLAND_PROTOCOLS)/stable/xdg-shell/xdg-shell.xml $@ - -xdg-shell-protocol.c: - $(WAYLAND_SCANNER) private-code \ - $(WAYLAND_PROTOCOLS)/stable/xdg-shell/xdg-shell.xml $@ - -xdg-shell-protocol.o: xdg-shell-protocol.h - -wlr-layer-shell-unstable-v1-protocol.h: - $(WAYLAND_SCANNER) server-header \ - protocols/wlr-layer-shell-unstable-v1.xml $@ - -wlr-layer-shell-unstable-v1-protocol.c: - $(WAYLAND_SCANNER) private-code \ - protocols/wlr-layer-shell-unstable-v1.xml $@ - -wlr-layer-shell-unstable-v1-protocol.o: wlr-layer-shell-unstable-v1-protocol.h - -wlr-screencopy-unstable-v1-protocol.h: - $(WAYLAND_SCANNER) server-header \ - protocols/wlr-screencopy-unstable-v1.xml $@ - -wlr-screencopy-unstable-v1-protocol.c: - $(WAYLAND_SCANNER) private-code \ - protocols/wlr-screencopy-unstable-v1.xml $@ - -wlr-screencopy-unstable-v1-protocol.o: wlr-screencopy-unstable-v1-protocol.h - -ext-workspace-unstable-v1-protocol.h: - $(WAYLAND_SCANNER) server-header \ - protocols/ext-workspace-unstable-v1.xml $@ - -ext-workspace-unstable-v1-protocol.c: - $(WAYLAND_SCANNER) private-code \ - protocols/ext-workspace-unstable-v1.xml $@ - -ext-workspace-unstable-v1-protocol.o: ext-workspace-unstable-v1-protocol.h - -pointer-constraints-unstable-v1-protocol.h: - $(WAYLAND_SCANNER) server-header \ - protocols/pointer-constraints-unstable-v1.xml $@ - -pointer-constraints-unstable-v1-protocol.c: - $(WAYLAND_SCANNER) private-code \ - protocols/pointer-constraints-unstable-v1.xml $@ - -pointer-constraints-unstable-v1-protocol.o: pointer-constraints-unstable-v1-protocol.h - -tablet-unstable-v2-protocol.h: - $(WAYLAND_SCANNER) server-header \ - protocols/tablet-unstable-v2.xml $@ - -tablet-unstable-v2-protocol.c: - $(WAYLAND_SCANNER) private-code \ - protocols/tablet-unstable-v2.xml $@ - -tablet-unstable-v2-protocol.o: tablet-unstable-v2-protocol.h - -idle-protocol.h: - $(WAYLAND_SCANNER) server-header \ - protocols/idle.xml $@ - -idle-protocol.c: - $(WAYLAND_SCANNER) private-code \ - protocols/idle.xml $@ - -idle-protocol.o: idle-protocol.h - -wlr-output-power-management-unstable-v1-protocol.h: - $(WAYLAND_SCANNER) server-header \ - protocols/wlr-output-power-management-unstable-v1.xml $@ - -wlr-output-power-management-unstable-v1-protocol.c: - $(WAYLAND_SCANNER) private-code \ - protocols/wlr-output-power-management-unstable-v1.xml $@ - -wlr-output-power-management-unstable-v1-protocol.o: wlr-output-power-management-unstable-v1-protocol.h - -hyprland-toplevel-export-v1-protocol.h: - $(WAYLAND_SCANNER) server-header \ - subprojects/hyprland-protocols/protocols/hyprland-toplevel-export-v1.xml $@ - -hyprland-toplevel-export-v1-protocol.c: - $(WAYLAND_SCANNER) private-code \ - subprojects/hyprland-protocols/protocols/hyprland-toplevel-export-v1.xml $@ - -hyprland-toplevel-export-v1-protocol.o: hyprland-toplevel-export-v1-protocol.h - -hyprland-global-shortcuts-v1-protocol.h: - $(WAYLAND_SCANNER) server-header \ - subprojects/hyprland-protocols/protocols/hyprland-global-shortcuts-v1.xml $@ - -hyprland-global-shortcuts-v1-protocol.c: - $(WAYLAND_SCANNER) private-code \ - subprojects/hyprland-protocols/protocols/hyprland-global-shortcuts-v1.xml $@ - -hyprland-global-shortcuts-v1-protocol.o: hyprland-global-shortcuts-v1-protocol.h - -linux-dmabuf-unstable-v1-protocol.h: - $(WAYLAND_SCANNER) server-header \ - $(WAYLAND_PROTOCOLS)/unstable/linux-dmabuf/linux-dmabuf-unstable-v1.xml $@ - -linux-dmabuf-unstable-v1-protocol.c: - $(WAYLAND_SCANNER) private-code \ - $(WAYLAND_PROTOCOLS)/unstable/linux-dmabuf/linux-dmabuf-unstable-v1.xml $@ - -linux-dmabuf-unstable-v1-protocol.o: linux-dmabuf-unstable-v1-protocol.h - -wlr-foreign-toplevel-management-unstable-v1-protocol.h: - $(WAYLAND_SCANNER) server-header \ - protocols/wlr-foreign-toplevel-management-unstable-v1.xml $@ - -wlr-foreign-toplevel-management-unstable-v1-protocol.c: - $(WAYLAND_SCANNER) private-code \ - protocols/wlr-foreign-toplevel-management-unstable-v1.xml $@ - -wlr-foreign-toplevel-management-unstable-v1-protocol.o: wlr-foreign-toplevel-management-unstable-v1-protocol.h - -fractional-scale-v1-protocol.h: - $(WAYLAND_SCANNER) server-header \ - $(WAYLAND_PROTOCOLS)/staging/fractional-scale/fractional-scale-v1.xml $@ - -fractional-scale-v1-protocol.c: - $(WAYLAND_SCANNER) private-code \ - $(WAYLAND_PROTOCOLS)/staging/fractional-scale/fractional-scale-v1.xml $@ - -fractional-scale-v1-protocol.o: fractional-scale-v1-protocol.h - -text-input-unstable-v1-protocol.h: - $(WAYLAND_SCANNER) server-header \ - $(WAYLAND_PROTOCOLS)/unstable/text-input/text-input-unstable-v1.xml $@ - -text-input-unstable-v1-protocol.c: - $(WAYLAND_SCANNER) private-code \ - $(WAYLAND_PROTOCOLS)/unstable/text-input/text-input-unstable-v1.xml $@ - -text-input-unstable-v1-protocol.o: text-input-unstable-v1-protocol.h +PREFIX = /usr/local legacyrenderer: cmake --no-warn-unused-cli -DCMAKE_BUILD_TYPE:STRING=Release -DLEGACY_RENDERER:BOOL=true -S . -B ./build -G Ninja @@ -169,7 +18,7 @@ debug: clear: rm -rf build - rm -f *.o *-protocol.h *-protocol.c + rm -f ./protocols/*-protocol.h ./protocols/*-protocol.c rm -f ./hyprctl/hyprctl rm -rf ./subprojects/wlroots/build @@ -178,7 +27,6 @@ all: make fixwlr cd ./subprojects/wlroots && meson setup build/ --buildtype=release && ninja -C build/ && 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$(shell nproc) - make protocols make release make -C hyprctl all @@ -187,7 +35,6 @@ install: make fixwlr cd ./subprojects/wlroots && meson setup build/ --buildtype=release && ninja -C build/ && 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$(shell nproc) && cd ../.. - make protocols make release make -C hyprctl all @@ -202,6 +49,13 @@ install: cp ./assets/wall_8K.png ${PREFIX}/share/hyprland install -Dm644 -t ${PREFIX}/share/man/man1 ./docs/*.1 + mkdir -p ${PREFIX}/include/hyprland + + mkdir -p ${PREFIX}/include/hyprland/protocols + mkdir -p ${PREFIX}/share/pkgconfig + find src -name '*.h*' -exec cp --parents '{}' ${PREFIX}/include/hyprland ';' + cp ./protocols/*-protocol.h ${PREFIX}/include/hyprland/protocols + cp ./build/hyprland.pc ${PREFIX}/share/pkgconfig cleaninstall: echo -en "make cleaninstall has been DEPRECATED, you should avoid using it in the future.\nRunning make install instead...\n" @@ -216,16 +70,12 @@ uninstall: rm -f ${PREFIX}/share/man/man1/Hyprland.1 rm -f ${PREFIX}/share/man/man1/hyprctl.1 -protocols: xdg-shell-protocol.o wlr-layer-shell-unstable-v1-protocol.o wlr-screencopy-unstable-v1-protocol.o idle-protocol.o ext-workspace-unstable-v1-protocol.o pointer-constraints-unstable-v1-protocol.o tablet-unstable-v2-protocol.o wlr-output-power-management-unstable-v1-protocol.o linux-dmabuf-unstable-v1-protocol.o hyprland-toplevel-export-v1-protocol.o wlr-foreign-toplevel-management-unstable-v1-protocol.o fractional-scale-v1-protocol.o text-input-unstable-v1-protocol.o hyprland-global-shortcuts-v1-protocol.o - fixwlr: sed -i -E 's/(soversion = 12)([^032]|$$)/soversion = 12032/g' subprojects/wlroots/meson.build rm -rf ./subprojects/wlroots/build config: - make protocols - make fixwlr meson setup subprojects/wlroots/build subprojects/wlroots --prefix=${PREFIX} --buildtype=release -Dwerror=false -Dexamples=false @@ -236,8 +86,6 @@ config: 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$(shell nproc) pluginenv: - make protocols - 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$(shell nproc) make fixwlr @@ -246,8 +94,6 @@ pluginenv: ninja -C subprojects/wlroots/build/ configdebug: - make protocols - make fixwlr meson setup subprojects/wlroots/build subprojects/wlroots --prefix=${PREFIX} --buildtype=debug -Dwerror=false -Dexamples=false -Db_sanitize=address |