fdf8888b6f
CheckTransaction is a context-free function that does not require access to the blockchain or mempool. Move it from src/consensus/tx_verify in lib_server to a new unit src/consensus/tx_check in lib_consensus so that it can be called by non-server libraries. |
||
---|---|---|
.. | ||
bench_bitcoin | ||
bitcoin-cli | ||
bitcoin-tx | ||
bitcoin-wallet | ||
bitcoind | ||
libbitcoin_cli | ||
libbitcoin_common | ||
libbitcoin_crypto | ||
libbitcoin_qt | ||
libbitcoin_server | ||
libbitcoin_util | ||
libbitcoin_wallet | ||
libbitcoin_wallet_tool | ||
libbitcoin_zmq | ||
libbitcoinconsensus | ||
libleveldb | ||
libsecp256k1 | ||
libunivalue | ||
msbuild/tasks | ||
test_bitcoin | ||
test_bitcoin-qt | ||
testconsensus | ||
.gitignore | ||
bitcoin.sln | ||
bitcoin_config.h | ||
common.init.vcxproj | ||
common.vcxproj | ||
libsecp256k1_config.h | ||
msvc-autogen.py | ||
README.md |
Building Bitcoin Core with Visual Studio
Introduction
Solution and project files to build the Bitcoin Core applications (except Qt dependent ones) with Visual Studio 2017 can be found in the build_msvc directory.
Building with Visual Studio is an alternative to the Linux based cross-compiler build.
Dependencies
A number of open source libraries are required in order to be able to build Bitcoin.
Options for installing the dependencies in a Visual Studio compatible manner are:
- Use Microsoft's vcpkg to download the source packages and build locally. This is the recommended approach.
- Download the source code, build each dependency, add the required include paths, link libraries and binary tools to the Visual Studio project files.
- Use nuget packages with the understanding that any binary files have been compiled by an untrusted third party.
The external dependencies required for the Visual Studio build are (see the dependencies doc for versions):
- Berkeley DB,
- OpenSSL,
- Boost,
- libevent,
- ZeroMQ
Additional dependencies required from the bitcoin-core github repository are:
- SECP256K1,
- LevelDB
Building
The instructions below use vcpkg
to install the dependencies.
- Clone
vcpkg
from the github repository and install as per the instructions in the main README.md. - Install the required packages (replace x64 with x86 as required):
PS >.\vcpkg install --triplet x64-windows-static boost-filesystem boost-signals2 boost-test libevent openssl zeromq berkeleydb secp256k1 leveldb
- Use Python to generate *.vcxproj from Makefile
PS >python msvc-autogen.py
- Build in Visual Studio.