From d48659051b3ef389d471409f300a4aa893999da6 Mon Sep 17 00:00:00 2001 From: Jack Cherng Date: Sun, 3 Dec 2023 15:11:35 +0800 Subject: [PATCH] fix: sublime.packages_path() can't be used before plugin loaded in ST 3 Signed-off-by: Jack Cherng --- plugin.py | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/plugin.py b/plugin.py index 266df3b..11bd872 100644 --- a/plugin.py +++ b/plugin.py @@ -12,7 +12,6 @@ from sublime_lib import ResourcePath ST_VERSION = int(sublime.version()) -ST_PACKAGES_PATH = sublime.packages_path() if ST_VERSION >= 4070: from LSP.plugin import MarkdownLangMap @@ -131,6 +130,8 @@ def patch_markdown_content(self, content: str) -> str: return content def detect_st_py_ver(self, dev_environment: str) -> Tuple[int, int]: + st_packages_path = sublime.packages_path() + default = (3, 3) if dev_environment == "sublime_text_33": @@ -145,7 +146,7 @@ def detect_st_py_ver(self, dev_environment: str) -> Tuple[int, int]: workspace_folders = session.get_workspace_folders() if not workspace_folders: return default - if workspace_folders[0].path == os.path.join(ST_PACKAGES_PATH, "User"): + if workspace_folders[0].path == os.path.join(st_packages_path, "User"): return (3, 8) python_version_file = os.path.join(workspace_folders[0].path, ".python-version") try: @@ -162,6 +163,8 @@ def get_plugin_setting(cls, key: str, default: Any = None) -> Any: return sublime.load_settings(cls.package_name + ".sublime-settings").get(key, default) def find_package_dependency_dirs(self, py_ver: Tuple[int, int] = (3, 3)) -> List[str]: + st_packages_path = sublime.packages_path() + dep_dirs = sys.path.copy() # replace paths for target Python version @@ -172,8 +175,8 @@ def find_package_dependency_dirs(self, py_ver: Tuple[int, int] = (3, 3)) -> List # move the "Packages/" to the last # @see https://github.com/sublimelsp/LSP-pyright/pull/26#discussion_r520747708 - dep_dirs.remove(ST_PACKAGES_PATH) - dep_dirs.append(ST_PACKAGES_PATH) + dep_dirs.remove(st_packages_path) + dep_dirs.append(st_packages_path) if py_ver == (3, 3): # sublime stubs - add as first