Make installation errors fatal (#437)
If `is_installed` doesn't return true after install than something
serious went wrong so make this into a warning.
Also, clean up couple of places to make the python code more
readable.
diff --git a/emsdk.py b/emsdk.py
index f29cd9f..8539a6b 100755
--- a/emsdk.py
+++ b/emsdk.py
@@ -1397,7 +1397,8 @@
path_add = [to_native_path(emsdk_path())]
for tool in active_tools:
if hasattr(tool, 'activated_path'):
- path_add += [to_native_path(tool.expand_vars(tool.activated_path))]
+ path = to_native_path(tool.expand_vars(tool.activated_path))
+ path_add.append(path)
return path_add
@@ -1685,13 +1686,13 @@
# clang-master-64bit, clang-master-32bit and clang-master-64bit each
# share the same git repo), require that in addition to the installation
# directory, each item in the activated PATH must exist.
- activated_path = self.expand_vars(self.activated_path).split(';') if hasattr(self, 'activated_path') else [self.installation_path()]
+ if hasattr(self, 'activated_path'):
+ activated_path = self.expand_vars(self.activated_path).split(';')
+ else:
+ activated_path = [self.installation_path()]
def each_path_exists(pathlist):
- for path in pathlist:
- if not os.path.exists(path):
- return False
- return True
+ return all(os.path.exists(p) for p in pathlist)
content_exists = os.path.exists(self.installation_path()) and each_path_exists(activated_path) and (os.path.isfile(self.installation_path()) or num_files_in_directory(self.installation_path()) > 0)
@@ -1919,7 +1920,9 @@
with open(version_file_path, 'w') as version_file:
version_file.write(version_id)
else:
- print("Warning: The installation of '" + str(self) + "' seems to have failed, but no error was detected. Either something went wrong with the installation, or this may indicate an internal emsdk error.")
+ print("Installation of '" + str(self) + "' failed, but no error was detected. Either something went wrong with the installation, or this may indicate an internal emsdk error.")
+ return False
+
return True
def cleanup_temp_install_files(self):
@@ -2567,22 +2570,23 @@
existing_path = os.environ['PATH'].split(ENVPATH_SEPARATOR)
emsdk_root_path = to_unix_path(emsdk_path())
- existing_emsdk_tools = [item for item in existing_path if to_unix_path(item).startswith(emsdk_root_path)]
- new_emsdk_tools = [item for item in path_add if not normalized_contains(existing_emsdk_tools, item)]
+ existing_emsdk_tools = [i for i in existing_path if to_unix_path(i).startswith(emsdk_root_path)]
+ new_emsdk_tools = [i for i in path_add if not normalized_contains(existing_emsdk_tools, i)]
# Existing non-emsdk tools
- existing_path = [item for item in existing_path if not to_unix_path(item).startswith(emsdk_root_path)]
- new_path = [item for item in path_add if not normalized_contains(existing_path, item)]
+ existing_path = [i for i in existing_path if not to_unix_path(i).startswith(emsdk_root_path)]
+ new_path = [i for i in path_add if not normalized_contains(existing_path, i)]
whole_path = unique_items(new_path + existing_path)
if MSYS:
# XXX Hack: If running native Windows Python in MSYS prompt where PATH
# entries look like "/c/Windows/System32", os.environ['PATH']
# in Python will transform to show them as "C:\\Windows\\System32", so need
# to reconvert path delimiter back to forward slashes.
- whole_path = list(map(to_msys_path, whole_path))
- new_emsdk_tools = list(map(to_msys_path, new_emsdk_tools))
+ whole_path = [to_msys_path(p) for p in whole_path]
+ new_emsdk_tools = [to_msys_path(p) for p in new_emsdk_tools]
- return ((':' if MSYS else ENVPATH_SEPARATOR).join(whole_path), new_emsdk_tools)
+ separator = ':' if MSYS else ENVPATH_SEPARATOR
+ return (separator.join(whole_path), new_emsdk_tools)
def construct_env(tools_to_activate, permanent):