summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAnderson Torres <torres.anderson.85@protonmail.com>2020-10-08 00:05:57 -0300
committerGitHub <noreply@github.com>2020-10-08 00:05:57 -0300
commit8aeaba64d757e5cc626ac525f7504308de83741f (patch)
treec701a29223d5b7d9e50ac32e18bf1a9734a4ecbe
parente4538ab8bb9066e1990f36d302c2c1aabcf8e30e (diff)
parentc9cea8264e5bb6e72f35f0f4e146bfe65cbef1a1 (diff)
Merge pull request #99604 from berbiche/cagebreak
cagebreak: init at 1.4.2
-rw-r--r--nixos/tests/all-tests.nix1
-rw-r--r--nixos/tests/cagebreak.nix98
-rw-r--r--pkgs/applications/window-managers/cagebreak/default.nix52
-rw-r--r--pkgs/top-level/all-packages.nix2
4 files changed, 153 insertions, 0 deletions
diff --git a/nixos/tests/all-tests.nix b/nixos/tests/all-tests.nix
index 8048c885e15c..0dc14e527d12 100644
--- a/nixos/tests/all-tests.nix
+++ b/nixos/tests/all-tests.nix
@@ -44,6 +44,7 @@ in
caddy = handleTest ./caddy.nix {};
cadvisor = handleTestOn ["x86_64-linux"] ./cadvisor.nix {};
cage = handleTest ./cage.nix {};
+ cagebreak = handleTest ./cagebreak.nix {};
cassandra = handleTest ./cassandra.nix {};
ceph-single-node = handleTestOn ["x86_64-linux"] ./ceph-single-node.nix {};
ceph-multi-node = handleTestOn ["x86_64-linux"] ./ceph-multi-node.nix {};
diff --git a/nixos/tests/cagebreak.nix b/nixos/tests/cagebreak.nix
new file mode 100644
index 000000000000..ecbb69646a93
--- /dev/null
+++ b/nixos/tests/cagebreak.nix
@@ -0,0 +1,98 @@
+import ./make-test-python.nix ({ pkgs, lib, ...} :
+
+let
+ cagebreakConfigfile = pkgs.writeText "config" ''
+ workspaces 1
+ escape C-t
+ bind t exec env DISPLAY=:0 ${pkgs.xterm}/bin/xterm -cm -pc
+ bind a exec ${pkgs.alacritty}/bin/alacritty
+ '';
+in
+{
+ name = "cagebreak";
+ meta = with pkgs.stdenv.lib.maintainers; {
+ maintainers = [ berbiche ];
+ };
+
+ machine = { config, ... }:
+ let
+ alice = config.users.users.alice;
+ in {
+ imports = [ ./common/user-account.nix ];
+
+ environment.systemPackages = [ pkgs.cagebreak ];
+ services.xserver = {
+ enable = true;
+ displayManager.autoLogin = {
+ enable = true;
+ user = alice.name;
+ };
+ };
+ services.xserver.windowManager.session = lib.singleton {
+ manage = "desktop";
+ name = "cagebreak";
+ start = ''
+ export XDG_RUNTIME_DIR=/run/user/${toString alice.uid}
+ ${pkgs.cagebreak}/bin/cagebreak &
+ waitPID=$!
+ '';
+ };
+
+ systemd.services.setupCagebreakConfig = {
+ wantedBy = [ "multi-user.target" ];
+ before = [ "multi-user.target" ];
+ environment = {
+ HOME = alice.home;
+ };
+ unitConfig = {
+ type = "oneshot";
+ RemainAfterExit = true;
+ user = alice.name;
+ };
+ script = ''
+ cd $HOME
+ CONFFILE=$HOME/.config/cagebreak/config
+ mkdir -p $(dirname $CONFFILE)
+ cp ${cagebreakConfigfile} $CONFFILE
+ '';
+ };
+
+ # Copied from cage:
+ # this needs a fairly recent kernel, otherwise:
+ # [backend/drm/util.c:215] Unable to add DRM framebuffer: No such file or directory
+ # [backend/drm/legacy.c:15] Virtual-1: Failed to set CRTC: No such file or directory
+ # [backend/drm/util.c:215] Unable to add DRM framebuffer: No such file or directory
+ # [backend/drm/legacy.c:15] Virtual-1: Failed to set CRTC: No such file or directory
+ # [backend/drm/drm.c:618] Failed to initialize renderer on connector 'Virtual-1': initial page-flip failed
+ # [backend/drm/drm.c:701] Failed to initialize renderer for plane
+ boot.kernelPackages = pkgs.linuxPackages_latest;
+
+ virtualisation.memorySize = 1024;
+ };
+
+ enableOCR = true;
+
+ testScript = { nodes, ... }: let
+ user = nodes.machine.config.users.users.alice;
+ in ''
+ start_all()
+ machine.wait_for_unit("multi-user.target")
+ machine.wait_for_file("/run/user/${toString user.uid}/wayland-0")
+
+ with subtest("ensure wayland works with alacritty"):
+ machine.send_key("ctrl-t")
+ machine.send_key("a")
+ machine.wait_until_succeeds("pgrep alacritty")
+ machine.wait_for_text("alice@machine")
+ machine.screenshot("screen")
+ machine.send_key("ctrl-d")
+
+ with subtest("ensure xwayland works with xterm"):
+ machine.send_key("ctrl-t")
+ machine.send_key("t")
+ machine.wait_until_succeeds("pgrep xterm")
+ machine.wait_for_text("alice@machine")
+ machine.screenshot("screen")
+ machine.send_key("ctrl-d")
+ '';
+})
diff --git a/pkgs/applications/window-managers/cagebreak/default.nix b/pkgs/applications/window-managers/cagebreak/default.nix
new file mode 100644
index 000000000000..7be643a23571
--- /dev/null
+++ b/pkgs/applications/window-managers/cagebreak/default.nix
@@ -0,0 +1,52 @@
+{ stdenv, fetchFromGitHub
+, meson, ninja, pkg-config, wayland, scdoc, makeWrapper
+, wlroots, wayland-protocols, pixman, libxkbcommon
+, cairo , pango, fontconfig, pandoc, systemd
+, withXwayland ? true, xwayland
+, nixosTests
+}:
+
+stdenv.mkDerivation rec {
+ pname = "cagebreak";
+ version = "1.4.2";
+
+ src = fetchFromGitHub {
+ owner = "project-repo";
+ repo = "cagebreak";
+ rev = version;
+ hash = "sha256-+Ww1rsUR7qe/BixLPR8GiRc3C6QmpLzWpT2wym8b4/M=";
+ };
+
+ nativeBuildInputs = [ meson ninja pkg-config wayland scdoc makeWrapper ];
+
+ buildInputs = [
+ wlroots wayland wayland-protocols pixman libxkbcommon cairo
+ pango fontconfig pandoc systemd
+ ];
+
+ outputs = [ "out" "contrib" ];
+
+ mesonFlags = [
+ "-Dxwayland=${stdenv.lib.boolToString withXwayland}"
+ "-Dversion_override=${version}"
+ ];
+
+ postInstall = ''
+ mkdir -p $contrib/share/cagebreak
+ cp $src/examples/config $contrib/share/cagebreak/config
+ '';
+
+ postFixup = stdenv.lib.optionalString withXwayland ''
+ wrapProgram $out/bin/cagebreak --prefix PATH : "${xwayland}/bin"
+ '';
+
+ passthru.tests.basic = nixosTests.cagebreak;
+
+ meta = with stdenv.lib; {
+ description = "A Wayland tiling compositor inspired by ratpoison";
+ homepage = "https://github.com/project-repo/cagebreak";
+ license = licenses.mit;
+ platforms = platforms.linux;
+ maintainers = with maintainers; [ berbiche ];
+ };
+}
diff --git a/pkgs/top-level/all-packages.nix b/pkgs/top-level/all-packages.nix
index 22817b63f1f8..7ec3297f45fb 100644
--- a/pkgs/top-level/all-packages.nix
+++ b/pkgs/top-level/all-packages.nix
@@ -28226,4 +28226,6 @@ in
bottom = callPackage ../tools/system/bottom {};
+ cagebreak = callPackage ../applications/window-managers/cagebreak/default.nix {};
+
}