@teambit/merge-lanes 0.0.38 → 0.0.39

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.
@@ -0,0 +1,28 @@
1
+ import { Command, CommandOptions } from '@teambit/cli';
2
+ import { MergeLanesMain } from './merge-lanes.main.runtime';
3
+ /**
4
+ * private command. the underscore prefix is intended.
5
+ */
6
+ export declare class MergeLaneFromScopeCmd implements Command {
7
+ private mergeLanes;
8
+ name: string;
9
+ description: string;
10
+ extendedDescription: string;
11
+ arguments: {
12
+ name: string;
13
+ description: string;
14
+ }[];
15
+ alias: string;
16
+ options: CommandOptions;
17
+ loader: boolean;
18
+ private: boolean;
19
+ migration: boolean;
20
+ remoteOp: boolean;
21
+ constructor(mergeLanes: MergeLanesMain);
22
+ report([name, pattern]: [string, string], { push, keepReadme, noSquash, includeDeps, }: {
23
+ push?: boolean;
24
+ keepReadme?: boolean;
25
+ noSquash: boolean;
26
+ includeDeps?: boolean;
27
+ }): Promise<string>;
28
+ }
@@ -0,0 +1,106 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ require("core-js/modules/es.array.iterator.js");
6
+
7
+ require("core-js/modules/es.promise.js");
8
+
9
+ Object.defineProperty(exports, "__esModule", {
10
+ value: true
11
+ });
12
+ exports.MergeLaneFromScopeCmd = void 0;
13
+
14
+ function _defineProperty2() {
15
+ const data = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
16
+
17
+ _defineProperty2 = function () {
18
+ return data;
19
+ };
20
+
21
+ return data;
22
+ }
23
+
24
+ function _chalk() {
25
+ const data = _interopRequireDefault(require("chalk"));
26
+
27
+ _chalk = function () {
28
+ return data;
29
+ };
30
+
31
+ return data;
32
+ }
33
+
34
+ function _bitError() {
35
+ const data = require("@teambit/bit-error");
36
+
37
+ _bitError = function () {
38
+ return data;
39
+ };
40
+
41
+ return data;
42
+ }
43
+
44
+ /**
45
+ * private command. the underscore prefix is intended.
46
+ */
47
+ class MergeLaneFromScopeCmd {
48
+ constructor(mergeLanes) {
49
+ this.mergeLanes = mergeLanes;
50
+ (0, _defineProperty2().default)(this, "name", '_merge-lane <lane> [pattern]');
51
+ (0, _defineProperty2().default)(this, "description", `merge a remote lane into main via a bare-scope (not workspace)`);
52
+ (0, _defineProperty2().default)(this, "extendedDescription", `to merge from a workspace, use "bit lane merge" command.
53
+ this is intended to use from the UI, which will have a button to merge an existing lane into main.
54
+ the lane must be up-to-date with main, otherwise, conflicts might occur which are not handled in this command`);
55
+ (0, _defineProperty2().default)(this, "arguments", [{
56
+ name: 'lane',
57
+ description: 'lane-id to merge to main'
58
+ }, {
59
+ name: 'pattern',
60
+ description: 'EXPERIMENTAL. partially merge the lane with the specified component-pattern'
61
+ }]);
62
+ (0, _defineProperty2().default)(this, "alias", '');
63
+ (0, _defineProperty2().default)(this, "options", [['', 'push', 'export the updated objects to the original scopes once done'], ['', 'keep-readme', 'skip deleting the lane readme component after merging'], ['', 'no-squash', 'EXPERIMENTAL. relevant for merging lanes into main, which by default squash.'], // ['', 'verbose', 'show details of components that were not merged legitimately'],
64
+ ['', 'include-deps', 'EXPERIMENTAL. relevant for "--pattern". merge also dependencies of the given components']]);
65
+ (0, _defineProperty2().default)(this, "loader", true);
66
+ (0, _defineProperty2().default)(this, "private", true);
67
+ (0, _defineProperty2().default)(this, "migration", true);
68
+ (0, _defineProperty2().default)(this, "remoteOp", true);
69
+ }
70
+
71
+ async report([name, pattern], {
72
+ push = false,
73
+ keepReadme = false,
74
+ noSquash = false,
75
+ includeDeps = false
76
+ }) {
77
+ if (includeDeps && !pattern) {
78
+ throw new (_bitError().BitError)(`"--include-deps" flag is relevant only for --pattern flag`);
79
+ }
80
+
81
+ const {
82
+ mergedNow,
83
+ mergedPreviously
84
+ } = await this.mergeLanes.mergeFromScope(name, {
85
+ push,
86
+ keepReadme,
87
+ noSquash,
88
+ pattern,
89
+ includeDeps
90
+ });
91
+
92
+ const mergedTitle = _chalk().default.green(`successfully merged ${mergedNow.length} components from ${name} to main`);
93
+
94
+ const mergedOutput = mergedNow.length ? `${mergedTitle}\n${mergedNow.join('\n')}` : '';
95
+
96
+ const nonMergedTitle = _chalk().default.bold(`the following ${mergedPreviously.length} components were already merged before, they were left intact`);
97
+
98
+ const nonMergedOutput = mergedPreviously.length ? `${nonMergedTitle}\n${mergedPreviously.join('\n')}` : '';
99
+ return `${mergedOutput}\n${nonMergedOutput}`;
100
+ }
101
+
102
+ }
103
+
104
+ exports.MergeLaneFromScopeCmd = MergeLaneFromScopeCmd;
105
+
106
+ //# sourceMappingURL=merge-lane-from-scope.cmd.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["MergeLaneFromScopeCmd","constructor","mergeLanes","name","description","report","pattern","push","keepReadme","noSquash","includeDeps","BitError","mergedNow","mergedPreviously","mergeFromScope","mergedTitle","chalk","green","length","mergedOutput","join","nonMergedTitle","bold","nonMergedOutput"],"sources":["merge-lane-from-scope.cmd.ts"],"sourcesContent":["import chalk from 'chalk';\nimport { Command, CommandOptions } from '@teambit/cli';\nimport { BitError } from '@teambit/bit-error';\nimport { MergeLanesMain } from './merge-lanes.main.runtime';\n\n/**\n * private command. the underscore prefix is intended.\n */\nexport class MergeLaneFromScopeCmd implements Command {\n name = '_merge-lane <lane> [pattern]';\n description = `merge a remote lane into main via a bare-scope (not workspace)`;\n extendedDescription = `to merge from a workspace, use \"bit lane merge\" command.\nthis is intended to use from the UI, which will have a button to merge an existing lane into main.\nthe lane must be up-to-date with main, otherwise, conflicts might occur which are not handled in this command`;\n arguments = [\n {\n name: 'lane',\n description: 'lane-id to merge to main',\n },\n {\n name: 'pattern',\n description: 'EXPERIMENTAL. partially merge the lane with the specified component-pattern',\n },\n ];\n alias = '';\n options = [\n ['', 'push', 'export the updated objects to the original scopes once done'],\n ['', 'keep-readme', 'skip deleting the lane readme component after merging'],\n ['', 'no-squash', 'EXPERIMENTAL. relevant for merging lanes into main, which by default squash.'],\n // ['', 'verbose', 'show details of components that were not merged legitimately'],\n ['', 'include-deps', 'EXPERIMENTAL. relevant for \"--pattern\". merge also dependencies of the given components'],\n ] as CommandOptions;\n loader = true;\n private = true;\n migration = true;\n remoteOp = true;\n\n constructor(private mergeLanes: MergeLanesMain) {}\n\n async report(\n [name, pattern]: [string, string],\n {\n push = false,\n keepReadme = false,\n noSquash = false,\n includeDeps = false,\n }: // verbose = false,\n {\n push?: boolean;\n keepReadme?: boolean;\n noSquash: boolean;\n includeDeps?: boolean;\n // verbose?: boolean;\n }\n ): Promise<string> {\n if (includeDeps && !pattern) {\n throw new BitError(`\"--include-deps\" flag is relevant only for --pattern flag`);\n }\n const { mergedNow, mergedPreviously } = await this.mergeLanes.mergeFromScope(name, {\n push,\n keepReadme,\n noSquash,\n pattern,\n includeDeps,\n });\n\n const mergedTitle = chalk.green(`successfully merged ${mergedNow.length} components from ${name} to main`);\n const mergedOutput = mergedNow.length ? `${mergedTitle}\\n${mergedNow.join('\\n')}` : '';\n\n const nonMergedTitle = chalk.bold(\n `the following ${mergedPreviously.length} components were already merged before, they were left intact`\n );\n const nonMergedOutput = mergedPreviously.length ? `${nonMergedTitle}\\n${mergedPreviously.join('\\n')}` : '';\n\n return `${mergedOutput}\\n${nonMergedOutput}`;\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAAA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AAEA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AAGA;AACA;AACA;AACO,MAAMA,qBAAN,CAA+C;EA6BpDC,WAAW,CAASC,UAAT,EAAqC;IAAA,KAA5BA,UAA4B,GAA5BA,UAA4B;IAAA,8CA5BzC,8BA4ByC;IAAA,qDA3BjC,gEA2BiC;IAAA,6DA1BzB;AACzB;AACA,8GAwBkD;IAAA,mDAvBpC,CACV;MACEC,IAAI,EAAE,MADR;MAEEC,WAAW,EAAE;IAFf,CADU,EAKV;MACED,IAAI,EAAE,SADR;MAEEC,WAAW,EAAE;IAFf,CALU,CAuBoC;IAAA,+CAbxC,EAawC;IAAA,iDAZtC,CACR,CAAC,EAAD,EAAK,MAAL,EAAa,6DAAb,CADQ,EAER,CAAC,EAAD,EAAK,aAAL,EAAoB,uDAApB,CAFQ,EAGR,CAAC,EAAD,EAAK,WAAL,EAAkB,8EAAlB,CAHQ,EAIR;IACA,CAAC,EAAD,EAAK,cAAL,EAAqB,yFAArB,CALQ,CAYsC;IAAA,gDALvC,IAKuC;IAAA,iDAJtC,IAIsC;IAAA,mDAHpC,IAGoC;IAAA,kDAFrC,IAEqC;EAAE;;EAEtC,MAANC,MAAM,CACV,CAACF,IAAD,EAAOG,OAAP,CADU,EAEV;IACEC,IAAI,GAAG,KADT;IAEEC,UAAU,GAAG,KAFf;IAGEC,QAAQ,GAAG,KAHb;IAIEC,WAAW,GAAG;EAJhB,CAFU,EAeO;IACjB,IAAIA,WAAW,IAAI,CAACJ,OAApB,EAA6B;MAC3B,MAAM,KAAIK,oBAAJ,EAAc,2DAAd,CAAN;IACD;;IACD,MAAM;MAAEC,SAAF;MAAaC;IAAb,IAAkC,MAAM,KAAKX,UAAL,CAAgBY,cAAhB,CAA+BX,IAA/B,EAAqC;MACjFI,IADiF;MAEjFC,UAFiF;MAGjFC,QAHiF;MAIjFH,OAJiF;MAKjFI;IALiF,CAArC,CAA9C;;IAQA,MAAMK,WAAW,GAAGC,gBAAA,CAAMC,KAAN,CAAa,uBAAsBL,SAAS,CAACM,MAAO,oBAAmBf,IAAK,UAA5E,CAApB;;IACA,MAAMgB,YAAY,GAAGP,SAAS,CAACM,MAAV,GAAoB,GAAEH,WAAY,KAAIH,SAAS,CAACQ,IAAV,CAAe,IAAf,CAAqB,EAA3D,GAA+D,EAApF;;IAEA,MAAMC,cAAc,GAAGL,gBAAA,CAAMM,IAAN,CACpB,iBAAgBT,gBAAgB,CAACK,MAAO,+DADpB,CAAvB;;IAGA,MAAMK,eAAe,GAAGV,gBAAgB,CAACK,MAAjB,GAA2B,GAAEG,cAAe,KAAIR,gBAAgB,CAACO,IAAjB,CAAsB,IAAtB,CAA4B,EAA5E,GAAgF,EAAxG;IAEA,OAAQ,GAAED,YAAa,KAAII,eAAgB,EAA3C;EACD;;AAnEmD"}
@@ -3,8 +3,10 @@ import { LanesMain } from '@teambit/lanes';
3
3
  import { MergingMain } from '@teambit/merging';
4
4
  import { Workspace } from '@teambit/workspace';
5
5
  import { MergeStrategy, ApplyVersionResults } from '@teambit/legacy/dist/consumer/versions-ops/merge-version';
6
+ import { ScopeMain } from '@teambit/scope';
6
7
  import { Logger, LoggerMain } from '@teambit/logger';
7
8
  import { RemoveMain } from '@teambit/remove';
9
+ import { ExportMain } from '@teambit/export';
8
10
  export declare type MergeLaneOptions = {
9
11
  mergeStrategy: MergeStrategy;
10
12
  noSnap: boolean;
@@ -27,21 +29,31 @@ export declare class MergeLanesMain {
27
29
  private lanes;
28
30
  private logger;
29
31
  private remove;
30
- constructor(workspace: Workspace | undefined, merging: MergingMain, lanes: LanesMain, logger: Logger, remove: RemoveMain);
32
+ private scope;
33
+ private exporter;
34
+ constructor(workspace: Workspace | undefined, merging: MergingMain, lanes: LanesMain, logger: Logger, remove: RemoveMain, scope: ScopeMain, exporter: ExportMain);
31
35
  mergeLane(laneName: string, options: MergeLaneOptions): Promise<{
32
36
  mergeResults: ApplyVersionResults;
33
37
  deleteResults: any;
34
38
  }>;
39
+ mergeFromScope(laneName: string, options: Partial<MergeLaneOptions> & {
40
+ push?: boolean;
41
+ }): Promise<{
42
+ mergedPreviously: string[];
43
+ mergedNow: string[];
44
+ }>;
35
45
  static slots: never[];
36
46
  static dependencies: import("@teambit/harmony").Aspect[];
37
47
  static runtime: import("@teambit/harmony").RuntimeDefinition;
38
- static provider([lanes, cli, workspace, merging, loggerMain, remove]: [
48
+ static provider([lanes, cli, workspace, merging, loggerMain, remove, scope, exporter]: [
39
49
  LanesMain,
40
50
  CLIMain,
41
51
  Workspace,
42
52
  MergingMain,
43
53
  LoggerMain,
44
- RemoveMain
54
+ RemoveMain,
55
+ ScopeMain,
56
+ ExportMain
45
57
  ]): Promise<MergeLanesMain>;
46
58
  }
47
59
  export default MergeLanesMain;
@@ -2,8 +2,12 @@
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
4
 
5
+ require("core-js/modules/es.array.flat.js");
6
+
5
7
  require("core-js/modules/es.array.iterator.js");
6
8
 
9
+ require("core-js/modules/es.array.unscopables.flat.js");
10
+
7
11
  require("core-js/modules/es.promise.js");
8
12
 
9
13
  Object.defineProperty(exports, "__esModule", {
@@ -101,6 +105,26 @@ function _bitId() {
101
105
  return data;
102
106
  }
103
107
 
108
+ function _scope() {
109
+ const data = require("@teambit/scope");
110
+
111
+ _scope = function () {
112
+ return data;
113
+ };
114
+
115
+ return data;
116
+ }
117
+
118
+ function _scopeComponentsImporter() {
119
+ const data = _interopRequireDefault(require("@teambit/legacy/dist/scope/component-ops/scope-components-importer"));
120
+
121
+ _scopeComponentsImporter = function () {
122
+ return data;
123
+ };
124
+
125
+ return data;
126
+ }
127
+
104
128
  function _laneId() {
105
129
  const data = require("@teambit/lane-id");
106
130
 
@@ -141,6 +165,36 @@ function _remove() {
141
165
  return data;
142
166
  }
143
167
 
168
+ function _lodash() {
169
+ const data = require("lodash");
170
+
171
+ _lodash = function () {
172
+ return data;
173
+ };
174
+
175
+ return data;
176
+ }
177
+
178
+ function _export() {
179
+ const data = require("@teambit/export");
180
+
181
+ _export = function () {
182
+ return data;
183
+ };
184
+
185
+ return data;
186
+ }
187
+
188
+ function _getDivergeData() {
189
+ const data = require("@teambit/legacy/dist/scope/component-ops/get-diverge-data");
190
+
191
+ _getDivergeData = function () {
192
+ return data;
193
+ };
194
+
195
+ return data;
196
+ }
197
+
144
198
  function _mergeLanes() {
145
199
  const data = require("./merge-lanes.aspect");
146
200
 
@@ -161,13 +215,25 @@ function _mergeLane() {
161
215
  return data;
162
216
  }
163
217
 
218
+ function _mergeLaneFromScope() {
219
+ const data = require("./merge-lane-from-scope.cmd");
220
+
221
+ _mergeLaneFromScope = function () {
222
+ return data;
223
+ };
224
+
225
+ return data;
226
+ }
227
+
164
228
  class MergeLanesMain {
165
- constructor(workspace, merging, lanes, logger, remove) {
229
+ constructor(workspace, merging, lanes, logger, remove, scope, exporter) {
166
230
  this.workspace = workspace;
167
231
  this.merging = merging;
168
232
  this.lanes = lanes;
169
233
  this.logger = logger;
170
234
  this.remove = remove;
235
+ this.scope = scope;
236
+ this.exporter = exporter;
171
237
  }
172
238
 
173
239
  async mergeLane(laneName, options) {
@@ -339,13 +405,83 @@ class MergeLanesMain {
339
405
  }
340
406
  }
341
407
 
342
- static async provider([lanes, cli, workspace, merging, loggerMain, remove]) {
408
+ async mergeFromScope(laneName, options) {
409
+ if (this.workspace) throw new (_bitError().BitError)(`unable to run this command from a workspace, please create a new bare-scope and run it from there`);
410
+
411
+ const laneId = _laneId().LaneId.parse(laneName);
412
+
413
+ const lane = await this.lanes.importLaneObject(laneId);
414
+ const laneIds = lane.toBitIds();
415
+
416
+ const scopeComponentsImporter = _scopeComponentsImporter().default.getInstance(this.scope.legacyScope);
417
+
418
+ await scopeComponentsImporter.importManyDeltaWithoutDeps(laneIds, true, lane, true); // get their main as well
419
+
420
+ await scopeComponentsImporter.importManyDeltaWithoutDeps(laneIds.toVersionLatest(), true, undefined, true);
421
+ const repo = this.scope.legacyScope.objects; // loop through all components, make sure they're all ahead of main (it might not be on main yet).
422
+ // then, change the version object to include an extra parent to point to the main.
423
+ // then, change the component object head to point to this changed version
424
+
425
+ const mergedPreviously = [];
426
+ const mergedNow = [];
427
+ const bitObjectsPerComp = await (0, _pMapSeries().default)(laneIds, async id => {
428
+ const modelComponent = await this.scope.legacyScope.getModelComponent(id);
429
+ const versionObj = await modelComponent.loadVersion(id.version, repo);
430
+ const laneHead = modelComponent.getRef(id.version);
431
+ if (!laneHead) throw new Error(`lane head must be defined for ${id.toString()}`);
432
+ const mainHead = modelComponent.head || null;
433
+
434
+ if (mainHead !== null && mainHead !== void 0 && mainHead.isEqual(laneHead)) {
435
+ mergedPreviously.push(id);
436
+ return undefined;
437
+ }
438
+
439
+ const divergeData = await (0, _getDivergeData().getDivergeData)(repo, modelComponent, laneHead, mainHead);
440
+ const modifiedVersion = squashOneComp(_laneId().DEFAULT_LANE, laneId, id, divergeData, versionObj);
441
+ modelComponent.setHead(laneHead);
442
+ const objects = [modelComponent, modifiedVersion];
443
+ mergedNow.push(id);
444
+ return {
445
+ id,
446
+ objects
447
+ };
448
+ });
449
+ const bitObjects = (0, _lodash().compact)(bitObjectsPerComp).map(b => b.objects);
450
+ await repo.writeObjectsToTheFS(bitObjects.flat());
451
+
452
+ if (options.push) {
453
+ const scopeRemotes = await this.scope._legacyRemotes();
454
+ const grouped = (0, _lodash().compact)(bitObjectsPerComp).reduce((acc, current) => {
455
+ const scopeName = current.id.scope;
456
+ if (!scopeName) throw new Error(`${current.id.toString()} has no scope-name`);
457
+ (acc[scopeName] || (acc[scopeName] = [])).push(...current.objects);
458
+ return acc;
459
+ }, {});
460
+ const manyObjectsPerRemote = await Promise.all(Object.keys(grouped).map(async scopeName => {
461
+ const remote = await scopeRemotes.resolve(scopeName, this.scope.legacyScope);
462
+ const objectList = await _export().ObjectList.fromBitObjects(grouped[scopeName]);
463
+ return {
464
+ remote,
465
+ objectList
466
+ };
467
+ }));
468
+ await this.exporter.exportObjectList(manyObjectsPerRemote, scopeRemotes);
469
+ }
470
+
471
+ return {
472
+ mergedPreviously: mergedPreviously.map(id => id.toString()),
473
+ mergedNow: mergedNow.map(id => id.toString())
474
+ };
475
+ }
476
+
477
+ static async provider([lanes, cli, workspace, merging, loggerMain, remove, scope, exporter]) {
343
478
  var _lanesCommand$command;
344
479
 
345
480
  const logger = loggerMain.createLogger(_mergeLanes().MergeLanesAspect.id);
346
481
  const lanesCommand = cli.getCommand('lane');
347
- const mergeLanesMain = new MergeLanesMain(workspace, merging, lanes, logger, remove);
482
+ const mergeLanesMain = new MergeLanesMain(workspace, merging, lanes, logger, remove, scope, exporter);
348
483
  lanesCommand === null || lanesCommand === void 0 ? void 0 : (_lanesCommand$command = lanesCommand.commands) === null || _lanesCommand$command === void 0 ? void 0 : _lanesCommand$command.push(new (_mergeLane().MergeLaneCmd)(mergeLanesMain));
484
+ cli.register(new (_mergeLaneFromScope().MergeLaneFromScopeCmd)(mergeLanesMain));
349
485
  return mergeLanesMain;
350
486
  }
351
487
 
@@ -353,7 +489,7 @@ class MergeLanesMain {
353
489
 
354
490
  exports.MergeLanesMain = MergeLanesMain;
355
491
  (0, _defineProperty2().default)(MergeLanesMain, "slots", []);
356
- (0, _defineProperty2().default)(MergeLanesMain, "dependencies", [_lanes().LanesAspect, _cli().CLIAspect, _workspace().default, _merging().default, _logger().LoggerAspect, _remove().RemoveAspect]);
492
+ (0, _defineProperty2().default)(MergeLanesMain, "dependencies", [_lanes().LanesAspect, _cli().CLIAspect, _workspace().default, _merging().default, _logger().LoggerAspect, _remove().RemoveAspect, _scope().ScopeAspect, _export().ExportAspect]);
357
493
  (0, _defineProperty2().default)(MergeLanesMain, "runtime", _cli().MainRuntime);
358
494
 
359
495
  async function filterComponentsStatus(allComponentsStatus, compIdsToKeep, allBitIds, workspace, includeDeps = false, lane) {
@@ -452,52 +588,63 @@ function squashSnaps(allComponentsStatus, otherLaneId, consumer) {
452
588
  throw new Error(`unable to squash. divergeData is missing from ${id.toString()}`);
453
589
  }
454
590
 
455
- if (divergeData.isDiverged()) {
456
- throw new (_bitError().BitError)(`unable to squash because ${id.toString()} is diverged in history.
591
+ const modifiedComp = squashOneComp(currentLaneName, otherLaneId, id, divergeData, componentFromModel);
592
+ if (modifiedComp) consumer.scope.objects.add(modifiedComp);
593
+ });
594
+ }
595
+ /**
596
+ * returns Version object if it was modified. otherwise, returns undefined
597
+ */
598
+
599
+
600
+ function squashOneComp(currentLaneName, otherLaneId, id, divergeData, componentFromModel) {
601
+ if (divergeData.isDiverged()) {
602
+ throw new (_bitError().BitError)(`unable to squash because ${id.toString()} is diverged in history.
457
603
  consider switching to "${otherLaneId.name}" first, merging "${currentLaneName}", then switching back to "${currentLaneName}" and merging "${otherLaneId.name}"
458
604
  alternatively, use "--no-squash" flag to keep the entire history of "${otherLaneId.name}"`);
459
- }
605
+ }
460
606
 
461
- if (divergeData.isLocalAhead()) {
462
- // nothing to do. current is ahead, nothing to merge. (it was probably filtered out already as a "failedComponent")
463
- return;
464
- }
607
+ if (divergeData.isLocalAhead()) {
608
+ // nothing to do. current is ahead, nothing to merge. (it was probably filtered out already as a "failedComponent")
609
+ return undefined;
610
+ }
465
611
 
466
- if (!divergeData.isRemoteAhead()) {
467
- // nothing to do. current and remote are the same, nothing to merge. (it was probably filtered out already as a "failedComponent")
468
- return;
469
- } // remote is ahead and was not diverge.
612
+ if (!divergeData.isRemoteAhead()) {
613
+ // nothing to do. current and remote are the same, nothing to merge. (it was probably filtered out already as a "failedComponent")
614
+ return undefined;
615
+ } // remote is ahead and was not diverge.
470
616
 
471
617
 
472
- const remoteSnaps = divergeData.snapsOnRemoteOnly;
618
+ const remoteSnaps = divergeData.snapsOnRemoteOnly;
473
619
 
474
- if (remoteSnaps.length === 0) {
475
- throw new Error(`remote is ahead but it has no snaps. it's impossible`);
476
- } // if (remoteSnaps.length === 1) {
477
- // // nothing to squash. it has only one commit.
478
- // return;
479
- // }
620
+ if (remoteSnaps.length === 0) {
621
+ throw new Error(`remote is ahead but it has no snaps. it's impossible`);
622
+ } // no need to check this case. even if it has only one snap ahead, we want to do the "squash", and run "addAsOnlyParent"
623
+ // to make sure it doesn't not have two parents.
624
+ // if (remoteSnaps.length === 1) {
625
+ // // nothing to squash. it has only one commit.
626
+ // return;
627
+ // }
480
628
 
481
629
 
482
- if (!componentFromModel) {
483
- throw new Error('unable to squash, the componentFromModel is missing');
484
- }
630
+ if (!componentFromModel) {
631
+ throw new Error('unable to squash, the componentFromModel is missing');
632
+ }
485
633
 
486
- const currentParents = componentFromModel.parents; // do the squash.
634
+ const currentParents = componentFromModel.parents; // do the squash.
487
635
 
488
- if (divergeData.commonSnapBeforeDiverge) {
489
- componentFromModel.addAsOnlyParent(divergeData.commonSnapBeforeDiverge);
490
- } else {
491
- // there is no commonSnapBeforeDiverge. the local has no snaps, all are remote, no need for parents. keep only head.
492
- componentFromModel.parents.forEach(ref => componentFromModel.removeParent(ref));
493
- }
636
+ if (divergeData.commonSnapBeforeDiverge) {
637
+ componentFromModel.addAsOnlyParent(divergeData.commonSnapBeforeDiverge);
638
+ } else {
639
+ // there is no commonSnapBeforeDiverge. the local has no snaps, all are remote, no need for parents. keep only head.
640
+ componentFromModel.parents.forEach(ref => componentFromModel.removeParent(ref));
641
+ }
494
642
 
495
- componentFromModel.setSquashed({
496
- previousParents: currentParents,
497
- laneId: otherLaneId
498
- });
499
- consumer.scope.objects.add(componentFromModel);
643
+ componentFromModel.setSquashed({
644
+ previousParents: currentParents,
645
+ laneId: otherLaneId
500
646
  });
647
+ return componentFromModel;
501
648
  }
502
649
 
503
650
  _mergeLanes().MergeLanesAspect.addRuntime(MergeLanesMain);
@@ -1 +1 @@
1
- {"version":3,"names":["MergeLanesMain","constructor","workspace","merging","lanes","logger","remove","mergeLane","laneName","options","BitError","consumer","mergeStrategy","noSnap","tag","snapMessage","existingOnWorkspaceOnly","build","keepReadme","noSquash","pattern","includeDeps","skipDependencyInstallation","resolveUnrelated","ignoreConfigChanges","remote","currentLaneId","getCurrentLaneId","isDefault","toString","otherLaneId","getParsedLaneId","isEqual","currentLane","scope","loadLane","isDefaultLane","getOtherLane","undefined","lane","fetchLaneWithItsComponents","otherLane","getBitIds","Error","DEFAULT_LANE","getDefaultLaneIdsFromLane","toBitIds","bitIds","debug","otherLaneName","getAllComponentsStatus","tmp","Tmp","componentsStatus","Promise","all","map","bitId","getComponentMergeStatus","clear","err","allComponentsStatus","componentIds","resolveMultipleComponentIds","compIdsFromPattern","filterIdsFromPoolIdsByPattern","filterComponentsStatus","forEach","find","c","id","isEqualWithoutVersion","push","unmergedLegitimately","unmergedMessage","workspaceIds","listIds","filter","_legacy","throwForFailures","squashSnaps","mergeResults","mergeSnaps","laneId","localLane","mergedSuccessfully","failedComponents","length","every","failedComponent","unchangedLegitimately","deleteResults","readmeComponent","readmeComponentId","changeVersion","head","hash","componentsPattern","force","track","deleteFiles","fromLane","readmeResult","name","onDestroy","failureMsgs","chalk","bold","red","join","provider","cli","loggerMain","createLogger","MergeLanesAspect","lanesCommand","getCommand","mergeLanesMain","commands","MergeLaneCmd","LanesAspect","CLIAspect","WorkspaceAspect","MergingAspect","LoggerAspect","RemoveAspect","MainRuntime","compIdsToKeep","allBitIds","bitIdsFromPattern","BitIds","fromArray","bitIdsNotFromPattern","hasWithoutVersion","filteredComponentStatus","depsToAdd","pMapSeries","compId","fromStatus","divergeData","remoteVersions","snapsOnRemoteOnly","modelComponent","getModelComponent","remoteVersion","versionObj","loadVersion","objects","flattenedDeps","getAllFlattenedDependencies","depsNotIncludeInPattern","depsOnLane","dep","isOnLane","isIdOnLane","d","depsUniq","uniqFromArray","currentLaneName","succeededComponents","componentFromModel","isDiverged","isLocalAhead","isRemoteAhead","remoteSnaps","currentParents","parents","commonSnapBeforeDiverge","addAsOnlyParent","ref","removeParent","setSquashed","previousParents","add","addRuntime"],"sources":["merge-lanes.main.runtime.ts"],"sourcesContent":["import { BitError } from '@teambit/bit-error';\nimport { CLIAspect, CLIMain, MainRuntime } from '@teambit/cli';\nimport { LanesAspect, LanesMain } from '@teambit/lanes';\nimport MergingAspect, { MergingMain, ComponentMergeStatus } from '@teambit/merging';\nimport WorkspaceAspect, { Workspace } from '@teambit/workspace';\nimport chalk from 'chalk';\nimport { BitId } from '@teambit/legacy-bit-id';\nimport pMapSeries from 'p-map-series';\nimport { Consumer } from '@teambit/legacy/dist/consumer';\nimport { MergeStrategy, ApplyVersionResults } from '@teambit/legacy/dist/consumer/versions-ops/merge-version';\nimport { BitIds } from '@teambit/legacy/dist/bit-id';\nimport { ComponentID } from '@teambit/component-id';\nimport { DEFAULT_LANE, LaneId } from '@teambit/lane-id';\nimport { Lane } from '@teambit/legacy/dist/scope/models';\nimport { Tmp } from '@teambit/legacy/dist/scope/repositories';\nimport { Logger, LoggerAspect, LoggerMain } from '@teambit/logger';\nimport { RemoveAspect, RemoveMain } from '@teambit/remove';\nimport { MergeLanesAspect } from './merge-lanes.aspect';\nimport { MergeLaneCmd } from './merge-lane.cmd';\n\nexport type MergeLaneOptions = {\n mergeStrategy: MergeStrategy;\n noSnap: boolean;\n snapMessage: string;\n existingOnWorkspaceOnly: boolean;\n build: boolean;\n keepReadme: boolean;\n noSquash: boolean;\n tag?: boolean;\n pattern?: string;\n includeDeps?: boolean;\n skipDependencyInstallation?: boolean;\n resolveUnrelated?: MergeStrategy;\n ignoreConfigChanges?: boolean;\n remote?: boolean;\n};\n\nexport class MergeLanesMain {\n constructor(\n private workspace: Workspace | undefined,\n private merging: MergingMain,\n private lanes: LanesMain,\n private logger: Logger,\n private remove: RemoveMain\n ) {}\n\n async mergeLane(\n laneName: string,\n options: MergeLaneOptions\n ): Promise<{ mergeResults: ApplyVersionResults; deleteResults: any }> {\n if (!this.workspace) {\n throw new BitError(`unable to merge a lane outside of Bit workspace`);\n }\n const consumer = this.workspace.consumer;\n\n const {\n mergeStrategy,\n noSnap,\n tag,\n snapMessage,\n existingOnWorkspaceOnly,\n build,\n keepReadme,\n noSquash,\n pattern,\n includeDeps,\n skipDependencyInstallation,\n resolveUnrelated,\n ignoreConfigChanges,\n remote,\n } = options;\n\n const currentLaneId = consumer.getCurrentLaneId();\n if (tag && !currentLaneId.isDefault()) {\n throw new BitError(`--tag only possible when on main. currently checked out to ${currentLaneId.toString()}`);\n }\n const otherLaneId = await consumer.getParsedLaneId(laneName);\n if (otherLaneId.isEqual(currentLaneId)) {\n throw new BitError(\n `unable to merge lane \"${otherLaneId.toString()}\", you're already at this lane. to get updates, simply run \"bit checkout head\"`\n );\n }\n const currentLane = currentLaneId.isDefault() ? null : await consumer.scope.loadLane(currentLaneId);\n const isDefaultLane = otherLaneId.isDefault();\n const getOtherLane = async () => {\n if (isDefaultLane) {\n return undefined;\n }\n const lane = await consumer.scope.loadLane(otherLaneId);\n if (remote || !lane) {\n return this.lanes.fetchLaneWithItsComponents(otherLaneId);\n }\n return lane;\n };\n const otherLane = await getOtherLane();\n const getBitIds = async () => {\n if (isDefaultLane) {\n if (!currentLane) throw new Error(`unable to merge ${DEFAULT_LANE}, the current lane was not found`);\n return consumer.scope.getDefaultLaneIdsFromLane(currentLane);\n }\n if (!otherLane) throw new Error(`lane must be defined for non-default`);\n return otherLane.toBitIds();\n };\n const bitIds = await getBitIds();\n this.logger.debug(`merging the following bitIds: ${bitIds.toString()}`);\n const otherLaneName = isDefaultLane ? DEFAULT_LANE : otherLaneId.toString();\n\n const getAllComponentsStatus = async (): Promise<ComponentMergeStatus[]> => {\n const tmp = new Tmp(consumer.scope);\n try {\n const componentsStatus = await Promise.all(\n bitIds.map((bitId) =>\n this.merging.getComponentMergeStatus(bitId, currentLane, otherLaneName, {\n resolveUnrelated,\n ignoreConfigChanges,\n })\n )\n );\n await tmp.clear();\n return componentsStatus;\n } catch (err: any) {\n await tmp.clear();\n throw err;\n }\n };\n let allComponentsStatus = await getAllComponentsStatus();\n\n if (pattern) {\n const componentIds = await this.workspace.resolveMultipleComponentIds(bitIds);\n const compIdsFromPattern = this.workspace.scope.filterIdsFromPoolIdsByPattern(pattern, componentIds);\n allComponentsStatus = await filterComponentsStatus(\n allComponentsStatus,\n compIdsFromPattern,\n bitIds,\n this.workspace,\n includeDeps,\n otherLane || undefined\n );\n bitIds.forEach((bitId) => {\n if (!allComponentsStatus.find((c) => c.id.isEqualWithoutVersion(bitId))) {\n allComponentsStatus.push({ id: bitId, unmergedLegitimately: true, unmergedMessage: `excluded by pattern` });\n }\n });\n }\n if (existingOnWorkspaceOnly) {\n const workspaceIds = await this.workspace.listIds();\n const compIdsFromPattern = workspaceIds.filter((id) =>\n allComponentsStatus.find((c) => c.id.isEqualWithoutVersion(id._legacy))\n );\n allComponentsStatus = await filterComponentsStatus(\n allComponentsStatus,\n compIdsFromPattern,\n bitIds,\n this.workspace,\n includeDeps\n );\n bitIds.forEach((bitId) => {\n if (!allComponentsStatus.find((c) => c.id.isEqualWithoutVersion(bitId))) {\n allComponentsStatus.push({ id: bitId, unmergedLegitimately: true, unmergedMessage: `not in the workspace` });\n }\n });\n }\n\n throwForFailures();\n\n if (currentLaneId.isDefault() && !noSquash) {\n squashSnaps(allComponentsStatus, otherLaneId, consumer);\n }\n\n const mergeResults = await this.merging.mergeSnaps({\n mergeStrategy,\n allComponentsStatus,\n laneId: otherLaneId,\n localLane: currentLane,\n noSnap,\n tag,\n snapMessage,\n build,\n skipDependencyInstallation,\n });\n\n const mergedSuccessfully =\n !mergeResults.failedComponents ||\n mergeResults.failedComponents.length === 0 ||\n mergeResults.failedComponents.every((failedComponent) => failedComponent.unchangedLegitimately);\n\n let deleteResults = {};\n\n if (!keepReadme && otherLane && otherLane.readmeComponent && mergedSuccessfully) {\n const readmeComponentId = otherLane.readmeComponent.id\n .changeVersion(otherLane.readmeComponent?.head?.hash)\n .toString();\n\n deleteResults = await this.remove.remove({\n componentsPattern: readmeComponentId,\n force: false,\n remote: false,\n track: false,\n deleteFiles: true,\n fromLane: false,\n });\n } else if (otherLane && !otherLane.readmeComponent) {\n deleteResults = { readmeResult: `\\nlane ${otherLane.name} doesn't have a readme component` };\n }\n\n await this.workspace.consumer.onDestroy();\n\n return { mergeResults, deleteResults };\n\n function throwForFailures() {\n const failedComponents = allComponentsStatus.filter((c) => c.unmergedMessage && !c.unmergedLegitimately);\n if (failedComponents.length) {\n const failureMsgs = failedComponents\n .map(\n (failedComponent) =>\n `${chalk.bold(failedComponent.id.toString())} - ${chalk.red(failedComponent.unmergedMessage as string)}`\n )\n .join('\\n');\n throw new BitError(`unable to merge due to the following failures:\\n${failureMsgs}`);\n }\n }\n }\n\n static slots = [];\n static dependencies = [LanesAspect, CLIAspect, WorkspaceAspect, MergingAspect, LoggerAspect, RemoveAspect];\n static runtime = MainRuntime;\n\n static async provider([lanes, cli, workspace, merging, loggerMain, remove]: [\n LanesMain,\n CLIMain,\n Workspace,\n MergingMain,\n LoggerMain,\n RemoveMain\n ]) {\n const logger = loggerMain.createLogger(MergeLanesAspect.id);\n const lanesCommand = cli.getCommand('lane');\n const mergeLanesMain = new MergeLanesMain(workspace, merging, lanes, logger, remove);\n lanesCommand?.commands?.push(new MergeLaneCmd(mergeLanesMain));\n return mergeLanesMain;\n }\n}\n\nasync function filterComponentsStatus(\n allComponentsStatus: ComponentMergeStatus[],\n compIdsToKeep: ComponentID[],\n allBitIds: BitId[],\n workspace: Workspace,\n includeDeps = false,\n lane?: Lane\n): Promise<ComponentMergeStatus[]> {\n const bitIdsFromPattern = BitIds.fromArray(compIdsToKeep.map((c) => c._legacy));\n const bitIdsNotFromPattern = allBitIds.filter((bitId) => !bitIdsFromPattern.hasWithoutVersion(bitId));\n const filteredComponentStatus: ComponentMergeStatus[] = [];\n const depsToAdd: BitId[] = [];\n await pMapSeries(compIdsToKeep, async (compId) => {\n const fromStatus = allComponentsStatus.find((c) => c.id.isEqualWithoutVersion(compId._legacy));\n if (!fromStatus) {\n throw new Error(`filterComponentsStatus: unable to find ${compId.toString()} in component-status`);\n }\n filteredComponentStatus.push(fromStatus);\n if (fromStatus.unmergedMessage) {\n return;\n }\n const { divergeData } = fromStatus;\n if (!divergeData) {\n throw new Error(`filterComponentsStatus: unable to find divergeData for ${compId.toString()}`);\n }\n const remoteVersions = divergeData.snapsOnRemoteOnly;\n if (!remoteVersions.length) {\n return;\n }\n const modelComponent = await workspace.consumer.scope.getModelComponent(compId._legacy);\n // optimization suggestion: if squash is given, check only the last version.\n await pMapSeries(remoteVersions, async (remoteVersion) => {\n const versionObj = await modelComponent.loadVersion(remoteVersion.toString(), workspace.consumer.scope.objects);\n const flattenedDeps = versionObj.getAllFlattenedDependencies();\n const depsNotIncludeInPattern = flattenedDeps.filter((id) =>\n bitIdsNotFromPattern.find((bitId) => bitId.isEqualWithoutVersion(id))\n );\n if (!depsNotIncludeInPattern.length) {\n return;\n }\n const depsOnLane: BitId[] = [];\n await Promise.all(\n depsNotIncludeInPattern.map(async (dep) => {\n const isOnLane = await workspace.consumer.scope.isIdOnLane(dep, lane);\n if (isOnLane) {\n depsOnLane.push(dep);\n }\n })\n );\n if (!depsOnLane.length) {\n return;\n }\n if (!includeDeps) {\n throw new BitError(`unable to merge ${compId.toString()}.\nit has (in version ${remoteVersion.toString()}) the following dependencies which were not included in the pattern. consider adding \"--include-deps\" flag\n${depsOnLane.map((d) => d.toString()).join('\\n')}`);\n }\n depsToAdd.push(...depsOnLane);\n });\n });\n if (depsToAdd.length) {\n const depsUniq = BitIds.uniqFromArray(depsToAdd);\n depsUniq.forEach((id) => {\n const fromStatus = allComponentsStatus.find((c) => c.id.isEqualWithoutVersion(id));\n if (!fromStatus) {\n throw new Error(`filterComponentsStatus: unable to find ${id.toString()} in component-status`);\n }\n filteredComponentStatus.push(fromStatus);\n });\n }\n return filteredComponentStatus;\n}\n\nfunction squashSnaps(allComponentsStatus: ComponentMergeStatus[], otherLaneId: LaneId, consumer: Consumer) {\n const currentLaneName = consumer.getCurrentLaneId().name;\n const succeededComponents = allComponentsStatus.filter((c) => !c.unmergedMessage);\n succeededComponents.forEach(({ id, divergeData, componentFromModel }) => {\n if (!divergeData) {\n throw new Error(`unable to squash. divergeData is missing from ${id.toString()}`);\n }\n if (divergeData.isDiverged()) {\n throw new BitError(`unable to squash because ${id.toString()} is diverged in history.\nconsider switching to \"${\n otherLaneId.name\n }\" first, merging \"${currentLaneName}\", then switching back to \"${currentLaneName}\" and merging \"${\n otherLaneId.name\n }\"\nalternatively, use \"--no-squash\" flag to keep the entire history of \"${otherLaneId.name}\"`);\n }\n if (divergeData.isLocalAhead()) {\n // nothing to do. current is ahead, nothing to merge. (it was probably filtered out already as a \"failedComponent\")\n return;\n }\n if (!divergeData.isRemoteAhead()) {\n // nothing to do. current and remote are the same, nothing to merge. (it was probably filtered out already as a \"failedComponent\")\n return;\n }\n // remote is ahead and was not diverge.\n const remoteSnaps = divergeData.snapsOnRemoteOnly;\n if (remoteSnaps.length === 0) {\n throw new Error(`remote is ahead but it has no snaps. it's impossible`);\n }\n // if (remoteSnaps.length === 1) {\n // // nothing to squash. it has only one commit.\n // return;\n // }\n if (!componentFromModel) {\n throw new Error('unable to squash, the componentFromModel is missing');\n }\n\n const currentParents = componentFromModel.parents;\n\n // do the squash.\n if (divergeData.commonSnapBeforeDiverge) {\n componentFromModel.addAsOnlyParent(divergeData.commonSnapBeforeDiverge);\n } else {\n // there is no commonSnapBeforeDiverge. the local has no snaps, all are remote, no need for parents. keep only head.\n componentFromModel.parents.forEach((ref) => componentFromModel.removeParent(ref));\n }\n componentFromModel.setSquashed({ previousParents: currentParents, laneId: otherLaneId });\n consumer.scope.objects.add(componentFromModel);\n });\n}\n\nMergeLanesAspect.addRuntime(MergeLanesMain);\n\nexport default MergeLanesMain;\n"],"mappings":"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"}
1
+ {"version":3,"names":["MergeLanesMain","constructor","workspace","merging","lanes","logger","remove","scope","exporter","mergeLane","laneName","options","BitError","consumer","mergeStrategy","noSnap","tag","snapMessage","existingOnWorkspaceOnly","build","keepReadme","noSquash","pattern","includeDeps","skipDependencyInstallation","resolveUnrelated","ignoreConfigChanges","remote","currentLaneId","getCurrentLaneId","isDefault","toString","otherLaneId","getParsedLaneId","isEqual","currentLane","loadLane","isDefaultLane","getOtherLane","undefined","lane","fetchLaneWithItsComponents","otherLane","getBitIds","Error","DEFAULT_LANE","getDefaultLaneIdsFromLane","toBitIds","bitIds","debug","otherLaneName","getAllComponentsStatus","tmp","Tmp","componentsStatus","Promise","all","map","bitId","getComponentMergeStatus","clear","err","allComponentsStatus","componentIds","resolveMultipleComponentIds","compIdsFromPattern","filterIdsFromPoolIdsByPattern","filterComponentsStatus","forEach","find","c","id","isEqualWithoutVersion","push","unmergedLegitimately","unmergedMessage","workspaceIds","listIds","filter","_legacy","throwForFailures","squashSnaps","mergeResults","mergeSnaps","laneId","localLane","mergedSuccessfully","failedComponents","length","every","failedComponent","unchangedLegitimately","deleteResults","readmeComponent","readmeComponentId","changeVersion","head","hash","componentsPattern","force","track","deleteFiles","fromLane","readmeResult","name","onDestroy","failureMsgs","chalk","bold","red","join","mergeFromScope","LaneId","parse","importLaneObject","laneIds","scopeComponentsImporter","ScopeComponentsImporter","getInstance","legacyScope","importManyDeltaWithoutDeps","toVersionLatest","repo","objects","mergedPreviously","mergedNow","bitObjectsPerComp","pMapSeries","modelComponent","getModelComponent","versionObj","loadVersion","version","laneHead","getRef","mainHead","divergeData","getDivergeData","modifiedVersion","squashOneComp","setHead","bitObjects","compact","b","writeObjectsToTheFS","flat","scopeRemotes","_legacyRemotes","grouped","reduce","acc","current","scopeName","manyObjectsPerRemote","Object","keys","resolve","objectList","ObjectList","fromBitObjects","exportObjectList","provider","cli","loggerMain","createLogger","MergeLanesAspect","lanesCommand","getCommand","mergeLanesMain","commands","MergeLaneCmd","register","MergeLaneFromScopeCmd","LanesAspect","CLIAspect","WorkspaceAspect","MergingAspect","LoggerAspect","RemoveAspect","ScopeAspect","ExportAspect","MainRuntime","compIdsToKeep","allBitIds","bitIdsFromPattern","BitIds","fromArray","bitIdsNotFromPattern","hasWithoutVersion","filteredComponentStatus","depsToAdd","compId","fromStatus","remoteVersions","snapsOnRemoteOnly","remoteVersion","flattenedDeps","getAllFlattenedDependencies","depsNotIncludeInPattern","depsOnLane","dep","isOnLane","isIdOnLane","d","depsUniq","uniqFromArray","currentLaneName","succeededComponents","componentFromModel","modifiedComp","add","isDiverged","isLocalAhead","isRemoteAhead","remoteSnaps","currentParents","parents","commonSnapBeforeDiverge","addAsOnlyParent","ref","removeParent","setSquashed","previousParents","addRuntime"],"sources":["merge-lanes.main.runtime.ts"],"sourcesContent":["import { BitError } from '@teambit/bit-error';\nimport { CLIAspect, CLIMain, MainRuntime } from '@teambit/cli';\nimport { LanesAspect, LanesMain } from '@teambit/lanes';\nimport MergingAspect, { MergingMain, ComponentMergeStatus } from '@teambit/merging';\nimport WorkspaceAspect, { Workspace } from '@teambit/workspace';\nimport chalk from 'chalk';\nimport { BitId } from '@teambit/legacy-bit-id';\nimport pMapSeries from 'p-map-series';\nimport { Consumer } from '@teambit/legacy/dist/consumer';\nimport { MergeStrategy, ApplyVersionResults } from '@teambit/legacy/dist/consumer/versions-ops/merge-version';\nimport { BitIds } from '@teambit/legacy/dist/bit-id';\nimport { ScopeAspect, ScopeMain } from '@teambit/scope';\nimport ScopeComponentsImporter from '@teambit/legacy/dist/scope/component-ops/scope-components-importer';\nimport { ComponentID } from '@teambit/component-id';\nimport { DEFAULT_LANE, LaneId } from '@teambit/lane-id';\nimport { Lane, Version } from '@teambit/legacy/dist/scope/models';\nimport { Tmp } from '@teambit/legacy/dist/scope/repositories';\nimport { Logger, LoggerAspect, LoggerMain } from '@teambit/logger';\nimport { DivergeData } from '@teambit/legacy/dist/scope/component-ops/diverge-data';\nimport { RemoveAspect, RemoveMain } from '@teambit/remove';\nimport { compact } from 'lodash';\nimport { ExportAspect, ExportMain, ObjectList } from '@teambit/export';\nimport { BitObject } from '@teambit/legacy/dist/scope/objects';\nimport { getDivergeData } from '@teambit/legacy/dist/scope/component-ops/get-diverge-data';\nimport { MergeLanesAspect } from './merge-lanes.aspect';\nimport { MergeLaneCmd } from './merge-lane.cmd';\nimport { MergeLaneFromScopeCmd } from './merge-lane-from-scope.cmd';\n\nexport type MergeLaneOptions = {\n mergeStrategy: MergeStrategy;\n noSnap: boolean;\n snapMessage: string;\n existingOnWorkspaceOnly: boolean;\n build: boolean;\n keepReadme: boolean;\n noSquash: boolean;\n tag?: boolean;\n pattern?: string;\n includeDeps?: boolean;\n skipDependencyInstallation?: boolean;\n resolveUnrelated?: MergeStrategy;\n ignoreConfigChanges?: boolean;\n remote?: boolean;\n};\n\nexport class MergeLanesMain {\n constructor(\n private workspace: Workspace | undefined,\n private merging: MergingMain,\n private lanes: LanesMain,\n private logger: Logger,\n private remove: RemoveMain,\n private scope: ScopeMain,\n private exporter: ExportMain\n ) {}\n\n async mergeLane(\n laneName: string,\n options: MergeLaneOptions\n ): Promise<{ mergeResults: ApplyVersionResults; deleteResults: any }> {\n if (!this.workspace) {\n throw new BitError(`unable to merge a lane outside of Bit workspace`);\n }\n const consumer = this.workspace.consumer;\n\n const {\n mergeStrategy,\n noSnap,\n tag,\n snapMessage,\n existingOnWorkspaceOnly,\n build,\n keepReadme,\n noSquash,\n pattern,\n includeDeps,\n skipDependencyInstallation,\n resolveUnrelated,\n ignoreConfigChanges,\n remote,\n } = options;\n\n const currentLaneId = consumer.getCurrentLaneId();\n if (tag && !currentLaneId.isDefault()) {\n throw new BitError(`--tag only possible when on main. currently checked out to ${currentLaneId.toString()}`);\n }\n const otherLaneId = await consumer.getParsedLaneId(laneName);\n if (otherLaneId.isEqual(currentLaneId)) {\n throw new BitError(\n `unable to merge lane \"${otherLaneId.toString()}\", you're already at this lane. to get updates, simply run \"bit checkout head\"`\n );\n }\n const currentLane = currentLaneId.isDefault() ? null : await consumer.scope.loadLane(currentLaneId);\n const isDefaultLane = otherLaneId.isDefault();\n const getOtherLane = async () => {\n if (isDefaultLane) {\n return undefined;\n }\n const lane = await consumer.scope.loadLane(otherLaneId);\n if (remote || !lane) {\n return this.lanes.fetchLaneWithItsComponents(otherLaneId);\n }\n return lane;\n };\n const otherLane = await getOtherLane();\n const getBitIds = async () => {\n if (isDefaultLane) {\n if (!currentLane) throw new Error(`unable to merge ${DEFAULT_LANE}, the current lane was not found`);\n return consumer.scope.getDefaultLaneIdsFromLane(currentLane);\n }\n if (!otherLane) throw new Error(`lane must be defined for non-default`);\n return otherLane.toBitIds();\n };\n const bitIds = await getBitIds();\n this.logger.debug(`merging the following bitIds: ${bitIds.toString()}`);\n const otherLaneName = isDefaultLane ? DEFAULT_LANE : otherLaneId.toString();\n\n const getAllComponentsStatus = async (): Promise<ComponentMergeStatus[]> => {\n const tmp = new Tmp(consumer.scope);\n try {\n const componentsStatus = await Promise.all(\n bitIds.map((bitId) =>\n this.merging.getComponentMergeStatus(bitId, currentLane, otherLaneName, {\n resolveUnrelated,\n ignoreConfigChanges,\n })\n )\n );\n await tmp.clear();\n return componentsStatus;\n } catch (err: any) {\n await tmp.clear();\n throw err;\n }\n };\n let allComponentsStatus = await getAllComponentsStatus();\n\n if (pattern) {\n const componentIds = await this.workspace.resolveMultipleComponentIds(bitIds);\n const compIdsFromPattern = this.workspace.scope.filterIdsFromPoolIdsByPattern(pattern, componentIds);\n allComponentsStatus = await filterComponentsStatus(\n allComponentsStatus,\n compIdsFromPattern,\n bitIds,\n this.workspace,\n includeDeps,\n otherLane || undefined\n );\n bitIds.forEach((bitId) => {\n if (!allComponentsStatus.find((c) => c.id.isEqualWithoutVersion(bitId))) {\n allComponentsStatus.push({ id: bitId, unmergedLegitimately: true, unmergedMessage: `excluded by pattern` });\n }\n });\n }\n if (existingOnWorkspaceOnly) {\n const workspaceIds = await this.workspace.listIds();\n const compIdsFromPattern = workspaceIds.filter((id) =>\n allComponentsStatus.find((c) => c.id.isEqualWithoutVersion(id._legacy))\n );\n allComponentsStatus = await filterComponentsStatus(\n allComponentsStatus,\n compIdsFromPattern,\n bitIds,\n this.workspace,\n includeDeps\n );\n bitIds.forEach((bitId) => {\n if (!allComponentsStatus.find((c) => c.id.isEqualWithoutVersion(bitId))) {\n allComponentsStatus.push({ id: bitId, unmergedLegitimately: true, unmergedMessage: `not in the workspace` });\n }\n });\n }\n\n throwForFailures();\n\n if (currentLaneId.isDefault() && !noSquash) {\n squashSnaps(allComponentsStatus, otherLaneId, consumer);\n }\n\n const mergeResults = await this.merging.mergeSnaps({\n mergeStrategy,\n allComponentsStatus,\n laneId: otherLaneId,\n localLane: currentLane,\n noSnap,\n tag,\n snapMessage,\n build,\n skipDependencyInstallation,\n });\n\n const mergedSuccessfully =\n !mergeResults.failedComponents ||\n mergeResults.failedComponents.length === 0 ||\n mergeResults.failedComponents.every((failedComponent) => failedComponent.unchangedLegitimately);\n\n let deleteResults = {};\n\n if (!keepReadme && otherLane && otherLane.readmeComponent && mergedSuccessfully) {\n const readmeComponentId = otherLane.readmeComponent.id\n .changeVersion(otherLane.readmeComponent?.head?.hash)\n .toString();\n\n deleteResults = await this.remove.remove({\n componentsPattern: readmeComponentId,\n force: false,\n remote: false,\n track: false,\n deleteFiles: true,\n fromLane: false,\n });\n } else if (otherLane && !otherLane.readmeComponent) {\n deleteResults = { readmeResult: `\\nlane ${otherLane.name} doesn't have a readme component` };\n }\n\n await this.workspace.consumer.onDestroy();\n\n return { mergeResults, deleteResults };\n\n function throwForFailures() {\n const failedComponents = allComponentsStatus.filter((c) => c.unmergedMessage && !c.unmergedLegitimately);\n if (failedComponents.length) {\n const failureMsgs = failedComponents\n .map(\n (failedComponent) =>\n `${chalk.bold(failedComponent.id.toString())} - ${chalk.red(failedComponent.unmergedMessage as string)}`\n )\n .join('\\n');\n throw new BitError(`unable to merge due to the following failures:\\n${failureMsgs}`);\n }\n }\n }\n\n async mergeFromScope(\n laneName: string,\n options: Partial<MergeLaneOptions> & { push?: boolean }\n ): Promise<{\n mergedPreviously: string[];\n mergedNow: string[];\n }> {\n if (this.workspace)\n throw new BitError(\n `unable to run this command from a workspace, please create a new bare-scope and run it from there`\n );\n const laneId = LaneId.parse(laneName);\n const lane = await this.lanes.importLaneObject(laneId);\n const laneIds = lane.toBitIds();\n const scopeComponentsImporter = ScopeComponentsImporter.getInstance(this.scope.legacyScope);\n await scopeComponentsImporter.importManyDeltaWithoutDeps(laneIds, true, lane, true);\n // get their main as well\n await scopeComponentsImporter.importManyDeltaWithoutDeps(laneIds.toVersionLatest(), true, undefined, true);\n const repo = this.scope.legacyScope.objects;\n // loop through all components, make sure they're all ahead of main (it might not be on main yet).\n // then, change the version object to include an extra parent to point to the main.\n // then, change the component object head to point to this changed version\n const mergedPreviously: BitId[] = [];\n const mergedNow: BitId[] = [];\n const bitObjectsPerComp = await pMapSeries(laneIds, async (id) => {\n const modelComponent = await this.scope.legacyScope.getModelComponent(id);\n const versionObj = await modelComponent.loadVersion(id.version as string, repo);\n const laneHead = modelComponent.getRef(id.version as string);\n if (!laneHead) throw new Error(`lane head must be defined for ${id.toString()}`);\n const mainHead = modelComponent.head || null;\n if (mainHead?.isEqual(laneHead)) {\n mergedPreviously.push(id);\n return undefined;\n }\n const divergeData = await getDivergeData(repo, modelComponent, laneHead, mainHead);\n const modifiedVersion = squashOneComp(DEFAULT_LANE, laneId, id, divergeData, versionObj);\n modelComponent.setHead(laneHead);\n const objects = [modelComponent, modifiedVersion];\n mergedNow.push(id);\n return { id, objects };\n });\n const bitObjects = compact(bitObjectsPerComp).map((b) => b.objects);\n await repo.writeObjectsToTheFS(bitObjects.flat() as BitObject[]);\n\n if (options.push) {\n const scopeRemotes = await this.scope._legacyRemotes();\n const grouped: { [scopeName: string]: BitObject[] } = compact(bitObjectsPerComp).reduce((acc, current) => {\n const scopeName = current.id.scope;\n if (!scopeName) throw new Error(`${current.id.toString()} has no scope-name`);\n (acc[scopeName] ||= []).push(...current.objects);\n return acc;\n }, {});\n const manyObjectsPerRemote = await Promise.all(\n Object.keys(grouped).map(async (scopeName) => {\n const remote = await scopeRemotes.resolve(scopeName, this.scope.legacyScope);\n const objectList = await ObjectList.fromBitObjects(grouped[scopeName]);\n return { remote, objectList };\n })\n );\n await this.exporter.exportObjectList(manyObjectsPerRemote, scopeRemotes);\n }\n\n return {\n mergedPreviously: mergedPreviously.map((id) => id.toString()),\n mergedNow: mergedNow.map((id) => id.toString()),\n };\n }\n\n static slots = [];\n static dependencies = [\n LanesAspect,\n CLIAspect,\n WorkspaceAspect,\n MergingAspect,\n LoggerAspect,\n RemoveAspect,\n ScopeAspect,\n ExportAspect,\n ];\n static runtime = MainRuntime;\n\n static async provider([lanes, cli, workspace, merging, loggerMain, remove, scope, exporter]: [\n LanesMain,\n CLIMain,\n Workspace,\n MergingMain,\n LoggerMain,\n RemoveMain,\n ScopeMain,\n ExportMain\n ]) {\n const logger = loggerMain.createLogger(MergeLanesAspect.id);\n const lanesCommand = cli.getCommand('lane');\n const mergeLanesMain = new MergeLanesMain(workspace, merging, lanes, logger, remove, scope, exporter);\n lanesCommand?.commands?.push(new MergeLaneCmd(mergeLanesMain));\n cli.register(new MergeLaneFromScopeCmd(mergeLanesMain));\n return mergeLanesMain;\n }\n}\n\nasync function filterComponentsStatus(\n allComponentsStatus: ComponentMergeStatus[],\n compIdsToKeep: ComponentID[],\n allBitIds: BitId[],\n workspace: Workspace,\n includeDeps = false,\n lane?: Lane\n): Promise<ComponentMergeStatus[]> {\n const bitIdsFromPattern = BitIds.fromArray(compIdsToKeep.map((c) => c._legacy));\n const bitIdsNotFromPattern = allBitIds.filter((bitId) => !bitIdsFromPattern.hasWithoutVersion(bitId));\n const filteredComponentStatus: ComponentMergeStatus[] = [];\n const depsToAdd: BitId[] = [];\n await pMapSeries(compIdsToKeep, async (compId) => {\n const fromStatus = allComponentsStatus.find((c) => c.id.isEqualWithoutVersion(compId._legacy));\n if (!fromStatus) {\n throw new Error(`filterComponentsStatus: unable to find ${compId.toString()} in component-status`);\n }\n filteredComponentStatus.push(fromStatus);\n if (fromStatus.unmergedMessage) {\n return;\n }\n const { divergeData } = fromStatus;\n if (!divergeData) {\n throw new Error(`filterComponentsStatus: unable to find divergeData for ${compId.toString()}`);\n }\n const remoteVersions = divergeData.snapsOnRemoteOnly;\n if (!remoteVersions.length) {\n return;\n }\n const modelComponent = await workspace.consumer.scope.getModelComponent(compId._legacy);\n // optimization suggestion: if squash is given, check only the last version.\n await pMapSeries(remoteVersions, async (remoteVersion) => {\n const versionObj = await modelComponent.loadVersion(remoteVersion.toString(), workspace.consumer.scope.objects);\n const flattenedDeps = versionObj.getAllFlattenedDependencies();\n const depsNotIncludeInPattern = flattenedDeps.filter((id) =>\n bitIdsNotFromPattern.find((bitId) => bitId.isEqualWithoutVersion(id))\n );\n if (!depsNotIncludeInPattern.length) {\n return;\n }\n const depsOnLane: BitId[] = [];\n await Promise.all(\n depsNotIncludeInPattern.map(async (dep) => {\n const isOnLane = await workspace.consumer.scope.isIdOnLane(dep, lane);\n if (isOnLane) {\n depsOnLane.push(dep);\n }\n })\n );\n if (!depsOnLane.length) {\n return;\n }\n if (!includeDeps) {\n throw new BitError(`unable to merge ${compId.toString()}.\nit has (in version ${remoteVersion.toString()}) the following dependencies which were not included in the pattern. consider adding \"--include-deps\" flag\n${depsOnLane.map((d) => d.toString()).join('\\n')}`);\n }\n depsToAdd.push(...depsOnLane);\n });\n });\n if (depsToAdd.length) {\n const depsUniq = BitIds.uniqFromArray(depsToAdd);\n depsUniq.forEach((id) => {\n const fromStatus = allComponentsStatus.find((c) => c.id.isEqualWithoutVersion(id));\n if (!fromStatus) {\n throw new Error(`filterComponentsStatus: unable to find ${id.toString()} in component-status`);\n }\n filteredComponentStatus.push(fromStatus);\n });\n }\n return filteredComponentStatus;\n}\n\nfunction squashSnaps(allComponentsStatus: ComponentMergeStatus[], otherLaneId: LaneId, consumer: Consumer) {\n const currentLaneName = consumer.getCurrentLaneId().name;\n const succeededComponents = allComponentsStatus.filter((c) => !c.unmergedMessage);\n succeededComponents.forEach(({ id, divergeData, componentFromModel }) => {\n if (!divergeData) {\n throw new Error(`unable to squash. divergeData is missing from ${id.toString()}`);\n }\n const modifiedComp = squashOneComp(currentLaneName, otherLaneId, id, divergeData, componentFromModel);\n if (modifiedComp) consumer.scope.objects.add(modifiedComp);\n });\n}\n\n/**\n * returns Version object if it was modified. otherwise, returns undefined\n */\nfunction squashOneComp(\n currentLaneName: string,\n otherLaneId: LaneId,\n id: BitId,\n divergeData: DivergeData,\n componentFromModel?: Version\n): Version | undefined {\n if (divergeData.isDiverged()) {\n throw new BitError(`unable to squash because ${id.toString()} is diverged in history.\nconsider switching to \"${\n otherLaneId.name\n }\" first, merging \"${currentLaneName}\", then switching back to \"${currentLaneName}\" and merging \"${\n otherLaneId.name\n }\"\nalternatively, use \"--no-squash\" flag to keep the entire history of \"${otherLaneId.name}\"`);\n }\n if (divergeData.isLocalAhead()) {\n // nothing to do. current is ahead, nothing to merge. (it was probably filtered out already as a \"failedComponent\")\n return undefined;\n }\n if (!divergeData.isRemoteAhead()) {\n // nothing to do. current and remote are the same, nothing to merge. (it was probably filtered out already as a \"failedComponent\")\n return undefined;\n }\n // remote is ahead and was not diverge.\n const remoteSnaps = divergeData.snapsOnRemoteOnly;\n if (remoteSnaps.length === 0) {\n throw new Error(`remote is ahead but it has no snaps. it's impossible`);\n }\n // no need to check this case. even if it has only one snap ahead, we want to do the \"squash\", and run \"addAsOnlyParent\"\n // to make sure it doesn't not have two parents.\n // if (remoteSnaps.length === 1) {\n // // nothing to squash. it has only one commit.\n // return;\n // }\n if (!componentFromModel) {\n throw new Error('unable to squash, the componentFromModel is missing');\n }\n\n const currentParents = componentFromModel.parents;\n\n // do the squash.\n if (divergeData.commonSnapBeforeDiverge) {\n componentFromModel.addAsOnlyParent(divergeData.commonSnapBeforeDiverge);\n } else {\n // there is no commonSnapBeforeDiverge. the local has no snaps, all are remote, no need for parents. keep only head.\n componentFromModel.parents.forEach((ref) => componentFromModel.removeParent(ref));\n }\n componentFromModel.setSquashed({ previousParents: currentParents, laneId: otherLaneId });\n return componentFromModel;\n}\n\nMergeLanesAspect.addRuntime(MergeLanesMain);\n\nexport default MergeLanesMain;\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,31 +1,35 @@
1
1
  {
2
2
  "name": "@teambit/merge-lanes",
3
- "version": "0.0.38",
3
+ "version": "0.0.39",
4
4
  "homepage": "https://bit.dev/teambit/lanes/merge-lanes",
5
5
  "main": "dist/index.js",
6
6
  "componentId": {
7
7
  "scope": "teambit.lanes",
8
8
  "name": "merge-lanes",
9
- "version": "0.0.38"
9
+ "version": "0.0.39"
10
10
  },
11
11
  "dependencies": {
12
12
  "chalk": "2.4.2",
13
+ "lodash": "4.17.21",
13
14
  "p-map-series": "2.1.0",
14
15
  "@babel/runtime": "7.12.18",
15
16
  "core-js": "^3.0.0",
16
17
  "@teambit/harmony": "0.3.3",
17
18
  "@teambit/bit-error": "0.0.400",
18
- "@teambit/cli": "0.0.572",
19
- "@teambit/merging": "0.0.176",
19
+ "@teambit/cli": "0.0.573",
20
+ "@teambit/merging": "0.0.177",
20
21
  "@teambit/component-id": "0.0.417",
21
- "@teambit/lane-id": "0.0.90",
22
- "@teambit/lanes": "0.0.433",
22
+ "@teambit/export": "0.0.862",
23
+ "@teambit/lane-id": "0.0.91",
24
+ "@teambit/lanes": "0.0.434",
23
25
  "@teambit/legacy-bit-id": "0.0.414",
24
- "@teambit/logger": "0.0.665",
25
- "@teambit/remove": "0.0.38",
26
- "@teambit/workspace": "0.0.861"
26
+ "@teambit/logger": "0.0.666",
27
+ "@teambit/remove": "0.0.39",
28
+ "@teambit/scope": "0.0.862",
29
+ "@teambit/workspace": "0.0.862"
27
30
  },
28
31
  "devDependencies": {
32
+ "@types/lodash": "4.14.165",
29
33
  "@types/mocha": "9.1.0",
30
34
  "@types/testing-library__jest-dom": "5.9.5",
31
35
  "@types/jest": "^26.0.0",
@@ -34,7 +38,7 @@
34
38
  "@types/node": "12.20.4"
35
39
  },
36
40
  "peerDependencies": {
37
- "@teambit/legacy": "1.0.352",
41
+ "@teambit/legacy": "1.0.354",
38
42
  "react-dom": "^16.8.0 || ^17.0.0",
39
43
  "react": "^16.8.0 || ^17.0.0"
40
44
  },