From c405159cf5b3b61c2007d3c08958cba1d0be171a Mon Sep 17 00:00:00 2001 From: krassowski Date: Sun, 25 Oct 2020 11:58:34 +0000 Subject: [PATCH 1/3] Fix syntax highlighting not being deactivated --- atest/05_Features/Syntax_highlighting.robot | 24 +++++++++++++++---- .../src/features/syntax_highlighting.ts | 22 ++++++++++++++--- 2 files changed, 39 insertions(+), 7 deletions(-) diff --git a/atest/05_Features/Syntax_highlighting.robot b/atest/05_Features/Syntax_highlighting.robot index 919481e07..04e1b921b 100644 --- a/atest/05_Features/Syntax_highlighting.robot +++ b/atest/05_Features/Syntax_highlighting.robot @@ -24,13 +24,29 @@ Highlighing Mode Works For Multiple Documents ${mode} = Get Mode Of A Cell 6 should be equal ${mode['name']} javascript +Highlighting Mode Changes Back And Forth After Edits + ${mode} = Get Mode Of A Cell 2 + should be equal ${mode['name']} markdown + Enter Cell Editor 2 line=1 + Press Keys None BACKSPACE + Capture Page Screenshot backapse.png + wait until keyword succeeds 5x 2s Mode Of A Cell Should Equal 2 ipython + Enter Cell Editor 2 line=1 + Press Keys None n + wait until keyword succeeds 5x 2s Mode Of A Cell Should Equal 2 markdown + *** Keywords *** Get Mode Of A Cell - [Arguments] ${cell_nr} - Click Element css:.jp-Cell:nth-child(${cell_nr}) - Wait Until Page Contains Element css:.jp-Cell:nth-child(${cell_nr}) .CodeMirror-focused - ${mode} = Execute JavaScript return document.querySelector('.jp-Cell:nth-child(${cell_nr}) .CodeMirror').CodeMirror.getMode() + [Arguments] ${cell_number} + Click Element css:.jp-Cell:nth-child(${cell_number}) + Wait Until Page Contains Element css:.jp-Cell:nth-child(${cell_number}) .CodeMirror-focused + ${mode} = Execute JavaScript return document.querySelector('.jp-Cell:nth-child(${cell_number}) .CodeMirror').CodeMirror.getMode() [Return] ${mode} Setup Highlighting Test Setup Notebook Python Syntax highlighting.ipynb + +Mode Of A Cell Should Equal + [Arguments] ${cell_number} ${expected_mode} + ${mode} = Get Mode Of A Cell ${cell_number} + should be equal ${mode['name']} ${expected_mode} diff --git a/packages/jupyterlab-lsp/src/features/syntax_highlighting.ts b/packages/jupyterlab-lsp/src/features/syntax_highlighting.ts index 2c8ad5c60..8fcd5cd06 100644 --- a/packages/jupyterlab-lsp/src/features/syntax_highlighting.ts +++ b/packages/jupyterlab-lsp/src/features/syntax_highlighting.ts @@ -29,10 +29,12 @@ const FEATURE_ID = PLUGIN_ID + ':syntax_highlighting'; export class CMSyntaxHighlighting extends CodeMirrorIntegration { lab_integration: SyntaxLabIntegration; settings: IFeatureSettings; + editors_with_active_highlight: Set; constructor(options: IEditorIntegrationOptions) { super(options); this.virtual_document.changed.connect(this.update_mode.bind(this), this); + this.editors_with_active_highlight = new Set(); } private get_mode(language: string) { @@ -52,10 +54,12 @@ export class CMSyntaxHighlighting extends CodeMirrorIntegration { update_mode() { let root = this.virtual_document; + let editors_with_current_highlight = new Set(); + for (let map of root.foreign_document_maps) { for (let [range, block] of map.entries()) { - let ce_editor = block.editor; - let editor = (ce_editor as CodeMirrorEditor).editor; + let ce_editor = block.editor as CodeMirrorEditor; + let editor = ce_editor.editor; let lines = editor.getValue('\n'); let total_area = lines.concat('').length; @@ -73,15 +77,27 @@ export class CMSyntaxHighlighting extends CodeMirrorIntegration { continue; } + let old_mode = editor.getOption('mode'); + // change the mode if the majority of the code is the foreign code if (coverage > this.settings.composite.foreignCodeThreshold) { - let old_mode = editor.getOption('mode'); + editors_with_current_highlight.add(ce_editor); if (old_mode != mode.mime) { editor.setOption('mode', mode.mime); } } } } + + if (editors_with_current_highlight != this.editors_with_active_highlight) { + for (let ce_editor of this.editors_with_active_highlight) { + if (!editors_with_current_highlight.has(ce_editor)) { + ce_editor.editor.setOption('mode', ce_editor.model.mimeType); + } + } + } + + this.editors_with_active_highlight = editors_with_current_highlight; } } From 6f34d9180ecdca340e8243e6110ade2369b534ea Mon Sep 17 00:00:00 2001 From: krassowski Date: Sun, 25 Oct 2020 12:10:02 +0000 Subject: [PATCH 2/3] Add changelog entry --- CHANGELOG.md | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index f3a42bada..5d9e4f42b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,13 @@ ## CHANGELOG +### `@krassowski/jupyterlab-lsp 2.0.8` (unreleased) + +- bug fixes + + - custom cell syntax highlighting is now properly removed when no longer needed ([#387]) + +[#387]: https://github.com/krassowski/jupyterlab-lsp/issues/387 + ### `@krassowski/jupyterlab-lsp 2.0.7` (2020-09-18) - bug fixes From 83ce87a4907a437c893567c112d765411ad7dc58 Mon Sep 17 00:00:00 2001 From: krassowski Date: Sun, 25 Oct 2020 12:15:57 +0000 Subject: [PATCH 3/3] Performance: only check old_mode if needed --- packages/jupyterlab-lsp/src/features/syntax_highlighting.ts | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/packages/jupyterlab-lsp/src/features/syntax_highlighting.ts b/packages/jupyterlab-lsp/src/features/syntax_highlighting.ts index 8fcd5cd06..ec9a3fef1 100644 --- a/packages/jupyterlab-lsp/src/features/syntax_highlighting.ts +++ b/packages/jupyterlab-lsp/src/features/syntax_highlighting.ts @@ -77,11 +77,10 @@ export class CMSyntaxHighlighting extends CodeMirrorIntegration { continue; } - let old_mode = editor.getOption('mode'); - // change the mode if the majority of the code is the foreign code if (coverage > this.settings.composite.foreignCodeThreshold) { editors_with_current_highlight.add(ce_editor); + let old_mode = editor.getOption('mode'); if (old_mode != mode.mime) { editor.setOption('mode', mode.mime); }