UNPKG

12.7 kBJavaScriptView Raw
1"use strict";
2/**
3 * @license
4 * Copyright Google LLC All Rights Reserved.
5 *
6 * Use of this source code is governed by an MIT-style license that can be
7 * found in the LICENSE file at https://angular.io/license
8 */
9Object.defineProperty(exports, "__esModule", { value: true });
10exports.scheduleByTarget = exports.scheduleByName = void 0;
11const rxjs_1 = require("rxjs");
12const api_1 = require("./api");
13const jobs_1 = require("./jobs");
14const progressSchema = require('./progress-schema.json');
15let _uniqueId = 0;
16async function scheduleByName(name, buildOptions, options) {
17 const childLoggerName = options.target ? `{${(0, api_1.targetStringFromTarget)(options.target)}}` : name;
18 const logger = options.logger.createChild(childLoggerName);
19 const job = options.scheduler.schedule(name, {});
20 let stateSubscription;
21 const workspaceRoot = await options.workspaceRoot;
22 const currentDirectory = await options.currentDirectory;
23 const description = await (0, rxjs_1.firstValueFrom)(job.description);
24 const info = description.info;
25 const id = ++_uniqueId;
26 const message = {
27 id,
28 currentDirectory,
29 workspaceRoot,
30 info: info,
31 options: buildOptions,
32 ...(options.target ? { target: options.target } : {}),
33 };
34 // Wait for the job to be ready.
35 if (job.state !== jobs_1.JobState.Started) {
36 stateSubscription = job.outboundBus.subscribe({
37 next: (event) => {
38 if (event.kind === jobs_1.JobOutboundMessageKind.Start) {
39 job.input.next(message);
40 }
41 },
42 error: () => { },
43 });
44 }
45 else {
46 job.input.next(message);
47 }
48 const logChannelSub = job.getChannel('log').subscribe({
49 next: (entry) => {
50 logger.next(entry);
51 },
52 error: () => { },
53 });
54 const outboundBusSub = job.outboundBus.subscribe({
55 error() { },
56 complete() {
57 outboundBusSub.unsubscribe();
58 logChannelSub.unsubscribe();
59 stateSubscription.unsubscribe();
60 },
61 });
62 const output = job.output.pipe((0, rxjs_1.map)((output) => ({
63 ...output,
64 ...(options.target ? { target: options.target } : 0),
65 info,
66 })), (0, rxjs_1.shareReplay)());
67 // Start the builder.
68 output.pipe((0, rxjs_1.first)()).subscribe({
69 error: () => { },
70 });
71 return {
72 id,
73 info,
74 // This is a getter so that it always returns the next output, and not the same one.
75 get result() {
76 return (0, rxjs_1.firstValueFrom)(output);
77 },
78 get lastOutput() {
79 return (0, rxjs_1.lastValueFrom)(output);
80 },
81 output,
82 progress: job
83 .getChannel('progress', progressSchema)
84 .pipe((0, rxjs_1.shareReplay)(1)),
85 stop() {
86 job.stop();
87 return job.outboundBus
88 .pipe((0, rxjs_1.ignoreElements)(), (0, rxjs_1.catchError)(() => rxjs_1.EMPTY))
89 .toPromise();
90 },
91 };
92}
93exports.scheduleByName = scheduleByName;
94async function scheduleByTarget(target, overrides, options) {
95 return scheduleByName(`{${(0, api_1.targetStringFromTarget)(target)}}`, overrides, {
96 ...options,
97 target,
98 logger: options.logger,
99 });
100}
101exports.scheduleByTarget = scheduleByTarget;
102//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schedule-by-name.js","sourceRoot":"","sources":["../../../../../../../packages/angular_devkit/architect/src/schedule-by-name.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport { json, logging } from '@angular-devkit/core';\nimport {\n  EMPTY,\n  Subscription,\n  catchError,\n  first,\n  firstValueFrom,\n  ignoreElements,\n  lastValueFrom,\n  map,\n  shareReplay,\n} from 'rxjs';\nimport {\n  BuilderInfo,\n  BuilderInput,\n  BuilderOutput,\n  BuilderProgressReport,\n  BuilderRun,\n  Target,\n  targetStringFromTarget,\n} from './api';\nimport { JobOutboundMessageKind, JobState, Scheduler } from './jobs';\n\nconst progressSchema = require('./progress-schema.json');\n\nlet _uniqueId = 0;\n\nexport async function scheduleByName(\n  name: string,\n  buildOptions: json.JsonObject,\n  options: {\n    target?: Target;\n    scheduler: Scheduler;\n    logger: logging.LoggerApi;\n    workspaceRoot: string | Promise<string>;\n    currentDirectory: string | Promise<string>;\n  },\n): Promise<BuilderRun> {\n  const childLoggerName = options.target ? `{${targetStringFromTarget(options.target)}}` : name;\n  const logger = options.logger.createChild(childLoggerName);\n  const job = options.scheduler.schedule<{}, BuilderInput, BuilderOutput>(name, {});\n  let stateSubscription: Subscription;\n\n  const workspaceRoot = await options.workspaceRoot;\n  const currentDirectory = await options.currentDirectory;\n\n  const description = await firstValueFrom(job.description);\n  const info = description.info as BuilderInfo;\n  const id = ++_uniqueId;\n\n  const message = {\n    id,\n    currentDirectory,\n    workspaceRoot,\n    info: info,\n    options: buildOptions,\n    ...(options.target ? { target: options.target } : {}),\n  };\n\n  // Wait for the job to be ready.\n  if (job.state !== JobState.Started) {\n    stateSubscription = job.outboundBus.subscribe({\n      next: (event) => {\n        if (event.kind === JobOutboundMessageKind.Start) {\n          job.input.next(message);\n        }\n      },\n      error: () => {},\n    });\n  } else {\n    job.input.next(message);\n  }\n\n  const logChannelSub = job.getChannel<logging.LogEntry>('log').subscribe({\n    next: (entry) => {\n      logger.next(entry);\n    },\n    error: () => {},\n  });\n\n  const outboundBusSub = job.outboundBus.subscribe({\n    error() {},\n    complete() {\n      outboundBusSub.unsubscribe();\n      logChannelSub.unsubscribe();\n      stateSubscription.unsubscribe();\n    },\n  });\n  const output = job.output.pipe(\n    map(\n      (output) =>\n        ({\n          ...output,\n          ...(options.target ? { target: options.target } : 0),\n          info,\n        } as unknown as BuilderOutput),\n    ),\n    shareReplay(),\n  );\n\n  // Start the builder.\n  output.pipe(first()).subscribe({\n    error: () => {},\n  });\n\n  return {\n    id,\n    info,\n    // This is a getter so that it always returns the next output, and not the same one.\n    get result() {\n      return firstValueFrom(output);\n    },\n    get lastOutput() {\n      return lastValueFrom(output);\n    },\n    output,\n    progress: job\n      .getChannel<BuilderProgressReport>('progress', progressSchema)\n      .pipe(shareReplay(1)),\n    stop() {\n      job.stop();\n\n      return job.outboundBus\n        .pipe(\n          ignoreElements(),\n          catchError(() => EMPTY),\n        )\n        .toPromise();\n    },\n  };\n}\n\nexport async function scheduleByTarget(\n  target: Target,\n  overrides: json.JsonObject,\n  options: {\n    scheduler: Scheduler;\n    logger: logging.LoggerApi;\n    workspaceRoot: string | Promise<string>;\n    currentDirectory: string | Promise<string>;\n  },\n): Promise<BuilderRun> {\n  return scheduleByName(`{${targetStringFromTarget(target)}}`, overrides, {\n    ...options,\n    target,\n    logger: options.logger,\n  });\n}\n"]}
\No newline at end of file