diff options
author | Nick Mathewson <nickm@torproject.org> | 2006-01-27 00:16:06 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2006-01-27 00:16:06 +0000 |
commit | b28dbb5b9990d0a5ee0ccd8a819c11bb17de817a (patch) | |
tree | c5d5018e27c8c91db816a561dae419423c8a81d0 | |
parent | 35f91db15f00495628e023de43dc3fab0c135633 (diff) | |
download | tor-b28dbb5b9990d0a5ee0ccd8a819c11bb17de817a.tar.gz tor-b28dbb5b9990d0a5ee0ccd8a819c11bb17de817a.zip |
Implement --with-libevent-dir. Improve libevent search techniques. May be buggy as my old apartment.
svn:r5870
-rw-r--r-- | configure.in | 182 |
1 files changed, 81 insertions, 101 deletions
diff --git a/configure.in b/configure.in index 0721205266..65ce6b74c9 100644 --- a/configure.in +++ b/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? +saved_LIBS="$LIBS" +saved_LDFLAGS="$LDFLAGS" +if test "x$prefix" != "xNONE" ; then + trylibeventdir="$trylibeventdir $prefix" +fi -# 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. - 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 - 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_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 "$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 ]) + if test ! -z "$ledir" ; then + if test -d "$ledir/lib" ; then + LDFLAGS="-L$ledir/lib $LDFLAGS" + else + LDFLAGS="-L$ledir $LDFLAGS" + fi 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 - LIBS="$LIBS -levent" - LDFLAGS="$LDFLAGS -L/usr/local/lib" - CPPFLAGS="$CPPFLAGS -I/usr/local/include" + # Can I link it? + AC_TRY_LINK([], [ void *event_init(void); event_init(); ], + [ libevent_linked=yes ], [ libevent_linked=no ]) + if test $libevent_linked = yes; then + if test ! -z "$ledir" ; then + ac_cv_libevent_dir=$ledir + else + ac_cv_libevent_dir="(system)" + fi + break + fi + done +]) +LIBS="$LIBS -levent" +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 + LDFLAGS="-L$ac_cv_libevent_dir $LDFLAGS" + le_libdir="$ac_cv_libevent_dir" 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 + 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 = 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 ? -=================================================]) +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 - AC_MSG_NOTICE([ -================================================= -Your libevent library is installed in /usr/local/lib, -but your dynamic linker isn't configured to look for -it there. -=================================================]) - 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/]) - fi + 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 ------------------------------------------------------ |