Add dohard and doset helper which die for EAPI 3. TODO: Make the die
authorZac Medico <zmedico@gentoo.org>
Fri, 24 Apr 2009 02:18:34 +0000 (02:18 -0000)
committerZac Medico <zmedico@gentoo.org>
Fri, 24 Apr 2009 02:18:34 +0000 (02:18 -0000)
helper use pipe or socket IPC instead of a signal, to avoid a potential
race condition in signal delivery. Thanks to to Tiziano Müller <dev-zero@g.o>
for the initial patch.

svn path=/main/trunk/; revision=13389

bin/banned-helper [new file with mode: 0755]
bin/ebuild-helpers/3/dohard [new symlink]
bin/ebuild-helpers/3/dosed [new symlink]
bin/ebuild-helpers/die [new file with mode: 0755]
bin/ebuild.sh

diff --git a/bin/banned-helper b/bin/banned-helper
new file mode 100755 (executable)
index 0000000..aa962a1
--- /dev/null
@@ -0,0 +1,7 @@
+#!/bin/bash
+# Copyright 2009 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+die "'${0##*/}' has been banned for EAPI '$EAPI'"
+exit 1
diff --git a/bin/ebuild-helpers/3/dohard b/bin/ebuild-helpers/3/dohard
new file mode 120000 (symlink)
index 0000000..1a6b57a
--- /dev/null
@@ -0,0 +1 @@
+../../banned-helper
\ No newline at end of file
diff --git a/bin/ebuild-helpers/3/dosed b/bin/ebuild-helpers/3/dosed
new file mode 120000 (symlink)
index 0000000..1a6b57a
--- /dev/null
@@ -0,0 +1 @@
+../../banned-helper
\ No newline at end of file
diff --git a/bin/ebuild-helpers/die b/bin/ebuild-helpers/die
new file mode 100755 (executable)
index 0000000..e871bd9
--- /dev/null
@@ -0,0 +1,12 @@
+#!/bin/bash
+# Copyright 2009 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Id$
+
+# TODO: Eliminate race condition in signal delivery by using pipe or socket
+# IPC to guarantee that the ebuild process and all of its children (including
+# this helper) are killed immediately, ensuring that "false success" is
+# impossible.
+source "${PORTAGE_BIN_PATH:-/usr/lib/portage/bin}"/isolated-functions.sh
+die "$@"
+exit 1
index 5f78c8e41c1eec171c6325a13075e20b56c58b19..9cbd748e6743a731cfeebc93254c80c16f0d9b69 100755 (executable)
@@ -56,8 +56,8 @@ qa_call() {
        return $retval
 }
 
-# subshell die support
-EBUILD_MASTER_PID=$$
+# Subshell/helper die support (must export for the die helper).
+export EBUILD_MASTER_PID=$$
 trap 'exit 1' SIGTERM
 
 EBUILD_SH_ARGS="$*"