aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorrezny <rezny@FreeBSD.org>2017-08-28 03:27:38 +0800
committerrezny <rezny@FreeBSD.org>2017-08-28 03:27:38 +0800
commit21e79f1d734d865c1e4aae51d82624096c41aa00 (patch)
tree940206f3ec40c84fa112084149b9d098d133be0b
parent26b2eaa95ad92f783c07429424fba89b893789c4 (diff)
downloadfreebsd-ports-gnome-21e79f1d734d865c1e4aae51d82624096c41aa00.tar.gz
freebsd-ports-gnome-21e79f1d734d865c1e4aae51d82624096c41aa00.tar.zst
freebsd-ports-gnome-21e79f1d734d865c1e4aae51d82624096c41aa00.zip
Set correct $displayname and remove expr GNUisms
PR: 220668 Reported by: parakleta@darkreality.org, wulf
-rw-r--r--x11/xinit/Makefile1
-rw-r--r--x11/xinit/files/patch-startx.cpp49
2 files changed, 50 insertions, 0 deletions
diff --git a/x11/xinit/Makefile b/x11/xinit/Makefile
index f8288f18c306..97c700729cba 100644
--- a/x11/xinit/Makefile
+++ b/x11/xinit/Makefile
@@ -2,6 +2,7 @@
PORTNAME= xinit
PORTVERSION= 1.3.4
+PORTREVISION= 1
PORTEPOCH= 1
CATEGORIES= x11
diff --git a/x11/xinit/files/patch-startx.cpp b/x11/xinit/files/patch-startx.cpp
new file mode 100644
index 000000000000..e3b3c01e9deb
--- /dev/null
+++ b/x11/xinit/files/patch-startx.cpp
@@ -0,0 +1,49 @@
+# remove expr GNUisms: use BRE syntax and remove match, based on
+# upstream commit e3bab0cc706880c22f2b205e7abad9d8c0227071, but
+# also shield expr from leading dash of X server args.
+#
+# generate displayname as dictated in the xauth manpage
+#
+--- startx.cpp.orig 2014-09-11 17:31:42 UTC
++++ startx.cpp
+@@ -154,7 +154,7 @@ while [ x"$1" != x ]; do
+ else
+ XCOMM display must be the FIRST server argument
+ if [ x"$serverargs" = x ] && @@
+- expr "$1" : ':[0-9][0-9]*$' > /dev/null 2>&1; then
++ expr \( "$1" \) : ':[0-9][0-9]*$' > /dev/null 2>&1; then
+ display="$1"
+ else
+ serverargs="$serverargs $1"
+@@ -193,7 +193,7 @@ if [ x"$server" = x ]; then
+ XCOMM the startx session being seen as inactive:
+ XCOMM "https://bugzilla.redhat.com/show_bug.cgi?id=806491"
+ tty=$(tty)
+- if expr match "$tty" '^/dev/tty[0-9]\+$' > /dev/null; then
++ if expr "$tty" : '/dev/tty[0-9][0-9]*$' > /dev/null; then
+ tty_num=$(echo "$tty" | grep -oE '[0-9]+$')
+ vtarg="vt$tty_num"
+ fi
+@@ -217,7 +217,7 @@ fi
+ XCOMM if no vt is specified add vtarg (which may be empty)
+ have_vtarg="no"
+ for i in $serverargs; do
+- if expr match "$i" '^vt[0-9]\+$' > /dev/null; then
++ if expr \( "$i" \) : 'vt[0-9][0-9]*$' > /dev/null; then
+ have_vtarg="yes"
+ fi
+ done
+@@ -283,10 +283,10 @@ EOF
+
+ XCOMM now add the same credentials to the client authority file
+ XCOMM if '$displayname' already exists do not overwrite it as another
+- XCOMM server man need it. Add them to the '$xserverauthfile' instead.
+- for displayname in $authdisplay $hostname$authdisplay; do
++ XCOMM server may need it. Add them to the '$xserverauthfile' instead.
++ for displayname in $authdisplay $hostname/unix$authdisplay; do
+ authcookie=`XAUTH list "$displayname" @@
+- | sed -n "s/.*$displayname[[:space:]*].*[[:space:]*]//p"` 2>/dev/null;
++ | sed -n "s|.*$displayname[[:space:]*].*[[:space:]*]||p"` 2>/dev/null;
+ if [ "z${authcookie}" = "z" ] ; then
+ XAUTH -q << EOF
+ add $displayname . $mcookie