-
Notifications
You must be signed in to change notification settings - Fork 149
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
Use language server implementation instead of language for URLs #199
Merged
krassowski
merged 18 commits into
jupyter-lsp:master
from
bollwyvl:add-urls-by-implementation
Feb 22, 2020
Merged
Changes from 4 commits
Commits
Show all changes
18 commits
Select commit
Hold shift + click to select a range
d6a8394
start refactor of language server URLs
bollwyvl a1e37cd
start language server manager
bollwyvl b1acd07
mock language server manager for python
bollwyvl f2f8ae5
wuks docker
bollwyvl 61bf62d
update changelog
bollwyvl b0b3571
more changelog
bollwyvl 371eedf
move queue puts to main loop
bollwyvl 35eaa1f
do stdio read/write in threadpool
bollwyvl 536790d
use put_nowait for queue reading for consistency
bollwyvl 67a593a
merge master
bollwyvl 99dc206
promote connection/language server managers to test environment
bollwyvl 45da449
add listener api changes to docs notebook
bollwyvl 6078327
some updating of the architecture docs
bollwyvl 5bfe3a2
revisit frontend arch a touch
bollwyvl 61e633d
ignore graphviz mypy errors
bollwyvl 5bc7b5f
also make shadow file ops async
bollwyvl aaf623a
lint architecture
bollwyvl d8966e0
add note about threading concerns
bollwyvl File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,86 @@ | ||
import { Signal } from '@phosphor/signaling'; | ||
|
||
import { PageConfig, URLExt } from '@jupyterlab/coreutils'; | ||
import { ServerConnection } from '@jupyterlab/services'; | ||
|
||
import { ILanguageServerManager, TSessionMap } from './tokens'; | ||
import * as SCHEMA from './_schema'; | ||
|
||
export class LanguageServerManager implements ILanguageServerManager { | ||
protected _sessionsChanged: Signal<ILanguageServerManager, void> = new Signal< | ||
ILanguageServerManager, | ||
void | ||
>(this); | ||
protected _sessions: TSessionMap = new Map(); | ||
private _settings: ServerConnection.ISettings; | ||
private _baseUrl: string; | ||
|
||
constructor(options: ILanguageServerManager.IOptions) { | ||
this._settings = options.settings || ServerConnection.makeSettings(); | ||
this._baseUrl = options.baseUrl || PageConfig.getBaseUrl(); | ||
this.fetchSessions().catch(console.warn); | ||
} | ||
|
||
get statusUrl() { | ||
return URLExt.join(this._baseUrl, ILanguageServerManager.URL_NS, 'status'); | ||
} | ||
|
||
get sessionsChanged() { | ||
return this._sessionsChanged; | ||
} | ||
|
||
get sessions(): TSessionMap { | ||
return this._sessions; | ||
} | ||
|
||
getServerId(options: ILanguageServerManager.IGetServerIdOptions) { | ||
// most things speak language | ||
for (const [key, session] of this._sessions.entries()) { | ||
if (options.language) { | ||
if (session.spec.languages.indexOf(options.language) !== -1) { | ||
return key; | ||
} | ||
} | ||
} | ||
return null; | ||
} | ||
|
||
async fetchSessions() { | ||
let response = await ServerConnection.makeRequest( | ||
this.statusUrl, | ||
{ method: 'GET' }, | ||
this._settings | ||
); | ||
|
||
if (!response.ok) { | ||
throw new Error(response.statusText); | ||
} | ||
|
||
let sessions: SCHEMA.Sessions; | ||
|
||
try { | ||
sessions = (await response.json()).sessions; | ||
} catch (err) { | ||
console.warn(err); | ||
return; | ||
} | ||
|
||
for (const key of Object.keys(sessions)) { | ||
if (this._sessions.has(key)) { | ||
Object.assign(this._sessions.get(key), sessions[key]); | ||
} else { | ||
this._sessions.set(key, sessions[key]); | ||
} | ||
} | ||
|
||
const oldKeys = this._sessions.keys(); | ||
|
||
for (const oldKey in oldKeys) { | ||
if (!sessions[oldKey]) { | ||
this._sessions.delete(oldKey); | ||
} | ||
} | ||
|
||
this._sessionsChanged.emit(void 0); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
import { ISignal } from '@phosphor/signaling'; | ||
import { ServerConnection } from '@jupyterlab/services'; | ||
|
||
import * as SCHEMA from './_schema'; | ||
|
||
export type TLanguageServerId = string; | ||
export type TLanguageId = string; | ||
|
||
export type TSessionMap = Map<TLanguageServerId, SCHEMA.LanguageServerSession>; | ||
|
||
export interface ILanguageServerManager { | ||
sessionsChanged: ISignal<ILanguageServerManager, void>; | ||
sessions: TSessionMap; | ||
getServerId( | ||
options: ILanguageServerManager.IGetServerIdOptions | ||
): TLanguageServerId; | ||
fetchSessions(): Promise<void>; | ||
statusUrl: string; | ||
} | ||
|
||
export namespace ILanguageServerManager { | ||
export const URL_NS = 'lsp'; | ||
export interface IOptions { | ||
settings?: ServerConnection.ISettings; | ||
baseUrl?: string; | ||
} | ||
export interface IGetServerIdOptions { | ||
language?: TLanguageId; | ||
mimeType?: string; | ||
} | ||
} |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So this "fixes" the problem, but the fact remains that you don't reliably get diagnostics back from a dockerfile on the first file opened until you change the file (then it seems to work every time). I tried sending more change events, but it didn't have an effect. I'm willing to deal with it if it makes the tests pass for now.