fix llamafile fails loading if the llamafile_path has a space within it

pull/118/head
SickanK 10 months ago
parent 6d0e885c55
commit 13a2a662ba

@ -5,9 +5,9 @@ import time
import wget import wget
import stat import stat
class Llm: class Llm:
def __init__(self, config): def __init__(self, config):
self.interpreter = config["interpreter"] self.interpreter = config["interpreter"]
config.pop("interpreter", None) config.pop("interpreter", None)
@ -20,8 +20,7 @@ class Llm:
self.llm = self.interpreter.llm.completions self.llm = self.interpreter.llm.completions
def install(self, service_directory): def install(self, service_directory):
if platform.system() == "Darwin": # Check if the system is MacOS
if platform.system() == "Darwin": # Check if the system is MacOS
result = subprocess.run( result = subprocess.run(
["xcode-select", "-p"], stdout=subprocess.PIPE, stderr=subprocess.STDOUT ["xcode-select", "-p"], stdout=subprocess.PIPE, stderr=subprocess.STDOUT
) )
@ -30,7 +29,9 @@ class Llm:
"Llamafile requires Mac users to have Xcode installed. You can install Xcode from https://developer.apple.com/xcode/ .\n\nAlternatively, you can use `LM Studio`, `Jan.ai`, or `Ollama` to manage local language models. Learn more at https://docs.openinterpreter.com/guides/running-locally ." "Llamafile requires Mac users to have Xcode installed. You can install Xcode from https://developer.apple.com/xcode/ .\n\nAlternatively, you can use `LM Studio`, `Jan.ai`, or `Ollama` to manage local language models. Learn more at https://docs.openinterpreter.com/guides/running-locally ."
) )
time.sleep(3) time.sleep(3)
raise Exception("Xcode is not installed. Please install Xcode and try again.") raise Exception(
"Xcode is not installed. Please install Xcode and try again."
)
# Define the path to the models directory # Define the path to the models directory
models_dir = os.path.join(service_directory, "models") models_dir = os.path.join(service_directory, "models")
@ -52,8 +53,6 @@ class Llm:
url = "https://huggingface.co/jartine/phi-2-llamafile/resolve/main/phi-2.Q4_K_M.llamafile" url = "https://huggingface.co/jartine/phi-2-llamafile/resolve/main/phi-2.Q4_K_M.llamafile"
wget.download(url, llamafile_path) wget.download(url, llamafile_path)
# Make the new llamafile executable # Make the new llamafile executable
if platform.system() != "Windows": if platform.system() != "Windows":
st = os.stat(llamafile_path) st = os.stat(llamafile_path)
@ -63,11 +62,15 @@ class Llm:
if os.path.exists(llamafile_path): if os.path.exists(llamafile_path):
try: try:
# Test if the llamafile is executable # Test if the llamafile is executable
subprocess.check_call([llamafile_path]) subprocess.check_call([f'"{llamafile_path}"'], shell=True)
except subprocess.CalledProcessError: except subprocess.CalledProcessError:
print("The llamafile is not executable. Please check the file permissions.") print(
"The llamafile is not executable. Please check the file permissions."
)
raise raise
subprocess.Popen([llamafile_path, "-ngl", "9999"]) subprocess.Popen(
f'"{llamafile_path}" ' + " ".join(["-ngl", "9999"]), shell=True
)
else: else:
error_message = "The llamafile does not exist or is corrupted. Please ensure it has been downloaded correctly or try again." error_message = "The llamafile does not exist or is corrupted. Please ensure it has been downloaded correctly or try again."
print(error_message) print(error_message)

Loading…
Cancel
Save