guix-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: Installing manually built software in Guix


From: Mark H Weaver
Subject: Re: Installing manually built software in Guix
Date: Sat, 08 Feb 2014 23:50:30 -0500
User-agent: Gnus/5.13 (Gnus v5.13) Emacs/24.3 (gnu/linux)

Hi Ludovic,

address@hidden (Ludovic Courtès) writes:

> Mark H Weaver <address@hidden> skribis:
>
>> As a Guile developer, I'm in the habit of building Guile from git, and
>> occasionally installing that version with --prefix=/usr.
>>
>> As a Guix enthusiast, I've recently been experimenting with building
>> Guile from git, with my environment variables set to attempt to use only
>> things from Guix:
>
> I’ve been doing something similar.
>
>> I just tried "make install", as root, with these same environment
>> variable settings (but with HOME=/home/mhw).  It failed in the middle.
>> Here's the tail of the log:
>>
>> make[2]: Entering directory `/home/mhw/guile/guile-readline'
>> make  install-am
>> make[3]: Entering directory `/home/mhw/guile/guile-readline'
>> make[4]: Entering directory `/home/mhw/guile/guile-readline'
>>  /home/mhw/.guix-profile/bin/mkdir -p '/usr/lib'
>>  /bin/bash ../libtool   --mode=install /home/mhw/.guix-profile/bin/install 
>> -c   libguilereadline-v-18.la '/usr/lib'
>> libtool: install: warning: relinking `libguilereadline-v-18.la'
>> libtool: install: (cd /home/mhw/guile/guile-readline; /bin/bash
>> /home/mhw/guile/libtool --silent --tag CC --mode=relink gcc -Wall
>> -Wmissing-prototypes -Wdeclaration-after-statement -Wpointer-arith
>> -Wswitch-enum -fno-strict-aliasing
>> -I/nix/store/a9j9bl7m73rhlal9z83z3wbl9m17di4i-libgc-7.4.0/include -g
>> -O2 -version-info 18:0:0 -export-dynamic -no-undefined -o
>> libguilereadline-v-18.la -rpath /usr/lib readline.lo -lreadline
>> -lncurses ../libguile/libguile-2.0.la ../lib/libgnu.la -lcrypt -lm )
>> libtool: relink: warning: `/home/mhw/.guix-profile/lib/libunistring.la' 
>> seems to be moved
>> libtool: relink: warning: `/home/mhw/.guix-profile/lib/libgmp.la' seems to 
>> be moved
>> libtool: relink: warning: `/home/mhw/.guix-profile/lib/libltdl.la' seems to 
>> be moved
>> /usr/lib/libgc.so: could not read symbols: File in wrong format
>> collect2: error: ld returned 1 exit status
>
> Here it’s trying to use the “wrong” libgc, which is itself possibly
> linked with a different libc.
>
> Can you try installing libgc from Guix, and make sure it’s the one
> that’s picked up when building Guile?

I already had libgc from Guix, and indeed it was the one picked up by
Guile.  The problem seems to be limited to guile-readline.

I guess the problem might be related to an "-rpath /usr/lib" that ends
up in 'relink_command' in guile-readline/libguilereadline-v-18.la:

--8<---------------cut here---------------start------------->8---
# Directory that this library needs to be installed in:
libdir='/usr/lib'
relink_command="(cd /home/mhw/guile/guile-readline; /bin/bash 
/home/mhw/guile/libtool  --silent --tag CC --mode=relink gcc -Wall 
-Wmissing-prototypes -Wdeclaration-after-statement -Wpointer-arith 
-Wswitch-enum -fno-strict-aliasing 
-I/nix/store/a9j9bl7m73rhlal9z83z3wbl9m17di4i-libgc-7.4.0/include -g -O2 
-version-info 18:0:0 -export-dynamic -no-undefined -o libguilereadline-v-18.la 
-rpath /usr/lib readline.lo -lreadline -lncurses ../libguile/libguile-2.0.la 
../lib/libgnu.la -lcrypt -lm @inst_prefix_dir@)"
--8<---------------cut here---------------end--------------->8---

I'm not sure why libtool is putting that rpath in there, but here are
some possibly relevant lines from config.log:

--8<---------------cut here---------------start------------->8---
BDW_GC_LIBS='-L/nix/store/a9j9bl7m73rhlal9z83z3wbl9m17di4i-libgc-7.4.0/lib -lgc 
 '
GUILE_LIBS='  -lcrypt -lm '
INTL_MACOSX_LIBS=''
LIBFFI_LIBS='-L/nix/store/49535xllwsa3mwddjj1hny84l0p7c453-libffi-3.0.13/lib 
-lffi  '
PTHREAD_LIBS=''
READLINE_LIBS='-lreadline -lncurses '
--8<---------------cut here---------------end--------------->8---

All of the libraries listed above are in ~/.guix-profile/lib, but it
seems that only the ones that are found using 'pkg-config' end up with
corresponding -L arguments.

Also possibly relevant: I don't have LD_LIBRARY_PATH set.  Should I?

The only environment variables I have pointing to anything Guix-related
are the ones I listed in my previous email.  Am I missing anything?

   Thanks,
     Mark



reply via email to

[Prev in Thread] Current Thread [Next in Thread]