X-Git-Url: http://git.liburcu.org/?p=lttv.git;a=blobdiff_plain;f=configure.ac;h=02ae6853fbbaa198be2df94a5911635a595600df;hp=416cd86187db5109a9586878e977fc71608210d9;hb=HEAD;hpb=2e589766126f5d4d3ac6fc01122eb684a12da47e diff --git a/configure.ac b/configure.ac index 416cd861..02ae6853 100644 --- a/configure.ac +++ b/configure.ac @@ -21,7 +21,7 @@ # Process this file with autoconf to produce a configure script. AC_PREREQ(2.57) -AC_INIT([lttv], [0.12.38-21032011], [yannick.brosseau@gmail.com]) +AC_INIT([lttv], [1.5], [yannick.brosseau@gmail.com]) AC_CONFIG_AUX_DIR([config]) AC_CONFIG_MACRO_DIR([config]) AM_INIT_AUTOMAKE([dist-bzip2 no-dist-gzip]) @@ -29,18 +29,8 @@ AM_SILENT_RULES([yes]) AC_CONFIG_HEADERS([config.h]) LT_INIT -# If requested, only build the ltt trace reading library -AC_ARG_WITH(lttv, - AS_HELP_STRING([--with-lttv], - [build whole LTTV system, as opposd to only the trace reading library [[default=yes]]]), - [with_lttv="$withval"], - [with_lttv="yes"]) - -# If we've requested the lib only, turn off the lttv-gui building as well -AS_IF([test "x$with_lttv" = "xno"], [with_lttv_gui="no"]) - -AM_CONDITIONAL([BUILD_LIB_ONLY], [ test "x$with_lttv" = "xno" ]) - +#Always build basic command line modules +with_lttv="yes" # If requested, avoid building LTTV part AC_ARG_WITH(lttv-gui, @@ -95,57 +85,39 @@ AS_IF([test "x$with_trace_sync" = "xyes"],[ AC_HEADER_STDC AC_CHECK_HEADERS([fcntl.h stdlib.h string.h sys/time.h unistd.h pthread.h]) -# Set compile flags to java include files if given -AC_ARG_WITH([java-jdk], - AS_HELP_STRING([--with-java-jdk=DIR], - [use java jdk from DIR. Ex : $JAVA_HOME.]), - [JAVA_SDK=$withval], - []) - -AS_IF([test $JAVA_SDK],[ - AS_IF([test -d $JAVA_SDK],[ - AC_MSG_RESULT([using java include in $JAVA_SDK]) - SUBDIRS=`find $JAVA_SDK/include -type d` - CFLAGS+=" " - CFLAGS+=`for x in $SUBDIRS; do echo -n "-I$x "; done` - CFLAGS+=" " - ],[ - AC_MSG_ERROR([Unable to find Java include files in $JAVA_JDK]) - ]) -]) - - -# Check for JNI header files if requested -AC_ARG_WITH(jni-interface, - AS_HELP_STRING([--with-jni-interface], - [build JNI interface between C and Java. Needs JNI header file. [[default=no]]]), - [with_jni_interface="$withval"], - [with_jni_interface="no"]) - -AS_IF([test "x$with_jni_interface" = "xyes"],[ - AC_CHECK_HEADERS([jni.h], [], AC_MSG_ERROR([missing jni.h -Make sure Sun Java or OpenJDK or GCJ is installed and that this header file exists in the system path. -Use --with-java-jdk=DIR flag to point to your java include files or deactivate the JNI interface.])) -]) -AM_CONDITIONAL([BUILD_JNI_INTERFACE], [ test "$with_jni_interface" = "yes" ] ) - # If we want the gui, we need additionnal flags for GTK AS_IF([test "x$with_lttv_gui" = "xyes"],[ pkg_modules="gtk+-2.0 >= 2.0.0" PKG_CHECK_MODULES(PACKAGE, [$pkg_modules]) -],[ - # Else, we still have a dependency on gmodule - # We will add flags for gmodule alone - pkg_modules="gmodule-2.0 >= 2.0.0" - PKG_CHECK_MODULES(GMODULE, [$pkg_modules]) ]) +pkg_modules="gmodule-2.0 >= 2.0.0" +PKG_CHECK_MODULES(GMODULE, [$pkg_modules]) + pkg_modules="gobject-2.0 >= 2.0.0" PKG_CHECK_MODULES(GOBJECT, [$pkg_modules]) -LIBS="$LIBS $GTK_LIBS $GOBJECT_LIBS $GMODULE_LIBS" +PKG_CHECK_MODULES(BABELTRACE, [babeltrace >= 1.1.0], [], + [AC_CHECK_LIB([babeltrace], [bt_context_create], [], + [AC_MSG_ERROR([Cannot find the babeltrace library.])] + ) + +# Check for libbabeltrace-ctf +AC_CHECK_LIB([babeltrace-ctf], [bt_ctf_iter_create], [], + [AC_MSG_ERROR([Cannot find the babeltrace-ctf library.])] + ) +]) + +AC_CHECK_LIB([babeltrace], [bt_iter_equals_pos], + [AC_DEFINE([HAVE_BT_ITER_EQUALS_POS],[],[Have equal function])], []) + +AC_CHECK_LIB([babeltrace-ctf], [bt_ctf_event_name], + [], [AC_MSG_ERROR([libbabeltrace-ctf is required in order to compile LTTV])]) + +LIBS="$LIBS $GTK_LIBS $GOBJECT_LIBS $GMODULE_LIBS $BABELTRACE_LIBS" PACKAGE_CFLAGS="$GTK_CFLAGS $GOBJECT_CFLAGS $GMODULE_CFLAGS -Wall -Wformat-security" + MODULE_CFLAGS="$PACKAGE_CFLAGS -fvisibility=hidden" MODULE_LDFLAGS="-module -avoid-version" AC_SUBST([PACKAGE_CFLAGS]) @@ -169,53 +141,45 @@ AC_CHECK_FUNCS([select]) AC_ARG_ENABLE(lttvstatic, AS_HELP_STRING([--enable-lttvstatic], [build a statically linked executable [[default=no]]]), - [with_lttvstatic="$withval"], - [with_lttvstatic="no"]) -AM_CONDITIONAL([LTTVSTATIC], [ test "x$with_lttvstatic" = "xyes" ] ) + [lttvstatic="$enableval"], + [lttvstatic="no"]) +AM_CONDITIONAL([LTTVSTATIC], [ test "x$lttvstatic" = "xyes" ] ) lttvlibdir="${libdir}/lttv" lttvplugindir="${lttvlibdir}/plugins" -#lttlibdir="${libdir}/ltt" top_lttvdir="\$(top_srcdir)/lttv" top_lttvwindowdir="\$(top_srcdir)/lttv/modules/gui/lttvwindow" DEFAULT_INCLUDES="-I\$(top_srcdir) -I\$(top_builddir) -I\$(top_lttvdir) -I\$(top_lttvwindowdir)" -lttincludedir="${includedir}/ltt" lttvincludedir="${includedir}/lttv" lttvwindowincludedir="${includedir}/lttvwindow" lttctlincludedir="${includedir}/liblttctl" AC_SUBST(lttvlibdir) AC_SUBST(lttvplugindir) -#AC_SUBST(lttlibdir) AC_SUBST(top_lttvdir) AC_SUBST(top_lttvwindowdir) AC_SUBST(DEFAULT_INCLUDES) -AC_SUBST(lttincludedir) AC_SUBST(lttvincludedir) AC_SUBST(lttvwindowincludedir) AC_SUBST(lttctlincludedir) +# ltt/Makefile + AC_CONFIG_FILES([Makefile lttv/Makefile lttv/lttv/Makefile - lttv/lttv/sync/Makefile lttv/modules/Makefile lttv/modules/text/Makefile lttv/modules/gui/Makefile lttv/modules/gui/lttvwindow/Makefile - lttv/modules/gui/interrupts/Makefile lttv/modules/gui/lttvwindow/lttvwindow/Makefile lttv/modules/gui/lttvwindow/pixmaps/Makefile lttv/modules/gui/controlflow/Makefile lttv/modules/gui/detailedevents/Makefile - lttv/modules/gui/statistics/Makefile lttv/modules/gui/histogram/Makefile - lttv/modules/gui/filter/Makefile - lttv/modules/gui/tracecontrol/Makefile lttv/modules/gui/resourceview/Makefile - ltt/Makefile doc/Makefile doc/developer/Makefile doc/developer/developer_guide/Makefile @@ -225,6 +189,32 @@ AC_CONFIG_FILES([Makefile doc/user/user_guide/Makefile doc/user/user_guide/docbook/Makefile doc/user/user_guide/html/Makefile]) +# lttv/lttv/sync/Makefile +# lttv/modules/gui/interrupts/Makefile +# lttv/modules/gui/statistics/Makefile +# lttv/modules/gui/filter/Makefile +# lttv/modules/gui/tracecontrol/Makefile + AC_OUTPUT +# Report on what will be built +AS_ECHO() +AS_ECHO("The following components will be built:") + +AS_ECHO_N("LTTV command line tool: ") +AS_IF([test "x$with_lttv" = "xyes"],[AS_ECHO("Enabled")],[AS_ECHO("Disabled")]) + +AS_ECHO_N("LTTV graphical interface: ") +AS_IF([test "x$with_lttv_gui" = "xyes"],[AS_ECHO("Enabled")],[AS_ECHO("Disabled")]) + +AS_ECHO_N("Trace synchronization: ") +AS_IF([test "x$with_trace_sync" = "xyes"],[AS_ECHO("Enabled")],[AS_ECHO("Disabled")]) + +AS_ECHO() +AS_ECHO_N("Statically linked executable: ") +AS_IF([test "x$lttvstatic" = "xyes"],[AS_ECHO("Yes")],[AS_ECHO("No")]) + +AS_ECHO() +AS_ECHO("Type 'make' to build LTTV.") +