@atlaspack/lsp 2.12.1-dev.3368 → 2.12.1-dev.3401

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 $jCidy$path = require("path");
2
- var $jCidy$fs = require("fs");
3
- var $jCidy$os = require("os");
4
- var $jCidy$vscodelanguageservernode = require("vscode-languageserver/node");
5
- var $jCidy$vscodejsonrpcnode = require("vscode-jsonrpc/node");
6
- var $jCidy$assert = require("assert");
7
- var $jCidy$url = require("url");
8
- var $jCidy$commonpathprefix = require("common-path-prefix");
9
- var $jCidy$parcelwatcher = require("@parcel/watcher");
10
- var $jCidy$atlaspacklspprotocol = require("@atlaspack/lsp-protocol");
1
+ var $4dDg2$path = require("path");
2
+ var $4dDg2$fs = require("fs");
3
+ var $4dDg2$os = require("os");
4
+ var $4dDg2$vscodelanguageservernode = require("vscode-languageserver/node");
5
+ var $4dDg2$vscodejsonrpcnode = require("vscode-jsonrpc/node");
6
+ var $4dDg2$assert = require("assert");
7
+ var $4dDg2$url = require("url");
8
+ var $4dDg2$commonpathprefix = require("common-path-prefix");
9
+ var $4dDg2$parcelwatcher = require("@parcel/watcher");
10
+ var $4dDg2$atlaspacklspprotocol = require("@atlaspack/lsp-protocol");
11
11
 
12
12
 
13
13
 
@@ -19,30 +19,30 @@ var $jCidy$atlaspacklspprotocol = require("@atlaspack/lsp-protocol");
19
19
 
20
20
 
21
21
 
22
- const $40b25ebbd3682ffd$var$connection = (0, $jCidy$vscodelanguageservernode.createConnection)((0, $jCidy$vscodelanguageservernode.ProposedFeatures).all);
23
- const $40b25ebbd3682ffd$var$WORKSPACE_ROOT = process.cwd();
24
- const $40b25ebbd3682ffd$var$LSP_SENTINEL_FILENAME = 'lsp-server';
22
+ const $f1ba282d4a2dc9ad$var$connection = (0, $4dDg2$vscodelanguageservernode.createConnection)((0, $4dDg2$vscodelanguageservernode.ProposedFeatures).all);
23
+ const $f1ba282d4a2dc9ad$var$WORKSPACE_ROOT = process.cwd();
24
+ const $f1ba282d4a2dc9ad$var$LSP_SENTINEL_FILENAME = 'lsp-server';
25
25
  // Create a simple text document manager.
26
26
  // const documents: TextDocuments<TextDocument> = new TextDocuments(TextDocument);
27
- let $40b25ebbd3682ffd$var$hasConfigurationCapability = false;
28
- let $40b25ebbd3682ffd$var$hasWorkspaceFolderCapability = false;
27
+ let $f1ba282d4a2dc9ad$var$hasConfigurationCapability = false;
28
+ let $f1ba282d4a2dc9ad$var$hasWorkspaceFolderCapability = false;
29
29
  // let hasDiagnosticRelatedInformationCapability = false;
30
- let $40b25ebbd3682ffd$var$hasDiagnosticsRefreshSupport = false;
31
- $40b25ebbd3682ffd$var$connection.onInitialize((params)=>{
30
+ let $f1ba282d4a2dc9ad$var$hasDiagnosticsRefreshSupport = false;
31
+ $f1ba282d4a2dc9ad$var$connection.onInitialize((params)=>{
32
32
  const capabilities = params.capabilities;
33
33
  // Does the client support the `workspace/configuration` request?
34
34
  // If not, we fall back using global settings.
35
- $40b25ebbd3682ffd$var$hasConfigurationCapability = !!(capabilities.workspace && !!capabilities.workspace.configuration);
36
- $40b25ebbd3682ffd$var$hasWorkspaceFolderCapability = !!(capabilities.workspace && !!capabilities.workspace.workspaceFolders);
35
+ $f1ba282d4a2dc9ad$var$hasConfigurationCapability = !!(capabilities.workspace && !!capabilities.workspace.configuration);
36
+ $f1ba282d4a2dc9ad$var$hasWorkspaceFolderCapability = !!(capabilities.workspace && !!capabilities.workspace.workspaceFolders);
37
37
  // hasDiagnosticRelatedInformationCapability = !!(
38
38
  // capabilities.textDocument &&
39
39
  // capabilities.textDocument.publishDiagnostics &&
40
40
  // capabilities.textDocument.publishDiagnostics.relatedInformation
41
41
  // );
42
- $40b25ebbd3682ffd$var$hasDiagnosticsRefreshSupport = Boolean(capabilities.workspace?.diagnostics?.refreshSupport);
42
+ $f1ba282d4a2dc9ad$var$hasDiagnosticsRefreshSupport = Boolean(capabilities.workspace?.diagnostics?.refreshSupport);
43
43
  const result = {
44
44
  capabilities: {
45
- textDocumentSync: (0, $jCidy$vscodelanguageservernode.TextDocumentSyncKind).Incremental,
45
+ textDocumentSync: (0, $4dDg2$vscodelanguageservernode.TextDocumentSyncKind).Incremental,
46
46
  // Tell the client that this server supports code completion.
47
47
  diagnosticProvider: {
48
48
  workspaceDiagnostics: false,
@@ -50,31 +50,31 @@ $40b25ebbd3682ffd$var$connection.onInitialize((params)=>{
50
50
  }
51
51
  }
52
52
  };
53
- if ($40b25ebbd3682ffd$var$hasWorkspaceFolderCapability) result.capabilities.workspace = {
53
+ if ($f1ba282d4a2dc9ad$var$hasWorkspaceFolderCapability) result.capabilities.workspace = {
54
54
  workspaceFolders: {
55
55
  supported: true
56
56
  }
57
57
  };
58
58
  return result;
59
59
  });
60
- $40b25ebbd3682ffd$var$connection.onInitialized(()=>{
61
- if ($40b25ebbd3682ffd$var$hasConfigurationCapability) // Register for all configuration changes.
62
- $40b25ebbd3682ffd$var$connection.client.register((0, $jCidy$vscodelanguageservernode.DidChangeConfigurationNotification).type, undefined);
63
- if ($40b25ebbd3682ffd$var$hasWorkspaceFolderCapability) $40b25ebbd3682ffd$var$connection.workspace.onDidChangeWorkspaceFolders(()=>{
64
- $40b25ebbd3682ffd$var$connection.console.log('Workspace folder change event received.');
60
+ $f1ba282d4a2dc9ad$var$connection.onInitialized(()=>{
61
+ if ($f1ba282d4a2dc9ad$var$hasConfigurationCapability) // Register for all configuration changes.
62
+ $f1ba282d4a2dc9ad$var$connection.client.register((0, $4dDg2$vscodelanguageservernode.DidChangeConfigurationNotification).type, undefined);
63
+ if ($f1ba282d4a2dc9ad$var$hasWorkspaceFolderCapability) $f1ba282d4a2dc9ad$var$connection.workspace.onDidChangeWorkspaceFolders(()=>{
64
+ $f1ba282d4a2dc9ad$var$connection.console.log('Workspace folder change event received.');
65
65
  });
66
66
  });
67
67
  // Proxy
68
- $40b25ebbd3682ffd$var$connection.onRequest((0, $jCidy$atlaspacklspprotocol.RequestImporters), async (params)=>{
69
- let client = $40b25ebbd3682ffd$var$findClient(params);
68
+ $f1ba282d4a2dc9ad$var$connection.onRequest((0, $4dDg2$atlaspacklspprotocol.RequestImporters), async (params)=>{
69
+ let client = $f1ba282d4a2dc9ad$var$findClient(params);
70
70
  if (client) {
71
- let result = await client.connection.sendRequest((0, $jCidy$atlaspacklspprotocol.RequestImporters), params);
71
+ let result = await client.connection.sendRequest((0, $4dDg2$atlaspacklspprotocol.RequestImporters), params);
72
72
  return result;
73
73
  }
74
74
  return null;
75
75
  });
76
- $40b25ebbd3682ffd$var$connection.onRequest((0, $jCidy$vscodelanguageservernode.DocumentDiagnosticRequest).type, async (params)=>{
77
- let client = $40b25ebbd3682ffd$var$findClient(params.textDocument.uri);
76
+ $f1ba282d4a2dc9ad$var$connection.onRequest((0, $4dDg2$vscodelanguageservernode.DocumentDiagnosticRequest).type, async (params)=>{
77
+ let client = $f1ba282d4a2dc9ad$var$findClient(params.textDocument.uri);
78
78
  let result;
79
79
  if (client) {
80
80
  // console.log(
@@ -83,23 +83,23 @@ $40b25ebbd3682ffd$var$connection.onRequest((0, $jCidy$vscodelanguageservernode.D
83
83
  // params.previousResultId === client.lastBuild,
84
84
  // );
85
85
  if (params.previousResultId === client.lastBuild) return {
86
- kind: (0, $jCidy$vscodelanguageservernode.DocumentDiagnosticReportKind).Unchanged,
86
+ kind: (0, $4dDg2$vscodelanguageservernode.DocumentDiagnosticReportKind).Unchanged,
87
87
  resultId: client.lastBuild
88
88
  };
89
- result = await client.connection.sendRequest((0, $jCidy$atlaspacklspprotocol.RequestDocumentDiagnostics), params.textDocument.uri);
89
+ result = await client.connection.sendRequest((0, $4dDg2$atlaspacklspprotocol.RequestDocumentDiagnostics), params.textDocument.uri);
90
90
  if (result) client.uris.add(params.textDocument.uri);
91
91
  }
92
92
  return {
93
- kind: (0, $jCidy$vscodelanguageservernode.DocumentDiagnosticReportKind).Full,
93
+ kind: (0, $4dDg2$vscodelanguageservernode.DocumentDiagnosticReportKind).Full,
94
94
  resultId: client?.lastBuild,
95
95
  items: result ?? []
96
96
  };
97
97
  });
98
- $40b25ebbd3682ffd$var$connection.listen();
99
- class $40b25ebbd3682ffd$var$ProgressReporter {
98
+ $f1ba282d4a2dc9ad$var$connection.listen();
99
+ class $f1ba282d4a2dc9ad$var$ProgressReporter {
100
100
  begin() {
101
101
  this.progressReporterPromise = (async ()=>{
102
- let reporter = await $40b25ebbd3682ffd$var$connection.window.createWorkDoneProgress();
102
+ let reporter = await $f1ba282d4a2dc9ad$var$connection.window.createWorkDoneProgress();
103
103
  reporter.begin('Atlaspack');
104
104
  return reporter;
105
105
  })();
@@ -109,7 +109,7 @@ class $40b25ebbd3682ffd$var$ProgressReporter {
109
109
  }
110
110
  async done() {
111
111
  if (this.progressReporterPromise == null) this.begin();
112
- $jCidy$assert(this.progressReporterPromise != null);
112
+ $4dDg2$assert(this.progressReporterPromise != null);
113
113
  (await this.progressReporterPromise).done();
114
114
  this.progressReporterPromise = null;
115
115
  }
@@ -123,17 +123,17 @@ class $40b25ebbd3682ffd$var$ProgressReporter {
123
123
  }
124
124
  }
125
125
  }
126
- function $40b25ebbd3682ffd$var$sendDiagnosticsRefresh() {
127
- if ($40b25ebbd3682ffd$var$hasDiagnosticsRefreshSupport) $40b25ebbd3682ffd$var$connection.sendRequest((0, $jCidy$vscodelanguageservernode.DiagnosticRefreshRequest).type);
126
+ function $f1ba282d4a2dc9ad$var$sendDiagnosticsRefresh() {
127
+ if ($f1ba282d4a2dc9ad$var$hasDiagnosticsRefreshSupport) $f1ba282d4a2dc9ad$var$connection.sendRequest((0, $4dDg2$vscodelanguageservernode.DiagnosticRefreshRequest).type);
128
128
  }
129
- let $40b25ebbd3682ffd$var$progressReporter = new $40b25ebbd3682ffd$var$ProgressReporter();
130
- let $40b25ebbd3682ffd$var$clients = new Map();
131
- function $40b25ebbd3682ffd$var$findClient(document) {
132
- let filepath = $jCidy$url.fileURLToPath(document);
129
+ let $f1ba282d4a2dc9ad$var$progressReporter = new $f1ba282d4a2dc9ad$var$ProgressReporter();
130
+ let $f1ba282d4a2dc9ad$var$clients = new Map();
131
+ function $f1ba282d4a2dc9ad$var$findClient(document) {
132
+ let filepath = $4dDg2$url.fileURLToPath(document);
133
133
  let longestPrefix = 0;
134
134
  let bestClient;
135
- for (let [, client] of $40b25ebbd3682ffd$var$clients){
136
- let prefix = $jCidy$commonpathprefix([
135
+ for (let [, client] of $f1ba282d4a2dc9ad$var$clients){
136
+ let prefix = $4dDg2$commonpathprefix([
137
137
  client.projectRoot,
138
138
  filepath
139
139
  ]).length;
@@ -144,14 +144,14 @@ function $40b25ebbd3682ffd$var$findClient(document) {
144
144
  }
145
145
  return bestClient;
146
146
  }
147
- function $40b25ebbd3682ffd$var$loadMetafile(filepath) {
148
- const file = $jCidy$fs.readFileSync(filepath, 'utf-8');
147
+ function $f1ba282d4a2dc9ad$var$loadMetafile(filepath) {
148
+ const file = $4dDg2$fs.readFileSync(filepath, 'utf-8');
149
149
  return JSON.parse(file);
150
150
  }
151
- function $40b25ebbd3682ffd$var$createClient(metafilepath, metafile) {
151
+ function $f1ba282d4a2dc9ad$var$createClient(metafilepath, metafile) {
152
152
  let socketfilepath = metafilepath.slice(0, -5);
153
- let [reader, writer] = (0, $jCidy$vscodejsonrpcnode.createServerPipeTransport)(socketfilepath);
154
- let client = (0, $jCidy$vscodejsonrpcnode.createMessageConnection)(reader, writer);
153
+ let [reader, writer] = (0, $4dDg2$vscodejsonrpcnode.createServerPipeTransport)(socketfilepath);
154
+ let client = (0, $4dDg2$vscodejsonrpcnode.createMessageConnection)(reader, writer);
155
155
  client.listen();
156
156
  let uris = new Set();
157
157
  let result = {
@@ -160,71 +160,71 @@ function $40b25ebbd3682ffd$var$createClient(metafilepath, metafile) {
160
160
  projectRoot: metafile.projectRoot,
161
161
  lastBuild: '0'
162
162
  };
163
- client.onNotification((0, $jCidy$atlaspacklspprotocol.NotificationBuildStatus), (state, message)=>{
163
+ client.onNotification((0, $4dDg2$atlaspacklspprotocol.NotificationBuildStatus), (state, message)=>{
164
164
  // console.log('got NotificationBuildStatus', state, message);
165
165
  if (state === 'start') {
166
- $40b25ebbd3682ffd$var$progressReporter.begin();
167
- for (let uri of uris)$40b25ebbd3682ffd$var$connection.sendDiagnostics({
166
+ $f1ba282d4a2dc9ad$var$progressReporter.begin();
167
+ for (let uri of uris)$f1ba282d4a2dc9ad$var$connection.sendDiagnostics({
168
168
  uri: uri,
169
169
  diagnostics: []
170
170
  });
171
- } else if (state === 'progress' && message != null) $40b25ebbd3682ffd$var$progressReporter.report(message);
171
+ } else if (state === 'progress' && message != null) $f1ba282d4a2dc9ad$var$progressReporter.report(message);
172
172
  else if (state === 'end') {
173
173
  result.lastBuild = String(Date.now());
174
- $40b25ebbd3682ffd$var$sendDiagnosticsRefresh();
175
- $40b25ebbd3682ffd$var$progressReporter.done();
176
- $40b25ebbd3682ffd$var$connection.sendNotification((0, $jCidy$atlaspacklspprotocol.NotificationBuild));
174
+ $f1ba282d4a2dc9ad$var$sendDiagnosticsRefresh();
175
+ $f1ba282d4a2dc9ad$var$progressReporter.done();
176
+ $f1ba282d4a2dc9ad$var$connection.sendNotification((0, $4dDg2$atlaspacklspprotocol.NotificationBuild));
177
177
  }
178
178
  });
179
- client.onNotification((0, $jCidy$atlaspacklspprotocol.NotificationWorkspaceDiagnostics), (diagnostics)=>{
179
+ client.onNotification((0, $4dDg2$atlaspacklspprotocol.NotificationWorkspaceDiagnostics), (diagnostics)=>{
180
180
  // console.log('got NotificationWorkspaceDiagnostics', diagnostics);
181
181
  for (let d of diagnostics){
182
182
  uris.add(d.uri);
183
- $40b25ebbd3682ffd$var$connection.sendDiagnostics(d);
183
+ $f1ba282d4a2dc9ad$var$connection.sendDiagnostics(d);
184
184
  }
185
185
  });
186
186
  client.onClose(()=>{
187
- $40b25ebbd3682ffd$var$clients.delete(JSON.stringify(metafile));
188
- $40b25ebbd3682ffd$var$sendDiagnosticsRefresh();
187
+ $f1ba282d4a2dc9ad$var$clients.delete(JSON.stringify(metafile));
188
+ $f1ba282d4a2dc9ad$var$sendDiagnosticsRefresh();
189
189
  return Promise.all([
190
190
  ...uris
191
- ].map((uri)=>$40b25ebbd3682ffd$var$connection.sendDiagnostics({
191
+ ].map((uri)=>$f1ba282d4a2dc9ad$var$connection.sendDiagnostics({
192
192
  uri: uri,
193
193
  diagnostics: []
194
194
  })));
195
195
  });
196
- $40b25ebbd3682ffd$var$sendDiagnosticsRefresh();
197
- $40b25ebbd3682ffd$var$clients.set(JSON.stringify(metafile), result);
196
+ $f1ba282d4a2dc9ad$var$sendDiagnosticsRefresh();
197
+ $f1ba282d4a2dc9ad$var$clients.set(JSON.stringify(metafile), result);
198
198
  }
199
199
  // Take realpath because to have consistent cache keys on macOS (/var -> /private/var)
200
- const $40b25ebbd3682ffd$var$BASEDIR = $jCidy$path.join($jCidy$fs.realpathSync($jCidy$os.tmpdir()), 'atlaspack-lsp');
201
- $jCidy$fs.mkdirSync($40b25ebbd3682ffd$var$BASEDIR, {
200
+ const $f1ba282d4a2dc9ad$var$BASEDIR = $4dDg2$path.join($4dDg2$fs.realpathSync($4dDg2$os.tmpdir()), 'parcel-lsp');
201
+ $4dDg2$fs.mkdirSync($f1ba282d4a2dc9ad$var$BASEDIR, {
202
202
  recursive: true
203
203
  });
204
- $jCidy$fs.writeFileSync($jCidy$path.join($40b25ebbd3682ffd$var$BASEDIR, $40b25ebbd3682ffd$var$LSP_SENTINEL_FILENAME), '');
205
- // Search for currently running Atlaspack processes in the atlaspack-lsp dir.
204
+ $4dDg2$fs.writeFileSync($4dDg2$path.join($f1ba282d4a2dc9ad$var$BASEDIR, $f1ba282d4a2dc9ad$var$LSP_SENTINEL_FILENAME), '');
205
+ // Search for currently running Atlaspack processes in the parcel-lsp dir.
206
206
  // Create an IPC client connection for each running process.
207
- for (let filename of $jCidy$fs.readdirSync($40b25ebbd3682ffd$var$BASEDIR)){
207
+ for (let filename of $4dDg2$fs.readdirSync($f1ba282d4a2dc9ad$var$BASEDIR)){
208
208
  if (!filename.endsWith('.json')) continue;
209
- let filepath = $jCidy$path.join($40b25ebbd3682ffd$var$BASEDIR, filename);
210
- const contents = $40b25ebbd3682ffd$var$loadMetafile(filepath);
209
+ let filepath = $4dDg2$path.join($f1ba282d4a2dc9ad$var$BASEDIR, filename);
210
+ const contents = $f1ba282d4a2dc9ad$var$loadMetafile(filepath);
211
211
  const { projectRoot: projectRoot } = contents;
212
- if ($40b25ebbd3682ffd$var$WORKSPACE_ROOT === projectRoot) $40b25ebbd3682ffd$var$createClient(filepath, contents);
212
+ if ($f1ba282d4a2dc9ad$var$WORKSPACE_ROOT === projectRoot) $f1ba282d4a2dc9ad$var$createClient(filepath, contents);
213
213
  }
214
- // Watch for new Atlaspack processes in the atlaspack-lsp dir, and disconnect the
214
+ // Watch for new Atlaspack processes in the parcel-lsp dir, and disconnect the
215
215
  // client for each corresponding connection when a Atlaspack process ends
216
- $jCidy$parcelwatcher.subscribe($40b25ebbd3682ffd$var$BASEDIR, async (err, events)=>{
216
+ $4dDg2$parcelwatcher.subscribe($f1ba282d4a2dc9ad$var$BASEDIR, async (err, events)=>{
217
217
  if (err) throw err;
218
218
  for (let event of events){
219
219
  if (event.type === 'create' && event.path.endsWith('.json')) {
220
- const contents = $40b25ebbd3682ffd$var$loadMetafile(event.path);
220
+ const contents = $f1ba282d4a2dc9ad$var$loadMetafile(event.path);
221
221
  const { projectRoot: projectRoot } = contents;
222
- if ($40b25ebbd3682ffd$var$WORKSPACE_ROOT === projectRoot) $40b25ebbd3682ffd$var$createClient(event.path, contents);
222
+ if ($f1ba282d4a2dc9ad$var$WORKSPACE_ROOT === projectRoot) $f1ba282d4a2dc9ad$var$createClient(event.path, contents);
223
223
  } else if (event.type === 'delete' && event.path.endsWith('.json')) {
224
- let existing = $40b25ebbd3682ffd$var$clients.get(event.path);
224
+ let existing = $f1ba282d4a2dc9ad$var$clients.get(event.path);
225
225
  console.log('existing', event.path, existing);
226
226
  if (existing) {
227
- $40b25ebbd3682ffd$var$clients.delete(event.path);
227
+ $f1ba282d4a2dc9ad$var$clients.delete(event.path);
228
228
  existing.connection.end();
229
229
  }
230
230
  }
@@ -1 +1 @@
1
- {"mappings":"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","sources":["packages/utils/atlaspack-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 '@atlaspack/lsp-protocol';\n\ntype Metafile = {\n projectRoot: string;\n pid: typeof process['pid'];\n argv: typeof process['argv'];\n};\n\nconst connection = createConnection(ProposedFeatures.all);\nconst WORKSPACE_ROOT = process.cwd();\nconst LSP_SENTINEL_FILENAME = 'lsp-server';\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('Atlaspack');\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 loadMetafile(filepath: string) {\n const file = fs.readFileSync(filepath, 'utf-8');\n return JSON.parse(file);\n}\n\nfunction createClient(metafilepath: string, metafile: Metafile) {\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(JSON.stringify(metafile));\n sendDiagnosticsRefresh();\n return Promise.all(\n [...uris].map(uri => connection.sendDiagnostics({uri, diagnostics: []})),\n );\n });\n\n sendDiagnosticsRefresh();\n clients.set(JSON.stringify(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()), 'atlaspack-lsp');\nfs.mkdirSync(BASEDIR, {recursive: true});\n\nfs.writeFileSync(path.join(BASEDIR, LSP_SENTINEL_FILENAME), '');\n\n// Search for currently running Atlaspack processes in the atlaspack-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 const contents = loadMetafile(filepath);\n const {projectRoot} = contents;\n\n if (WORKSPACE_ROOT === projectRoot) {\n createClient(filepath, contents);\n }\n}\n\n// Watch for new Atlaspack processes in the atlaspack-lsp dir, and disconnect the\n// client for each corresponding connection when a Atlaspack 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 const contents = loadMetafile(event.path);\n const {projectRoot} = contents;\n\n if (WORKSPACE_ROOT === projectRoot) {\n createClient(event.path, contents);\n }\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 }\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","Metafile","projectRoot","pid","process","argv","connection","all","WORKSPACE_ROOT","cwd","LSP_SENTINEL_FILENAME","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","Set","progressReporter","clients","Map","document","filepath","fileURLToPath","longestPrefix","bestClient","prefix","length","warn","loadMetafile","file","readFileSync","JSON","parse","createClient","metafilepath","metafile","socketfilepath","slice","reader","writer","onNotification","state","sendDiagnostics","String","Date","now","sendNotification","d","onClose","delete","stringify","map","set","BASEDIR","join","realpathSync","tmpdir","mkdirSync","recursive","writeFileSync","filename","readdirSync","endsWith","contents","subscribe","err","events","event","existing","get","end"],"version":3,"file":"LspServer.js.map","sourceRoot":"../../../../"}
1
+ {"mappings":"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","sources":["packages/utils/atlaspack-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 '@atlaspack/lsp-protocol';\n\ntype Metafile = {\n projectRoot: string;\n pid: typeof process['pid'];\n argv: typeof process['argv'];\n};\n\nconst connection = createConnection(ProposedFeatures.all);\nconst WORKSPACE_ROOT = process.cwd();\nconst LSP_SENTINEL_FILENAME = 'lsp-server';\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('Atlaspack');\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 loadMetafile(filepath: string) {\n const file = fs.readFileSync(filepath, 'utf-8');\n return JSON.parse(file);\n}\n\nfunction createClient(metafilepath: string, metafile: Metafile) {\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(JSON.stringify(metafile));\n sendDiagnosticsRefresh();\n return Promise.all(\n [...uris].map(uri => connection.sendDiagnostics({uri, diagnostics: []})),\n );\n });\n\n sendDiagnosticsRefresh();\n clients.set(JSON.stringify(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\nfs.writeFileSync(path.join(BASEDIR, LSP_SENTINEL_FILENAME), '');\n\n// Search for currently running Atlaspack 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 const contents = loadMetafile(filepath);\n const {projectRoot} = contents;\n\n if (WORKSPACE_ROOT === projectRoot) {\n createClient(filepath, contents);\n }\n}\n\n// Watch for new Atlaspack processes in the parcel-lsp dir, and disconnect the\n// client for each corresponding connection when a Atlaspack 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 const contents = loadMetafile(event.path);\n const {projectRoot} = contents;\n\n if (WORKSPACE_ROOT === projectRoot) {\n createClient(event.path, contents);\n }\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 }\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","Metafile","projectRoot","pid","process","argv","connection","all","WORKSPACE_ROOT","cwd","LSP_SENTINEL_FILENAME","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","Set","progressReporter","clients","Map","document","filepath","fileURLToPath","longestPrefix","bestClient","prefix","length","warn","loadMetafile","file","readFileSync","JSON","parse","createClient","metafilepath","metafile","socketfilepath","slice","reader","writer","onNotification","state","sendDiagnostics","String","Date","now","sendNotification","d","onClose","delete","stringify","map","set","BASEDIR","join","realpathSync","tmpdir","mkdirSync","recursive","writeFileSync","filename","readdirSync","endsWith","contents","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": "@atlaspack/lsp",
3
- "version": "2.12.1-dev.3368+af1db7f65",
3
+ "version": "2.12.1-dev.3401+b483af77f",
4
4
  "license": "MIT",
5
5
  "publishConfig": {
6
6
  "access": "public"
@@ -18,10 +18,10 @@
18
18
  },
19
19
  "engines": {
20
20
  "node": ">= 16.0.0",
21
- "atlaspack": "^2.12.1-dev.3368+af1db7f65"
21
+ "parcel": "^2.12.1-dev.3401+b483af77f"
22
22
  },
23
23
  "dependencies": {
24
- "@atlaspack/lsp-protocol": "2.12.1-dev.3368+af1db7f65",
24
+ "@atlaspack/lsp-protocol": "2.12.1-dev.3401+b483af77f",
25
25
  "@parcel/watcher": "^2.0.7",
26
26
  "common-path-prefix": "^3.0.0",
27
27
  "nullthrows": "^1.1.1",
@@ -40,5 +40,5 @@
40
40
  "targets": {
41
41
  "types": false
42
42
  },
43
- "gitHead": "af1db7f65c4816917ddf83716deedc536a1b8b27"
43
+ "gitHead": "b483af77f02d1258c8dad156e097b94f83671d8e"
44
44
  }
package/src/LspServer.ts CHANGED
@@ -285,12 +285,12 @@ function createClient(metafilepath: string, metafile: Metafile) {
285
285
  }
286
286
 
287
287
  // Take realpath because to have consistent cache keys on macOS (/var -> /private/var)
288
- const BASEDIR = path.join(fs.realpathSync(os.tmpdir()), 'atlaspack-lsp');
288
+ const BASEDIR = path.join(fs.realpathSync(os.tmpdir()), 'parcel-lsp');
289
289
  fs.mkdirSync(BASEDIR, {recursive: true});
290
290
 
291
291
  fs.writeFileSync(path.join(BASEDIR, LSP_SENTINEL_FILENAME), '');
292
292
 
293
- // Search for currently running Atlaspack processes in the atlaspack-lsp dir.
293
+ // Search for currently running Atlaspack processes in the parcel-lsp dir.
294
294
  // Create an IPC client connection for each running process.
295
295
  for (let filename of fs.readdirSync(BASEDIR)) {
296
296
  if (!filename.endsWith('.json')) continue;
@@ -303,7 +303,7 @@ for (let filename of fs.readdirSync(BASEDIR)) {
303
303
  }
304
304
  }
305
305
 
306
- // Watch for new Atlaspack processes in the atlaspack-lsp dir, and disconnect the
306
+ // Watch for new Atlaspack processes in the parcel-lsp dir, and disconnect the
307
307
  // client for each corresponding connection when a Atlaspack process ends
308
308
  watcher.subscribe(BASEDIR, async (err, events) => {
309
309
  if (err) {