1
0
mirror of git://sigrok.org/libserialport synced 2023-08-10 21:13:24 +03:00

Generate a config.h rather than passing defines on command line.

Fixes bug #553.
This commit is contained in:
Martin Ling 2015-03-24 23:15:32 +00:00
parent 7c1101dc08
commit 7c081505e5
4 changed files with 29 additions and 8 deletions

3
.gitignore vendored
View File

@ -6,6 +6,8 @@ Makefile.in
aclocal.m4 aclocal.m4
autom4te.cache/ autom4te.cache/
autostuff/ autostuff/
config.h.in
config.h
config.log config.log
config.status config.status
configure configure
@ -13,5 +15,6 @@ libserialport.la
libserialport.pc libserialport.pc
libserialport.h libserialport.h
libtool libtool
stamp-h1
*.o *.o
*.lo *.lo

View File

@ -55,6 +55,7 @@ fi
echo "Generating build system..." echo "Generating build system..."
${LIBTOOLIZE} --install --copy --quiet || exit 1 ${LIBTOOLIZE} --install --copy --quiet || exit 1
aclocal ${ACLOCAL_DIR} || exit 1 aclocal ${ACLOCAL_DIR} || exit 1
autoheader || exit 1
automake --add-missing --copy || exit 1 automake --add-missing --copy || exit 1
autoconf || exit 1 autoconf || exit 1

View File

@ -29,6 +29,7 @@ m4_define([sp_package_version], [sp_package_version_major.sp_package_version_min
AC_INIT([libserialport], [sp_package_version], [martin-libserialport@earth.li], AC_INIT([libserialport], [sp_package_version], [martin-libserialport@earth.li],
[libserialport], [http://sigrok.org/wiki/Libserialport]) [libserialport], [http://sigrok.org/wiki/Libserialport])
AC_CONFIG_HEADERS([config.h])
AC_CONFIG_MACRO_DIR([autostuff]) AC_CONFIG_MACRO_DIR([autostuff])
AC_CONFIG_AUX_DIR([autostuff]) AC_CONFIG_AUX_DIR([autostuff])
@ -111,8 +112,8 @@ mingw* | cygwin*)
AM_CONDITIONAL([WIN32], false) AM_CONDITIONAL([WIN32], false)
AM_CONDITIONAL([MACOSX], false) AM_CONDITIONAL([MACOSX], false)
AM_CONDITIONAL([FREEBSD], false) AM_CONDITIONAL([FREEBSD], false)
AC_DEFINE(NO_ENUMERATION) AC_DEFINE(NO_ENUMERATION,,[Enumeration is unsupported])
AC_DEFINE(NO_PORT_METADATA) AC_DEFINE(NO_PORT_METADATA,,[Port metadata is unavailable])
esac esac
AC_SUBST(SP_PKGLIBS) AC_SUBST(SP_PKGLIBS)
@ -122,12 +123,22 @@ AC_SUBST(SP_LIBS)
AC_TYPE_SIZE_T AC_TYPE_SIZE_T
# Check for specific termios structures. # Check for specific termios structures.
AC_CHECK_TYPE([struct termios2], [AC_DEFINE(HAVE_TERMIOS2, 1)], [], [[#include <linux/termios.h>]]) AC_CHECK_TYPE([struct termios2],
AC_CHECK_TYPE([struct termiox], [AC_DEFINE(HAVE_TERMIOX, 1)], [], [[#include <linux/termios.h>]]) [AC_DEFINE(HAVE_TERMIOS2, 1,
[struct termios2 is available.])],
[], [[#include <linux/termios.h>]])
AC_CHECK_TYPE([struct termiox],
[AC_DEFINE(HAVE_TERMIOX, 1,
[struct termiox is available.])],
[], [[#include <linux/termios.h>]])
AC_CHECK_MEMBERS([struct termios.c_ispeed, struct termios.c_ospeed], AC_CHECK_MEMBERS([struct termios.c_ispeed, struct termios.c_ospeed],
[AC_DEFINE(HAVE_TERMIOS_SPEED, 1)], [], [[#include <linux/termios.h>]]) [AC_DEFINE(HAVE_TERMIOS_SPEED, 1,
[struct termios has c_ispeed/c_ospeed.])],
[], [[#include <linux/termios.h>]])
AC_CHECK_MEMBERS([struct termios2.c_ispeed, struct termios2.c_ospeed], AC_CHECK_MEMBERS([struct termios2.c_ispeed, struct termios2.c_ospeed],
[AC_DEFINE(HAVE_TERMIOS2_SPEED, 1)], [], [[#include <linux/termios.h>]]) [AC_DEFINE(HAVE_TERMIOS2_SPEED, 1,
[struct termios2 has c_ispeed/c_ospeed.])],
[], [[#include <linux/termios.h>]])
# Check for the BOTHER definition, needed for setting arbitrary baud rates. # Check for the BOTHER definition, needed for setting arbitrary baud rates.
# We can't just #ifdef BOTHER in the code, because of the separation between # We can't just #ifdef BOTHER in the code, because of the separation between
@ -141,14 +152,18 @@ AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
#error BOTHER is not defined #error BOTHER is not defined
#endif #endif
]])], ]])],
[AC_DEFINE(HAVE_BOTHER, 1) [AC_DEFINE(HAVE_BOTHER, 1, [BOTHER macro is available])
AC_MSG_RESULT([yes])], [AC_MSG_RESULT([no])]) AC_MSG_RESULT([yes])], [AC_MSG_RESULT([no])])
# Check for serial_struct. # Check for serial_struct.
AC_CHECK_TYPE([struct serial_struct], [AC_DEFINE(HAVE_SERIAL_STRUCT, 1)], AC_CHECK_TYPE([struct serial_struct],
[AC_DEFINE(HAVE_SERIAL_STRUCT, 1,
[struct serial is available.])],
[], [[#include <linux/serial.h>]]) [], [[#include <linux/serial.h>]])
saved="$CFLAGS"; CFLAGS="$CFLAGS -Werror" saved="$CFLAGS"; CFLAGS="$CFLAGS -Werror"
AC_DEFINE(SP_API,,[Macro preceding public API functions])
AC_DEFINE(SP_PRIV,,[Macro preceding private functions])
AC_COMPILE_IFELSE([AC_LANG_SOURCE([[ AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
__attribute__((visibility("hidden"))) void foo(void) { } __attribute__((visibility("hidden"))) void foo(void) { }
]])], ]])],

View File

@ -18,6 +18,8 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>. * along with this program. If not, see <http://www.gnu.org/licenses/>.
*/ */
#include "config.h"
#ifdef __linux__ #ifdef __linux__
#define _BSD_SOURCE // for timeradd, timersub, timercmp #define _BSD_SOURCE // for timeradd, timersub, timercmp
#endif #endif