-
Notifications
You must be signed in to change notification settings - Fork 704
/
Building on Windows.txt
290 lines (240 loc) · 12.1 KB
/
Building on Windows.txt
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
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
# SPDX-FileCopyrightText: 2024 Duncan Greatwood
#
# SPDX-License-Identifier: Apache-2.0
Building Pistache on Windows
============================
Pistache has been built and tested on Windows 11, Windows Server 2022
and Windows Server 2019. It could perhaps be made to work on older
Windows versions too, though going back before Windows 8 would
be more difficult due to Windows API changes.
Convenience scripts are provided to configure Pistache to be built
either with GCC (MinGW-w64) or with Visual Studio. These scripts will
download and install the needed dependencies on your Windows machine,
if not already present.
The following instructions assume you are at a PowerShell terminal
prompt. The terminal prompt can be at the console of the target
Windows machine, or via a remote SSH session. Just a regular
PowerShell prompt is needed - you do NOT need to use a preconfigured
"Developer PowerShell" prompt, and in fact the Pistache configuration
scripts will configure a Developer prompt for you if
required. Likewise, you can use a prompt without administrator rights.
Newer versions of Windows may disable script execution by default. To
enable script execution, at a PowerShell prompt with admin rights do:
Set-ExecutionPolicy -ExecutionPolicy Bypass
Older versions of Windows (e.g. Windows Server 2019) that default to
Internet Explorer may block access to Internet downloads needed by the
Pistache setup scripts. To enable that Internet access, see that the
note "Disabling Enhanced Security Configuration for Internet Explorer"
later in this document.
To begin - clone, fork or download and expand the zip of Pistache to
fetch Pistache to your Windows machine:
To get Pistache using "git clone":
If you don't already have git, but do have winget on your machine:
Invoke-WebRequest -Uri "https://git.io/JXGyd" -OutFile "git.inf"
winget install Git.Git --override '/SILENT /LOADINF="git.inf"'
Or to install git without using winget:
$mingit_latest_url=(Invoke-WebRequest -Uri "https://raw.githubusercontent.com/git-for-windows/git-for-windows.github.io/refs/heads/main/latest-64-bit-mingit.url").Content
Invoke-WebRequest -Uri "$mingit_latest_url" -Outfile "mingit_latest.zip"
Expand-Archive -Path "mingit_latest.zip" -DestinationPath "$env:ProgramFiles/Git"
$git_dir = "$env:ProgramFiles/Git"
$env:Path="$git_dir\cmd;$git_dir\mingw64\bin;$git_dir\usr\bin;$env:Path"
You can configure your newly installed git:
git config --global user.email "[email protected]"
git config --global user.name "Your Name"
etc.
Then, once git is installed:
git clone https://github.com/pistacheio/pistache.git
OR to get Pistache using zip download:
Invoke-WebRequest -Uri "https://github.com/pistacheio/pistache/archive/refs/heads/master.zip" -OutFile "pistache.zip"
Expand-Archive -Path "pistache.zip" -DestinationPath "pistache"
(Or you can download and expand the zip using a web browser in the GUI)
Then configure for either GCC or Visual Studio:
cd pistache
and EITHER:
winscripts\msvcsetup.ps1
OR:
winscripts\gccsetup.ps1
Note: You should run msvcsetup.ps1 or gccsetup.ps1 each time you start
a new PowerShell prompt that you will use for building Pistache.
Then run:
winscripts\mesbuild.ps1
winscripts\mestest.ps1
winscripts\mesinstall.ps1
Pistache is installed to the pistache_distribution subdirectory of the
"Program Files" directory, most commonly:
C:\Program Files\pistache_distribution
You can link your own executables to Pistache via
\Program Files\pistache_distribution. Note that you will link your
executable to the Pistache import library (.lib file) and, to run your
program, you will ensure that your $env:path includes the location of
the Pistache DLL; Windows then loads the Pistache DLL when your
executable runs, based on the information provided in the .lib file.
Note also that you do not need to link to or load pistachelog.dll in
any way. pistachelog.dll's only purpose is to provide a place to keep
certain strings that are needed when registering the Pistache logging
manifest with Windows logging (see "Logging" below).
If you prefer not to use msvcsetup.ps1 or gccsetup.ps1, dependencies
can be installed manually and the environment can be configured
manually. See the later "Dependencies and Configuration" section
below.
Logging
=======
In Windows, Pistache uses the ETW ("Event Tracing") system for logging.
For events above level DEBUG, the event is sent to the Windows
Application channel. This makes events appear in Windows Event
Viewer. You can see the Pistache events in Event Viewer under Windows
Logs / Application, looking for Source type Pistache.
DEBUG events (in Pistache debug builds) are sent to the Pistache debug
channel.
Since DEBUG events are not consumed automatically by EventViewer via the
Application channel, you will need another event consumer to record the
events. You can use the Windows utility logman.exe.
To use logman, you can do:
logman start -ets Pistache -p "Pistache-Provider" 0 0 -o pistache.etl
Then run your program, which you want to log.
Once your program is complete, you can do:
logman stop Pistache -ets
This causes the log information to be written out to pistache.etl
You can view the etl file:
1/ Use Event Viewer. (In Event Viewer, Action -> Open Saved Log, then
choose pistache.etl).
2/ Convert the to XML:
tracerpt -y pistache.etl
Then view dumpfile.xml in a text editor or XML viewer
Alternatively, you can have logman generate a CSV file instead of an .etl
by adding the "-f csv" option to the "logman start..." command.
logman has many other options, do "logman -?" to see the list.
To use logging, you must also:
1/ First, copy pistachelog.dll to the predefined location
"$env:ProgramFiles\pistache_distribution\bin"
2/ Install the Pistache manifest file by doing:
wevtutil im "pist_winlog.man"
The Pistache build process will do both 1/ and 2/ automatically upon
running "meson build" (e.g. when doing winscripts\mesbuild.ps1).
If needed or preferred you can also cause Pistache log messages to be
written to the console i.e. to "stdout". This is controlled by a
registry entry:
HKCU:\Software\pistacheio\pistache\psLogToStdoutAsWell
A value of zero means, don't send to stdout; 1 means do send to
stdout; and 10 means don't send to stdout even if the Pistache binary
has been preconfigured and built to send every log message to stdout.
The pistache build process creates the psLogToStdoutAsWell property
automatically, giving it an initial value of zero. You can change its
value via the WIndows GUI using the Windows Registry Editor, or at
PowerShell command line:
$psre_path = "HKCU:\Software\pistacheio\pistache"
Set-ItemProperty -Path $psre_path -Name "psLogToStdoutAsWell" -Value 1
Pistache will respond dynamically while a program is running to a
change in psLogToStdoutAsWell's value, but typically you will set
psLogToStdoutAsWell's value before you run your program.
Note: To run mesinstall.ps1 or mesinstalldebug.ps1, you will typically
have to close Windows Event Viewer if it's open. Event Viewer holds
open the prior pistachelog.dll, preventing it being overwritten by the
meson install methods.
Debug Builds
============
To create and install a debug version of Pistache, do the following:
winscripts\mesbuilddebug.ps1
winscripts\mestestdebug.ps1
winscripts\mesinstalldebug.ps1
The debug build can generate verbose debug log output if desired.
Dependencies and Configuration
==============================
If installing dependencies by hand, install the following:
git
Either GCC or Visual Studio, or both
Windows Kits (aka Windows SDK)
vcpkg
pkg-config (aka pkgconf)
Ninja (comes automatically with Visual Studio)
Python3 (with PIP)
meson
doxygen
googletest
howard-hinnant-date
libevent
curl[openssl]
brotli (library)
zstd (library)
Add the locations of the above utilities and libraries to
$env:path. Note that $env:path is used by Windows to look for
executables, but also to look for the locations of DLLs.
Set $env:PKG_CONFIG_PATH to point to the location(s) of your
pkg-config information. If you have installed some components using
vcpkg, you will likely want to include:
<vcpkg base directory>\installed\x64-windows\lib\pkgconfig
in your $env:PKG_CONFIG_PATH.
For GCC builds:
$env:CXX="g++"
$env:CC="gcc"
For Visual Studio builds, set:
$env:CXX="cl"
$env:CC=$env:CXX
Once you have built your executable that links to Pistache, if you
find that the executable exits silently when you try to run it, it
probably means that the executable is failing to find a needed DLL on
$env:path, or it is finding the wrong version of a DLL. Try going to
the Windows GUI, open Windows Explorer, and double click on your
executable - when the executable tries and fails to run, Windows may
show you an error message that tells you what is wrong.
Using A Source-Code Debugger
============================
A debugger such as Visual Studio Code can be used to debug binaries
linked to a Pistache debug build, locally or remotely.
For Visual Studio Code -
For GCC debug builds, include in your launch.json entry:
"type": "cppdbg",
"MIMode": "gdb",
"miDebuggerPath": "C:\\msys64\\ucrt64\\bin\\gdb.exe",
"environment": [
{"name": "Path", "value":
"C:\\msys64\\ucrt64\\bin;${env:Path};<Pistache Build Directory>\\src;;C:\\vcpkg\\installed\\x64-windows\\bin;C:\\Program Files (x86)\\Windows Kits\\<Windows Version>\\bin\\<Windows SDK Version>\\x64"},
],
(Substituting in your <Pistache Build Directory>, <Windows Version>
and <Windows SDK Version>)
For Visual Studio debug builds, include in your launch.json entry:
"type": "cppvsdbg",
"environment": [
{"name": "Path", "value":
"C:\\msys64\\ucrt64\\bin;${env:Path};<Pistache Build Directory>\\src;;C:\\vcpkg\\installed\\x64-windows\\bin;C:\\Program Files (x86)\\Windows Kits\\<Windows Version>\\bin\\<Windows SDK Version>\\x64"},
],
(Substituting in your <Pistache Build Directory>, <Windows Version>
and <Windows SDK Version>)
You can also use the native debugggers, i.e. the Visual Studio
debugger for Visual Studio debug builds, and gdb for GCC debug builds
(note: gccsetup.ps1 configures gdb on the path if not already
installed).
Disabling Enhanced Security Configuration for Internet Explorer
===============================================================
Older versions of Windows (e.g. Windows Server 2019) that default to
Internet Explorer may block access to Internet downloads needed by the
Pistache setup scripts. To enable that Internet access:
Via the Windows GUI on Windows Server 2019, go to:
Server Manager > Local Server > IE Enhanced Security Configuration
Then, select Off for both Administrators and Users
And restart Internet Explorer
OR at a PowerShell prompt with admin rights, do:
$AdminKey = "HKLM:\SOFTWARE\Microsoft\Active Setup\Installed Components\{A509B1A7-37EF-4b3f-8CFC-4F3A74704073}"
$UserKey = "HKLM:\SOFTWARE\Microsoft\Active Setup\Installed Components\{A509B1A8-37EF-4b3f-8CFC-4F3A74704073}"
Set-ItemProperty -Path $AdminKey -Name "IsInstalled" -Value 0
Set-ItemProperty -Path $UserKey -Name "IsInstalled" -Value 0
Stop-Process -Name Explorer
Troubleshooting
===============
If mingit is installed, and you get an error "fatal exceeded maximum
include depth" on invoking git, you likely have a circular include in
the file "$env:ProgramFiles\Git\etc\gitconfig". Open that gitconfig
file in an editor and comment out the line that looks like:
path = C:/Program Files/Git/etc/gitconfig
You can comment it out by placing a semicolon at the line's start:
; path = C:/Program Files/Git/etc/gitconfig
More generally, if the setup script goes wrong in a hard-to-understand
way, one thing to try is quitting the shell, starting a new shell, and
running the script again.
How It Works
============
Pistache on Windows works very much as it does on macOS, i.e. by using
the libevent library to provide the core event loop. Additionally, it
uses the libevent mechanisms to emulate Linux-style or macOS-style
edge-triggered events to the extent needed by Pistache, even though
Windows native events are level-triggered not edge-triggered.