nx 22.0.0 → 22.0.2

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.
Files changed (89) hide show
  1. package/package.json +12 -12
  2. package/project.json +5 -1
  3. package/src/ai/utils.d.ts.map +1 -1
  4. package/src/ai/utils.js +3 -1
  5. package/src/command-line/init/ai-agent-prompts.d.ts.map +1 -1
  6. package/src/command-line/init/ai-agent-prompts.js +12 -11
  7. package/src/command-line/init/init-v2.d.ts.map +1 -1
  8. package/src/command-line/init/init-v2.js +4 -0
  9. package/src/command-line/release/config/config.d.ts +1 -1
  10. package/src/command-line/release/config/config.d.ts.map +1 -1
  11. package/src/command-line/release/config/config.js +39 -0
  12. package/src/command-line/release/version/release-group-processor.d.ts.map +1 -1
  13. package/src/command-line/release/version/release-group-processor.js +3 -2
  14. package/src/config/nx-json.d.ts +2 -0
  15. package/src/config/nx-json.d.ts.map +1 -1
  16. package/src/core/graph/main.js +1 -1
  17. package/src/daemon/client/client.d.ts.map +1 -1
  18. package/src/daemon/client/client.js +25 -19
  19. package/src/daemon/client/daemon-socket-messenger.d.ts +1 -1
  20. package/src/daemon/client/daemon-socket-messenger.d.ts.map +1 -1
  21. package/src/daemon/client/daemon-socket-messenger.js +5 -3
  22. package/src/daemon/is-v8-serializer-enabled.d.ts +6 -0
  23. package/src/daemon/is-v8-serializer-enabled.d.ts.map +1 -0
  24. package/src/daemon/is-v8-serializer-enabled.js +10 -0
  25. package/src/daemon/server/file-watching/file-watcher-sockets.d.ts.map +1 -1
  26. package/src/daemon/server/file-watching/file-watcher-sockets.js +1 -1
  27. package/src/daemon/server/handle-context-file-data.js +1 -1
  28. package/src/daemon/server/handle-flush-sync-generator-changes-to-disk.js +1 -1
  29. package/src/daemon/server/handle-get-files-in-directory.js +1 -1
  30. package/src/daemon/server/handle-get-registered-sync-generators.js +1 -1
  31. package/src/daemon/server/handle-get-sync-generator-changes.js +1 -1
  32. package/src/daemon/server/handle-glob.js +2 -2
  33. package/src/daemon/server/handle-hash-tasks.d.ts +1 -1
  34. package/src/daemon/server/handle-hash-tasks.d.ts.map +1 -1
  35. package/src/daemon/server/handle-hash-tasks.js +1 -1
  36. package/src/daemon/server/handle-nx-workspace-files.js +1 -1
  37. package/src/daemon/server/handle-outputs-tracking.js +1 -1
  38. package/src/daemon/server/handle-task-history.d.ts +2 -2
  39. package/src/daemon/server/handle-task-history.js +2 -2
  40. package/src/daemon/server/handle-tasks-execution-hooks.d.ts +1 -1
  41. package/src/daemon/server/handle-tasks-execution-hooks.js +1 -1
  42. package/src/daemon/server/project-graph-incremental-recomputation.d.ts.map +1 -1
  43. package/src/daemon/server/project-graph-incremental-recomputation.js +14 -1
  44. package/src/daemon/server/project-graph-listener-sockets.d.ts.map +1 -1
  45. package/src/daemon/server/project-graph-listener-sockets.js +3 -2
  46. package/src/daemon/server/server.d.ts +2 -2
  47. package/src/daemon/server/server.d.ts.map +1 -1
  48. package/src/daemon/server/server.js +49 -28
  49. package/src/daemon/server/shutdown-utils.d.ts.map +1 -1
  50. package/src/daemon/server/shutdown-utils.js +2 -1
  51. package/src/daemon/socket-utils.d.ts +11 -0
  52. package/src/daemon/socket-utils.d.ts.map +1 -1
  53. package/src/daemon/socket-utils.js +41 -0
  54. package/src/devkit-internals.d.ts +1 -0
  55. package/src/devkit-internals.d.ts.map +1 -1
  56. package/src/devkit-internals.js +3 -1
  57. package/src/native/nx.wasm32-wasi.wasm +0 -0
  58. package/src/plugins/js/index.d.ts.map +1 -1
  59. package/src/plugins/js/index.js +34 -20
  60. package/src/plugins/js/lock-file/pnpm-parser.d.ts.map +1 -1
  61. package/src/plugins/js/lock-file/pnpm-parser.js +5 -3
  62. package/src/plugins/js/lock-file/project-graph-pruning.js +1 -1
  63. package/src/project-graph/plugins/isolation/messaging.d.ts.map +1 -1
  64. package/src/project-graph/plugins/isolation/messaging.js +2 -1
  65. package/src/project-graph/plugins/isolation/plugin-pool.js +19 -5
  66. package/src/project-graph/plugins/loaded-nx-plugin.d.ts.map +1 -1
  67. package/src/project-graph/plugins/loaded-nx-plugin.js +2 -0
  68. package/src/project-graph/plugins/resolve-plugin.d.ts.map +1 -1
  69. package/src/project-graph/plugins/resolve-plugin.js +4 -2
  70. package/src/project-graph/utils/project-configuration-utils.d.ts +1 -1
  71. package/src/project-graph/utils/project-configuration-utils.d.ts.map +1 -1
  72. package/src/project-graph/utils/project-configuration-utils.js +7 -4
  73. package/src/tasks-runner/cache.d.ts.map +1 -1
  74. package/src/tasks-runner/cache.js +27 -14
  75. package/src/tasks-runner/fork.js +3 -1
  76. package/src/tasks-runner/is-tui-enabled.d.ts.map +1 -1
  77. package/src/tasks-runner/is-tui-enabled.js +1 -1
  78. package/src/tasks-runner/pseudo-ipc.d.ts.map +1 -1
  79. package/src/tasks-runner/pseudo-ipc.js +4 -4
  80. package/src/tasks-runner/run-command.d.ts.map +1 -1
  81. package/src/tasks-runner/run-command.js +4 -1
  82. package/src/utils/consume-messages-from-socket.d.ts +2 -0
  83. package/src/utils/consume-messages-from-socket.d.ts.map +1 -1
  84. package/src/utils/consume-messages-from-socket.js +27 -8
  85. package/src/utils/exit-codes.d.ts +1 -1
  86. package/src/utils/exit-codes.d.ts.map +1 -1
  87. package/src/utils/git-utils.js +1 -1
  88. package/src/utils/package-json.js +1 -1
  89. package/src/utils/package-manager.js +2 -2
@@ -1 +1 @@
1
- {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../../../../packages/nx/src/daemon/client/client.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAS,MAAM,eAAe,CAAC;AAoBpD,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAUpE,OAAO,EAAE,IAAI,EAAE,MAAM,0BAA0B,CAAC;AAChD,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,uBAAuB,EAAE,MAAM,uDAAuD,CAAC;AAKhG,OAAO,EAAW,gBAAgB,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAoC9E,OAAO,KAAK,EACV,+BAA+B,EAC/B,sBAAsB,EACvB,MAAM,6BAA6B,CAAC;AAcrC,OAAO,EACL,yBAAyB,EACzB,wBAAwB,EACzB,MAAM,wCAAwC,CAAC;AAiBhD,MAAM,MAAM,kBAAkB,GAAG,MAAM,IAAI,CAAC;AAC5C,MAAM,MAAM,WAAW,GAAG;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,QAAQ,GAAG,QAAQ,GAAG,QAAQ,CAAC;CACtC,CAAC;AAQF,qBAAa,YAAY;IACvB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA6B;;IAWpD,OAAO,CAAC,KAAK,CAAqB;IAClC,OAAO,CAAC,eAAe,CAAwB;IAE/C,OAAO,CAAC,cAAc,CAAC;IACvB,OAAO,CAAC,cAAc,CAAC;IACvB,OAAO,CAAC,aAAa,CAAC;IAEtB,OAAO,CAAC,QAAQ,CAAsB;IACtC,OAAO,CAAC,aAAa,CAA2C;IAChE,OAAO,CAAC,mBAAmB,CAA8B;IACzD,OAAO,CAAC,YAAY,CAA2B;IAC/C,OAAO,CAAC,IAAI,CAAoB;IAChC,OAAO,CAAC,IAAI,CAAoB;IAEhC,OAAO;IA6CP,KAAK;IAoBC,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC;IAIhC,4BAA4B,IAAI,OAAO,CAAC;QAC5C,YAAY,EAAE,YAAY,CAAC;QAC3B,UAAU,EAAE,uBAAuB,CAAC;KACrC,CAAC;IA4BI,cAAc,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;IAI3C,SAAS,CACP,aAAa,EAAE,GAAG,EAClB,KAAK,EAAE,IAAI,EAAE,EACb,SAAS,EAAE,SAAS,EACpB,GAAG,EAAE,MAAM,CAAC,UAAU,GACrB,OAAO,CAAC,IAAI,EAAE,CAAC;IAUZ,mBAAmB,CACvB,MAAM,EAAE;QACN,aAAa,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC;QAChC,2BAA2B,CAAC,EAAE,OAAO,CAAC;QACtC,wBAAwB,CAAC,EAAE,OAAO,CAAC;QACnC,iBAAiB,CAAC,EAAE,OAAO,CAAC;KAC7B,EACD,QAAQ,EAAE,CACR,KAAK,EAAE,KAAK,GAAG,IAAI,GAAG,QAAQ,EAC9B,IAAI,EAAE;QACJ,eAAe,EAAE,MAAM,EAAE,CAAC;QAC1B,YAAY,EAAE,WAAW,EAAE,CAAC;KAC7B,GAAG,IAAI,KACL,IAAI,GACR,OAAO,CAAC,kBAAkB,CAAC;IAqCxB,yCAAyC,CAC7C,QAAQ,EAAE,CACR,KAAK,EAAE,KAAK,GAAG,IAAI,GAAG,QAAQ,EAC9B,IAAI,EAAE;QACJ,YAAY,EAAE,YAAY,CAAC;QAC3B,UAAU,EAAE,uBAAuB,CAAC;KACrC,GAAG,IAAI,KACL,IAAI,GACR,OAAO,CAAC,kBAAkB,CAAC;IA8B9B,mBAAmB,CAAC,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC;IAQjE,iBAAiB,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IAUhE,kBAAkB,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IAUjE,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,OAAO,CAAC,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAS5D,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,OAAO,CAAC,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC;IASnE,2BAA2B,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;IAOlD,iBAAiB,CACf,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GACrC,OAAO,CAAC,gBAAgB,CAAC;IAQ5B,mBAAmB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAQnD,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,OAAO,CAAC,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC;IAS9D,aAAa,CAAC,UAAU,EAAE,MAAM,EAAE,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAQxD,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAS5C,uBAAuB,CAC3B,OAAO,EAAE,UAAU,EAAE,GACpB,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IASlC,cAAc,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAQlD,uBAAuB,CACrB,UAAU,EAAE,MAAM,EAAE,GACnB,OAAO,CAAC,sBAAsB,EAAE,CAAC;IAQpC,+BAA+B,CAC7B,UAAU,EAAE,MAAM,EAAE,GACnB,OAAO,CAAC,+BAA+B,CAAC;IAQ3C,2BAA2B,IAAI,OAAO,CAAC;QACrC,gBAAgB,EAAE,MAAM,EAAE,CAAC;QAC3B,cAAc,EAAE,MAAM,EAAE,CAAC;KAC1B,CAAC;IAOF,sBAAsB,CACpB,YAAY,EAAE,MAAM,EAAE,EACtB,YAAY,EAAE,MAAM,EAAE,EACtB,YAAY,EAAE,MAAM,EAAE,GACrB,OAAO,CAAC,IAAI,CAAC;IAUV,oBAAoB,CACxB,OAAO,EAAE,wBAAwB,GAChC,OAAO,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;IAQzB,qBAAqB,CACzB,OAAO,EAAE,yBAAyB,GACjC,OAAO,CAAC,IAAI,CAAC;IAQV,iBAAiB,IAAI,OAAO,CAAC,OAAO,CAAC;YAgB7B,oBAAoB;IAMlC,OAAO,CAAC,eAAe;YA8DT,mBAAmB;IA8BjC,OAAO,CAAC,gCAAgC;IAyBxC,OAAO,CAAC,aAAa;IAgDf,iBAAiB,IAAI,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;IAwDjD,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;CAkB5B;AAED,eAAO,MAAM,YAAY,cAAqB,CAAC;AAE/C,wBAAgB,eAAe,YAE9B"}
1
+ {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../../../../packages/nx/src/daemon/client/client.ts"],"names":[],"mappings":"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"}
@@ -32,6 +32,8 @@ const flush_sync_generator_changes_to_disk_1 = require("../message-types/flush-s
32
32
  const delayed_spinner_1 = require("../../utils/delayed-spinner");
33
33
  const run_tasks_execution_hooks_1 = require("../message-types/run-tasks-execution-hooks");
34
34
  const register_project_graph_listener_1 = require("../message-types/register-project-graph-listener");
35
+ const node_v8_1 = require("node:v8");
36
+ const consume_messages_from_socket_1 = require("../../utils/consume-messages-from-socket");
35
37
  const DAEMON_ENV_SETTINGS = {
36
38
  NX_PROJECT_GLOB_CACHE: 'false',
37
39
  NX_CACHE_PROJECTS_CONFIG: 'false',
@@ -149,7 +151,9 @@ class DaemonClient {
149
151
  return this.sendToDaemonViaQueue({
150
152
  type: 'HASH_TASKS',
151
153
  runnerOptions,
152
- env,
154
+ env: process.env.NX_USE_V8_SERIALIZER !== 'false'
155
+ ? structuredClone(process.env)
156
+ : env,
153
157
  tasks,
154
158
  taskGraph,
155
159
  });
@@ -170,7 +174,9 @@ class DaemonClient {
170
174
  await this.queue.sendToQueue(() => {
171
175
  messenger = new daemon_socket_messenger_1.DaemonSocketMessenger((0, net_1.connect)((0, socket_utils_1.getFullOsSocketPath)())).listen((message) => {
172
176
  try {
173
- const parsedMessage = JSON.parse(message);
177
+ const parsedMessage = (0, consume_messages_from_socket_1.isJsonMessage)(message)
178
+ ? JSON.parse(message)
179
+ : (0, node_v8_1.deserialize)(Buffer.from(message, 'binary'));
174
180
  callback(null, parsedMessage);
175
181
  }
176
182
  catch (e) {
@@ -190,7 +196,9 @@ class DaemonClient {
190
196
  await this.queue.sendToQueue(() => {
191
197
  messenger = new daemon_socket_messenger_1.DaemonSocketMessenger((0, net_1.connect)((0, socket_utils_1.getFullOsSocketPath)())).listen((message) => {
192
198
  try {
193
- const parsedMessage = JSON.parse(message);
199
+ const parsedMessage = (0, consume_messages_from_socket_1.isJsonMessage)(message)
200
+ ? JSON.parse(message)
201
+ : (0, node_v8_1.deserialize)(Buffer.from(message, 'binary'));
194
202
  callback(null, parsedMessage);
195
203
  }
196
204
  catch (e) {
@@ -212,7 +220,9 @@ class DaemonClient {
212
220
  type: 'PROCESS_IN_BACKGROUND',
213
221
  requirePath,
214
222
  data,
215
- });
223
+ // This method is sometimes passed data that cannot be serialized with v8
224
+ // so we force JSON serialization here
225
+ }, 'json');
216
226
  }
217
227
  recordOutputsHash(outputs, hash) {
218
228
  return this.sendToDaemonViaQueue({
@@ -363,8 +373,8 @@ class DaemonClient {
363
373
  }
364
374
  });
365
375
  }
366
- async sendToDaemonViaQueue(messageToDaemon) {
367
- return this.queue.sendToQueue(() => this.sendMessageToDaemon(messageToDaemon));
376
+ async sendToDaemonViaQueue(messageToDaemon, force) {
377
+ return this.queue.sendToQueue(() => this.sendMessageToDaemon(messageToDaemon, force));
368
378
  }
369
379
  setUpConnection() {
370
380
  this.socketMessenger = new daemon_socket_messenger_1.DaemonSocketMessenger((0, net_1.connect)((0, socket_utils_1.getFullOsSocketPath)())).listen((message) => this.handleMessage(message), () => {
@@ -389,12 +399,6 @@ class DaemonClient {
389
399
  if (!err.message) {
390
400
  return this.currentReject(daemonProcessException(err.toString()));
391
401
  }
392
- if (err.message.startsWith('LOCK-FILES-CHANGED')) {
393
- // retry the current message
394
- // we cannot send it via the queue because we are in the middle of processing
395
- // a message from the queue
396
- return this.sendMessageToDaemon(this.currentMessage).then(this.currentResolve, this.currentReject);
397
- }
398
402
  let error;
399
403
  if (err.message.startsWith('connect ENOENT')) {
400
404
  error = daemonProcessException('The Daemon Server is not running');
@@ -412,7 +416,7 @@ class DaemonClient {
412
416
  return this.currentReject(error);
413
417
  });
414
418
  }
415
- async sendMessageToDaemon(message) {
419
+ async sendMessageToDaemon(message, force) {
416
420
  if (this._daemonStatus == DaemonStatus.DISCONNECTED) {
417
421
  this._daemonStatus = DaemonStatus.CONNECTING;
418
422
  if (!(await this.isServerAvailable())) {
@@ -434,7 +438,7 @@ class DaemonClient {
434
438
  this.currentMessage = message;
435
439
  this.currentResolve = resolve;
436
440
  this.currentReject = reject;
437
- this.socketMessenger.sendMessage(message);
441
+ this.socketMessenger.sendMessage(message, force);
438
442
  }).finally(() => {
439
443
  clearTimeout(keepAlive);
440
444
  });
@@ -464,10 +468,12 @@ class DaemonClient {
464
468
  }
465
469
  handleMessage(serializedResult) {
466
470
  try {
467
- perf_hooks_1.performance.mark('json-parse-start');
468
- const parsedResult = JSON.parse(serializedResult);
469
- perf_hooks_1.performance.mark('json-parse-end');
470
- perf_hooks_1.performance.measure('deserialize daemon response', 'json-parse-start', 'json-parse-end');
471
+ perf_hooks_1.performance.mark('result-parse-start');
472
+ const parsedResult = (0, consume_messages_from_socket_1.isJsonMessage)(serializedResult)
473
+ ? JSON.parse(serializedResult)
474
+ : (0, node_v8_1.deserialize)(Buffer.from(serializedResult, 'binary'));
475
+ perf_hooks_1.performance.mark('result-parse-end');
476
+ perf_hooks_1.performance.measure('deserialize daemon response', 'result-parse-start', 'result-parse-end');
471
477
  if (parsedResult.error) {
472
478
  if ('message' in parsedResult.error &&
473
479
  (parsedResult.error.message === 'NX_VERSION_CHANGED' ||
@@ -479,7 +485,7 @@ class DaemonClient {
479
485
  }
480
486
  }
481
487
  else {
482
- perf_hooks_1.performance.measure('total for sendMessageToDaemon()', 'sendMessageToDaemon-start', 'json-parse-end');
488
+ perf_hooks_1.performance.measure('total for sendMessageToDaemon()', 'sendMessageToDaemon-start', 'result-parse-end');
483
489
  return this.currentResolve(parsedResult);
484
490
  }
485
491
  }
@@ -6,7 +6,7 @@ export interface Message extends Record<string, any> {
6
6
  export declare class DaemonSocketMessenger {
7
7
  private socket;
8
8
  constructor(socket: Socket);
9
- sendMessage(messageToDaemon: Message): Promise<void>;
9
+ sendMessage(messageToDaemon: Message, force?: 'v8' | 'json'): Promise<void>;
10
10
  listen(onData: (message: string) => void, onClose?: () => void, onError?: (err: Error) => void): this;
11
11
  close(): void;
12
12
  }
@@ -1 +1 @@
1
- {"version":3,"file":"daemon-socket-messenger.d.ts","sourceRoot":"","sources":["../../../../../../packages/nx/src/daemon/client/daemon-socket-messenger.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,KAAK,CAAC;AAI7B,MAAM,WAAW,OAAQ,SAAQ,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAClD,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,GAAG,CAAC;CACZ;AAED,qBAAa,qBAAqB;IACpB,OAAO,CAAC,MAAM;gBAAN,MAAM,EAAE,MAAM;IAE5B,WAAW,CAAC,eAAe,EAAE,OAAO;IAM1C,MAAM,CACJ,MAAM,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,EACjC,OAAO,GAAE,MAAM,IAAe,EAC9B,OAAO,GAAE,CAAC,GAAG,EAAE,KAAK,KAAK,IAAkB;IAe7C,KAAK;CAGN"}
1
+ {"version":3,"file":"daemon-socket-messenger.d.ts","sourceRoot":"","sources":["../../../../../../packages/nx/src/daemon/client/daemon-socket-messenger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,KAAK,CAAC;AAQ7B,MAAM,WAAW,OAAQ,SAAQ,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC;IAClD,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,GAAG,CAAC;CACZ;AAED,qBAAa,qBAAqB;IACpB,OAAO,CAAC,MAAM;gBAAN,MAAM,EAAE,MAAM;IAE5B,WAAW,CAAC,eAAe,EAAE,OAAO,EAAE,KAAK,CAAC,EAAE,IAAI,GAAG,MAAM;IAOjE,MAAM,CACJ,MAAM,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,EACjC,OAAO,GAAE,MAAM,IAAe,EAC9B,OAAO,GAAE,CAAC,GAAG,EAAE,KAAK,KAAK,IAAkB;IAe7C,KAAK;CAGN"}
@@ -2,14 +2,16 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.DaemonSocketMessenger = void 0;
4
4
  const consume_messages_from_socket_1 = require("../../utils/consume-messages-from-socket");
5
+ const socket_utils_1 = require("../socket-utils");
5
6
  class DaemonSocketMessenger {
6
7
  constructor(socket) {
7
8
  this.socket = socket;
8
9
  }
9
- async sendMessage(messageToDaemon) {
10
- this.socket.write(JSON.stringify(messageToDaemon));
10
+ async sendMessage(messageToDaemon, force) {
11
+ const serialized = (0, socket_utils_1.serialize)(messageToDaemon, force);
12
+ this.socket.write(serialized);
11
13
  // send EOT to indicate that the message has been fully written
12
- this.socket.write(String.fromCodePoint(4));
14
+ this.socket.write(consume_messages_from_socket_1.MESSAGE_END_SEQ);
13
15
  }
14
16
  listen(onData, onClose = () => { }, onError = (err) => { }) {
15
17
  this.socket.on('data', (0, consume_messages_from_socket_1.consumeMessagesFromSocket)(async (message) => {
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Check if v8 serializer is enabled for daemon communication.
3
+ * V8 serializer is enabled by default unless explicitly disabled.
4
+ */
5
+ export declare function isV8SerializerEnabled(): boolean;
6
+ //# sourceMappingURL=is-v8-serializer-enabled.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"is-v8-serializer-enabled.d.ts","sourceRoot":"","sources":["../../../../../packages/nx/src/daemon/is-v8-serializer-enabled.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,wBAAgB,qBAAqB,IAAI,OAAO,CAE/C"}
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isV8SerializerEnabled = isV8SerializerEnabled;
4
+ /**
5
+ * Check if v8 serializer is enabled for daemon communication.
6
+ * V8 serializer is enabled by default unless explicitly disabled.
7
+ */
8
+ function isV8SerializerEnabled() {
9
+ return process.env.NX_USE_V8_SERIALIZER === 'true';
10
+ }
@@ -1 +1 @@
1
- {"version":3,"file":"file-watcher-sockets.d.ts","sourceRoot":"","sources":["../../../../../../../packages/nx/src/daemon/server/file-watching/file-watcher-sockets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,KAAK,CAAC;AAU7B,eAAO,IAAI,4BAA4B,EAAE;IACvC,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE;QACN,aAAa,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC;QAChC,2BAA2B,EAAE,OAAO,CAAC;QACrC,wBAAwB,EAAE,OAAO,CAAC;KACnC,CAAC;CACH,EAAO,CAAC;AAET,wBAAgB,iCAAiC,CAAC,MAAM,EAAE,MAAM,QAI/D;AAED,wBAAgB,+BAA+B,YAE9C;AAED,wBAAgB,wBAAwB,CACtC,YAAY,EAAE,MAAM,EAAE,GAAG,IAAI,EAC7B,YAAY,EAAE,MAAM,EAAE,EACtB,YAAY,EAAE,MAAM,EAAE,QAwEvB"}
1
+ {"version":3,"file":"file-watcher-sockets.d.ts","sourceRoot":"","sources":["../../../../../../../packages/nx/src/daemon/server/file-watching/file-watcher-sockets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,KAAK,CAAC;AAU7B,eAAO,IAAI,4BAA4B,EAAE;IACvC,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE;QACN,aAAa,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC;QAChC,2BAA2B,EAAE,OAAO,CAAC;QACrC,wBAAwB,EAAE,OAAO,CAAC;KACnC,CAAC;CACH,EAAO,CAAC;AAET,wBAAgB,iCAAiC,CAAC,MAAM,EAAE,MAAM,QAI/D;AAED,wBAAgB,+BAA+B,YAE9C;AAED,wBAAgB,wBAAwB,CACtC,YAAY,EAAE,MAAM,EAAE,GAAG,IAAI,EAC7B,YAAY,EAAE,MAAM,EAAE,EACtB,YAAY,EAAE,MAAM,EAAE,QA4EvB"}
@@ -59,7 +59,7 @@ function notifyFileWatcherSockets(createdFiles, updatedFiles, deletedFiles) {
59
59
  changedProjects,
60
60
  changedFiles,
61
61
  }),
62
- }));
62
+ }), 'json');
63
63
  }
64
64
  }));
65
65
  });
@@ -6,7 +6,7 @@ const workspace_root_1 = require("../../utils/workspace-root");
6
6
  async function handleContextFileData() {
7
7
  const files = await (0, workspace_context_1.getAllFileDataInContext)(workspace_root_1.workspaceRoot);
8
8
  return {
9
- response: JSON.stringify(files),
9
+ response: files,
10
10
  description: 'handleContextFileData',
11
11
  };
12
12
  }
@@ -5,7 +5,7 @@ const sync_generators_1 = require("./sync-generators");
5
5
  async function handleFlushSyncGeneratorChangesToDisk(generators) {
6
6
  const result = await (0, sync_generators_1.flushSyncGeneratorChangesToDisk)(generators);
7
7
  return {
8
- response: JSON.stringify(result),
8
+ response: result,
9
9
  description: 'handleFlushSyncGeneratorChangesToDisk',
10
10
  };
11
11
  }
@@ -6,7 +6,7 @@ const workspace_root_1 = require("../../utils/workspace-root");
6
6
  async function handleGetFilesInDirectory(dir) {
7
7
  const files = await (0, workspace_context_1.getFilesInDirectoryUsingContext)(workspace_root_1.workspaceRoot, dir);
8
8
  return {
9
- response: JSON.stringify(files),
9
+ response: files,
10
10
  description: 'handleNxWorkspaceFiles',
11
11
  };
12
12
  }
@@ -5,7 +5,7 @@ const sync_generators_1 = require("./sync-generators");
5
5
  async function handleGetRegisteredSyncGenerators() {
6
6
  const syncGenerators = await (0, sync_generators_1.getCachedRegisteredSyncGenerators)();
7
7
  return {
8
- response: JSON.stringify(syncGenerators),
8
+ response: syncGenerators,
9
9
  description: 'handleGetSyncGeneratorChanges',
10
10
  };
11
11
  }
@@ -14,7 +14,7 @@ async function handleGetSyncGeneratorChanges(generators) {
14
14
  outOfSyncDetails: change.outOfSyncDetails,
15
15
  });
16
16
  return {
17
- response: JSON.stringify(result),
17
+ response: result,
18
18
  description: 'handleGetSyncGeneratorChanges',
19
19
  };
20
20
  }
@@ -7,14 +7,14 @@ const workspace_context_1 = require("../../utils/workspace-context");
7
7
  async function handleGlob(globs, exclude) {
8
8
  const files = await (0, workspace_context_1.globWithWorkspaceContext)(workspace_root_1.workspaceRoot, globs, exclude);
9
9
  return {
10
- response: JSON.stringify(files),
10
+ response: files,
11
11
  description: 'handleGlob',
12
12
  };
13
13
  }
14
14
  async function handleMultiGlob(globs, exclude) {
15
15
  const files = await (0, workspace_context_1.multiGlobWithWorkspaceContext)(workspace_root_1.workspaceRoot, globs, exclude);
16
16
  return {
17
- response: JSON.stringify(files),
17
+ response: files,
18
18
  description: 'handleMultiGlob',
19
19
  };
20
20
  }
@@ -5,7 +5,7 @@ export declare function handleHashTasks(payload: {
5
5
  tasks: Task[];
6
6
  taskGraph: TaskGraph;
7
7
  }): Promise<{
8
- response: string;
8
+ response: import("../../hasher/task-hasher").Hash[];
9
9
  description: string;
10
10
  }>;
11
11
  //# sourceMappingURL=handle-hash-tasks.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"handle-hash-tasks.d.ts","sourceRoot":"","sources":["../../../../../../packages/nx/src/daemon/server/handle-hash-tasks.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AAa1D,wBAAsB,eAAe,CAAC,OAAO,EAAE;IAC7C,aAAa,EAAE,GAAG,CAAC;IACnB,GAAG,EAAE,GAAG,CAAC;IACT,KAAK,EAAE,IAAI,EAAE,CAAC;IACd,SAAS,EAAE,SAAS,CAAC;CACtB;;;GAoCA"}
1
+ {"version":3,"file":"handle-hash-tasks.d.ts","sourceRoot":"","sources":["../../../../../../packages/nx/src/daemon/server/handle-hash-tasks.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AAa1D,wBAAsB,eAAe,CAAC,OAAO,EAAE;IAC7C,aAAa,EAAE,GAAG,CAAC;IACnB,GAAG,EAAE,GAAG,CAAC;IACT,KAAK,EAAE,IAAI,EAAE,CAAC;IACd,SAAS,EAAE,SAAS,CAAC;CACtB;;;GAsCA"}
@@ -27,7 +27,7 @@ async function handleHashTasks(payload) {
27
27
  storedProjectGraph = projectGraph;
28
28
  storedHasher = new task_hasher_1.InProcessTaskHasher(projectGraph, nxJson, rustReferences, payload.runnerOptions);
29
29
  }
30
- const response = JSON.stringify(await storedHasher.hashTasks(payload.tasks, payload.taskGraph, payload.env));
30
+ const response = await storedHasher.hashTasks(payload.tasks, payload.taskGraph, payload.env);
31
31
  return {
32
32
  response,
33
33
  description: 'handleHashTasks',
@@ -6,7 +6,7 @@ const workspace_root_1 = require("../../utils/workspace-root");
6
6
  async function handleNxWorkspaceFiles(projectRootMap) {
7
7
  const files = await (0, workspace_context_1.getNxWorkspaceFilesFromContext)(workspace_root_1.workspaceRoot, projectRootMap);
8
8
  return {
9
- response: JSON.stringify(files),
9
+ response: files,
10
10
  description: 'handleNxWorkspaceFiles',
11
11
  };
12
12
  }
@@ -22,7 +22,7 @@ async function handleOutputsHashesMatch(payload) {
22
22
  try {
23
23
  const res = await (0, outputs_tracking_1.outputsHashesMatch)(payload.data.outputs, payload.data.hash);
24
24
  return {
25
- response: JSON.stringify(res),
25
+ response: res,
26
26
  description: 'outputsHashesMatch',
27
27
  };
28
28
  }
@@ -4,11 +4,11 @@ export declare function handleRecordTaskRuns(taskRuns: TaskRun[]): Promise<{
4
4
  description: string;
5
5
  }>;
6
6
  export declare function handleGetFlakyTasks(hashes: string[]): Promise<{
7
- response: string;
7
+ response: string[];
8
8
  description: string;
9
9
  }>;
10
10
  export declare function handleGetEstimatedTaskTimings(targets: TaskTarget[]): Promise<{
11
- response: string;
11
+ response: Record<string, number>;
12
12
  description: string;
13
13
  }>;
14
14
  //# sourceMappingURL=handle-task-history.d.ts.map
@@ -16,7 +16,7 @@ async function handleGetFlakyTasks(hashes) {
16
16
  const taskHistory = (0, task_history_1.getTaskHistory)();
17
17
  const history = await taskHistory.getFlakyTasks(hashes);
18
18
  return {
19
- response: JSON.stringify(history),
19
+ response: history,
20
20
  description: 'handleGetFlakyTasks',
21
21
  };
22
22
  }
@@ -24,7 +24,7 @@ async function handleGetEstimatedTaskTimings(targets) {
24
24
  const taskHistory = (0, task_history_1.getTaskHistory)();
25
25
  const history = await taskHistory.getEstimatedTaskTimings(targets);
26
26
  return {
27
- response: JSON.stringify(history),
27
+ response: history,
28
28
  description: 'handleGetEstimatedTaskTimings',
29
29
  };
30
30
  }
@@ -1,6 +1,6 @@
1
1
  import type { PostTasksExecutionContext, PreTasksExecutionContext } from '../../project-graph/plugins/public-api';
2
2
  export declare function handleRunPreTasksExecution(context: PreTasksExecutionContext): Promise<{
3
- response: string;
3
+ response: NodeJS.ProcessEnv[];
4
4
  description: string;
5
5
  error?: undefined;
6
6
  } | {
@@ -7,7 +7,7 @@ async function handleRunPreTasksExecution(context) {
7
7
  try {
8
8
  const envs = await (0, tasks_execution_hooks_1.runPreTasksExecution)(context);
9
9
  return {
10
- response: JSON.stringify(envs),
10
+ response: envs,
11
11
  description: 'handleRunPreTasksExecution',
12
12
  };
13
13
  }
@@ -1 +1 @@
1
- {"version":3,"file":"project-graph-incremental-recomputation.d.ts","sourceRoot":"","sources":["../../../../../../packages/nx/src/daemon/server/project-graph-incremental-recomputation.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,QAAQ,EACR,OAAO,EACP,YAAY,EAEb,MAAM,4BAA4B,CAAC;AAKpC,OAAO,EACL,YAAY,EAIb,MAAM,mCAAmC,CAAC;AAc3C,OAAO,EAAE,yBAAyB,EAAE,MAAM,cAAc,CAAC;AACzD,OAAO,EAEL,uBAAuB,EACxB,MAAM,uDAAuD,CAAC;AAS/D,UAAU,sBAAsB;IAC9B,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,YAAY,EAAE,YAAY,GAAG,IAAI,CAAC;IAClC,mBAAmB,EAAE,YAAY,GAAG,IAAI,CAAC;IACzC,OAAO,EAAE,OAAO,GAAG,IAAI,CAAC;IACxB,iBAAiB,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC;IACrC,sBAAsB,EAAE,MAAM,GAAG,IAAI,CAAC;IACtC,oBAAoB,EAAE,MAAM,GAAG,IAAI,CAAC;IACpC,UAAU,EAAE,uBAAuB,GAAG,IAAI,CAAC;IAC3C,cAAc,EAAE,yBAAyB,GAAG,IAAI,CAAC;CAClD;AAGD,eAAO,IAAI,gBAAgB,EACvB;IACE,OAAO,EAAE,OAAO,CAAC;IACjB,iBAAiB,EAAE,QAAQ,EAAE,CAAC;IAC9B,cAAc,EAAE,yBAAyB,CAAC;CAC3C,GACD,SAAS,CAAC;AACd,eAAO,IAAI,0BAA0B,EAAE,YAAY,GAAG,SAAS,CAAC;AAChE,eAAO,IAAI,mBAAmB,EAAE,YAAY,GAAG,SAAS,CAAC;AAYzD,wBAAsB,sCAAsC,IAAI,OAAO,CAAC,sBAAsB,CAAC,CAwD9F;AAED,wBAAgB,yBAAyB,CACvC,YAAY,EAAE,MAAM,EAAE,EACtB,YAAY,EAAE,MAAM,EAAE,EACtB,YAAY,EAAE,MAAM,EAAE,QAuCvB;AAED,wBAAgB,yCAAyC,CACvD,QAAQ,EAAE,CACR,YAAY,EAAE,YAAY,EAC1B,UAAU,EAAE,uBAAuB,KAChC,IAAI,QAGV"}
1
+ {"version":3,"file":"project-graph-incremental-recomputation.d.ts","sourceRoot":"","sources":["../../../../../../packages/nx/src/daemon/server/project-graph-incremental-recomputation.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,QAAQ,EACR,OAAO,EACP,YAAY,EAEb,MAAM,4BAA4B,CAAC;AAKpC,OAAO,EACL,YAAY,EAIb,MAAM,mCAAmC,CAAC;AAc3C,OAAO,EAAE,yBAAyB,EAAE,MAAM,cAAc,CAAC;AACzD,OAAO,EAEL,uBAAuB,EACxB,MAAM,uDAAuD,CAAC;AAS/D,UAAU,sBAAsB;IAC9B,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,YAAY,EAAE,YAAY,GAAG,IAAI,CAAC;IAClC,mBAAmB,EAAE,YAAY,GAAG,IAAI,CAAC;IACzC,OAAO,EAAE,OAAO,GAAG,IAAI,CAAC;IACxB,iBAAiB,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC;IACrC,sBAAsB,EAAE,MAAM,GAAG,IAAI,CAAC;IACtC,oBAAoB,EAAE,MAAM,GAAG,IAAI,CAAC;IACpC,UAAU,EAAE,uBAAuB,GAAG,IAAI,CAAC;IAC3C,cAAc,EAAE,yBAAyB,GAAG,IAAI,CAAC;CAClD;AAGD,eAAO,IAAI,gBAAgB,EACvB;IACE,OAAO,EAAE,OAAO,CAAC;IACjB,iBAAiB,EAAE,QAAQ,EAAE,CAAC;IAC9B,cAAc,EAAE,yBAAyB,CAAC;CAC3C,GACD,SAAS,CAAC;AACd,eAAO,IAAI,0BAA0B,EAAE,YAAY,GAAG,SAAS,CAAC;AAChE,eAAO,IAAI,mBAAmB,EAAE,YAAY,GAAG,SAAS,CAAC;AAYzD,wBAAsB,sCAAsC,IAAI,OAAO,CAAC,sBAAsB,CAAC,CA+E9F;AAED,wBAAgB,yBAAyB,CACvC,YAAY,EAAE,MAAM,EAAE,EACtB,YAAY,EAAE,MAAM,EAAE,EACtB,YAAY,EAAE,MAAM,EAAE,QAuCvB;AAED,wBAAgB,yCAAyC,CACvD,QAAQ,EAAE,CACR,YAAY,EAAE,YAAY,EAC1B,UAAU,EAAE,uBAAuB,KAChC,IAAI,QAGV"}
@@ -59,6 +59,20 @@ async function getCachedSerializedProjectGraphPromise() {
59
59
  if (wasScheduled) {
60
60
  notifyProjectGraphRecomputationListeners(result.projectGraph, result.sourceMaps);
61
61
  }
62
+ const errors = result.error
63
+ ? result.error instanceof error_types_1.DaemonProjectGraphError
64
+ ? result.error.errors
65
+ : [result.error]
66
+ : [];
67
+ // Always write the daemon's current graph to disk to ensure disk cache
68
+ // stays in sync with the daemon's in-memory cache. This prevents issues
69
+ // where a non-daemon process writes a stale/errored cache that never
70
+ // gets overwritten by the daemon's valid graph.
71
+ if (result.projectGraph &&
72
+ result.projectFileMapCache &&
73
+ result.sourceMaps) {
74
+ (0, nx_deps_cache_1.writeCache)(result.projectFileMapCache, result.projectGraph, result.sourceMaps, errors);
75
+ }
62
76
  return result;
63
77
  }
64
78
  catch (e) {
@@ -197,7 +211,6 @@ async function processFilesAndCreateAndSerializeProjectGraph(plugins) {
197
211
  };
198
212
  }
199
213
  }
200
- (0, nx_deps_cache_1.writeCache)(g.projectFileMapCache, g.projectGraph, projectConfigurationsResult.sourceMaps, errors);
201
214
  if (errors.length > 0) {
202
215
  return {
203
216
  error: new error_types_1.DaemonProjectGraphError(errors, g.projectGraph, projectConfigurationsResult.sourceMaps),
@@ -1 +1 @@
1
- {"version":3,"file":"project-graph-listener-sockets.d.ts","sourceRoot":"","sources":["../../../../../../packages/nx/src/daemon/server/project-graph-listener-sockets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,KAAK,CAAC;AAC7B,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EAAE,uBAAuB,EAAE,MAAM,uDAAuD,CAAC;AAGhG,eAAO,IAAI,qCAAqC,EAAE,MAAM,EAAO,CAAC;AAEhE,wBAAgB,0CAA0C,CAAC,MAAM,EAAE,MAAM,QAGxE;AAED,wBAAgB,wCAAwC,YAEvD;AAED,wBAAsB,iCAAiC,CACrD,YAAY,EAAE,YAAY,EAC1B,UAAU,EAAE,uBAAuB,iBAgBpC"}
1
+ {"version":3,"file":"project-graph-listener-sockets.d.ts","sourceRoot":"","sources":["../../../../../../packages/nx/src/daemon/server/project-graph-listener-sockets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,KAAK,CAAC;AAC7B,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EAAE,uBAAuB,EAAE,MAAM,uDAAuD,CAAC;AAIhG,eAAO,IAAI,qCAAqC,EAAE,MAAM,EAAO,CAAC;AAEhE,wBAAgB,0CAA0C,CAAC,MAAM,EAAE,MAAM,QAGxE;AAED,wBAAgB,wCAAwC,YAEvD;AAED,wBAAsB,iCAAiC,CACrD,YAAY,EAAE,YAAY,EAC1B,UAAU,EAAE,uBAAuB,iBAoBpC"}
@@ -5,6 +5,7 @@ exports.removeRegisteredProjectGraphListenerSocket = removeRegisteredProjectGrap
5
5
  exports.hasRegisteredProjectGraphListenerSockets = hasRegisteredProjectGraphListenerSockets;
6
6
  exports.notifyProjectGraphListenerSockets = notifyProjectGraphListenerSockets;
7
7
  const server_1 = require("./server");
8
+ const is_v8_serializer_enabled_1 = require("../is-v8-serializer-enabled");
8
9
  exports.registeredProjectGraphListenerSockets = [];
9
10
  function removeRegisteredProjectGraphListenerSocket(socket) {
10
11
  exports.registeredProjectGraphListenerSockets =
@@ -19,6 +20,6 @@ async function notifyProjectGraphListenerSockets(projectGraph, sourceMaps) {
19
20
  }
20
21
  await Promise.all(exports.registeredProjectGraphListenerSockets.map((socket) => (0, server_1.handleResult)(socket, 'PROJECT_GRAPH_UPDATED', () => Promise.resolve({
21
22
  description: 'Project graph updated',
22
- response: JSON.stringify({ projectGraph, sourceMaps }),
23
- }))));
23
+ response: { projectGraph, sourceMaps },
24
+ }), (0, is_v8_serializer_enabled_1.isV8SerializerEnabled)() ? 'v8' : 'json')));
24
25
  }
@@ -2,9 +2,9 @@ import { Server, Socket } from 'net';
2
2
  export type HandlerResult = {
3
3
  description: string;
4
4
  error?: any;
5
- response?: string;
5
+ response?: string | object | boolean;
6
6
  };
7
7
  export declare const openSockets: Set<Socket>;
8
- export declare function handleResult(socket: Socket, type: string, hrFn: () => Promise<HandlerResult>): Promise<void>;
8
+ export declare function handleResult(socket: Socket, type: string, hrFn: () => Promise<HandlerResult>, mode: 'json' | 'v8'): Promise<void>;
9
9
  export declare function startServer(): Promise<Server>;
10
10
  //# sourceMappingURL=server.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../../../../../packages/nx/src/daemon/server/server.ts"],"names":[],"mappings":"AACA,OAAO,EAAgB,MAAM,EAAE,MAAM,EAAE,MAAM,KAAK,CAAC;AAkJnD,MAAM,MAAM,aAAa,GAAG;IAC1B,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,GAAG,CAAC;IACZ,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB,CAAC;AAGF,eAAO,MAAM,WAAW,EAAE,GAAG,CAAC,MAAM,CAAa,CAAC;AAyLlD,wBAAsB,YAAY,CAChC,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,OAAO,CAAC,aAAa,CAAC,iBAqBnC;AAoMD,wBAAsB,WAAW,IAAI,OAAO,CAAC,MAAM,CAAC,CAgEnD"}
1
+ {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../../../../../packages/nx/src/daemon/server/server.ts"],"names":[],"mappings":"AACA,OAAO,EAAgB,MAAM,EAAE,MAAM,EAAE,MAAM,KAAK,CAAC;AAsJnD,MAAM,MAAM,aAAa,GAAG;IAC1B,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,GAAG,CAAC;IACZ,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC;CACtC,CAAC;AAGF,eAAO,MAAM,WAAW,EAAE,GAAG,CAAC,MAAM,CAAa,CAAC;AA2QlD,wBAAsB,YAAY,CAChC,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,OAAO,CAAC,aAAa,CAAC,EAClC,IAAI,EAAE,MAAM,GAAG,IAAI,iBAyBpB;AAoMD,wBAAsB,WAAW,IAAI,OAAO,CAAC,MAAM,CAAC,CAgEnD"}