Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Register Context Commands with already added types #399

Merged
merged 3 commits into from
Nov 11, 2020
Merged
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 16 additions & 4 deletions packages/jupyterlab-lsp/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import {
import { ICommandPalette } from '@jupyterlab/apputils';
import { ISettingRegistry } from '@jupyterlab/settingregistry';
import { IDocumentManager } from '@jupyterlab/docmanager';
import { IDocumentWidget } from '@jupyterlab/docregistry';
import { Signal } from '@lumino/signaling';
import { LanguageServerManager } from './manager';
import '../style/index.css';
Expand All @@ -13,6 +14,7 @@ import { IStatusBar } from '@jupyterlab/statusbar';
import { LSPStatus } from './components/statusbar';
import { DocumentConnectionManager } from './connection_manager';
import {
IAdapterTypeOptions,
ILSPAdapterManager,
ILSPCodeExtractorsManager,
ILSPFeatureManager,
Expand All @@ -26,7 +28,7 @@ import { SIGNATURE_PLUGIN } from './features/signature';
import { HOVER_PLUGIN } from './features/hover';
import { RENAME_PLUGIN } from './features/rename';
import { HIGHLIGHTS_PLUGIN } from './features/highlights';
import { WIDGET_ADAPTER_MANAGER } from './adapter_manager';
import { WidgetAdapterManager, WIDGET_ADAPTER_MANAGER } from './adapter_manager';
import { FILE_EDITOR_ADAPTER } from './adapters/file_editor';
import { NOTEBOOK_ADAPTER } from './adapters/notebook';
import { VIRTUAL_EDITOR_MANAGER } from './virtual/editor';
Expand Down Expand Up @@ -166,9 +168,7 @@ export class LSPExtension implements ILSPExtension {
console.error(reason.message);
});

adapterManager.registerExtension(this);
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

if the ordering of this line and the connect below doesn't matter, perhaps we could:

  • connect first
  • resigterExtension
    • have registerExtension (which I assume can only be called once?) do this.types.foreach((t) => this.adapterTypeAdded.emit(t))

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I like this idea! In addition, it is worth noting that registerExtension already does two loops (one to connect to already registered adapters and second to watch for future registrations), so it seems like a natural place to address this problem.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you both for your quick response!
It sounds like a good idea; but I do have concerns (maybe they are unfounded).
If we do reemit adapterTypeAdded signal won't we cause potential problems if another extension decides to connect to it and then starts to receive multiple events with the same type?
Also, can we really assume that resigterExtension can be called only once? If so should we have something in place to enforce that?
Thank you!

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@bollwyvl @krassowski
I am more then happy to make the requested changes; but I thought I will make a small proposal first :)
I made some alterations please have a look and let me know what you think.
Thank you!

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Gah, lost what i was typing. So it goes.

So: it looks like registerExtension is expecting an LSPExtension, rather than an ILSPExtension. I think this kinda signals that it's meant for in-house usage, or would be entirely replaced, rather than having multiple. Perhaps @krassowski can suggest some tactical docstrings. If it can be multiple, then registerAdapterType probably needs to be added to the interface...

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

it looks like registerExtension is expecting an LSPExtension, rather than an ILSPExtension. I think this kinda signals that it's meant for in-house usage

yes, this is an accurate description.


adapterManager.adapterTypeAdded.connect((manager, type) => {
const registerContextCommandManager = (type: IAdapterTypeOptions<IDocumentWidget>): void => {
let command_manger = new ContextCommandManager({
adapter_manager: adapterManager,
app: app,
Expand All @@ -179,6 +179,18 @@ export class LSPExtension implements ILSPExtension {
...type.context_menu
});
this.feature_manager.registerCommandManager(command_manger);
};

// Register context commands with already added types
adapterManager.types.forEach((type: IAdapterTypeOptions<IDocumentWidget>) => {
registerContextCommandManager(type);
});

adapterManager.registerExtension(this);

// Register context commands with any types that may be added later
adapterManager.adapterTypeAdded.connect((manager: WidgetAdapterManager, type: IAdapterTypeOptions<IDocumentWidget>) => {
registerContextCommandManager(type);
});
}

Expand Down