Skip to content

Commit

Permalink
refactor: tidy codes
Browse files Browse the repository at this point in the history
Signed-off-by: Jack Cherng <[email protected]>
  • Loading branch information
jfcherng committed Oct 30, 2023
1 parent 3efb223 commit 2854aef
Show file tree
Hide file tree
Showing 3 changed files with 23 additions and 10 deletions.
9 changes: 4 additions & 5 deletions plugin/commands/auto_set_syntax_download_guesslang_server.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
from __future__ import annotations

import gzip
import shutil
import tarfile
import threading
import time
Expand All @@ -17,7 +16,7 @@
from ..guesslang.server import GuesslangServer
from ..settings import get_merged_plugin_setting
from ..shared import G
from ..utils import first_true
from ..utils import first_true, rmtree_ex

PathLike = Union[Path, str]

Expand All @@ -40,7 +39,7 @@ def _worker(cls) -> None:
server.stop()
time.sleep(1) # wait for stopping the server

shutil.rmtree(GuesslangServer.SERVER_DIR, ignore_errors=True)
rmtree_ex(GuesslangServer.SERVER_DIR, ignore_errors=True)

try:
cls._prepare_bin()
Expand Down Expand Up @@ -76,9 +75,9 @@ def _prepare_bin() -> None:
# move the decompressed folder one level up
guesslang_server_dir = folder.parent
tmp_dir = guesslang_server_dir.parent / ".tmp"
shutil.rmtree(tmp_dir, ignore_errors=True)
rmtree_ex(tmp_dir, ignore_errors=True)
folder.replace(tmp_dir)
shutil.rmtree(guesslang_server_dir, ignore_errors=True)
rmtree_ex(guesslang_server_dir, ignore_errors=True)
tmp_dir.replace(guesslang_server_dir)
# cleanup
zip_path.unlink(missing_ok=True)
Expand Down
10 changes: 5 additions & 5 deletions plugin/guesslang/server.py
Original file line number Diff line number Diff line change
Expand Up @@ -24,10 +24,10 @@ def __init__(self, host: str, port: int) -> None:

def start(self) -> bool:
"""Starts the guesslang server and return whether it starts."""
node_path, node_args = parse_node_path_args()
if not node_path:
if not (node_info := parse_node_path_args()):
Logger.log("❌ Node.js binary is not found or not executable")
return False
node_path, node_args = node_info
Logger.log(f"✔ Use Node.js binary ({node_path}) and args ({node_args})")

try:
Expand Down Expand Up @@ -98,13 +98,13 @@ def _start_process(
)


def parse_node_path_args() -> tuple[str | None, list[str]]:
def parse_node_path_args() -> tuple[str, list[str]] | None:
for node, args in (
(
get_merged_plugin_setting("guesslang.node_bin"),
get_merged_plugin_setting("guesslang.node_bin_args"),
),
(R"${lsp_utils_node_bin}", []),
("${lsp_utils_node_bin}", []),
(shutil.which("electron"), []),
(shutil.which("node"), []),
(shutil.which("code"), ["--ms-enable-electron-run-as-node"]), # VSCode
Expand All @@ -113,7 +113,7 @@ def parse_node_path_args() -> tuple[str | None, list[str]]:
):
if (node := expand_variables(node)) and is_executable(node):
return (node, args)
return (None, [])
return None


def is_executable(path: str | Path) -> bool:
Expand Down
14 changes: 14 additions & 0 deletions plugin/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,9 @@

import inspect
import operator
import os
import re
import shutil
import sys
import tempfile
import threading
Expand Down Expand Up @@ -456,6 +458,18 @@ def str_finditer(content: str, substr: str) -> Generator[int, None, None]:
idx += len(substr)


def rmtree_ex(path: str | Path, ignore_errors: bool = False, **kwargs: Any) -> None:
"""
Same with `shutil.rmtree` but with a workaround for long path on Windows.
@see https://stackoverflow.com/a/14076169/4643765
@see https://learn.microsoft.com/en-us/windows/win32/fileio/maximum-file-path-limitation
"""
if os.name == "nt" and (path := Path(path)).is_absolute():
path = R"\\?\{}".format(path)
shutil.rmtree(path, ignore_errors, **kwargs)


def stringify(obj: Any) -> str:
"""Custom object-to-string converter. Just used for debug messages."""
if isinstance(obj, sublime.View):
Expand Down

0 comments on commit 2854aef

Please sign in to comment.