@parcel/lsp 2.8.4-nightly.2921 → 2.8.4-nightly.2937

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/LspServer.js CHANGED
@@ -1,13 +1,13 @@
1
- var $h7GWc$path = require("path");
2
- var $h7GWc$fs = require("fs");
3
- var $h7GWc$os = require("os");
4
- var $h7GWc$vscodelanguageservernode = require("vscode-languageserver/node");
5
- var $h7GWc$vscodejsonrpcnode = require("vscode-jsonrpc/node");
6
- var $h7GWc$assert = require("assert");
7
- var $h7GWc$url = require("url");
8
- var $h7GWc$commonpathprefix = require("common-path-prefix");
9
- var $h7GWc$parcelwatcher = require("@parcel/watcher");
10
- var $h7GWc$parcellspprotocol = require("@parcel/lsp-protocol");
1
+ var $dVHCG$path = require("path");
2
+ var $dVHCG$fs = require("fs");
3
+ var $dVHCG$os = require("os");
4
+ var $dVHCG$vscodelanguageservernode = require("vscode-languageserver/node");
5
+ var $dVHCG$vscodejsonrpcnode = require("vscode-jsonrpc/node");
6
+ var $dVHCG$assert = require("assert");
7
+ var $dVHCG$url = require("url");
8
+ var $dVHCG$commonpathprefix = require("common-path-prefix");
9
+ var $dVHCG$parcelwatcher = require("@parcel/watcher");
10
+ var $dVHCG$parcellspprotocol = require("@parcel/lsp-protocol");
11
11
 
12
12
 
13
13
 
@@ -19,25 +19,29 @@ var $h7GWc$parcellspprotocol = require("@parcel/lsp-protocol");
19
19
 
20
20
 
21
21
 
22
- const $d8a78e51eb7c0a45$var$connection = (0, $h7GWc$vscodelanguageservernode.createConnection)((0, $h7GWc$vscodelanguageservernode.ProposedFeatures).all); // Create a simple text document manager.
22
+ const $2475bcbbe4d83464$var$connection = (0, $dVHCG$vscodelanguageservernode.createConnection)((0, $dVHCG$vscodelanguageservernode.ProposedFeatures).all);
23
+ // Create a simple text document manager.
23
24
  // const documents: TextDocuments<TextDocument> = new TextDocuments(TextDocument);
24
- let $d8a78e51eb7c0a45$var$hasConfigurationCapability = false;
25
- let $d8a78e51eb7c0a45$var$hasWorkspaceFolderCapability = false; // let hasDiagnosticRelatedInformationCapability = false;
26
- let $d8a78e51eb7c0a45$var$hasDiagnosticsRefreshSupport = false;
27
- $d8a78e51eb7c0a45$var$connection.onInitialize((params)=>{
25
+ let $2475bcbbe4d83464$var$hasConfigurationCapability = false;
26
+ let $2475bcbbe4d83464$var$hasWorkspaceFolderCapability = false;
27
+ // let hasDiagnosticRelatedInformationCapability = false;
28
+ let $2475bcbbe4d83464$var$hasDiagnosticsRefreshSupport = false;
29
+ $2475bcbbe4d83464$var$connection.onInitialize((params)=>{
28
30
  var _capabilities_workspace, _capabilities_workspace_diagnostics;
29
- const capabilities = params.capabilities; // Does the client support the `workspace/configuration` request?
31
+ const capabilities = params.capabilities;
32
+ // Does the client support the `workspace/configuration` request?
30
33
  // If not, we fall back using global settings.
31
- $d8a78e51eb7c0a45$var$hasConfigurationCapability = !!(capabilities.workspace && !!capabilities.workspace.configuration);
32
- $d8a78e51eb7c0a45$var$hasWorkspaceFolderCapability = !!(capabilities.workspace && !!capabilities.workspace.workspaceFolders); // hasDiagnosticRelatedInformationCapability = !!(
34
+ $2475bcbbe4d83464$var$hasConfigurationCapability = !!(capabilities.workspace && !!capabilities.workspace.configuration);
35
+ $2475bcbbe4d83464$var$hasWorkspaceFolderCapability = !!(capabilities.workspace && !!capabilities.workspace.workspaceFolders);
36
+ // hasDiagnosticRelatedInformationCapability = !!(
33
37
  // capabilities.textDocument &&
34
38
  // capabilities.textDocument.publishDiagnostics &&
35
39
  // capabilities.textDocument.publishDiagnostics.relatedInformation
36
40
  // );
37
- $d8a78e51eb7c0a45$var$hasDiagnosticsRefreshSupport = Boolean((_capabilities_workspace = capabilities.workspace) === null || _capabilities_workspace === void 0 ? void 0 : (_capabilities_workspace_diagnostics = _capabilities_workspace.diagnostics) === null || _capabilities_workspace_diagnostics === void 0 ? void 0 : _capabilities_workspace_diagnostics.refreshSupport);
41
+ $2475bcbbe4d83464$var$hasDiagnosticsRefreshSupport = Boolean((_capabilities_workspace = capabilities.workspace) === null || _capabilities_workspace === void 0 ? void 0 : (_capabilities_workspace_diagnostics = _capabilities_workspace.diagnostics) === null || _capabilities_workspace_diagnostics === void 0 ? void 0 : _capabilities_workspace_diagnostics.refreshSupport);
38
42
  const result = {
39
43
  capabilities: {
40
- textDocumentSync: (0, $h7GWc$vscodelanguageservernode.TextDocumentSyncKind).Incremental,
44
+ textDocumentSync: (0, $dVHCG$vscodelanguageservernode.TextDocumentSyncKind).Incremental,
41
45
  // Tell the client that this server supports code completion.
42
46
  diagnosticProvider: {
43
47
  workspaceDiagnostics: false,
@@ -45,30 +49,31 @@ $d8a78e51eb7c0a45$var$connection.onInitialize((params)=>{
45
49
  }
46
50
  }
47
51
  };
48
- if ($d8a78e51eb7c0a45$var$hasWorkspaceFolderCapability) result.capabilities.workspace = {
52
+ if ($2475bcbbe4d83464$var$hasWorkspaceFolderCapability) result.capabilities.workspace = {
49
53
  workspaceFolders: {
50
54
  supported: true
51
55
  }
52
56
  };
53
57
  return result;
54
58
  });
55
- $d8a78e51eb7c0a45$var$connection.onInitialized(()=>{
56
- if ($d8a78e51eb7c0a45$var$hasConfigurationCapability) // Register for all configuration changes.
57
- $d8a78e51eb7c0a45$var$connection.client.register((0, $h7GWc$vscodelanguageservernode.DidChangeConfigurationNotification).type, undefined);
58
- if ($d8a78e51eb7c0a45$var$hasWorkspaceFolderCapability) $d8a78e51eb7c0a45$var$connection.workspace.onDidChangeWorkspaceFolders(()=>{
59
- $d8a78e51eb7c0a45$var$connection.console.log("Workspace folder change event received.");
59
+ $2475bcbbe4d83464$var$connection.onInitialized(()=>{
60
+ if ($2475bcbbe4d83464$var$hasConfigurationCapability) // Register for all configuration changes.
61
+ $2475bcbbe4d83464$var$connection.client.register((0, $dVHCG$vscodelanguageservernode.DidChangeConfigurationNotification).type, undefined);
62
+ if ($2475bcbbe4d83464$var$hasWorkspaceFolderCapability) $2475bcbbe4d83464$var$connection.workspace.onDidChangeWorkspaceFolders(()=>{
63
+ $2475bcbbe4d83464$var$connection.console.log("Workspace folder change event received.");
60
64
  });
61
- }); // Proxy
62
- $d8a78e51eb7c0a45$var$connection.onRequest((0, $h7GWc$parcellspprotocol.RequestImporters), async (params)=>{
63
- let client = $d8a78e51eb7c0a45$var$findClient(params);
65
+ });
66
+ // Proxy
67
+ $2475bcbbe4d83464$var$connection.onRequest((0, $dVHCG$parcellspprotocol.RequestImporters), async (params)=>{
68
+ let client = $2475bcbbe4d83464$var$findClient(params);
64
69
  if (client) {
65
- let result = await client.connection.sendRequest((0, $h7GWc$parcellspprotocol.RequestImporters), params);
70
+ let result = await client.connection.sendRequest((0, $dVHCG$parcellspprotocol.RequestImporters), params);
66
71
  return result;
67
72
  }
68
73
  return null;
69
74
  });
70
- $d8a78e51eb7c0a45$var$connection.onRequest((0, $h7GWc$vscodelanguageservernode.DocumentDiagnosticRequest).type, async (params)=>{
71
- let client = $d8a78e51eb7c0a45$var$findClient(params.textDocument.uri);
75
+ $2475bcbbe4d83464$var$connection.onRequest((0, $dVHCG$vscodelanguageservernode.DocumentDiagnosticRequest).type, async (params)=>{
76
+ let client = $2475bcbbe4d83464$var$findClient(params.textDocument.uri);
72
77
  let result;
73
78
  if (client) {
74
79
  // console.log(
@@ -77,23 +82,23 @@ $d8a78e51eb7c0a45$var$connection.onRequest((0, $h7GWc$vscodelanguageservernode.D
77
82
  // params.previousResultId === client.lastBuild,
78
83
  // );
79
84
  if (params.previousResultId === client.lastBuild) return {
80
- kind: (0, $h7GWc$vscodelanguageservernode.DocumentDiagnosticReportKind).Unchanged,
85
+ kind: (0, $dVHCG$vscodelanguageservernode.DocumentDiagnosticReportKind).Unchanged,
81
86
  resultId: client.lastBuild
82
87
  };
83
- result = await client.connection.sendRequest((0, $h7GWc$parcellspprotocol.RequestDocumentDiagnostics), params.textDocument.uri);
88
+ result = await client.connection.sendRequest((0, $dVHCG$parcellspprotocol.RequestDocumentDiagnostics), params.textDocument.uri);
84
89
  if (result) client.uris.add(params.textDocument.uri);
85
90
  }
86
91
  return {
87
- kind: (0, $h7GWc$vscodelanguageservernode.DocumentDiagnosticReportKind).Full,
92
+ kind: (0, $dVHCG$vscodelanguageservernode.DocumentDiagnosticReportKind).Full,
88
93
  resultId: client === null || client === void 0 ? void 0 : client.lastBuild,
89
94
  items: result !== null && result !== void 0 ? result : []
90
95
  };
91
96
  });
92
- $d8a78e51eb7c0a45$var$connection.listen();
93
- class $d8a78e51eb7c0a45$var$ProgressReporter {
97
+ $2475bcbbe4d83464$var$connection.listen();
98
+ class $2475bcbbe4d83464$var$ProgressReporter {
94
99
  begin() {
95
100
  this.progressReporterPromise = (async ()=>{
96
- let reporter = await $d8a78e51eb7c0a45$var$connection.window.createWorkDoneProgress();
101
+ let reporter = await $2475bcbbe4d83464$var$connection.window.createWorkDoneProgress();
97
102
  reporter.begin("Parcel");
98
103
  return reporter;
99
104
  })();
@@ -103,7 +108,7 @@ class $d8a78e51eb7c0a45$var$ProgressReporter {
103
108
  }
104
109
  async done() {
105
110
  if (this.progressReporterPromise == null) this.begin();
106
- $h7GWc$assert(this.progressReporterPromise != null);
111
+ $dVHCG$assert(this.progressReporterPromise != null);
107
112
  (await this.progressReporterPromise).done();
108
113
  this.progressReporterPromise = null;
109
114
  }
@@ -117,17 +122,17 @@ class $d8a78e51eb7c0a45$var$ProgressReporter {
117
122
  }
118
123
  }
119
124
  }
120
- function $d8a78e51eb7c0a45$var$sendDiagnosticsRefresh() {
121
- if ($d8a78e51eb7c0a45$var$hasDiagnosticsRefreshSupport) $d8a78e51eb7c0a45$var$connection.sendRequest((0, $h7GWc$vscodelanguageservernode.DiagnosticRefreshRequest).type);
125
+ function $2475bcbbe4d83464$var$sendDiagnosticsRefresh() {
126
+ if ($2475bcbbe4d83464$var$hasDiagnosticsRefreshSupport) $2475bcbbe4d83464$var$connection.sendRequest((0, $dVHCG$vscodelanguageservernode.DiagnosticRefreshRequest).type);
122
127
  }
123
- let $d8a78e51eb7c0a45$var$progressReporter = new $d8a78e51eb7c0a45$var$ProgressReporter();
124
- let $d8a78e51eb7c0a45$var$clients = new Map();
125
- function $d8a78e51eb7c0a45$var$findClient(document) {
126
- let filepath = $h7GWc$url.fileURLToPath(document);
128
+ let $2475bcbbe4d83464$var$progressReporter = new $2475bcbbe4d83464$var$ProgressReporter();
129
+ let $2475bcbbe4d83464$var$clients = new Map();
130
+ function $2475bcbbe4d83464$var$findClient(document) {
131
+ let filepath = $dVHCG$url.fileURLToPath(document);
127
132
  let longestPrefix = 0;
128
133
  let bestClient;
129
- for (let [, client] of $d8a78e51eb7c0a45$var$clients){
130
- let prefix = $h7GWc$commonpathprefix([
134
+ for (let [, client] of $2475bcbbe4d83464$var$clients){
135
+ let prefix = $dVHCG$commonpathprefix([
131
136
  client.projectRoot,
132
137
  filepath
133
138
  ]).length;
@@ -138,11 +143,11 @@ function $d8a78e51eb7c0a45$var$findClient(document) {
138
143
  }
139
144
  return bestClient;
140
145
  }
141
- function $d8a78e51eb7c0a45$var$createClient(metafilepath) {
142
- let metafile = JSON.parse($h7GWc$fs.readFileSync(metafilepath, "utf8"));
146
+ function $2475bcbbe4d83464$var$createClient(metafilepath) {
147
+ let metafile = JSON.parse($dVHCG$fs.readFileSync(metafilepath, "utf8"));
143
148
  let socketfilepath = metafilepath.slice(0, -5);
144
- let [reader, writer] = (0, $h7GWc$vscodejsonrpcnode.createServerPipeTransport)(socketfilepath);
145
- let client = (0, $h7GWc$vscodejsonrpcnode.createMessageConnection)(reader, writer);
149
+ let [reader, writer] = (0, $dVHCG$vscodejsonrpcnode.createServerPipeTransport)(socketfilepath);
150
+ let client = (0, $dVHCG$vscodejsonrpcnode.createMessageConnection)(reader, writer);
146
151
  client.listen();
147
152
  let uris = new Set();
148
153
  let result = {
@@ -151,62 +156,68 @@ function $d8a78e51eb7c0a45$var$createClient(metafilepath) {
151
156
  projectRoot: metafile.projectRoot,
152
157
  lastBuild: "0"
153
158
  };
154
- client.onNotification((0, $h7GWc$parcellspprotocol.NotificationBuildStatus), (state, message)=>{
159
+ client.onNotification((0, $dVHCG$parcellspprotocol.NotificationBuildStatus), (state, message)=>{
155
160
  // console.log('got NotificationBuildStatus', state, message);
156
161
  if (state === "start") {
157
- $d8a78e51eb7c0a45$var$progressReporter.begin();
158
- for (let uri of uris)$d8a78e51eb7c0a45$var$connection.sendDiagnostics({
162
+ $2475bcbbe4d83464$var$progressReporter.begin();
163
+ for (let uri of uris)$2475bcbbe4d83464$var$connection.sendDiagnostics({
159
164
  uri: uri,
160
165
  diagnostics: []
161
166
  });
162
- } else if (state === "progress" && message != null) $d8a78e51eb7c0a45$var$progressReporter.report(message);
167
+ } else if (state === "progress" && message != null) $2475bcbbe4d83464$var$progressReporter.report(message);
163
168
  else if (state === "end") {
164
169
  result.lastBuild = String(Date.now());
165
- $d8a78e51eb7c0a45$var$sendDiagnosticsRefresh();
166
- $d8a78e51eb7c0a45$var$progressReporter.done();
167
- $d8a78e51eb7c0a45$var$connection.sendNotification((0, $h7GWc$parcellspprotocol.NotificationBuild));
170
+ $2475bcbbe4d83464$var$sendDiagnosticsRefresh();
171
+ $2475bcbbe4d83464$var$progressReporter.done();
172
+ $2475bcbbe4d83464$var$connection.sendNotification((0, $dVHCG$parcellspprotocol.NotificationBuild));
168
173
  }
169
174
  });
170
- client.onNotification((0, $h7GWc$parcellspprotocol.NotificationWorkspaceDiagnostics), (diagnostics)=>{
175
+ client.onNotification((0, $dVHCG$parcellspprotocol.NotificationWorkspaceDiagnostics), (diagnostics)=>{
171
176
  // console.log('got NotificationWorkspaceDiagnostics', diagnostics);
172
177
  for (let d of diagnostics){
173
178
  uris.add(d.uri);
174
- $d8a78e51eb7c0a45$var$connection.sendDiagnostics(d);
179
+ $2475bcbbe4d83464$var$connection.sendDiagnostics(d);
175
180
  }
176
181
  });
177
182
  client.onClose(()=>{
178
- $d8a78e51eb7c0a45$var$clients.delete(metafile);
179
- $d8a78e51eb7c0a45$var$sendDiagnosticsRefresh();
183
+ $2475bcbbe4d83464$var$clients.delete(metafile);
184
+ $2475bcbbe4d83464$var$sendDiagnosticsRefresh();
180
185
  return Promise.all([
181
186
  ...uris
182
- ].map((uri)=>$d8a78e51eb7c0a45$var$connection.sendDiagnostics({
187
+ ].map((uri)=>$2475bcbbe4d83464$var$connection.sendDiagnostics({
183
188
  uri: uri,
184
189
  diagnostics: []
185
190
  })));
186
191
  });
187
- $d8a78e51eb7c0a45$var$sendDiagnosticsRefresh();
188
- $d8a78e51eb7c0a45$var$clients.set(metafile, result);
189
- } // Take realpath because to have consistent cache keys on macOS (/var -> /private/var)
190
- const $d8a78e51eb7c0a45$var$BASEDIR = $h7GWc$path.join($h7GWc$fs.realpathSync($h7GWc$os.tmpdir()), "parcel-lsp");
191
- $h7GWc$fs.mkdirSync($d8a78e51eb7c0a45$var$BASEDIR, {
192
+ $2475bcbbe4d83464$var$sendDiagnosticsRefresh();
193
+ $2475bcbbe4d83464$var$clients.set(metafile, result);
194
+ }
195
+ // Take realpath because to have consistent cache keys on macOS (/var -> /private/var)
196
+ const $2475bcbbe4d83464$var$BASEDIR = $dVHCG$path.join($dVHCG$fs.realpathSync($dVHCG$os.tmpdir()), "parcel-lsp");
197
+ $dVHCG$fs.mkdirSync($2475bcbbe4d83464$var$BASEDIR, {
192
198
  recursive: true
193
- }); // Search for currently running Parcel processes in the parcel-lsp dir.
199
+ });
200
+ // Search for currently running Parcel processes in the parcel-lsp dir.
194
201
  // Create an IPC client connection for each running process.
195
- for (let filename of $h7GWc$fs.readdirSync($d8a78e51eb7c0a45$var$BASEDIR)){
202
+ for (let filename of $dVHCG$fs.readdirSync($2475bcbbe4d83464$var$BASEDIR)){
196
203
  if (!filename.endsWith(".json")) continue;
197
- let filepath = $h7GWc$path.join($d8a78e51eb7c0a45$var$BASEDIR, filename);
198
- $d8a78e51eb7c0a45$var$createClient(filepath); // console.log('connected initial', filepath);
199
- } // Watch for new Parcel processes in the parcel-lsp dir, and disconnect the
204
+ let filepath = $dVHCG$path.join($2475bcbbe4d83464$var$BASEDIR, filename);
205
+ $2475bcbbe4d83464$var$createClient(filepath);
206
+ // console.log('connected initial', filepath);
207
+ }
208
+ // Watch for new Parcel processes in the parcel-lsp dir, and disconnect the
200
209
  // client for each corresponding connection when a Parcel process ends
201
- $h7GWc$parcelwatcher.subscribe($d8a78e51eb7c0a45$var$BASEDIR, async (err, events)=>{
210
+ $dVHCG$parcelwatcher.subscribe($2475bcbbe4d83464$var$BASEDIR, async (err, events)=>{
202
211
  if (err) throw err;
203
212
  for (let event of events){
204
- if (event.type === "create" && event.path.endsWith(".json")) $d8a78e51eb7c0a45$var$createClient(event.path); // console.log('connected watched', event.path);
213
+ if (event.type === "create" && event.path.endsWith(".json")) $2475bcbbe4d83464$var$createClient(event.path);
205
214
  else if (event.type === "delete" && event.path.endsWith(".json")) {
206
- let existing = $d8a78e51eb7c0a45$var$clients.get(event.path); // console.log('existing', event.path, existing);
215
+ let existing = $2475bcbbe4d83464$var$clients.get(event.path);
216
+ // console.log('existing', event.path, existing);
207
217
  if (existing) {
208
- $d8a78e51eb7c0a45$var$clients.delete(event.path);
209
- existing.connection.end(); // console.log('disconnected watched', event.path);
218
+ $2475bcbbe4d83464$var$clients.delete(event.path);
219
+ existing.connection.end();
220
+ // console.log('disconnected watched', event.path);
210
221
  }
211
222
  }
212
223
  }
@@ -1 +1 @@
1
- {"mappings":";;;;;;;;;;;;;;;;;;;;;AAsCA,MAAM4B,mCAAazB,CAAAA,GAAAA,gDAAAA,EAAiBU,CAAAA,GAAAA,gDAAgB,AAAhBA,EAAiBgB,GAAlB,GAEnC,yCAFA;AAGA,kFAAA;AAEA,IAAIC,mDAA6B,KAAjC;AACA,IAAIC,qDAA+B,KAAnC,EACA,yDADA;AAEA,IAAIC,qDAA+B,KAAnC;AAEAJ,iCAAWK,YAAX,CAAwB,CAACC,SAA6B;QAiBlDC;IAhBF,MAAMA,eAAeD,OAAOC,YAA5B,EAEA,iEAFA;IAGA,8CAAA;IACAL,mDAA6B,CAAC,CAC5BK,CAAAA,aAAaC,SAAb,IAA0B,CAAC,CAACD,aAAaC,SAAb,CAAuBC,aADvB,AACuBA;IAErDN,qDAA+B,CAAC,CAC9BI,CAAAA,aAAaC,SAAb,IAA0B,CAAC,CAACD,aAAaC,SAAb,CAAuBE,gBADrB,AACqBA,GAErD,kDAHAP;IAIA,iCAAA;IACA,oDAAA;IACA,oEAAA;IACA,KAAA;IACAC,qDAA+BO,QAC7BJ,CAAAA,0BAAAA,aAAaC,SAAb,cAAAD,qCAAAA,KAAAA,IAAAA,uCAAAA,wBAAwBK,0EAAxBL,KAAAA,wCAAqCM,cAArC;IAGF,MAAMC,SAA2B;QAC/BP,cAAc;YACZQ,kBAAkB7B,CAAAA,GAAAA,oDAAoB,AAApBA,EAAqB8B,WAD3B;YAEZ,6DAAA;YACAC,oBAAoB;gBAClBC,sBAAsB,KADJ;gBAElBC,uBAAuB,IAAvBA;YAFkB;QAHR;IADiB;IAWjC,IAAIhB,oDACFW,OAAOP,YAAP,CAAoBC,SAApB,GAAgC;QAC9BE,kBAAkB;YAChBU,WAAW,IAAXA;QADgB;IADY;IAMlC,OAAON;AACR;AAEDd,iCAAWqB,aAAX,CAAyB,IAAM;IAC7B,IAAInB,kDACF,0CAAA;IACAF,iCAAWsB,MAAX,CAAkBC,QAAlB,CACE9C,CAAAA,GAAAA,kEAAkC,AAAlCA,EAAmC+C,IADrC,EAEEC;IAGJ,IAAItB,oDACFH,iCAAWQ,SAAX,CAAqBkB,2BAArB,CAAiD,IAAU;QACzD1B,iCAAW2B,OAAX,CAAmBC,GAAnB,CAAuB;IACxB;AAEJ,IAED,QAFC;AAGD5B,iCAAW6B,SAAX,CAAqB9B,CAAAA,GAAAA,yCAAAA,GAAkB,OAAMO,SAAU;IACrD,IAAIgB,SAASQ,iCAAWxB;IACxB,IAAIgB,QAAQ;QACV,IAAIR,SAAS,MAAMQ,OAAOtB,UAAP,CAAkB+B,WAAlB,CAA8BhC,CAAAA,GAAAA,yCAA9B,AAA8BA,GAAkBO;QACnE,OAAOQ;IACR,CAAA;IACD,OAAO,IAAP;AACD;AAEDd,iCAAW6B,SAAX,CACEhD,CAAAA,GAAAA,yDAAyB,AAAzBA,EAA0B2C,IAD5B,EAEE,OACElB,SACsC;IACtC,IAAIgB,SAASQ,iCAAWxB,OAAO2B,YAAP,CAAoBC,GAArB;IACvB,IAAIpB;IACJ,IAAIQ,QAAQ;QACV,eAAA;QACA,iCAAA;QACA,6BAAA;QACA,kDAAA;QACA,KAAA;QAEA,IAAIhB,OAAO6B,gBAAP,KAA4Bb,OAAOc,SAAvC,EACE,OAAO;YACLC,MAAMzD,CAAAA,GAAAA,4DAA4B,AAA5BA,EAA6B0D,SAD9B;YAELC,UAAUjB,OAAOc,SAAjBG;QAFK;QAMTzB,SAAS,MAAMQ,OAAOtB,UAAP,CAAkB+B,WAAlB,CACbjC,CAAAA,GAAAA,mDAAAA,GACAQ,OAAO2B,YAAP,CAAoBC,GAFP;QAKf,IAAIpB,QACFQ,OAAOkB,IAAP,CAAYC,GAAZ,CAAgBnC,OAAO2B,YAAP,CAAoBC,GAApC;IAEH,CAAA;IAED,OAAO;QACLG,MAAMzD,CAAAA,GAAAA,4DAA4B,AAA5BA,EAA6B8D,IAD9B;QAELH,UAAUjB,mBAAAA,oBAAAA,KAAAA,IAAAA,OAAQc,SAFb;QAGLO,OAAO7B,mBAAAA,oBAAAA,SAAU,EAAjB6B;IAHK;AAKR;AAGH3C,iCAAW4C,MAAX;AAEA,MAAMC;IAGJC,QAAQ;QACN,IAAA,CAAKC,uBAAL,GAA+B,AAAC,CAAA,UAAY;YAC1C,IAAIC,WAAW,MAAMhD,iCAAWiD,MAAX,CAAkBC,sBAAlB;YACrBF,SAASF,KAAT,CAAe;YACf,OAAOE;QACR,CAAA;QACD,IAAA,CAAKD,uBAAL,CAA6BI,IAA7B,CAAkCH,CAAAA,WAAY;YAC5C,IAAI,IAAA,CAAKI,WAAL,IAAoB,IAAxB,EACEJ,SAASK,MAAT,CAAgB,IAAA,CAAKD,WAArB;QAEH;IACF;IACS,MAAJE,OAAO;QACX,IAAI,IAAA,CAAKP,uBAAL,IAAgC,IAApC,EACE,IAAA,CAAKD,KAAL;QAEFvD,cAAU,IAAA,CAAKwD,uBAAL,IAAgC,IAAjC;QACR,CAAA,MAAM,IAAA,CAAKA,uBAAZ,AAAYA,EAAyBO,IAArC;QACA,IAAA,CAAKP,uBAAL,GAA+B,IAA/B;IACD;IACW,MAANM,OAAOE,OAAD,EAAkB;QAC5B,IAAI,IAAA,CAAKR,uBAAL,IAAgC,IAApC,EAA0C;YACxC,IAAA,CAAKK,WAAL,GAAmBG;YACnB,IAAA,CAAKT,KAAL;QACD,OAAM;YACL,IAAIU,IAAI,MAAM,IAAA,CAAKT,uBAAnB;YACAS,EAAEH,MAAF,CAASE;QACV,CAAA;IACF;AA/BoB;AAkCvB,SAASE,+CAAyB;IAChC,IAAIrD,oDACFJ,iCAAW+B,WAAX,CAAuBvD,CAAAA,GAAAA,wDAAAA,EAAyBgD,IAAhD;AAEH;AASD,IAAIqC,yCAAmB,IAAIhB;AAC3B,IAAIiB,gCAA+B,IAAIC;AAEvC,SAASjC,iCAAWkC,QAApB,EAA+D;IAC7D,IAAIC,WAAWzE,yBAAkBwE;IAEjC,IAAIG,gBAAgB;IACpB,IAAIC;IACJ,KAAK,IAAI,GAAG9C,OAAZ,IAAuBwC,8BAAS;QAC9B,IAAIO,SAAS5E,wBAAiB;YAAC6B,OAAOqC,WAAR;YAAqBM;SAAtB,EAAiCK,MAA9D;QACA,IAAIH,gBAAgBE,QAAQ;YAC1BF,gBAAgBE;YAChBD,aAAa9C;QACd,OAAM,IAAI6C,kBAAkBE,QAC3B1C,QAAQ4C,IAAR,CAAa,0BAA0BN;IAE1C;IACD,OAAOG;AACR;AAED,SAASI,mCAAaC,YAAtB,EAA4C;IAC1C,IAAIC,WAAWC,KAAKC,KAAL,CAAWvG,uBAAgBoG,cAAc;IAExD,IAAIK,iBAAiBL,aAAaM,KAAb,CAAmB,GAAG;IAC3C,IAAI,CAACC,QAAQC,OAAT,GAAmB7F,CAAAA,GAAAA,kDAAyB,AAAzBA,EAA0B0F;IACjD,IAAIxD,SAASjC,CAAAA,GAAAA,gDAAAA,EAAwB2F,QAAQC;IAC7C3D,OAAOsB,MAAP;IAEA,IAAIJ,OAAO,IAAIoB;IAEf,IAAI9C,SAAS;QACXd,YAAYsB;cACZkB;QACAmB,aAAae,SAASf,WAHX;QAIXvB,WAAW;IAJA;IAObd,OAAO4D,cAAP,CAAsBtF,CAAAA,GAAAA,gDAAtB,AAAsBA,GAAyB,CAACuF,OAAO5B,UAAY;QACjE,8DAAA;QACA,IAAI4B,UAAU,SAAS;YACrBtB,uCAAiBf,KAAjB;YACA,KAAK,IAAIZ,OAAOM,KACdxC,iCAAWoF,eAAX,CAA2B;qBAAClD;gBAAKtB,aAAa,EAAbA;YAAN;QAE9B,OAAM,IAAIuE,UAAU,cAAc5B,WAAW,IAAvC,EACLM,uCAAiBR,MAAjB,CAAwBE;aACnB,IAAI4B,UAAU,OAAO;YAC1BrE,OAAOsB,SAAP,GAAmBiD,OAAOC,KAAKC,GAAL;YAC1B9B;YACAI,uCAAiBP,IAAjB;YACAtD,iCAAWwF,gBAAX,CAA4B7F,CAAAA,GAAAA,0CAA5B,AAA4BA;QAC7B,CAAA;IACF;IAED2B,OAAO4D,cAAP,CAAsBrF,CAAAA,GAAAA,yDAAAA,GAAkCe,CAAAA,cAAe;QACrE,oEAAA;QACA,KAAK,IAAI6E,KAAK7E,YAAa;YACzB4B,KAAKC,GAAL,CAASgD,EAAEvD,GAAX;YACAlC,iCAAWoF,eAAX,CAA2BK;QAC5B;IACF;IAEDnE,OAAOoE,OAAP,CAAe,IAAM;QACnB5B,8BAAQ6B,MAAR,CAAejB;QACfjB;QACA,OAAOzB,QAAQ/B,GAAR,CACL;eAAIuC;SAAJ,CAAUoD,GAAV,CAAc1D,CAAAA,MAAOlC,iCAAWoF,eAAX,CAA2B;qBAAClD;gBAAKtB,aAAa,EAAbA;YAAN;IAEnD;IAED6C;IACAK,8BAAQ+B,GAAR,CAAYnB,UAAU5D;AACvB,EAED,sFAFC;AAGD,MAAMgF,gCAAU1H,iBAAUC,uBAAgBC,qBAAc;AACxDD,oBAAayH,+BAAS;IAACK,WAAW,IAAXA;AAAD,IACtB,uEADsB;AAEtB,4DAAA;AACA,KAAK,IAAIC,YAAY/H,sBAAeyH,+BAAU;IAC5C,IAAI,CAACM,SAASE,QAAT,CAAkB,UAAU,QAAjC;IACA,IAAIrC,WAAW7F,iBAAU0H,+BAASM;IAClC5B,mCAAaP,WACb,8CADAO;AAED,EAED,2EAFC;AAGD,sEAAA;AACA9E,+BAAkBoG,+BAAS,OAAOU,KAAKC,SAAW;IAChD,IAAID,KACF,MAAMA,IAAN;IAGF,KAAK,IAAIE,SAASD,OAAQ;QACxB,IAAIC,MAAMlF,IAAN,KAAe,YAAYkF,MAAMtI,IAAN,CAAWkI,QAAX,CAAoB,UACjD9B,mCAAakC,MAAMtI,IAAP,GACZ,gDADAoG;aAEK,IAAIkC,MAAMlF,IAAN,KAAe,YAAYkF,MAAMtI,IAAN,CAAWkI,QAAX,CAAoB,UAAU;YAClE,IAAIK,WAAW7C,8BAAQ8C,GAAR,CAAYF,MAAMtI,IAAlB,GACf,iDADA;YAEA,IAAIuI,UAAU;gBACZ7C,8BAAQ6B,MAAR,CAAee,MAAMtI,IAArB;gBACAuI,SAAS3G,UAAT,CAAoB6G,GAApB,IACA,mDADAF;YAED,CAAA;QACF,CAAA;IACF;AACF","sources":["packages/utils/parcel-lsp/src/LspServer.ts"],"sourcesContent":["import * as path from 'path';\nimport * as fs from 'fs';\nimport * as os from 'os';\nimport {\n createConnection,\n DiagnosticRefreshRequest,\n DidChangeConfigurationNotification,\n DocumentDiagnosticParams,\n DocumentDiagnosticReport,\n DocumentDiagnosticReportKind,\n DocumentDiagnosticRequest,\n DocumentUri,\n InitializeParams,\n InitializeResult,\n ProposedFeatures,\n TextDocumentSyncKind,\n WorkDoneProgressServerReporter,\n} from 'vscode-languageserver/node';\n\nimport {\n createServerPipeTransport,\n createMessageConnection,\n MessageConnection,\n} from 'vscode-jsonrpc/node';\nimport * as invariant from 'assert';\nimport * as url from 'url';\nimport commonPathPrefix = require('common-path-prefix');\n\n// import {TextDocument} from 'vscode-languageserver-textdocument';\nimport * as watcher from '@parcel/watcher';\nimport {\n NotificationBuild,\n NotificationBuildStatus,\n NotificationWorkspaceDiagnostics,\n RequestDocumentDiagnostics,\n RequestImporters,\n} from '@parcel/lsp-protocol';\n\nconst connection = createConnection(ProposedFeatures.all);\n\n// Create a simple text document manager.\n// const documents: TextDocuments<TextDocument> = new TextDocuments(TextDocument);\n\nlet hasConfigurationCapability = false;\nlet hasWorkspaceFolderCapability = false;\n// let hasDiagnosticRelatedInformationCapability = false;\nlet hasDiagnosticsRefreshSupport = false;\n\nconnection.onInitialize((params: InitializeParams) => {\n const capabilities = params.capabilities;\n\n // Does the client support the `workspace/configuration` request?\n // If not, we fall back using global settings.\n hasConfigurationCapability = !!(\n capabilities.workspace && !!capabilities.workspace.configuration\n );\n hasWorkspaceFolderCapability = !!(\n capabilities.workspace && !!capabilities.workspace.workspaceFolders\n );\n // hasDiagnosticRelatedInformationCapability = !!(\n // capabilities.textDocument &&\n // capabilities.textDocument.publishDiagnostics &&\n // capabilities.textDocument.publishDiagnostics.relatedInformation\n // );\n hasDiagnosticsRefreshSupport = Boolean(\n capabilities.workspace?.diagnostics?.refreshSupport,\n );\n\n const result: InitializeResult = {\n capabilities: {\n textDocumentSync: TextDocumentSyncKind.Incremental,\n // Tell the client that this server supports code completion.\n diagnosticProvider: {\n workspaceDiagnostics: false,\n interFileDependencies: true,\n },\n },\n };\n\n if (hasWorkspaceFolderCapability) {\n result.capabilities.workspace = {\n workspaceFolders: {\n supported: true,\n },\n };\n }\n return result;\n});\n\nconnection.onInitialized(() => {\n if (hasConfigurationCapability) {\n // Register for all configuration changes.\n connection.client.register(\n DidChangeConfigurationNotification.type,\n undefined,\n );\n }\n if (hasWorkspaceFolderCapability) {\n connection.workspace.onDidChangeWorkspaceFolders(_event => {\n connection.console.log('Workspace folder change event received.');\n });\n }\n});\n\n// Proxy\nconnection.onRequest(RequestImporters, async params => {\n let client = findClient(params);\n if (client) {\n let result = await client.connection.sendRequest(RequestImporters, params);\n return result;\n }\n return null;\n});\n\nconnection.onRequest(\n DocumentDiagnosticRequest.type,\n async (\n params: DocumentDiagnosticParams,\n ): Promise<DocumentDiagnosticReport> => {\n let client = findClient(params.textDocument.uri);\n let result;\n if (client) {\n // console.log(\n // 'DocumentDiagnosticRequest',\n // params.textDocument.uri,\n // params.previousResultId === client.lastBuild,\n // );\n\n if (params.previousResultId === client.lastBuild) {\n return {\n kind: DocumentDiagnosticReportKind.Unchanged,\n resultId: client.lastBuild,\n };\n }\n\n result = await client.connection.sendRequest(\n RequestDocumentDiagnostics,\n params.textDocument.uri,\n );\n\n if (result) {\n client.uris.add(params.textDocument.uri);\n }\n }\n\n return {\n kind: DocumentDiagnosticReportKind.Full,\n resultId: client?.lastBuild,\n items: result ?? [],\n };\n },\n);\n\nconnection.listen();\n\nclass ProgressReporter {\n progressReporterPromise?: Promise<WorkDoneProgressServerReporter> | null;\n lastMessage?: string;\n begin() {\n this.progressReporterPromise = (async () => {\n let reporter = await connection.window.createWorkDoneProgress();\n reporter.begin('Parcel');\n return reporter;\n })();\n this.progressReporterPromise.then(reporter => {\n if (this.lastMessage != null) {\n reporter.report(this.lastMessage);\n }\n });\n }\n async done() {\n if (this.progressReporterPromise == null) {\n this.begin();\n }\n invariant(this.progressReporterPromise != null);\n (await this.progressReporterPromise).done();\n this.progressReporterPromise = null;\n }\n async report(message: string) {\n if (this.progressReporterPromise == null) {\n this.lastMessage = message;\n this.begin();\n } else {\n let r = await this.progressReporterPromise;\n r.report(message);\n }\n }\n}\n\nfunction sendDiagnosticsRefresh() {\n if (hasDiagnosticsRefreshSupport) {\n connection.sendRequest(DiagnosticRefreshRequest.type);\n }\n}\n\ntype Client = {\n connection: MessageConnection;\n projectRoot: string;\n uris: Set<DocumentUri>;\n lastBuild: string;\n};\n\nlet progressReporter = new ProgressReporter();\nlet clients: Map<string, Client> = new Map();\n\nfunction findClient(document: DocumentUri): Client | undefined {\n let filepath = url.fileURLToPath(document);\n\n let longestPrefix = 0;\n let bestClient;\n for (let [, client] of clients) {\n let prefix = commonPathPrefix([client.projectRoot, filepath]).length;\n if (longestPrefix < prefix) {\n longestPrefix = prefix;\n bestClient = client;\n } else if (longestPrefix === prefix) {\n console.warn('Ambiguous client for ' + filepath);\n }\n }\n return bestClient;\n}\n\nfunction createClient(metafilepath: string) {\n let metafile = JSON.parse(fs.readFileSync(metafilepath, 'utf8'));\n\n let socketfilepath = metafilepath.slice(0, -5);\n let [reader, writer] = createServerPipeTransport(socketfilepath);\n let client = createMessageConnection(reader, writer);\n client.listen();\n\n let uris = new Set<DocumentUri>();\n\n let result = {\n connection: client,\n uris,\n projectRoot: metafile.projectRoot,\n lastBuild: '0',\n };\n\n client.onNotification(NotificationBuildStatus, (state, message) => {\n // console.log('got NotificationBuildStatus', state, message);\n if (state === 'start') {\n progressReporter.begin();\n for (let uri of uris) {\n connection.sendDiagnostics({uri, diagnostics: []});\n }\n } else if (state === 'progress' && message != null) {\n progressReporter.report(message);\n } else if (state === 'end') {\n result.lastBuild = String(Date.now());\n sendDiagnosticsRefresh();\n progressReporter.done();\n connection.sendNotification(NotificationBuild);\n }\n });\n\n client.onNotification(NotificationWorkspaceDiagnostics, diagnostics => {\n // console.log('got NotificationWorkspaceDiagnostics', diagnostics);\n for (let d of diagnostics) {\n uris.add(d.uri);\n connection.sendDiagnostics(d);\n }\n });\n\n client.onClose(() => {\n clients.delete(metafile);\n sendDiagnosticsRefresh();\n return Promise.all(\n [...uris].map(uri => connection.sendDiagnostics({uri, diagnostics: []})),\n );\n });\n\n sendDiagnosticsRefresh();\n clients.set(metafile, result);\n}\n\n// Take realpath because to have consistent cache keys on macOS (/var -> /private/var)\nconst BASEDIR = path.join(fs.realpathSync(os.tmpdir()), 'parcel-lsp');\nfs.mkdirSync(BASEDIR, {recursive: true});\n// Search for currently running Parcel processes in the parcel-lsp dir.\n// Create an IPC client connection for each running process.\nfor (let filename of fs.readdirSync(BASEDIR)) {\n if (!filename.endsWith('.json')) continue;\n let filepath = path.join(BASEDIR, filename);\n createClient(filepath);\n // console.log('connected initial', filepath);\n}\n\n// Watch for new Parcel processes in the parcel-lsp dir, and disconnect the\n// client for each corresponding connection when a Parcel process ends\nwatcher.subscribe(BASEDIR, async (err, events) => {\n if (err) {\n throw err;\n }\n\n for (let event of events) {\n if (event.type === 'create' && event.path.endsWith('.json')) {\n createClient(event.path);\n // console.log('connected watched', event.path);\n } else if (event.type === 'delete' && event.path.endsWith('.json')) {\n let existing = clients.get(event.path);\n // console.log('existing', event.path, existing);\n if (existing) {\n clients.delete(event.path);\n existing.connection.end();\n // console.log('disconnected watched', event.path);\n }\n }\n }\n});\n"],"names":["path","fs","os","createConnection","DiagnosticRefreshRequest","DidChangeConfigurationNotification","DocumentDiagnosticParams","DocumentDiagnosticReport","DocumentDiagnosticReportKind","DocumentDiagnosticRequest","DocumentUri","InitializeParams","InitializeResult","ProposedFeatures","TextDocumentSyncKind","WorkDoneProgressServerReporter","createServerPipeTransport","createMessageConnection","MessageConnection","invariant","url","commonPathPrefix","watcher","NotificationBuild","NotificationBuildStatus","NotificationWorkspaceDiagnostics","RequestDocumentDiagnostics","RequestImporters","connection","all","hasConfigurationCapability","hasWorkspaceFolderCapability","hasDiagnosticsRefreshSupport","onInitialize","params","capabilities","workspace","configuration","workspaceFolders","Boolean","diagnostics","refreshSupport","result","textDocumentSync","Incremental","diagnosticProvider","workspaceDiagnostics","interFileDependencies","supported","onInitialized","client","register","type","undefined","onDidChangeWorkspaceFolders","console","log","onRequest","findClient","sendRequest","Promise","textDocument","uri","previousResultId","lastBuild","kind","Unchanged","resultId","uris","add","Full","items","listen","ProgressReporter","begin","progressReporterPromise","reporter","window","createWorkDoneProgress","then","lastMessage","report","done","message","r","sendDiagnosticsRefresh","Client","projectRoot","Set","progressReporter","clients","Map","document","filepath","fileURLToPath","longestPrefix","bestClient","prefix","length","warn","createClient","metafilepath","metafile","JSON","parse","readFileSync","socketfilepath","slice","reader","writer","onNotification","state","sendDiagnostics","String","Date","now","sendNotification","d","onClose","delete","map","set","BASEDIR","join","realpathSync","tmpdir","mkdirSync","recursive","filename","readdirSync","endsWith","subscribe","err","events","event","existing","get","end"],"version":3,"file":"LspServer.js.map","sourceRoot":"../../../../"}
1
+ {"mappings":"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","sources":["packages/utils/parcel-lsp/src/LspServer.ts"],"sourcesContent":["import * as path from 'path';\nimport * as fs from 'fs';\nimport * as os from 'os';\nimport {\n createConnection,\n DiagnosticRefreshRequest,\n DidChangeConfigurationNotification,\n DocumentDiagnosticParams,\n DocumentDiagnosticReport,\n DocumentDiagnosticReportKind,\n DocumentDiagnosticRequest,\n DocumentUri,\n InitializeParams,\n InitializeResult,\n ProposedFeatures,\n TextDocumentSyncKind,\n WorkDoneProgressServerReporter,\n} from 'vscode-languageserver/node';\n\nimport {\n createServerPipeTransport,\n createMessageConnection,\n MessageConnection,\n} from 'vscode-jsonrpc/node';\nimport * as invariant from 'assert';\nimport * as url from 'url';\nimport commonPathPrefix = require('common-path-prefix');\n\n// import {TextDocument} from 'vscode-languageserver-textdocument';\nimport * as watcher from '@parcel/watcher';\nimport {\n NotificationBuild,\n NotificationBuildStatus,\n NotificationWorkspaceDiagnostics,\n RequestDocumentDiagnostics,\n RequestImporters,\n} from '@parcel/lsp-protocol';\n\nconst connection = createConnection(ProposedFeatures.all);\n\n// Create a simple text document manager.\n// const documents: TextDocuments<TextDocument> = new TextDocuments(TextDocument);\n\nlet hasConfigurationCapability = false;\nlet hasWorkspaceFolderCapability = false;\n// let hasDiagnosticRelatedInformationCapability = false;\nlet hasDiagnosticsRefreshSupport = false;\n\nconnection.onInitialize((params: InitializeParams) => {\n const capabilities = params.capabilities;\n\n // Does the client support the `workspace/configuration` request?\n // If not, we fall back using global settings.\n hasConfigurationCapability = !!(\n capabilities.workspace && !!capabilities.workspace.configuration\n );\n hasWorkspaceFolderCapability = !!(\n capabilities.workspace && !!capabilities.workspace.workspaceFolders\n );\n // hasDiagnosticRelatedInformationCapability = !!(\n // capabilities.textDocument &&\n // capabilities.textDocument.publishDiagnostics &&\n // capabilities.textDocument.publishDiagnostics.relatedInformation\n // );\n hasDiagnosticsRefreshSupport = Boolean(\n capabilities.workspace?.diagnostics?.refreshSupport,\n );\n\n const result: InitializeResult = {\n capabilities: {\n textDocumentSync: TextDocumentSyncKind.Incremental,\n // Tell the client that this server supports code completion.\n diagnosticProvider: {\n workspaceDiagnostics: false,\n interFileDependencies: true,\n },\n },\n };\n\n if (hasWorkspaceFolderCapability) {\n result.capabilities.workspace = {\n workspaceFolders: {\n supported: true,\n },\n };\n }\n return result;\n});\n\nconnection.onInitialized(() => {\n if (hasConfigurationCapability) {\n // Register for all configuration changes.\n connection.client.register(\n DidChangeConfigurationNotification.type,\n undefined,\n );\n }\n if (hasWorkspaceFolderCapability) {\n connection.workspace.onDidChangeWorkspaceFolders(_event => {\n connection.console.log('Workspace folder change event received.');\n });\n }\n});\n\n// Proxy\nconnection.onRequest(RequestImporters, async params => {\n let client = findClient(params);\n if (client) {\n let result = await client.connection.sendRequest(RequestImporters, params);\n return result;\n }\n return null;\n});\n\nconnection.onRequest(\n DocumentDiagnosticRequest.type,\n async (\n params: DocumentDiagnosticParams,\n ): Promise<DocumentDiagnosticReport> => {\n let client = findClient(params.textDocument.uri);\n let result;\n if (client) {\n // console.log(\n // 'DocumentDiagnosticRequest',\n // params.textDocument.uri,\n // params.previousResultId === client.lastBuild,\n // );\n\n if (params.previousResultId === client.lastBuild) {\n return {\n kind: DocumentDiagnosticReportKind.Unchanged,\n resultId: client.lastBuild,\n };\n }\n\n result = await client.connection.sendRequest(\n RequestDocumentDiagnostics,\n params.textDocument.uri,\n );\n\n if (result) {\n client.uris.add(params.textDocument.uri);\n }\n }\n\n return {\n kind: DocumentDiagnosticReportKind.Full,\n resultId: client?.lastBuild,\n items: result ?? [],\n };\n },\n);\n\nconnection.listen();\n\nclass ProgressReporter {\n progressReporterPromise?: Promise<WorkDoneProgressServerReporter> | null;\n lastMessage?: string;\n begin() {\n this.progressReporterPromise = (async () => {\n let reporter = await connection.window.createWorkDoneProgress();\n reporter.begin('Parcel');\n return reporter;\n })();\n this.progressReporterPromise.then(reporter => {\n if (this.lastMessage != null) {\n reporter.report(this.lastMessage);\n }\n });\n }\n async done() {\n if (this.progressReporterPromise == null) {\n this.begin();\n }\n invariant(this.progressReporterPromise != null);\n (await this.progressReporterPromise).done();\n this.progressReporterPromise = null;\n }\n async report(message: string) {\n if (this.progressReporterPromise == null) {\n this.lastMessage = message;\n this.begin();\n } else {\n let r = await this.progressReporterPromise;\n r.report(message);\n }\n }\n}\n\nfunction sendDiagnosticsRefresh() {\n if (hasDiagnosticsRefreshSupport) {\n connection.sendRequest(DiagnosticRefreshRequest.type);\n }\n}\n\ntype Client = {\n connection: MessageConnection;\n projectRoot: string;\n uris: Set<DocumentUri>;\n lastBuild: string;\n};\n\nlet progressReporter = new ProgressReporter();\nlet clients: Map<string, Client> = new Map();\n\nfunction findClient(document: DocumentUri): Client | undefined {\n let filepath = url.fileURLToPath(document);\n\n let longestPrefix = 0;\n let bestClient;\n for (let [, client] of clients) {\n let prefix = commonPathPrefix([client.projectRoot, filepath]).length;\n if (longestPrefix < prefix) {\n longestPrefix = prefix;\n bestClient = client;\n } else if (longestPrefix === prefix) {\n console.warn('Ambiguous client for ' + filepath);\n }\n }\n return bestClient;\n}\n\nfunction createClient(metafilepath: string) {\n let metafile = JSON.parse(fs.readFileSync(metafilepath, 'utf8'));\n\n let socketfilepath = metafilepath.slice(0, -5);\n let [reader, writer] = createServerPipeTransport(socketfilepath);\n let client = createMessageConnection(reader, writer);\n client.listen();\n\n let uris = new Set<DocumentUri>();\n\n let result = {\n connection: client,\n uris,\n projectRoot: metafile.projectRoot,\n lastBuild: '0',\n };\n\n client.onNotification(NotificationBuildStatus, (state, message) => {\n // console.log('got NotificationBuildStatus', state, message);\n if (state === 'start') {\n progressReporter.begin();\n for (let uri of uris) {\n connection.sendDiagnostics({uri, diagnostics: []});\n }\n } else if (state === 'progress' && message != null) {\n progressReporter.report(message);\n } else if (state === 'end') {\n result.lastBuild = String(Date.now());\n sendDiagnosticsRefresh();\n progressReporter.done();\n connection.sendNotification(NotificationBuild);\n }\n });\n\n client.onNotification(NotificationWorkspaceDiagnostics, diagnostics => {\n // console.log('got NotificationWorkspaceDiagnostics', diagnostics);\n for (let d of diagnostics) {\n uris.add(d.uri);\n connection.sendDiagnostics(d);\n }\n });\n\n client.onClose(() => {\n clients.delete(metafile);\n sendDiagnosticsRefresh();\n return Promise.all(\n [...uris].map(uri => connection.sendDiagnostics({uri, diagnostics: []})),\n );\n });\n\n sendDiagnosticsRefresh();\n clients.set(metafile, result);\n}\n\n// Take realpath because to have consistent cache keys on macOS (/var -> /private/var)\nconst BASEDIR = path.join(fs.realpathSync(os.tmpdir()), 'parcel-lsp');\nfs.mkdirSync(BASEDIR, {recursive: true});\n// Search for currently running Parcel processes in the parcel-lsp dir.\n// Create an IPC client connection for each running process.\nfor (let filename of fs.readdirSync(BASEDIR)) {\n if (!filename.endsWith('.json')) continue;\n let filepath = path.join(BASEDIR, filename);\n createClient(filepath);\n // console.log('connected initial', filepath);\n}\n\n// Watch for new Parcel processes in the parcel-lsp dir, and disconnect the\n// client for each corresponding connection when a Parcel process ends\nwatcher.subscribe(BASEDIR, async (err, events) => {\n if (err) {\n throw err;\n }\n\n for (let event of events) {\n if (event.type === 'create' && event.path.endsWith('.json')) {\n createClient(event.path);\n // console.log('connected watched', event.path);\n } else if (event.type === 'delete' && event.path.endsWith('.json')) {\n let existing = clients.get(event.path);\n // console.log('existing', event.path, existing);\n if (existing) {\n clients.delete(event.path);\n existing.connection.end();\n // console.log('disconnected watched', event.path);\n }\n }\n }\n});\n"],"names":["path","fs","os","createConnection","DiagnosticRefreshRequest","DidChangeConfigurationNotification","DocumentDiagnosticParams","DocumentDiagnosticReport","DocumentDiagnosticReportKind","DocumentDiagnosticRequest","DocumentUri","InitializeParams","InitializeResult","ProposedFeatures","TextDocumentSyncKind","WorkDoneProgressServerReporter","createServerPipeTransport","createMessageConnection","MessageConnection","invariant","url","commonPathPrefix","watcher","NotificationBuild","NotificationBuildStatus","NotificationWorkspaceDiagnostics","RequestDocumentDiagnostics","RequestImporters","connection","all","hasConfigurationCapability","hasWorkspaceFolderCapability","hasDiagnosticsRefreshSupport","onInitialize","params","capabilities","workspace","configuration","workspaceFolders","Boolean","diagnostics","refreshSupport","result","textDocumentSync","Incremental","diagnosticProvider","workspaceDiagnostics","interFileDependencies","supported","onInitialized","client","register","type","undefined","onDidChangeWorkspaceFolders","console","log","onRequest","findClient","sendRequest","Promise","textDocument","uri","previousResultId","lastBuild","kind","Unchanged","resultId","uris","add","Full","items","listen","ProgressReporter","begin","progressReporterPromise","reporter","window","createWorkDoneProgress","then","lastMessage","report","done","message","r","sendDiagnosticsRefresh","Client","projectRoot","Set","progressReporter","clients","Map","document","filepath","fileURLToPath","longestPrefix","bestClient","prefix","length","warn","createClient","metafilepath","metafile","JSON","parse","readFileSync","socketfilepath","slice","reader","writer","onNotification","state","sendDiagnostics","String","Date","now","sendNotification","d","onClose","delete","map","set","BASEDIR","join","realpathSync","tmpdir","mkdirSync","recursive","filename","readdirSync","endsWith","subscribe","err","events","event","existing","get","end"],"version":3,"file":"LspServer.js.map","sourceRoot":"../../../../"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@parcel/lsp",
3
- "version": "2.8.4-nightly.2921+eb76826da",
3
+ "version": "2.8.4-nightly.2937+3ad435157",
4
4
  "license": "MIT",
5
5
  "publishConfig": {
6
6
  "access": "public"
@@ -22,10 +22,10 @@
22
22
  },
23
23
  "engines": {
24
24
  "node": ">= 12.0.0",
25
- "parcel": "2.0.0-nightly.1296+eb76826da"
25
+ "parcel": "2.0.0-nightly.1312+3ad435157"
26
26
  },
27
27
  "dependencies": {
28
- "@parcel/lsp-protocol": "2.8.4-nightly.2921+eb76826da",
28
+ "@parcel/lsp-protocol": "2.8.4-nightly.2937+3ad435157",
29
29
  "@parcel/watcher": "^2.0.7",
30
30
  "common-path-prefix": "^3.0.0",
31
31
  "nullthrows": "^1.1.1",
@@ -44,5 +44,5 @@
44
44
  "targets": {
45
45
  "types": false
46
46
  },
47
- "gitHead": "eb76826da305db1e5668bb9b0c1cb5dbe0951a4c"
47
+ "gitHead": "3ad435157d443da806c215d68ccf292b4e95ae0c"
48
48
  }