Skip to content

Commit

Permalink
Merge branch 'master' into toni/QTUMCORE-27
Browse files Browse the repository at this point in the history
  • Loading branch information
toniqtum authored Apr 4, 2017
2 parents e0e71a3 + 1a51f52 commit 8937b05
Show file tree
Hide file tree
Showing 38 changed files with 793 additions and 62 deletions.
1 change: 0 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
*.tar.gz

*.exe
src/qtum
src/qtum-cli
src/qtum-tx
src/qtumd
Expand Down
3 changes: 3 additions & 0 deletions .gitmodules
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
[submodule "src/cpp-ethereum"]
path = src/cpp-ethereum
url = https://github.com/qtumproject/cpp-eth-qtum.git
6 changes: 6 additions & 0 deletions autogen.sh
Original file line number Diff line number Diff line change
Expand Up @@ -13,3 +13,9 @@ fi
which autoreconf >/dev/null || \
(echo "configuration failed, please install autoconf first" && exit 1)
autoreconf --install --force --warnings=all

cd src/cpp-ethereum
git submodule update --init
./scripts/install_deps.sh
cmake .
make -j `nproc`
122 changes: 122 additions & 0 deletions build-aux/m4/ax_boost_random.m4
Original file line number Diff line number Diff line change
@@ -0,0 +1,122 @@
# ===========================================================================
# http://www.gnu.org/software/autoconf-archive/ax_boost_random.html
# ===========================================================================
#
# SYNOPSIS
#
# AX_BOOST_RANDOM
#
# DESCRIPTION
#
# Test for Random library from the Boost C++ libraries. The macro requires a
# preceding call to AX_BOOST_BASE. Further documentation is available at
# <http://randspringer.de/boost/index.html>.
#
# This macro calls:
#
# AC_SUBST(BOOST_RANDOM_LIB)
#
# And sets:
#
# HAVE_BOOST_RANDOM
#
# LICENSE
#
# Copyright (c) 2008 Thomas Porschberg <[email protected]>
# Copyright (c) 2008 Michael Tindal
# Copyright (c) 2013 Daniel Casimiro <[email protected]>
#
# Copying and distribution of this file, with or without modification, are
# permitted in any medium without royalty provided the copyright notice
# and this notice are preserved. This file is offered as-is, without any
# warranty.

#serial 1

AC_DEFUN([AX_BOOST_RANDOM],
[
AC_ARG_WITH([boost-random],
AS_HELP_STRING([--with-boost-random@<:@=special-lib@:>@],
[use the Random library from boost - it is possible to specify a certain library for the linker
e.g. --with-boost-random=boost_random-gcc-mt ]), [
if test "$withval" = "no"; then
want_boost="no"
elif test "$withval" = "yes"; then
want_boost="yes"
ax_boost_user_random_lib=""
else
want_boost="yes"
ax_boost_user_random_lib="$withval"
fi
], [want_boost="yes"]
)
if test "x$want_boost" = "xyes"; then
AC_REQUIRE([AC_PROG_CC])
AC_REQUIRE([AC_CANONICAL_BUILD])
CPPFLAGS_SAVED="$CPPFLAGS"
CPPFLAGS="$CPPFLAGS $BOOST_CPPFLAGS"
export CPPFLAGS
LDFLAGS_SAVED="$LDFLAGS"
LDFLAGS="$LDFLAGS $BOOST_LDFLAGS"
export LDFLAGS
AC_CACHE_CHECK(whether the Boost::Random library is available,
ax_cv_boost_random,
[AC_LANG_PUSH([C++])
CXXFLAGS_SAVE=$CXXFLAGS
AC_COMPILE_IFELSE([AC_LANG_PROGRAM(
[[@%:@include <boost/random/random_device.hpp>]],
[[boost::random::random_device()();]])],
ax_cv_boost_random=yes, ax_cv_boost_random=no)
CXXFLAGS=$CXXFLAGS_SAVE
AC_LANG_POP([C++])
])
if test "x$ax_cv_boost_random" = "xyes"; then
AC_SUBST(BOOST_CPPFLAGS)
AC_DEFINE(HAVE_BOOST_RANDOM,,[define if the Boost::Random library is available])
BOOSTLIBDIR=`echo $BOOST_LDFLAGS | sed -e 's/@<:@^\/@:>@*//'`
if test "x$ax_boost_user_random_lib" = "x"; then
for libextension in `ls $BOOSTLIBDIR/libboost_random*.so* $BOOSTLIBDIR/libboost_random*.dylib* $BOOSTLIBDIR/libboost_random*.a* 2>/dev/null | sed 's,.*/,,' | sed -e 's;^lib\(boost_random.*\)\.so.*$;\1;' -e 's;^lib\(boost_random.*\)\.dylib.*$;\1;' -e 's;^lib\(boost_random.*\)\.a.*$;\1;'` ; do
ax_lib=${libextension}
AC_CHECK_LIB($ax_lib, exit,
[BOOST_RANDOM_LIB="-l$ax_lib"; AC_SUBST(BOOST_RANDOM_LIB) link_random="yes"; break],
[link_random="no"])
done
if test "x$link_random" != "xyes"; then
for libextension in `ls $BOOSTLIBDIR/boost_random*.dll* $BOOSTLIBDIR/boost_random*.a* 2>/dev/null | sed 's,.*/,,' | sed -e 's;^\(boost_random.*\)\.dll.*$;\1;' -e 's;^\(boost_random.*\)\.a.*$;\1;'` ; do
ax_lib=${libextension}
AC_CHECK_LIB($ax_lib, exit,
[BOOST_RANDOM_LIB="-l$ax_lib"; AC_SUBST(BOOST_RANDOM_LIB) link_random="yes"; break],
[link_random="no"])
done
fi
else
for ax_lib in $ax_boost_user_random_lib boost_random-$ax_boost_user_random_lib; do
AC_CHECK_LIB($ax_lib, exit,
[BOOST_RANDOM_LIB="-l$ax_lib"; AC_SUBST(BOOST_RANDOM_LIB) link_random="yes"; break],
[link_random="no"])
done
fi
if test "x$ax_lib" = "x"; then
AC_MSG_ERROR(Could not find a version of the library!)
fi
if test "x$link_random" = "xno"; then
AC_MSG_ERROR(Could not link against $ax_lib !)
fi
fi
CPPFLAGS="$CPPFLAGS_SAVED"
LDFLAGS="$LDFLAGS_SAVED"
fi
])
9 changes: 7 additions & 2 deletions configure.ac
Original file line number Diff line number Diff line change
Expand Up @@ -582,11 +582,15 @@ fi
LEVELDB_CPPFLAGS=
LIBLEVELDB=
LIBMEMENV=
AM_CONDITIONAL([EMBEDDED_LEVELDB],[true])
AM_CONDITIONAL([EMBEDDED_LEVELDB],[false])
AC_SUBST(LEVELDB_CPPFLAGS)
AC_SUBST(LIBLEVELDB)
AC_SUBST(LIBMEMENV)

AC_CHECK_LIB([leveldb], [main],AC_SUBST([LIBLEVELDB],[-lleveldb]), AC_MSG_ERROR(LIBLEVELDB missing))
AC_CHECK_LIB([memenv], [main],AC_SUBST([LIBMEMENV],[-lmemenv]), AC_MSG_ERROR(LIBMEMENV missing))
LIBLEVELDB="$LIBLEVELDB $LIBMEMENV"

if test x$enable_wallet != xno; then
dnl Check for libdb_cxx only if wallet enabled
BITCOIN_FIND_BDB48
Expand Down Expand Up @@ -623,6 +627,7 @@ AX_BOOST_SYSTEM
AX_BOOST_FILESYSTEM
AX_BOOST_PROGRAM_OPTIONS
AX_BOOST_THREAD
AX_BOOST_RANDOM
AX_BOOST_CHRONO


Expand Down Expand Up @@ -686,7 +691,7 @@ fi

if test x$use_boost = xyes; then

BOOST_LIBS="$BOOST_LDFLAGS $BOOST_SYSTEM_LIB $BOOST_FILESYSTEM_LIB $BOOST_PROGRAM_OPTIONS_LIB $BOOST_THREAD_LIB $BOOST_CHRONO_LIB"
BOOST_LIBS="$BOOST_LDFLAGS $BOOST_SYSTEM_LIB $BOOST_FILESYSTEM_LIB $BOOST_PROGRAM_OPTIONS_LIB $BOOST_THREAD_LIB $BOOST_CHRONO_LIB $BOOST_RANDOM_LIB"


dnl If boost (prior to 1.57) was built without c++11, it emulated scoped enums
Expand Down
65 changes: 60 additions & 5 deletions src/Makefile.am
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,8 @@ BITCOIN_INCLUDES=-I$(builddir) -I$(builddir)/obj $(BDB_CPPFLAGS) $(BOOST_CPPFLAG
BITCOIN_INCLUDES += -I$(srcdir)/secp256k1/include
BITCOIN_INCLUDES += $(UNIVALUE_CFLAGS)

BITCOIN_INCLUDES += -I$(srcdir)/cpp-ethereum/

LIBBITCOIN_SERVER=libbitcoin_server.a
LIBBITCOIN_COMMON=libbitcoin_common.a
LIBBITCOIN_CONSENSUS=libbitcoin_consensus.a
Expand All @@ -33,6 +35,19 @@ LIBBITCOIN_CRYPTO=crypto/libbitcoin_crypto.a
LIBBITCOINQT=qt/libbitcoinqt.a
LIBSECP256K1=secp256k1/libsecp256k1.la

LIBETHEREUM=cpp-ethereum/libethereum/libethereum.a
LIBDEVCORE=cpp-ethereum/libdevcore/libdevcore.a
LIBETHCORE=cpp-ethereum/libethcore/libethcore.a
LIBJSONCPP=cpp-ethereum/deps/lib/libjsoncpp.a
LIBEVM=cpp-ethereum/libevm/libevm.a
LIBEVMCORE=cpp-ethereum/libevmcore/libevmcore.a
LIBDEVCRYPTO=cpp-ethereum/libdevcrypto/libdevcrypto.a
LIBCRYPTOPP=cpp-ethereum/deps/lib/libcryptopp.a
LIBSECP256K1ETH=cpp-ethereum/deps/lib/libsecp256k1.a
LIBSCRYIPT=cpp-ethereum/utils/libscrypt/libscrypt.a
LIBETHASHSEAL=cpp-ethereum/libethashseal/libethashseal.a
LIBETHASH=cpp-ethereum/libethash/libethash.a

if ENABLE_ZMQ
LIBBITCOIN_ZMQ=libbitcoin_zmq.a
endif
Expand Down Expand Up @@ -162,7 +177,9 @@ BITCOIN_CORE_H = \
zmq/zmqabstractnotifier.h \
zmq/zmqconfig.h\
zmq/zmqnotificationinterface.h \
zmq/zmqpublishnotifier.h
zmq/zmqpublishnotifier.h \
qtum/qtumstate.h \
qtum/qtumtransaction.h


obj/build.h: FORCE
Expand Down Expand Up @@ -210,6 +227,8 @@ libbitcoin_server_a_SOURCES = \
validation.cpp \
validationinterface.cpp \
versionbits.cpp \
qtum/qtumstate.cpp \
qtum/qtumtransaction.cpp \
$(BITCOIN_CORE_H)

if ENABLE_ZMQ
Expand Down Expand Up @@ -371,7 +390,18 @@ qtumd_LDADD = \
$(LIBBITCOIN_CRYPTO) \
$(LIBLEVELDB) \
$(LIBMEMENV) \
$(LIBSECP256K1)
$(LIBETHEREUM) \
$(LIBETHASHSEAL) \
$(LIBETHASH) \
$(LIBETHCORE) \
$(LIBDEVCORE) \
$(LIBJSONCPP) \
$(LIBEVM) \
$(LIBEVMCORE) \
$(LIBDEVCRYPTO) \
$(LIBCRYPTOPP) \
$(LIBSECP256K1ETH) \
$(LIBSCRYIPT)

qtumd_LDADD += $(BOOST_LIBS) $(BDB_LIBS) $(SSL_LIBS) $(CRYPTO_LIBS) $(MINIUPNPC_LIBS) $(EVENT_PTHREADS_LIBS) $(EVENT_LIBS) $(ZMQ_LIBS)

Expand All @@ -389,7 +419,20 @@ qtum_cli_LDADD = \
$(LIBBITCOIN_CLI) \
$(LIBUNIVALUE) \
$(LIBBITCOIN_UTIL) \
$(LIBBITCOIN_CRYPTO)
$(LIBBITCOIN_CRYPTO) \
$(LIBLEVELDB) \
$(LIBETHEREUM) \
$(LIBETHASHSEAL) \
$(LIBETHASH) \
$(LIBETHCORE) \
$(LIBDEVCORE) \
$(LIBJSONCPP) \
$(LIBEVM) \
$(LIBEVMCORE) \
$(LIBDEVCRYPTO) \
$(LIBCRYPTOPP) \
$(LIBSECP256K1ETH) \
$(LIBSCRYIPT)

qtum_cli_LDADD += $(BOOST_LIBS) $(SSL_LIBS) $(CRYPTO_LIBS) $(EVENT_LIBS)
#
Expand All @@ -410,7 +453,19 @@ qtum_tx_LDADD = \
$(LIBBITCOIN_UTIL) \
$(LIBBITCOIN_CONSENSUS) \
$(LIBBITCOIN_CRYPTO) \
$(LIBSECP256K1)
$(LIBLEVELDB) \
$(LIBETHEREUM) \
$(LIBETHASHSEAL) \
$(LIBETHASH) \
$(LIBETHCORE) \
$(LIBDEVCORE) \
$(LIBJSONCPP) \
$(LIBEVM) \
$(LIBEVMCORE) \
$(LIBDEVCRYPTO) \
$(LIBCRYPTOPP) \
$(LIBSECP256K1ETH) \
$(LIBSCRYIPT)

qtum_tx_LDADD += $(BOOST_LIBS) $(CRYPTO_LIBS)
#
Expand All @@ -425,7 +480,7 @@ if GLIBC_BACK_COMPAT
endif

libbitcoinconsensus_la_LDFLAGS = $(AM_LDFLAGS) -no-undefined $(RELDFLAGS)
libbitcoinconsensus_la_LIBADD = $(LIBSECP256K1)
libbitcoinconsensus_la_LIBADD = $(LIBSECP256K1ETH)
libbitcoinconsensus_la_CPPFLAGS = $(AM_CPPFLAGS) -I$(builddir)/obj -I$(srcdir)/secp256k1/include -DBUILD_BITCOIN_INTERNAL
libbitcoinconsensus_la_CXXFLAGS = $(AM_CXXFLAGS) $(PIE_FLAGS)

Expand Down
16 changes: 14 additions & 2 deletions src/Makefile.bench.include
Original file line number Diff line number Diff line change
Expand Up @@ -39,8 +39,20 @@ bench_bench_qtum_LDADD = \
$(LIBBITCOIN_CRYPTO) \
$(LIBLEVELDB) \
$(LIBMEMENV) \
$(LIBSECP256K1) \
$(LIBUNIVALUE)
#$(LIBSECP256K1) \
$(LIBUNIVALUE) \
$(LIBETHEREUM) \
$(LIBETHASHSEAL) \
$(LIBETHASH) \
$(LIBETHCORE) \
$(LIBDEVCORE) \
$(LIBJSONCPP) \
$(LIBEVM) \
$(LIBEVMCORE) \
$(LIBDEVCRYPTO) \
$(LIBCRYPTOPP) \
$(LIBSECP256K1ETH) \
$(LIBSCRYIPT)

if ENABLE_ZMQ
bench_bench_qtum_LDADD += $(LIBBITCOIN_ZMQ) $(ZMQ_LIBS)
Expand Down
5 changes: 3 additions & 2 deletions src/Makefile.qt.include
Original file line number Diff line number Diff line change
Expand Up @@ -405,8 +405,9 @@ if ENABLE_ZMQ
qt_qtum_qt_LDADD += $(LIBBITCOIN_ZMQ) $(ZMQ_LIBS)
endif
qt_qtum_qt_LDADD += $(LIBBITCOIN_CLI) $(LIBBITCOIN_COMMON) $(LIBBITCOIN_UTIL) $(LIBBITCOIN_CONSENSUS) $(LIBBITCOIN_CRYPTO) $(LIBUNIVALUE) $(LIBLEVELDB) $(LIBMEMENV) \
$(BOOST_LIBS) $(QT_LIBS) $(QT_DBUS_LIBS) $(QR_LIBS) $(PROTOBUF_LIBS) $(BDB_LIBS) $(SSL_LIBS) $(CRYPTO_LIBS) $(MINIUPNPC_LIBS) $(LIBSECP256K1) \
$(EVENT_PTHREADS_LIBS) $(EVENT_LIBS)
$(QT_LIBS) $(QT_DBUS_LIBS) $(QR_LIBS) $(PROTOBUF_LIBS) $(BDB_LIBS) $(SSL_LIBS) $(CRYPTO_LIBS) $(MINIUPNPC_LIBS) \
$(EVENT_PTHREADS_LIBS) $(EVENT_LIBS) $(LIBLEVELDB) $(LIBMEMENV) $(LIBETHEREUM) $(LIBETHASHSEAL) $(LIBETHASH) \
$(LIBETHCORE) $(LIBDEVCORE) $(LIBJSONCPP) $(LIBEVM) $(LIBEVMCORE) $(LIBDEVCRYPTO) $(LIBCRYPTOPP) $(BOOST_LIBS) $(LIBSECP256K1ETH) $(LIBSCRYIPT)
qt_qtum_qt_LDFLAGS = $(RELDFLAGS) $(AM_LDFLAGS) $(QT_LDFLAGS) $(LIBTOOL_APP_LDFLAGS)
qt_qtum_qt_LIBTOOLFLAGS = --tag CXX

Expand Down
4 changes: 3 additions & 1 deletion src/Makefile.qttest.include
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,9 @@ if ENABLE_ZMQ
qt_test_test_qtum_qt_LDADD += $(LIBBITCOIN_ZMQ) $(ZMQ_LIBS)
endif
qt_test_test_qtum_qt_LDADD += $(LIBBITCOIN_CLI) $(LIBBITCOIN_COMMON) $(LIBBITCOIN_UTIL) $(LIBBITCOIN_CONSENSUS) $(LIBBITCOIN_CRYPTO) $(LIBUNIVALUE) $(LIBLEVELDB) \
$(LIBMEMENV) $(BOOST_LIBS) $(QT_DBUS_LIBS) $(QT_TEST_LIBS) $(QT_LIBS) \
$(LIBMEMENV) $(LIBETHEREUM) $(LIBETHASHSEAL) $(LIBETHASH) \
$(LIBETHCORE) $(LIBDEVCORE) $(LIBJSONCPP) $(LIBEVM) $(LIBEVMCORE) $(LIBDEVCRYPTO) $(LIBCRYPTOPP) \
$(BOOST_LIBS) $(LIBSECP256K1ETH) $(LIBSCRYIPT) $(BOOST_LIBS) $(QT_DBUS_LIBS) $(QT_TEST_LIBS) $(QT_LIBS) \
$(QR_LIBS) $(PROTOBUF_LIBS) $(BDB_LIBS) $(SSL_LIBS) $(CRYPTO_LIBS) $(MINIUPNPC_LIBS) $(LIBSECP256K1) \
$(EVENT_PTHREADS_LIBS) $(EVENT_LIBS)
qt_test_test_qtum_qt_LDFLAGS = $(RELDFLAGS) $(AM_LDFLAGS) $(QT_LDFLAGS) $(LIBTOOL_APP_LDFLAGS)
Expand Down
3 changes: 2 additions & 1 deletion src/Makefile.test.include
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,8 @@ endif
test_test_qtum_SOURCES = $(BITCOIN_TESTS) $(JSON_TEST_FILES) $(RAW_TEST_FILES)
test_test_qtum_CPPFLAGS = $(AM_CPPFLAGS) $(BITCOIN_INCLUDES) -I$(builddir)/test/ $(TESTDEFS) $(EVENT_CFLAGS)
test_test_qtum_LDADD = $(LIBBITCOIN_SERVER) $(LIBBITCOIN_CLI) $(LIBBITCOIN_COMMON) $(LIBBITCOIN_UTIL) $(LIBBITCOIN_CONSENSUS) $(LIBBITCOIN_CRYPTO) $(LIBUNIVALUE) $(LIBLEVELDB) $(LIBMEMENV) \
$(BOOST_LIBS) $(BOOST_UNIT_TEST_FRAMEWORK_LIB) $(LIBSECP256K1) $(EVENT_LIBS)
$(BOOST_LIBS) $(BOOST_UNIT_TEST_FRAMEWORK_LIB) $(EVENT_LIBS) $(LIBETHEREUM) $(LIBETHASHSEAL) $(LIBETHASH) $(LIBETHCORE) \
$(LIBDEVCORE) $(LIBJSONCPP) $(LIBEVM) $(LIBEVMCORE) $(LIBDEVCRYPTO) $(LIBCRYPTOPP) $(LIBSECP256K1ETH) $(LIBSCRYIPT) $(BOOST_LIBS)
test_test_qtum_CXXFLAGS = $(AM_CXXFLAGS) $(PIE_FLAGS)
if ENABLE_WALLET
test_test_qtum_LDADD += $(LIBBITCOIN_WALLET)
Expand Down
Loading

0 comments on commit 8937b05

Please sign in to comment.