From 15cd8daca2623b2ecf09df490b00bb68d157fe25 Mon Sep 17 00:00:00 2001 From: herr kaste Date: Sat, 11 Nov 2023 00:13:52 +0100 Subject: [PATCH 1/2] Use the `context` object to inject the stdin-filename into the command If we use SublimeLinter's standard way of injecting variables, we don't need to watch out for `$` characters because SublineLinter will do. This is what we did before #326 as well. This is a follow-up of #331. --- linter.py | 30 ++++++++++++++---------------- 1 file changed, 14 insertions(+), 16 deletions(-) diff --git a/linter.py b/linter.py index 55a58cd..46a782b 100644 --- a/linter.py +++ b/linter.py @@ -65,15 +65,24 @@ class ESLint(NodeLinter): line_col_base = (1, 1) defaults = { 'selector': OPTIMISTIC_SELECTOR, + '--stdin-filename': '${file:fallback_filename}', 'prefer_eslint_d': True, } def cmd(self): - cmd = ['eslint', '--format=json', '--stdin'] - stdin_filename = self.get_stdin_filename() - if stdin_filename: - cmd.append('--stdin-filename=' + stdin_filename.replace('$', '\\$')) - return cmd + if not self.context.get('file'): + fallback_filename = self.compute_fallback_filename() + if fallback_filename: + self.context['fallback_filename'] = fallback_filename + return ['eslint', '--format=json', '--stdin'] + + def compute_fallback_filename(self): + # type: () -> Optional[str] + view_selectors = set(self.view.scope_name(0).split(' ')) + for selector in BUFFER_FILE_EXTENSIONS.keys(): + if selector in view_selectors: + return '.'.join([BUFFER_FILE_STEM, BUFFER_FILE_EXTENSIONS[selector]]) + return None def run(self, cmd, code): # Workaround eslint bug https://github.com/eslint/eslint/issues/9515 @@ -138,17 +147,6 @@ def ensure_plugin_installed(self) -> bool: self.notify_unassign() # Abort linting without popping error dialog raise PermanentError() - def get_stdin_filename(self): - # type: () -> Optional[str] - filename = self.view.file_name() - if filename is None: - view_selectors = set(self.view.scope_name(0).split(' ')) - for selector in BUFFER_FILE_EXTENSIONS.keys(): - if selector in view_selectors: - filename = '.'.join([BUFFER_FILE_STEM, BUFFER_FILE_EXTENSIONS[selector]]) - break - return filename - def find_local_executable(self, start_dir, npm_name): # type: (str, str) -> Union[None, str, List[str]] """Automatically switch to `eslint_d` if available (and wanted).""" From b8b4d1dae0d3bc2dd5d9afb61e88ca598f9a4861 Mon Sep 17 00:00:00 2001 From: herr kaste Date: Sat, 11 Nov 2023 00:14:41 +0100 Subject: [PATCH 2/2] Use `"` to avoid escaping an `'` --- linter.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/linter.py b/linter.py index 46a782b..f921c9f 100644 --- a/linter.py +++ b/linter.py @@ -59,7 +59,7 @@ class ESLint(NodeLinter): """Provides an interface to the eslint executable.""" missing_config_regex = re.compile( - r'^(.*?)\r?\n\w*(ESLint couldn\'t find a configuration file.)', + r"^(.*?)\r?\n\w*(ESLint couldn't find a configuration file.)", re.DOTALL ) line_col_base = (1, 1)