1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
|
// file : BOOTSTRAP-WINDOWS.cli
// copyright : Copyright (c) 2014-2016 Code Synthesis Ltd
// license : MIT; see accompanying LICENSE file
"
The following instructions are for bootstrapping \c{build2} with either MSVC
or MinGW using the Windows command prompt. If you are using any kind of UNIX
emulation layer (for example, MSYS2 or Cygwin) and already have a UNIX shell
with standard utilitis, then you most likely should follow \l{#BOOTSTRAP-UNIX
Bootstrapping on UNIX} instead.
The \c{build2} toolchain on Windows requires a set of extra utilities
(\c{install}, \c{diff}, \c{wget}, \c{tar}, etc). These are provided in the
\c{build2-baseutils} package (see the \c{README} file inside for details).
Normally the \c{build2} toolchain itself is installed into the same directory
as the utilities in order to produce a combined \c{build2+utilities}
installation.
To build on Windows you will need either MSVC 14 Update 2 or later or MinGW
GCC 4.8 or later. Note also that MinGW GCC must be configured with the
\c{posix} threading model (this is currently the only configuration that
implements C++11 threads; run \c{g++ --version} to verify).
If you don't already have a suitable C++ compiler, then you can use the
\c{build2-mingw} package which provides a minimal MinGW-W64 GCC distribution
(see the \c{README} file inside for details). If used, then it should be
unpacked into the same directory as \c{build2-baseutils} as described below.
\dl|
\li|1. Open Command Prompt\n
Start the standard Windows Command Prompt. If you plan to build with MSVC,
then you may go ahead and start the Visual Studio Command Prompt (or wait
until MSVC-specific instructions).
|
\li|\n2. Create Build Directory\n
Note that you will want to keep this directory around in order to upgrade
to new toolchain versions in the future. In this guide we will use
\c{C:\\build2-build\\} as the build directory and \c{C:\\build2\\} as the
installation directory but you can use other paths.
\
> C:
> cd \
> mkdir build2-build
> cd build2-build
\
|
\li|\n3. Download Archives\n
Download the following files as well as their \c{.sha256} checksums from
\l{https://download.build2.org}, replacing \i{<arch>} with \c{x86_64} for
64-bin Windows and with \c{i686} for 32-bit. Place everything into
\c{C:\\build2-build\\} (build directory).
\
build2-baseutils-X.Y.Z-<arch>.zip
build2-mingw-X.Y.Z-<arch>.tar.xz (if required)
build2-toolchain-X.Y.Z.tar.xz
\
|
\li|\n4. Verify Archive Checksums\n
Verify archive checksums match:
\
> type *.sha256
> for %f in (*.zip *.xz) do certutil -hashfile %f SHA256
\
|
\li|\n5. Unpack \c{build2-baseutils}\n
Unpack the \c{build2-baseutils-X.Y.Z-<arch>.zip} archive into to \c{C:\\} using
Windows Explorer (for example, copy the archive directory and paste it).
Rename it to \c{C:\\build2\\}. This will be the toolchain installation
directory.
|
\li|\n6. Set \c{PATH}\n
Also verify the utilities are found and work:
\
> set PATH=C:\build2\bin;%PATH%
> where tar
> tar --version
\
|
\li|\n7. Unpack \c{build2-mingw}\n
If required, unpack the \c{build2-mingw-X.Y.Z-<arch>.tar.xz} archive into
\c{C:\\build2\\}:
\
> tar xf build2-mingw-X.Y.Z-<arch>-windows.tar.xz ^
--one-top-level=C:\build2 --strip-components=1
\
Verify the MinGW GCC is found and works:
\
> where g++
> g++ --version
\
|
\li|\n8. Unpack \c{build2-toolchain}\n
Unpack the \c{build2-toolchain-X.Y.Z.tar.xz} archive and change to its
directory:
\
> tar xf build2-toolchain-X.Y.Z.tar.xz
> cd build2-toolchain-X.Y.Z
\
||
If building with MSVC, continue with \l{#BOOTSTRAP-MSVC Bootstrapping with
MSVC}.
If building with MinGW, continue with \l{#BOOTSTRAP-MINGW Bootstrapping with
MINGW}.
"
|