summaryrefslogtreecommitdiffstats
path: root/Tools/msi/get_wix.py
diff options
context:
space:
mode:
authorSteve Dower <steve.dower@microsoft.com>2015-02-06 06:08:48 (GMT)
committerSteve Dower <steve.dower@microsoft.com>2015-02-06 06:08:48 (GMT)
commitbb24087a2cbfb186b540cc71a74ec8c39c1ebe3a (patch)
tree3b586e72b5744c4076a222e8f803a00d17b5f20f /Tools/msi/get_wix.py
parent7425f36ee74ccf5bfc2894aca6e6b86815894f98 (diff)
downloadcpython-bb24087a2cbfb186b540cc71a74ec8c39c1ebe3a.zip
cpython-bb24087a2cbfb186b540cc71a74ec8c39c1ebe3a.tar.gz
cpython-bb24087a2cbfb186b540cc71a74ec8c39c1ebe3a.tar.bz2
Issue #23260: Update Windows installer
Diffstat (limited to 'Tools/msi/get_wix.py')
-rw-r--r--Tools/msi/get_wix.py49
1 files changed, 49 insertions, 0 deletions
diff --git a/Tools/msi/get_wix.py b/Tools/msi/get_wix.py
new file mode 100644
index 0000000..85b02f2
--- /dev/null
+++ b/Tools/msi/get_wix.py
@@ -0,0 +1,49 @@
+'''
+Downloads and extracts WiX to a local directory
+'''
+
+__author__ = 'Steve Dower <steve.dower@microsoft.com>'
+
+import io
+import os
+import sys
+
+from pathlib import Path
+from subprocess import Popen
+from zipfile import ZipFile
+
+EXTERNALS_DIR = None
+for p in Path(__file__).parents:
+ if any(p.glob("PCBuild/*.vcxproj")):
+ EXTERNALS_DIR = p / "externals"
+ break
+
+if not EXTERNALS_DIR:
+ print("Cannot find project root")
+ sys.exit(1)
+
+WIX_BINARIES_ZIP = 'http://wixtoolset.org/downloads/v3.10.1124.0/wix310-binaries.zip'
+TARGET_BIN_ZIP = EXTERNALS_DIR / "wix.zip"
+TARGET_BIN_DIR = EXTERNALS_DIR / "wix"
+
+POWERSHELL_COMMAND = "[IO.File]::WriteAllBytes('{}', (Invoke-WebRequest {} -UseBasicParsing).Content)"
+
+if __name__ == '__main__':
+ if TARGET_BIN_DIR.exists() and any(TARGET_BIN_DIR.glob("*")):
+ print('WiX is already installed')
+ sys.exit(0)
+
+ try:
+ TARGET_BIN_DIR.mkdir()
+ except FileExistsError:
+ pass
+
+ print('Downloading WiX to', TARGET_BIN_ZIP)
+ p = Popen(["powershell.exe", "-Command", POWERSHELL_COMMAND.format(TARGET_BIN_ZIP, WIX_BINARIES_ZIP)])
+ p.wait()
+ print('Extracting WiX to', TARGET_BIN_DIR)
+ with ZipFile(str(TARGET_BIN_ZIP)) as z:
+ z.extractall(str(TARGET_BIN_DIR))
+ TARGET_BIN_ZIP.unlink()
+
+ print('Extracted WiX')