From a3292075d84892d7a63bdbc48c8cec746466a765 Mon Sep 17 00:00:00 2001 From: John Marino Date: Fri, 31 Oct 2014 13:13:09 +0000 Subject: [PATCH] lang/mono: allow overriding Environment.SpecialFolder.Personal Any port that writes to Environment.SpecialFolder.Personal during build or when running tests may end up with files outside of the stage area that aren't cleaned up by the ports framework. The issue lies with Mono looking in /etc/passwd first and only if no entry found there in $HOME. This PR was an unnoticed prerequisite for the new port games/openra. Patch based on discussion in https://github.com/mono/mono/pull/371 PR: 193426 Submitted by: Jan Beich Approved by: maintainer timeout (8 weeks) --- lang/mono/Makefile | 1 + lang/mono/files/patch-eglib_src_gmisc-unix.c | 43 ++++++++++++++++++++ 2 files changed, 44 insertions(+) create mode 100644 lang/mono/files/patch-eglib_src_gmisc-unix.c diff --git a/lang/mono/Makefile b/lang/mono/Makefile index 29a3d749c4f9..423e22940204 100644 --- a/lang/mono/Makefile +++ b/lang/mono/Makefile @@ -3,6 +3,7 @@ PORTNAME= mono PORTVERSION= 3.10.0 +PORTREVISION= 1 CATEGORIES= lang MASTER_SITES= http://download.mono-project.com/sources/${PORTNAME}/ diff --git a/lang/mono/files/patch-eglib_src_gmisc-unix.c b/lang/mono/files/patch-eglib_src_gmisc-unix.c new file mode 100644 index 000000000000..cc59be590409 --- /dev/null +++ b/lang/mono/files/patch-eglib_src_gmisc-unix.c @@ -0,0 +1,43 @@ +https://github.com/mono/mono/pull/371 + +--- eglib/src/gmisc-unix.c~ ++++ eglib/src/gmisc-unix.c +@@ -93,24 +93,27 @@ get_pw_data (void) + pthread_mutex_unlock (&pw_lock); + return; + } ++ ++ home_dir = g_getenv ("HOME"); ++ user_name = g_getenv ("USER"); ++ + #ifdef HAVE_GETPWUID_R +- if (getpwuid_r (getuid (), &pw, buf, 4096, &result) == 0) { +- home_dir = g_strdup (pw.pw_dir); +- user_name = g_strdup (pw.pw_name); ++ if (home_dir == NULL || user_name == NULL) { ++ if (getpwuid_r (getuid (), &pw, buf, 4096, &result) == 0) { ++ if (home_dir == NULL) ++ home_dir = g_strdup (pw.pw_dir); ++ if (user_name == NULL) ++ user_name = g_strdup (pw.pw_name); ++ } else { ++ if (user_name == NULL) ++ user_name = "somebody"; ++ } + } + #endif +- if (home_dir == NULL) +- home_dir = g_getenv ("HOME"); + +- if (user_name == NULL) { +- user_name = g_getenv ("USER"); +- if (user_name == NULL) +- user_name = "somebody"; +- } + pthread_mutex_unlock (&pw_lock); + } + +-/* Give preference to /etc/passwd than HOME */ + const gchar * + g_get_home_dir (void) + {