mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-11-10 05:03:43 +01:00
Implement --with-libevent-dir. Improve libevent search techniques. May be buggy as my old apartment.
svn:r5870
This commit is contained in:
parent
35f91db15f
commit
b28dbb5b99
172
configure.in
172
configure.in
@ -56,6 +56,7 @@ AC_PROG_RANLIB
|
||||
|
||||
# The big search for OpenSSL
|
||||
# copied from openssh's configure.ac
|
||||
tryssldir=""
|
||||
AC_ARG_WITH(ssl-dir,
|
||||
[ --with-ssl-dir=PATH Specify path to OpenSSL installation ],
|
||||
[
|
||||
@ -65,6 +66,16 @@ AC_ARG_WITH(ssl-dir,
|
||||
]
|
||||
)
|
||||
|
||||
trylibeventdir=""
|
||||
AC_ARG_WITH(libevent-dir,
|
||||
[ --with-libevent-dir=PATH Specify path to Libevent installation ],
|
||||
[
|
||||
if test "x$withval" != "xno" ; then
|
||||
trylibeventdir=$withval
|
||||
fi
|
||||
]
|
||||
)
|
||||
|
||||
TORUSER=_tor
|
||||
AC_ARG_WITH(tor-user,
|
||||
[ --with-tor-user=NAME Specify username for tor daemon ],
|
||||
@ -95,115 +106,84 @@ fi
|
||||
dnl ------------------------------------------------------
|
||||
dnl Where do you live, libevent? And how do we call you?
|
||||
|
||||
|
||||
# Step 1. Try to link and run a program using libevent. If it works,
|
||||
# great! Just add -levent.
|
||||
AC_CACHE_CHECK([for a normal libevent], ac_cv_libevent_normal, [
|
||||
saved_LIBS="$LIBS"
|
||||
LIBS="$LIBS -levent"
|
||||
AC_TRY_RUN([
|
||||
void *event_init(void);
|
||||
int main(void)
|
||||
{
|
||||
event_init();
|
||||
return 0;
|
||||
}], ac_cv_libevent_normal=yes, ac_cv_libevent_normal=no)
|
||||
LIBS="$saved_LIBS"
|
||||
])
|
||||
|
||||
if test "$ac_cv_libevent_normal" = yes; then
|
||||
LIBS="$LIBS -levent"
|
||||
else
|
||||
AC_CACHE_CHECK([for libevent in /usr/local/lib], ac_cv_libevent_local, [
|
||||
saved_LIBS="$LIBS"
|
||||
saved_LDFLAGS="$LDFLAGS"
|
||||
LIBS="$LIBS -levent"
|
||||
LDFLAGS="$LDFLAGS -L/usr/local/lib"
|
||||
# Step 2. Otherwise, check whether adding -L/usr/local/lib allows
|
||||
# us to link. If not, assume we have no libevent at all.
|
||||
if test "x$prefix" != "xNONE" ; then
|
||||
trylibeventdir="$trylibeventdir $prefix"
|
||||
fi
|
||||
|
||||
AC_CACHE_CHECK([for libevent location], ac_cv_libevent_dir, [
|
||||
for ledir in $trylibeventdir "" /usr/local ; do
|
||||
LDFLAGS="$saved_LDFLAGS"
|
||||
LIBS="$saved_LIBS -levent"
|
||||
|
||||
# Skip the directory if it isn't there.
|
||||
if test ! -z "$ledir" -a ! -d "$ledir" ; then
|
||||
continue;
|
||||
fi
|
||||
if test ! -z "$ledir" ; then
|
||||
if test -d "$ledir/lib" ; then
|
||||
LDFLAGS="-L$ledir/lib $LDFLAGS"
|
||||
else
|
||||
LDFLAGS="-L$ledir $LDFLAGS"
|
||||
fi
|
||||
fi
|
||||
# Can I link it?
|
||||
AC_TRY_LINK([], [ void *event_init(void); event_init(); ],
|
||||
[ libevent_is_in_local=yes ], [ libevent_is_in_local=no ])
|
||||
if test $libevent_is_in_local = no ; then
|
||||
ac_cv_libevent_local=no
|
||||
[ libevent_linked=yes ], [ libevent_linked=no ])
|
||||
if test $libevent_linked = yes; then
|
||||
if test ! -z "$ledir" ; then
|
||||
ac_cv_libevent_dir=$ledir
|
||||
else
|
||||
# Step 3. Does adding -L/usr/local/lib allow us to run, too?
|
||||
# If so, all we have to do as adjust LDFLAGS and CFLAGS.
|
||||
AC_TRY_RUN([
|
||||
void *event_init(void);
|
||||
int main(void)
|
||||
{
|
||||
event_init();
|
||||
return 0;
|
||||
}], [ ac_cv_libevent_local=yes ], [ ac_cv_libevent_local=unlinked ])
|
||||
ac_cv_libevent_dir="(system)"
|
||||
fi
|
||||
if test "$GCC" = yes -a $ac_cv_libevent_local = unlinked ; then
|
||||
# Step 4. Okay, so we can link but not run. This probably means
|
||||
# that the dynamic linker doesn't have /usr/local/lib in
|
||||
# its search path. If we're lucky enough to be running
|
||||
# GCC on an ELF system, we might have a workaround for that.
|
||||
# See whether -Wl,-R/usr/local/lib makes things better.
|
||||
LDFLAGS="$LDFLAGS -Wl,-R/usr/local/lib"
|
||||
AC_TRY_RUN([
|
||||
void *event_init(void);
|
||||
int main(void)
|
||||
{
|
||||
event_init();
|
||||
return 0;
|
||||
}], [ ac_cv_libevent_local=unlinked_gcc_elf ])
|
||||
break
|
||||
fi
|
||||
|
||||
LIBS="$saved_LIBS"
|
||||
LDFLAGS="$saved_LDFLAGS" ])
|
||||
|
||||
# Now we're done. ac_vc_libevent_local could be:
|
||||
# yes -- Add -L/usr/local/lib and we can link fine.
|
||||
# unlinked_gcc_elf -- We can link, but we need to use the GCC-ELF
|
||||
# workaround. Complain a little.
|
||||
# unlinked -- We can link, but we can't run. Complain a lot.
|
||||
# no -- we can't link at all. Give an error and die.
|
||||
|
||||
if test $ac_cv_libevent_local != no; then
|
||||
done
|
||||
])
|
||||
LIBS="$LIBS -levent"
|
||||
LDFLAGS="$LDFLAGS -L/usr/local/lib"
|
||||
CPPFLAGS="$CPPFLAGS -I/usr/local/include"
|
||||
fi
|
||||
if test $ac_cv_libevent_local = unlinked_gcc_elf; then
|
||||
LDFLAGS="$LDFLAGS -Wl,-R/usr/local/lib"
|
||||
if test -f /etc/ld.so.conf ; then
|
||||
AC_MSG_NOTICE([
|
||||
Apparently, you don't have /usr/local/lib in your /etc/ld.so.conf.
|
||||
Tor is smart enought to deal this now, but other applications aren't.
|
||||
You might want to add it in.])
|
||||
fi
|
||||
fi
|
||||
|
||||
if test $ac_cv_libevent_local = unlinked ; then
|
||||
if test -f /etc/ld.so.conf ; then
|
||||
AC_MSG_NOTICE([
|
||||
=================================================
|
||||
Your libevent library is installed in /usr/local/lib,
|
||||
but your dynamic linker isn't configured to look for
|
||||
it there.
|
||||
|
||||
Maybe you need to add /usr/local/lib to /etc/ld.so.conf,
|
||||
and then run ldconfig -v ?
|
||||
=================================================])
|
||||
if test $ac_cv_libevent_dir != "(system)"; then
|
||||
if test -d "$ac_cv_libevent_dir/lib" ; then
|
||||
LDFLAGS="-L$ac_cv_libevent_dir/lib $LDFLAGS"
|
||||
le_libdir="$ac_cv_libevent_dir/lib"
|
||||
else
|
||||
AC_MSG_NOTICE([
|
||||
=================================================
|
||||
Your libevent library is installed in /usr/local/lib,
|
||||
but your dynamic linker isn't configured to look for
|
||||
it there.
|
||||
=================================================])
|
||||
LDFLAGS="-L$ac_cv_libevent_dir $LDFLAGS"
|
||||
le_libdir="$ac_cv_libevent_dir"
|
||||
fi
|
||||
if test -d "$ac_cv_libevent_dir/include" ; then
|
||||
CPPFLAGS="-I$ac_cv_libevent_dir/include $CPPFLAGS"
|
||||
else
|
||||
CPPFLAGS="-I$ac_cv_libevent_dir $CPPFLAGS"
|
||||
fi
|
||||
fi
|
||||
|
||||
if test $ac_cv_libevent_local = no ; then
|
||||
AC_MSG_ERROR([
|
||||
Tor requires libevent to build. You can download the latest
|
||||
version of libevent from http://monkey.org/~provos/libevent/])
|
||||
AC_CACHE_CHECK([whether libevent is in LDPATH], ac_cv_libevent_in_ldpath, [
|
||||
saved_LDFLAGS="$LDFLAGS"
|
||||
AC_TRY_RUN([void *event_init(void);
|
||||
int main(int c, char **v) {
|
||||
event_init(); return 0;
|
||||
}],
|
||||
libevent_runs=yes, libevent_runs=no)
|
||||
if test $libevent_runs = yes; then
|
||||
ac_cv_libevent_in_ldpath=yes
|
||||
else
|
||||
LDFLAGS="$LDFLAGS -Wl,-R$le_libdir"
|
||||
AC_TRY_RUN([void *event_init(void);
|
||||
int main(int c, char **v) {
|
||||
event_init(); return 0;
|
||||
}],
|
||||
libevent_runs_with_r=yes, libevent_runs_with_r=no)
|
||||
if test $libevent_runs_with_r = yes; then
|
||||
ac_cv_libevent_in_ldpath=no
|
||||
else
|
||||
AC_MSG_ERROR([Found linkable libevent in $ac_cv_libevent_dir, but it doesn't run, even with -R. Maybe specify another using --with-libevent-dir?])
|
||||
fi
|
||||
fi
|
||||
LDFLAGS="$saved_LDFLAGS"
|
||||
])
|
||||
|
||||
if test $ac_cv_libevent_in_ldpath = no ; then
|
||||
LDFLAGS="$LDFLAGS -Wl,-R$le_libdir"
|
||||
fi
|
||||
|
||||
dnl ------------------------------------------------------
|
||||
|
Loading…
Reference in New Issue
Block a user