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:
parent
7c1101dc08
commit
7c081505e5
3
.gitignore
vendored
3
.gitignore
vendored
@ -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
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
31
configure.ac
31
configure.ac
@ -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) { }
|
||||||
]])],
|
]])],
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user