1 = WiX (.msi) Installer For Wireshark
3 This is an experimental feature to provide Wireshark with an .msi installer as requested in https://gitlab.com/wireshark/wireshark/-/issues/8814[issue 8814].
4 It might one day replace the NSIS installer, but needs to be a little more complete before doing so.
6 == Differences/Notes Compared To The NSIS Installer
8 . You need the https://wixtoolset.org/[WiX toolset] to build the .msi installer.
9 Version 3.10 or later is recommended.
11 . The User's Guide, SNMP, Radius, Diameter, and Qt translations files are harvested to
12 be included in the installer. Any custom/additional files just need to be written to the
13 appropriate build output directory and the installer will pick them up. NSIS required
14 modifying a file (custom_mibs.txt, etc) for inclusion
16 . Plugin DLLs are not automatically harvested. To include your DLL, modify Plugins.wxi.
18 . To build the WiX installer run:
20 > msbuild /m /p:Configuration=RelWithDebInfo wireshark_wix_prep.vcxproj
21 > msbuild /m /p:Configuration=RelWithDebInfo wireshark_wix.vcxproj
26 . The .msi installer does not include and install Npcap or USBPcap like the NSIS installer does.
27 These currently come as NSIS-generated .exe installers.
28 We might be able to bundle them as https://wixtoolset.org/documentation/manual/v3/xsd/wix/exepackage.html[ExePackage elements].
30 // This appears to be fixed in the MERGE_MODULE_DIR code in CMakeLists.txt?
31 // . Needs more flexible handling of VC CRT Merge module (need build script to provide appropriate macros).
32 // Something like (or modifying existing) FindMSVC_REDIST.cmake.
33 // Currently only VS2013 / CRT120 and VS 2015 / CRT140 are supported.
35 . Transitioning, upgrading, downgrading, and reinstalling is more tricky.
36 The NSIS-based installer handles previously-installed versions by running any existing uninstaller prior to installation, which empties the installation directory and removes registry entries.
37 These are subsequently filled back in by the installer.
38 The Windows Installer architecture keeps track of installed items in a https://docs.microsoft.com/en-us/windows/win32/msi/installer-database[database] and uses the https://docs.microsoft.com/en-us/windows/win32/msi/upgradecode[UpgradeCode property] to identify installed products and the https://wixtoolset.org/documentation/manual/v3/xsd/wix/majorupgrade.html[MajorUpgrade property] to control upgrade behavior.
40 * We can't easily upgrade from an NSIS-based installation to a .msi installation, and vice versa.
41 * We have to be careful about setting things like UpgradeCode, MajorUpgrade, and REINSTALLMODE in our WiX configuration.
43 . The lax behavior of the NSIS-based installer lets you install more than one copy of Wireshark if you specify different installation directories.
44 (The most recently installed version "wins" as far as registry entries and file associations go).
45 The .msi installer doesn't allow this.
47 Patches welcome to address any of the issues above or improvements you think can be made.