Skip to content

Commit

Permalink
Merge pull request #300 from bollwyvl/gh-299-no-throw
Browse files Browse the repository at this point in the history
stop using throw
  • Loading branch information
krassowski authored Jul 28, 2020
2 parents acf17ab + cd8783f commit 913689d
Show file tree
Hide file tree
Showing 7 changed files with 34 additions and 13 deletions.
9 changes: 9 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,14 @@
## CHANGELOG

### `@krassowski/jupyterlab-lsp 1.1.1` (unreleased)

- bug fixes

- emits console warnings instead of throwing errors in hover handlers and connections ([#299][], [#300][])

[#299]: https://github.com/krassowski/jupyterlab-lsp/pull/299
[#300]: https://github.com/krassowski/jupyterlab-lsp/pull/300

### `jupyter-lsp 0.9.x` (unreleased)

- autodetects the `texlab` language server for `.tex` files ([#288][])
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -201,7 +201,7 @@ export class Hover extends CodeMirrorLSPFeature {
e.message === "Cannot read property 'string' of undefined"
)
) {
throw e;
console.warn(e);
}
}
};
Expand Down
9 changes: 7 additions & 2 deletions packages/jupyterlab-lsp/src/command_manager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -201,7 +201,7 @@ export class NotebookCommandManager extends ContextCommandManager {
return notebook_adapters.get(notebook.id);
}

context_from_active_document(): ICommandContext {
context_from_active_document(): ICommandContext | null {
if (!this.is_widget_current) {
return null;
}
Expand All @@ -213,7 +213,7 @@ export class NotebookCommandManager extends ContextCommandManager {

let virtual_editor = this.current_adapter?.virtual_editor;

if (!virtual_editor) {
if (virtual_editor == null) {
return null;
}

Expand All @@ -222,6 +222,11 @@ export class NotebookCommandManager extends ContextCommandManager {
cm_cursor
);

if (root_position == null) {
console.warn('Could not retrieve current context', virtual_editor);
return null;
}

return this.current_adapter?.get_context(root_position);
}
}
Expand Down
3 changes: 2 additions & 1 deletion packages/jupyterlab-lsp/src/manager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,8 @@ export class LanguageServerManager implements ILanguageServerManager {
);

if (!response.ok) {
throw new Error(response.statusText);
console.error('Could not fetch sessions', response);
return;
}

let sessions: SCHEMA.Sessions;
Expand Down
7 changes: 4 additions & 3 deletions packages/jupyterlab-lsp/src/virtual/editors/notebook.ts
Original file line number Diff line number Diff line change
Expand Up @@ -118,11 +118,12 @@ export class VirtualEditorForNotebook extends VirtualEditor {
transform_from_notebook_to_root(
cell: Cell,
position: IEditorPosition
): IRootPosition {
): IRootPosition | null {
// TODO: if cell is not known, refresh
let shift = this.cell_to_corresponding_source_line.get(cell);
if (shift === undefined) {
throw Error('Cell not found in cell_line_map');
if (shift == null) {
console.warn('Cell not found in cell_line_map');
return null;
}
return {
...(position as CodeMirror.Position),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ interface IFlexibleServerCapabilities extends ServerCapabilities {
function registerServerCapability(
serverCapabilities: ServerCapabilities,
registration: Registration
): ServerCapabilities {
): ServerCapabilities | null {
const serverCapabilitiesCopy = JSON.parse(
JSON.stringify(serverCapabilities)
) as IFlexibleServerCapabilities;
Expand All @@ -27,7 +27,8 @@ function registerServerCapability(
);
}
} else {
throw new Error('Could not register server capability.');
console.warn('Could not register server capability.', registration);
return null;
}

return serverCapabilitiesCopy;
Expand Down
12 changes: 8 additions & 4 deletions packages/lsp-ws-connection/src/ws-connection.ts
Original file line number Diff line number Diff line change
Expand Up @@ -79,10 +79,14 @@ export class LspWsConnection extends events.EventEmitter
(params: protocol.RegistrationParams) => {
params.registrations.forEach(
(capabilityRegistration: protocol.Registration) => {
this.serverCapabilities = registerServerCapability(
this.serverCapabilities,
capabilityRegistration
);
try {
this.serverCapabilities = registerServerCapability(
this.serverCapabilities,
capabilityRegistration
);
} catch (err) {
console.error(err);
}
}
);

Expand Down

0 comments on commit 913689d

Please sign in to comment.