Only link model after download if shortcut link (#3378)

This commit is contained in:
Ines Montani 2019-03-10 13:02:24 +01:00 committed by Matthew Honnibal
parent 231bc7bb7b
commit 3fe5811fa7

View File

@ -41,24 +41,32 @@ def download(model, direct=False, *pip_args):
dl = download_model(dl_tpl.format(m=model_name, v=version), pip_args) dl = download_model(dl_tpl.format(m=model_name, v=version), pip_args)
if dl != 0: # if download subprocess doesn't return 0, exit if dl != 0: # if download subprocess doesn't return 0, exit
sys.exit(dl) sys.exit(dl)
try: msg.good(
# Get package path here because link uses "Download and installation successful",
# pip.get_installed_distributions() to check if model is a "You can now load the model via spacy.load('{}')".format(model_name),
# package, which fails if model was just installed via )
# subprocess # Only create symlink if the model is installed via a shortcut like 'en'.
package_path = get_package_path(model_name) # There's no real advantage over an additional symlink for en_core_web_sm
link(model_name, model, force=True, model_path=package_path) # and if anything, it's more error prone and causes more confusion.
except: # noqa: E722 if model in shortcuts:
# Dirty, but since spacy.download and the auto-linking is try:
# mostly a convenience wrapper, it's best to show a success # Get package path here because link uses
# message and loading instructions, even if linking fails. # pip.get_installed_distributions() to check if model is a
msg.warn( # package, which fails if model was just installed via
"Download successful but linking failed", # subprocess
"Creating a shortcut link for 'en' didn't work (maybe you " package_path = get_package_path(model_name)
"don't have admin permissions?), but you can still load the " link(model_name, model, force=True, model_path=package_path)
"model via its full package name: " except: # noqa: E722
"nlp = spacy.load('{}')".format(model_name), # Dirty, but since spacy.download and the auto-linking is
) # mostly a convenience wrapper, it's best to show a success
# message and loading instructions, even if linking fails.
msg.warn(
"Download successful but linking failed",
"Creating a shortcut link for '{}' didn't work (maybe you "
"don't have admin permissions?), but you can still load "
"the model via its full package name: "
"nlp = spacy.load('{}')".format(model, model_name),
)
def get_json(url, desc): def get_json(url, desc):