- try Settings -> System -> About and look under System Type
- When in doubt, see http://www.tenforums.com/tutorials/4399-system-type-32-bit-x86-64-bit-x64-windows-10-a.html
Download and install Visual Studio 2017
(for Visual C++) ; the Community Edition is free and fully functional.
- See https://www.visualstudio.com/downloads/
- When installing, you will need to select:
- Desktop Development with C++
- C++ Profiling (optional)
- Windows 8.1 SDK
- Visual C++ tools for Cmake
- Visual C++ ATL Support
- C++/CLI Support
Note: if you do not want to use postgres you can select DebugNoPostgres
as the build target.
Get version 9.4.8 from https://www.enterprisedb.com/download-postgresql-binaries
The default project file defines USE_POSTGRES and links against it.
- Pick a directory for the database
- Set an admin password for the database
- Accept the default port (5432)
- Accept
default
for the locale (not clear if anything depends on this. Thedefault
locale will presumably depend on your operating system's setting might cause inconsistencies) - Add
c:\Program Files\PostgreSQL\9.4\bin
to your PATH (else the binary will fail to start, not findinglibpq.dll
) - If you install postgres in a different folder, you will have to update the project file in two places:
- "additional include locations" and
- "Linker input"
If the installation fails, look into
%TEMP%\install-postgresql.log
for hints.
In order to compile xdrc and run the binary you will need to either
-
Download and install MinGW from http://sourceforge.net/projects/mingw/files/
- In the MinGW Installation Manager in
MSYS/MinGW Developer Toolkit
chooseFlex
andBison
packages for installation - Add
C:\MinGW\msys\1.0\bin;C:\MinGW\bin
to the end of%PATH%
- In the MinGW Installation Manager in
-
Download and install cygwin 64 bit build from https://cygwin.com/install.html
- Get cygwin setup to install
Flex
Bison
curl
(command line)gcc-core
- Add
c:\cygwin64\bin
to the end of%PATH%
(at least for Visual Studio)
Note: if you're going to use 'cp'and 'mkdir' from cygwin (tests do), make sure that your install is correct by trying to copy a file from a
cmd.exe
console (not from a cygwin terminal).cp in.txt out.txt
and then try to open out.txt with notepad. You should not get a permission denied error.Note: both MinGW and CygWin may run into virtual memory address space conflicts on modern versions of Windows. You will run into errors like
Couldn't reserve space for mingw's heap, Win32 error 0
. A workaround is to reboot until you can runbison.exe
from a cmd.exe prompt. - Get cygwin setup to install
If you do not have cURL installed
- Download and install/extract cURL from https://curl.haxx.se/download.html#Win64
- Add installation/extraction directory (e.g.
C:\Program Files\curl_7_47_1_x64
) to the end of%PATH%
For making changes to the code, you should install the clang-format tool and Visual Studio extension, you can find both at http://llvm.org/builds/
- note that the version of clang-format used currently is 5.0 (other versions may not format the same way).
- we recommend downloading 5.0.0 from http://releases.llvm.org/download.html
To setup the subsystem, go to https://msdn.microsoft.com/en-us/commandline/wsl/install_guide
Then, you can simply follow the Linux instructions
Note that you can (and should) install the Windows version of postgres even when running stellar-core from within WSL.
git clone PATH_TO_STELLAR_CORE
git submodule init
git submodule update
- Open the solution
Builds\VisualStudio\stellar-core.sln
- Pick the target architecture and flavor (e.g. x64, Release)
- Hit "Build Solution (F7)"