Skip to content

Commit 7032352

Browse files
authored
Switch to nuget python package for windows (#1001)
This allows us to use pip and install other packages. Fixes #16466
1 parent 433a2d1 commit 7032352

File tree

2 files changed

+42
-34
lines changed

2 files changed

+42
-34
lines changed

emsdk_manifest.json

Lines changed: 11 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -420,6 +420,15 @@
420420
"activated_env": "EMSDK_PYTHON=%installation_dir%/bin/python3;SSL_CERT_FILE=%installation_dir%/lib/python3.7/site-packages/certifi/cacert.pem",
421421
"is_old": true
422422
},
423+
{
424+
"id": "python",
425+
"version": "3.9.2-nuget",
426+
"bitness": 64,
427+
"arch": "x86_64",
428+
"windows_url": "python-3.9.2-4-amd64+pywin32.zip",
429+
"activated_cfg": "PYTHON='%installation_dir%/python.exe'",
430+
"activated_env": "EMSDK_PYTHON=%installation_dir%/python.exe"
431+
},
423432
{
424433
"id": "python",
425434
"version": "3.9.2",
@@ -644,7 +653,7 @@
644653
{
645654
"version": "upstream-main",
646655
"bitness": 64,
647-
"uses": ["python-3.9.2-64bit", "llvm-git-main-64bit", "node-14.18.2-64bit", "emscripten-main-64bit", "binaryen-main-64bit"],
656+
"uses": ["python-3.9.2-nuget-64bit", "llvm-git-main-64bit", "node-14.18.2-64bit", "emscripten-main-64bit", "binaryen-main-64bit"],
648657
"os": "win"
649658
},
650659
{
@@ -727,7 +736,7 @@
727736
{
728737
"version": "releases-upstream-%releases-tag%",
729738
"bitness": 64,
730-
"uses": ["node-14.18.2-64bit", "python-3.9.2-64bit", "java-8.152-64bit", "releases-upstream-%releases-tag%-64bit"],
739+
"uses": ["node-14.18.2-64bit", "python-3.9.2-nuget-64bit", "java-8.152-64bit", "releases-upstream-%releases-tag%-64bit"],
731740
"os": "win",
732741
"custom_install_script": "emscripten_npm_install"
733742
},

scripts/update_python.py

Lines changed: 31 additions & 32 deletions
Original file line numberDiff line numberDiff line change
@@ -33,8 +33,8 @@
3333

3434
version = '3.9.2'
3535
major_minor_version = '.'.join(version.split('.')[:2]) # e.g. '3.9.2' -> '3.9'
36-
base = 'https://www.python.org/ftp/python/%s/' % version
37-
revision = '3'
36+
download_url = 'https://www.nuget.org/api/v2/package/python/%s' % version
37+
revision = '4'
3838

3939
pywin32_version = '227'
4040
pywin32_base = 'https://github.com/mhammond/pywin32/releases/download/b%s/' % pywin32_version
@@ -44,7 +44,7 @@
4444

4545
def unzip_cmd():
4646
# Use 7-Zip if available (https://www.7-zip.org/)
47-
sevenzip = os.path.join(os.getenv('ProgramFiles'), '7-Zip', '7z.exe')
47+
sevenzip = os.path.join(os.getenv('ProgramFiles', ''), '7-Zip', '7z.exe')
4848
if os.path.isfile(sevenzip):
4949
return [sevenzip, 'x']
5050
# Fall back to 'unzip' tool
@@ -53,52 +53,49 @@ def unzip_cmd():
5353

5454
def zip_cmd():
5555
# Use 7-Zip if available (https://www.7-zip.org/)
56-
sevenzip = os.path.join(os.getenv('ProgramFiles'), '7-Zip', '7z.exe')
56+
sevenzip = os.path.join(os.getenv('ProgramFiles', ''), '7-Zip', '7z.exe')
5757
if os.path.isfile(sevenzip):
5858
return [sevenzip, 'a', '-mx9']
5959
# Fall back to 'zip' tool
6060
return ['zip', '-rq']
6161

6262

63-
def make_python_patch(arch):
64-
if arch == 'amd64':
65-
pywin32_filename = 'pywin32-%s.win-%s-py%s.exe' % (pywin32_version, arch, major_minor_version)
66-
else:
67-
pywin32_filename = 'pywin32-%s.%s-py%s.exe' % (pywin32_version, arch, major_minor_version)
68-
filename = 'python-%s-embed-%s.zip' % (version, arch)
69-
out_filename = 'python-%s-%s-embed-%s+pywin32.zip' % (version, revision, arch)
63+
def make_python_patch():
64+
pywin32_filename = 'pywin32-%s.win-amd64-py%s.exe' % (pywin32_version, major_minor_version)
65+
filename = 'python-%s-amd64.zip' % (version)
66+
out_filename = 'python-%s-%s-amd64+pywin32.zip' % (version, revision)
7067
if not os.path.exists(pywin32_filename):
71-
download_url = pywin32_base + pywin32_filename
72-
print('Downloading pywin32: ' + download_url)
73-
urllib.request.urlretrieve(download_url, pywin32_filename)
68+
url = pywin32_base + pywin32_filename
69+
print('Downloading pywin32: ' + url)
70+
urllib.request.urlretrieve(url, pywin32_filename)
7471

7572
if not os.path.exists(filename):
76-
download_url = base + filename
7773
print('Downloading python: ' + download_url)
7874
urllib.request.urlretrieve(download_url, filename)
7975

80-
os.mkdir('python-embed')
81-
check_call(unzip_cmd() + [os.path.abspath(filename)], cwd='python-embed')
82-
os.remove(os.path.join('python-embed', 'python%s._pth' % major_minor_version.replace('.', '')))
76+
os.mkdir('python-nuget')
77+
check_call(unzip_cmd() + [os.path.abspath(filename)], cwd='python-nuget')
8378

8479
os.mkdir('pywin32')
8580
rtn = subprocess.call(unzip_cmd() + [os.path.abspath(pywin32_filename)], cwd='pywin32')
8681
assert rtn in [0, 1]
8782

88-
os.mkdir(os.path.join('python-embed', 'lib'))
89-
shutil.move(os.path.join('pywin32', 'PLATLIB'), os.path.join('python-embed', 'lib', 'site-packages'))
83+
os.mkdir(os.path.join('python-nuget', 'lib'))
84+
shutil.move(os.path.join('pywin32', 'PLATLIB'), os.path.join('python-nuget', 'toolss', 'Lib', 'site-packages'))
9085

91-
check_call(zip_cmd() + [os.path.join('..', out_filename), '.'], cwd='python-embed')
86+
check_call(zip_cmd() + [os.path.join('..', '..', out_filename), '.'], cwd='python-nuget/tools')
9287

9388
# cleanup if everything went fine
94-
shutil.rmtree('python-embed')
89+
shutil.rmtree('python-nuget')
9590
shutil.rmtree('pywin32')
9691

97-
upload_url = upload_base + out_filename
98-
print('Uploading: ' + upload_url)
99-
cmd = ['gsutil', 'cp', '-n', out_filename, upload_url]
100-
print(' '.join(cmd))
101-
check_call(cmd)
92+
print('Created: %s' % out_filename)
93+
if '--upload' in sys.argv:
94+
upload_url = upload_base + out_filename
95+
print('Uploading: ' + upload_url)
96+
cmd = ['gsutil', 'cp', '-n', out_filename, upload_url]
97+
print(' '.join(cmd))
98+
check_call(cmd)
10299

103100

104101
def build_python():
@@ -169,14 +166,16 @@ def build_python():
169166
for lib in glob.glob(os.path.join(dirname, 'lib', 'lib*.a')):
170167
os.remove(lib)
171168
check_call(['tar', 'zcvf', tarball, dirname])
172-
print('Uploading: ' + upload_base + tarball)
173-
check_call(['gsutil', 'cp', '-n', tarball, upload_base + tarball])
169+
170+
print('Created: %s' % tarball)
171+
if '--upload' in sys.argv:
172+
print('Uploading: ' + upload_base + tarball)
173+
check_call(['gsutil', 'cp', '-n', tarball, upload_base + tarball])
174174

175175

176176
def main():
177-
if sys.platform.startswith('win'):
178-
for arch in ('amd64', 'win32'):
179-
make_python_patch(arch)
177+
if sys.platform.startswith('win') or '--win32' in sys.argv:
178+
make_python_patch()
180179
else:
181180
build_python()
182181
return 0

0 commit comments

Comments
 (0)