Commit 7129187f authored by Pieter Hintjens's avatar Pieter Hintjens

Problem: getting various warnings in tweetnacl

libzmq used to switch off pedantic checks when using tweetnacl. As
this is now the default, that means pedantic checks are always off.
This is not good.

Solution: in tweetnacl.c alone, use a GCC pragma to disable sign
comparison warnings. We could also clean the code up yet this is
simpler. In other code, we still want those warnings, hence I've
used a pragma rather than global compile option.

Second, use -Wno-long-long all the time, as this warning does not
work with a pragma.

I removed code that set -wno-long-long, for MinGW and Solaris.

Related problem 2: --with-relaxed is badly named

This option switches off pedantic checks, so should be called
--disable-pedantic. 'with' is for optional packages.
parent 3443da21
...@@ -24,6 +24,9 @@ autom4te.cache ...@@ -24,6 +24,9 @@ autom4te.cache
*.ps *.ps
*~ *~
.*~ .*~
.deps
.dirstamp
.libs
curve_keygen curve_keygen
test_heartbeats test_heartbeats
test_msg_ffn test_msg_ffn
......
...@@ -101,17 +101,9 @@ AC_RUN_IFELSE( ...@@ -101,17 +101,9 @@ AC_RUN_IFELSE(
AC_MSG_RESULT([$libzmq_tipc_support]) AC_MSG_RESULT([$libzmq_tipc_support])
AC_ARG_WITH([relaxed], AC_ARG_ENABLE([pedantic],
[AS_HELP_STRING([--with-relaxed], [AS_HELP_STRING([--disable-pedantic], [disable pedantic compiler checks [default=enabled]])],
[switch off pedantic compiler])], [libzmq_pedantic=$enableval], [libzmq_pedantic=yes])
[zmq_relaxed="yes"],
[])
if test "x$zmq_relaxed" = "xyes"; then
libzmq_pedantic="no"
else
libzmq_pedantic="yes"
fi
AC_ARG_WITH([militant], AC_ARG_WITH([militant],
[AS_HELP_STRING([--with-militant], [AS_HELP_STRING([--with-militant],
...@@ -137,8 +129,8 @@ libzmq_on_android="no" ...@@ -137,8 +129,8 @@ libzmq_on_android="no"
libzmq_on_linux="no" libzmq_on_linux="no"
libzmq_on_gnu="no" libzmq_on_gnu="no"
# Set some default features required by 0MQ code. # Set some default features required by ZeroMQ code
CPPFLAGS="-D_REENTRANT -D_THREAD_SAFE $CPPFLAGS" CPPFLAGS="-D_REENTRANT -D_THREAD_SAFE -Wno-long-long $CPPFLAGS"
# For host type checks # For host type checks
AC_CANONICAL_HOST AC_CANONICAL_HOST
...@@ -255,10 +247,6 @@ case "${host_os}" in ...@@ -255,10 +247,6 @@ case "${host_os}" in
[AC_MSG_ERROR([cannot link with rpcrt4.dll.])]) [AC_MSG_ERROR([cannot link with rpcrt4.dll.])])
AC_CHECK_LIB(iphlpapi, main, , AC_CHECK_LIB(iphlpapi, main, ,
[AC_MSG_ERROR([cannot link with iphlpapi.dll.])]) [AC_MSG_ERROR([cannot link with iphlpapi.dll.])])
# mingw defines __int64_t as long long
AC_LANG_PUSH([C++])
LIBZMQ_CHECK_LANG_FLAG_PREPEND([-Wno-long-long])
AC_LANG_POP([C++])
libzmq_on_mingw="yes" libzmq_on_mingw="yes"
libzmq_dso_visibility="no" libzmq_dso_visibility="no"
...@@ -434,7 +422,7 @@ AS_IF([test "x$with_libsodium" = "xyes"], [ ...@@ -434,7 +422,7 @@ AS_IF([test "x$with_libsodium" = "xyes"], [
AC_ARG_ENABLE([curve], AC_ARG_ENABLE([curve],
AS_HELP_STRING([--disable-curve], [disable CURVE security [default=no]])) AS_HELP_STRING([--disable-curve], [disable CURVE security [default=no]]))
x
if test "x$enable_curve" == "xno"; then if test "x$enable_curve" == "xno"; then
curve_library="" curve_library=""
AC_MSG_NOTICE([CURVE security is disabled]) AC_MSG_NOTICE([CURVE security is disabled])
...@@ -450,7 +438,6 @@ elif test "x$with_libsodium" == "xyes"; then ...@@ -450,7 +438,6 @@ elif test "x$with_libsodium" == "xyes"; then
case "${host_os}" in case "${host_os}" in
*solaris*) *solaris*)
LDFLAGS="-lssp $LDFLAGS" LDFLAGS="-lssp $LDFLAGS"
CPPFLAGS="-Wno-long-long $CPPFLAGS"
;; ;;
esac esac
else else
...@@ -458,7 +445,6 @@ else ...@@ -458,7 +445,6 @@ else
AC_DEFINE(ZMQ_HAVE_CURVE, [1], [Using curve encryption]) AC_DEFINE(ZMQ_HAVE_CURVE, [1], [Using curve encryption])
AC_DEFINE(ZMQ_USE_TWEETNACL, [1], [Using tweetnacl for curve encryption]) AC_DEFINE(ZMQ_USE_TWEETNACL, [1], [Using tweetnacl for curve encryption])
curve_library="tweetnacl" curve_library="tweetnacl"
libzmq_pedantic="no" # Disable pedantic warnings
fi fi
AM_CONDITIONAL(USE_LIBSODIUM, test "$curve_library" == "libsodium") AM_CONDITIONAL(USE_LIBSODIUM, test "$curve_library" == "libsodium")
......
...@@ -30,6 +30,8 @@ ...@@ -30,6 +30,8 @@
#include "platform.hpp" #include "platform.hpp"
#if defined (ZMQ_USE_TWEETNACL) #if defined (ZMQ_USE_TWEETNACL)
#pragma GCC diagnostic ignored "-Wsign-compare"
#include "tweetnacl.h" #include "tweetnacl.h"
#define FOR(i,n) for (i = 0;i < n;++i) #define FOR(i,n) for (i = 0;i < n;++i)
......
...@@ -31,6 +31,7 @@ ...@@ -31,6 +31,7 @@
#define TWEETNACL_H #define TWEETNACL_H
#include "platform.hpp" #include "platform.hpp"
#if defined (ZMQ_USE_TWEETNACL) #if defined (ZMQ_USE_TWEETNACL)
#define crypto_box_SECRETKEYBYTES 32 #define crypto_box_SECRETKEYBYTES 32
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment