From mboxrd@z Thu Jan 1 00:00:00 1970 From: Chris Marusich Subject: bug#30093: Installing python-ipython breaks Gnome on Fedora. Date: Sun, 14 Jan 2018 14:25:48 -0800 Message-ID: <876084dqmr.fsf@gmail.com> References: <871sitcm4j.fsf@gmail.com> Mime-Version: 1.0 Content-Type: multipart/signed; boundary="=-=-="; micalg=pgp-sha256; protocol="application/pgp-signature" Return-path: Received: from eggs.gnu.org ([2001:4830:134:3::10]:35351) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1eaqjA-00047G-GA for bug-guix@gnu.org; Sun, 14 Jan 2018 17:26:09 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1eaqj5-00021W-F3 for bug-guix@gnu.org; Sun, 14 Jan 2018 17:26:08 -0500 Received: from debbugs.gnu.org ([208.118.235.43]:48542) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1eaqj5-00021P-A1 for bug-guix@gnu.org; Sun, 14 Jan 2018 17:26:03 -0500 Received: from Debian-debbugs by debbugs.gnu.org with local (Exim 4.84_2) (envelope-from ) id 1eaqj5-00033c-4I for bug-guix@gnu.org; Sun, 14 Jan 2018 17:26:03 -0500 Sender: "Debbugs-submit" Resent-Message-ID: In-Reply-To: (Fis Trivial's message of "Sun, 14 Jan 2018 18:31:26 +0000") List-Id: Bug reports for GNU Guix List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: bug-guix-bounces+gcggb-bug-guix=m.gmane.org@gnu.org Sender: "bug-Guix" To: Fis Trivial Cc: "30093@debbugs.gnu.org" <30093@debbugs.gnu.org> --=-=-= Content-Type: text/plain Content-Transfer-Encoding: quoted-printable Fis Trivial writes: > Maybe we can Maybe we can divide those environment variables into two typ= es: > 1. Needed directly by human. For example the *PATH* environment, we= use it > to start whatever program from the shell. > 2. Environment variables only needed by programs. For examples, the > *PYTHONPATH*, or in this case *GI_TYPELIB_PATH*. > > For _type 2_, we can try to wrap every program with a simple script, and > propagate all the needed environment variables from its dependencies to t= hat > wrapping script. This should eliminate the need to put any of those envir= onment > variables into ~/.guix-profile/etc/profile, guaranteeing the safety of th= ese > variables. > > But this method won't solve all the problems. For examples *XDG_DATA_DIRS= * will > be classified as one of variables that needed by human because we need t= o use > it to find GUI programs with GUI shell, and it's also needed by some pro= grams > (a script in this case): I'm not sure this will help. As you just pointed out, the classification doesn't really match reality, which limits its usefulness. >> This sounds similar to the following bug: >> >> https://debbugs.gnu.org/cgi/bugreport.cgi?bug=3D26202 >> > To mitigate the problem in above link, which is the problem introduced by > _type 1_ variables, maybe we can treat these environment variables differ= ently. > When guix is updating it to a new value due to change of profile, it shou= ld > explicitly append the original value to the upgraded definition (explicit= ly > means writing it down in expanded form, like "/home/fis/.bin", not $HOME/= .bin or > $VARIABLE_NAME). In the above bug, there is no way guix can define the > *XDG_DATA_DIRS* earlier than the distro. (You have to run the distro then > install guix, right?). It's not perfect, but it seems to work. It sounds like you're suggesting that when Guix builds the new profile, it should take into consideration current value of the user's environment variables when building the profile. This is not permissible in the purely functional software deployment model that Guix follows. The work-around suggested in Bug 26202 is a specific, "impure" work-around for a specific problem on a specific foreign distribution, which requires a user to modify their environment outside the scope of Guix's purely functional model. In general, for any given foreign distribution, there may be other problems that occur because the environment variables set by Guix are not formed or used in precisely the way that the foreign distribution expects. These problems may require changes that are, in general, impossible for Guix to predict or (if the solution requires changes that depend impurely on the environment) impossible for Guix to make without violating the purely functional model. I suspect that this class of problem won't be easy to fix generically from within Guix. Instead, I suspect it's more realistic to look for solutions on a case-by-case basis. For example, the work-around for Bug 26202 is currently a reasonable solution for that particular issue on that particular foreign distribution. Even if we might be able to solve a particular problem like that one by introducing impurities into the build, I'm not convinced it would fix this class of problems in general. In any case, I'm afraid that the fact that it would require us to introduce impurities into the build probably makes it a non-starter for the reasons I mentioned above. Of course, if there is a way to solve this class of problem more generally without introducing impurities, that'd be great. I just can't think of one at this time. =2D-=20 Chris --=-=-= Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iQIzBAEBCAAdFiEEy/WXVcvn5+/vGD+x3UCaFdgiRp0FAlpb2OwACgkQ3UCaFdgi Rp1ATBAAwAui9DKp4jXn8RUerVeQs5hedbLYXe/atup4fuoqqYfqwnXvHyUfuqEv uAOK/N80dk8V+H2qUQmsri6JxE4OnHaOh932KBLDY2Bx4DOX2oxfo9bDMXnxxmHy 7RpvxrI5p4xHprUxtnlKJ4vgkKRo846tqxllw2HnagARb03H1tWwCdNazK2CIQF9 1IePWIHFhmWIod1FwAQZZ4l1FRNJwD738NqsZfVysWL8Urg1wfbrtgRuGckuBfhz REE4NvdBCYeeONdvlDdjac+edzwMYedE/kHGNe5eKWv+O/TCf+BiBkHsr2C56lst mJBZZhAB9Jc9BVBK0KIthuq7ehbNLZi6//Hnm4Y0D0gh9AaNUx/jIXprFMjnjr/q hgu+zvFRghnUqxZVj6yJl63Mt7QJuDnjXKvn11aCCg+dtfdAM30vRp19L/PaCvHA KHl1lng5irjsBPZDXGxu6YG8gtpAuI0b4gvhC+tu9TReQ7IWofFByXg0+Tp/EqCg f9n1S8GTLq8xLrxvFTviwP19h1dTJPnPKL4lquLmzgfovAwQ2cVXZYNrqrXHykH/ uh4TzalrtGUk+IwjL3TkadyuNpG/wDn54dFcChYGjNkx+LtH2DuPKp9Y75nEsoGD kVgE+pMZcNH/uRMxkM9DQ7yBoE5pPIvAl5B09ZxSw8JeiLyTJgE= =4KLO -----END PGP SIGNATURE----- --=-=-=--