release-monorepo-semantically 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/Controller.spec.d.ts +2 -0
- package/dist/Controller.spec.d.ts.map +1 -0
- package/dist/Controller.spec.js +39 -0
- package/dist/Controller.spec.js.map +1 -0
- package/dist/MonorepoController.d.ts +21 -0
- package/dist/MonorepoController.d.ts.map +1 -0
- package/dist/MonorepoController.js +75 -0
- package/dist/MonorepoController.js.map +1 -0
- package/dist/main.d.ts +2 -0
- package/dist/main.d.ts.map +1 -0
- package/dist/main.js +29 -0
- package/dist/main.js.map +1 -0
- package/dist/models/ConventionalCommit.d.ts +13 -0
- package/dist/models/ConventionalCommit.d.ts.map +1 -0
- package/dist/models/ConventionalCommit.js +38 -0
- package/dist/models/ConventionalCommit.js.map +1 -0
- package/dist/models/ConventionalCommit.spec.d.ts +2 -0
- package/dist/models/ConventionalCommit.spec.d.ts.map +1 -0
- package/dist/models/ConventionalCommit.spec.js +72 -0
- package/dist/models/ConventionalCommit.spec.js.map +1 -0
- package/dist/models/NpmPackage.d.ts +15 -0
- package/dist/models/NpmPackage.d.ts.map +1 -0
- package/dist/models/NpmPackage.js +26 -0
- package/dist/models/NpmPackage.js.map +1 -0
- package/dist/models/NpmPackage.spec.d.ts +2 -0
- package/dist/models/NpmPackage.spec.d.ts.map +1 -0
- package/dist/models/NpmPackage.spec.js +19 -0
- package/dist/models/NpmPackage.spec.js.map +1 -0
- package/dist/models/PackageJSON.d.ts +9 -0
- package/dist/models/PackageJSON.d.ts.map +1 -0
- package/dist/models/PackageJSON.js +2 -0
- package/dist/models/PackageJSON.js.map +1 -0
- package/dist/models/SemVerBumpType.d.ts +9 -0
- package/dist/models/SemVerBumpType.d.ts.map +1 -0
- package/dist/models/SemVerBumpType.js +33 -0
- package/dist/models/SemVerBumpType.js.map +1 -0
- package/dist/models/SemVerBumpType.spec.d.ts +2 -0
- package/dist/models/SemVerBumpType.spec.d.ts.map +1 -0
- package/dist/models/SemVerBumpType.spec.js +17 -0
- package/dist/models/SemVerBumpType.spec.js.map +1 -0
- package/dist/services/ChangelogRenderer.d.ts +16 -0
- package/dist/services/ChangelogRenderer.d.ts.map +1 -0
- package/dist/services/ChangelogRenderer.js +26 -0
- package/dist/services/ChangelogRenderer.js.map +1 -0
- package/dist/services/ConsoleLogger.d.ts +6 -0
- package/dist/services/ConsoleLogger.d.ts.map +1 -0
- package/dist/services/ConsoleLogger.js +10 -0
- package/dist/services/ConsoleLogger.js.map +1 -0
- package/dist/services/GitService.d.ts +8 -0
- package/dist/services/GitService.d.ts.map +1 -0
- package/dist/services/GitService.js +25 -0
- package/dist/services/GitService.js.map +1 -0
- package/dist/services/HandlebarsRenderService.d.ts +6 -0
- package/dist/services/HandlebarsRenderService.d.ts.map +1 -0
- package/dist/services/HandlebarsRenderService.js +15 -0
- package/dist/services/HandlebarsRenderService.js.map +1 -0
- package/dist/services/NodeFileSystemService.d.ts +9 -0
- package/dist/services/NodeFileSystemService.d.ts.map +1 -0
- package/dist/services/NodeFileSystemService.js +24 -0
- package/dist/services/NodeFileSystemService.js.map +1 -0
- package/dist/services/PackageManager.d.ts +6 -0
- package/dist/services/PackageManager.d.ts.map +1 -0
- package/dist/services/PackageManager.js +15 -0
- package/dist/services/PackageManager.js.map +1 -0
- package/dist/services/PackageManager.spec.d.ts +2 -0
- package/dist/services/PackageManager.spec.d.ts.map +1 -0
- package/dist/services/PackageManager.spec.js +27 -0
- package/dist/services/PackageManager.spec.js.map +1 -0
- package/dist/services/ReleaseCommit.d.ts +9 -0
- package/dist/services/ReleaseCommit.d.ts.map +1 -0
- package/dist/services/ReleaseCommit.js +12 -0
- package/dist/services/ReleaseCommit.js.map +1 -0
- package/dist/sortLessDependenciesFirst.d.ts +6 -0
- package/dist/sortLessDependenciesFirst.d.ts.map +1 -0
- package/dist/sortLessDependenciesFirst.js +32 -0
- package/dist/sortLessDependenciesFirst.js.map +1 -0
- package/package.json +52 -0
- package/templates/changelog.hbs +55 -0
- package/templates/release-commit-msg.hbs +1 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Controller.spec.d.ts","sourceRoot":"","sources":["../src/Controller.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { NpmPackage } from './models/NpmPackage';
|
|
3
|
+
import { sortLessDependenciesFirst } from './sortLessDependenciesFirst';
|
|
4
|
+
function createPkg(name, deps = {}) {
|
|
5
|
+
return new NpmPackage(name, `/${name}`, '1.0.0', false, deps, {});
|
|
6
|
+
}
|
|
7
|
+
describe('sortLessDependenciesFirst', () => {
|
|
8
|
+
it('puts dependencies before dependents (simple pair)', () => {
|
|
9
|
+
// A depends on B => order should be B, A
|
|
10
|
+
const A = createPkg('A', { B: '1.0.0' });
|
|
11
|
+
const B = createPkg('B');
|
|
12
|
+
const result = sortLessDependenciesFirst([A, B]).map((p) => p.name);
|
|
13
|
+
expect(result).toEqual(['B', 'A']);
|
|
14
|
+
});
|
|
15
|
+
it('handles dependency chains (C -> B -> A order)', () => {
|
|
16
|
+
const A = createPkg('A', { B: '1.0.0' });
|
|
17
|
+
const B = createPkg('B', { C: '1.0.0' });
|
|
18
|
+
const C = createPkg('C');
|
|
19
|
+
const result = sortLessDependenciesFirst([A, B, C]).map((p) => p.name);
|
|
20
|
+
expect(result).toEqual(['C', 'B', 'A']);
|
|
21
|
+
});
|
|
22
|
+
it('ignores external dependencies', () => {
|
|
23
|
+
const A = createPkg('A', { react: '18.0.0' });
|
|
24
|
+
const B = createPkg('B');
|
|
25
|
+
const result = sortLessDependenciesFirst([A, B]).map((p) => p.name);
|
|
26
|
+
// No internal dependency between A and B, relative order can be [A,B] or [B,A].
|
|
27
|
+
// But both must appear exactly once.
|
|
28
|
+
expect(result.sort()).toEqual(['A', 'B'].sort());
|
|
29
|
+
});
|
|
30
|
+
it('terminates and includes all packages even with cycles', () => {
|
|
31
|
+
// A <-> B cycle
|
|
32
|
+
const A = createPkg('A', { B: '1.0.0' });
|
|
33
|
+
const B = createPkg('B', { A: '1.0.0' });
|
|
34
|
+
const result = sortLessDependenciesFirst([A, B]).map((p) => p.name);
|
|
35
|
+
// In a cycle, exact order is undefined, but should include both once and terminate
|
|
36
|
+
expect(result.sort()).toEqual(['A', 'B'].sort());
|
|
37
|
+
});
|
|
38
|
+
});
|
|
39
|
+
//# sourceMappingURL=Controller.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Controller.spec.js","sourceRoot":"","sources":["../src/Controller.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { ReleaseCommit } from './services/ReleaseCommit';
|
|
2
|
+
import { ChangelogRenderer } from './services/ChangelogRenderer';
|
|
3
|
+
import { PackageManager } from './services/PackageManager';
|
|
4
|
+
import { NodeFileSystemService } from './services/NodeFileSystemService';
|
|
5
|
+
import { GitService } from './services/GitService';
|
|
6
|
+
import { ConsoleLogger } from './services/ConsoleLogger';
|
|
7
|
+
export declare class MonorepoController {
|
|
8
|
+
private fileSystemService;
|
|
9
|
+
private vscService;
|
|
10
|
+
private changelog;
|
|
11
|
+
private releaseCommit;
|
|
12
|
+
private packageManager;
|
|
13
|
+
private logger;
|
|
14
|
+
private packages;
|
|
15
|
+
private rootPackageJson;
|
|
16
|
+
constructor(fileSystemService: NodeFileSystemService, vscService: GitService, changelog: ChangelogRenderer, releaseCommit: ReleaseCommit, packageManager: PackageManager, logger: ConsoleLogger);
|
|
17
|
+
discoverRootPackageJSON(): void;
|
|
18
|
+
discoverPackages(): void;
|
|
19
|
+
release(): void;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=MonorepoController.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MonorepoController.d.ts","sourceRoot":"","sources":["../src/MonorepoController.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AAEjE,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAE3D,OAAO,EAAE,qBAAqB,EAAE,MAAM,kCAAkC,CAAC;AACzE,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAEzD,qBAAa,kBAAkB;IAK3B,OAAO,CAAC,iBAAiB;IACzB,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,aAAa;IACrB,OAAO,CAAC,cAAc;IACtB,OAAO,CAAC,MAAM;IAThB,OAAO,CAAC,QAAQ,CAAoB;IACpC,OAAO,CAAC,eAAe,CAAe;gBAG5B,iBAAiB,EAAE,qBAAqB,EACxC,UAAU,EAAE,UAAU,EACtB,SAAS,EAAE,iBAAiB,EAC5B,aAAa,EAAE,aAAa,EAC5B,cAAc,EAAE,cAAc,EAC9B,MAAM,EAAE,aAAa;IAG/B,uBAAuB,IAAI,IAAI;IAI/B,gBAAgB,IAAI,IAAI;IAOxB,OAAO,IAAI,IAAI;CAsDhB"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { NpmPackage } from './models/NpmPackage';
|
|
2
|
+
import { bumpTypeToString, bumpVersion, SemVerBumpType } from './models/SemVerBumpType';
|
|
3
|
+
import { sortLessDependenciesFirst } from './sortLessDependenciesFirst';
|
|
4
|
+
import path from 'node:path';
|
|
5
|
+
export class MonorepoController {
|
|
6
|
+
fileSystemService;
|
|
7
|
+
vscService;
|
|
8
|
+
changelog;
|
|
9
|
+
releaseCommit;
|
|
10
|
+
packageManager;
|
|
11
|
+
logger;
|
|
12
|
+
packages = [];
|
|
13
|
+
rootPackageJson;
|
|
14
|
+
constructor(fileSystemService, vscService, changelog, releaseCommit, packageManager, logger) {
|
|
15
|
+
this.fileSystemService = fileSystemService;
|
|
16
|
+
this.vscService = vscService;
|
|
17
|
+
this.changelog = changelog;
|
|
18
|
+
this.releaseCommit = releaseCommit;
|
|
19
|
+
this.packageManager = packageManager;
|
|
20
|
+
this.logger = logger;
|
|
21
|
+
}
|
|
22
|
+
discoverRootPackageJSON() {
|
|
23
|
+
this.rootPackageJson = this.fileSystemService.readJson(path.resolve(process.cwd(), 'package.json'));
|
|
24
|
+
}
|
|
25
|
+
discoverPackages() {
|
|
26
|
+
this.packages = this.fileSystemService.findManyByGlob(this.rootPackageJson.workspaces ?? [], process.cwd()).map((path) => {
|
|
27
|
+
const pkg = this.fileSystemService.readJson(path);
|
|
28
|
+
return NpmPackage.createFromPackage(pkg, path);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
release() {
|
|
32
|
+
const sorted = sortLessDependenciesFirst(this.packages.filter((p) => !p.isPrivate));
|
|
33
|
+
const versionBumpMap = new Map();
|
|
34
|
+
for (const pkg of sorted) {
|
|
35
|
+
const commits = this.vscService.findManyCommitsSinceTag(`${pkg.name}@${pkg.version}`);
|
|
36
|
+
// calculate version bump
|
|
37
|
+
const versionBump = Math.max(SemVerBumpType.NONE, ...commits.map((commit) => (commit.isBreaking ? SemVerBumpType.MAJOR : commit.bumpType)), ...Object.entries(versionBumpMap).map(([k, v]) => {
|
|
38
|
+
return v !== SemVerBumpType.NONE && pkg.hasDependency(k) ? SemVerBumpType.MINOR : SemVerBumpType.NONE;
|
|
39
|
+
}));
|
|
40
|
+
versionBumpMap.set(pkg.name, versionBump);
|
|
41
|
+
if (versionBump === SemVerBumpType.NONE) {
|
|
42
|
+
this.logger.info(`bump(${pkg.name}) ${pkg.version} (skipped)`);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
this.packageManager.bumpVersion(pkg, versionBump);
|
|
46
|
+
this.logger.info(`bump(${pkg.name}) ${pkg.version} (${bumpTypeToString(versionBump)})`);
|
|
47
|
+
}
|
|
48
|
+
// collect changelog logs and render after bump to capture new version
|
|
49
|
+
for (const commit of commits.filter((c) => c.isReleaseTrigger())) {
|
|
50
|
+
this.changelog.addLog(commit);
|
|
51
|
+
}
|
|
52
|
+
this.changelog.render({
|
|
53
|
+
packageName: pkg.name,
|
|
54
|
+
packageVersion: pkg.version,
|
|
55
|
+
packagePath: pkg.path,
|
|
56
|
+
});
|
|
57
|
+
this.logger.info(`changelog(${pkg.name}) generated`);
|
|
58
|
+
}
|
|
59
|
+
// create release commit
|
|
60
|
+
this.releaseCommit.commit({});
|
|
61
|
+
this.logger.info(`releaseCommit generated`);
|
|
62
|
+
// create git tags for every released package
|
|
63
|
+
for (const [packageName, versionBump] of versionBumpMap) {
|
|
64
|
+
const pkg = this.packages.find((p) => p.name === packageName);
|
|
65
|
+
if (versionBump !== SemVerBumpType.NONE) {
|
|
66
|
+
const newVersion = bumpVersion(pkg.version, versionBump);
|
|
67
|
+
this.vscService.createTag(`${pkg.name}@${newVersion}`);
|
|
68
|
+
this.logger.info(`createTag ${pkg.name}@${newVersion}`);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
this.vscService.push(true);
|
|
72
|
+
this.logger.info('VSC pushed');
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
//# sourceMappingURL=MonorepoController.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MonorepoController.js","sourceRoot":"","sources":["../src/MonorepoController.ts"],"names":[],"mappings":"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"}
|
package/dist/main.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"main.d.ts","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":""}
|
package/dist/main.js
ADDED
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { MonorepoController } from './MonorepoController';
|
|
2
|
+
import { NodeFileSystemService } from './services/NodeFileSystemService';
|
|
3
|
+
import { GitService } from './services/GitService';
|
|
4
|
+
import { ChangelogRenderer } from './services/ChangelogRenderer';
|
|
5
|
+
import { HandlebarsRenderService } from './services/HandlebarsRenderService';
|
|
6
|
+
import { ReleaseCommit } from './services/ReleaseCommit';
|
|
7
|
+
import { PackageManager } from './services/PackageManager';
|
|
8
|
+
import { ConsoleLogger } from './services/ConsoleLogger';
|
|
9
|
+
try {
|
|
10
|
+
// Dependencies
|
|
11
|
+
const fsService = new NodeFileSystemService();
|
|
12
|
+
const vcs = new GitService();
|
|
13
|
+
const renderService = new HandlebarsRenderService(process.cwd());
|
|
14
|
+
const changelog = new ChangelogRenderer(renderService, fsService);
|
|
15
|
+
const releaseCommit = new ReleaseCommit(vcs, renderService);
|
|
16
|
+
const packageManager = new PackageManager();
|
|
17
|
+
const controller = new MonorepoController(fsService, vcs, changelog, releaseCommit, packageManager, new ConsoleLogger('Release'));
|
|
18
|
+
controller.discoverRootPackageJSON();
|
|
19
|
+
controller.discoverPackages();
|
|
20
|
+
controller.release();
|
|
21
|
+
}
|
|
22
|
+
catch (error) {
|
|
23
|
+
console.error(error);
|
|
24
|
+
process.exit(1);
|
|
25
|
+
}
|
|
26
|
+
finally {
|
|
27
|
+
process.exit(0);
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=main.js.map
|
package/dist/main.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"main.js","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,qBAAqB,EAAE,MAAM,kCAAkC,CAAC;AACzE,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,uBAAuB,EAAE,MAAM,oCAAoC,CAAC;AAC7E,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAEzD,IAAI,CAAC;IACH,eAAe;IACf,MAAM,SAAS,GAAG,IAAI,qBAAqB,EAAE,CAAC;IAC9C,MAAM,GAAG,GAAG,IAAI,UAAU,EAAE,CAAC;IAC7B,MAAM,aAAa,GAAG,IAAI,uBAAuB,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC;IACjE,MAAM,SAAS,GAAG,IAAI,iBAAiB,CAAC,aAAa,EAAE,SAAS,CAAC,CAAC;IAClE,MAAM,aAAa,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE,aAAa,CAAC,CAAC;IAC5D,MAAM,cAAc,GAAG,IAAI,cAAc,EAAE,CAAC;IAE5C,MAAM,UAAU,GAAG,IAAI,kBAAkB,CAAC,SAAS,EAAE,GAAG,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE,IAAI,aAAa,CAAC,SAAS,CAAC,CAAC,CAAC;IAElI,UAAU,CAAC,uBAAuB,EAAE,CAAC;IACrC,UAAU,CAAC,gBAAgB,EAAE,CAAC;IAC9B,UAAU,CAAC,OAAO,EAAE,CAAC;AACvB,CAAC;AAAC,OAAO,KAAK,EAAE,CAAC;IACf,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACrB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC;QAAS,CAAC;IACT,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { SemVerBumpType } from './SemVerBumpType';
|
|
2
|
+
export declare class ConventionalCommit {
|
|
3
|
+
readonly type: string;
|
|
4
|
+
readonly scope: string | null;
|
|
5
|
+
readonly subject: string;
|
|
6
|
+
readonly isBreaking: boolean;
|
|
7
|
+
constructor(type: string, scope: string | null, subject: string, isBreaking: boolean);
|
|
8
|
+
static parse(raw: string): ConventionalCommit;
|
|
9
|
+
get bumpType(): SemVerBumpType;
|
|
10
|
+
isReleaseTrigger(): boolean;
|
|
11
|
+
matchesScope(packageName: string): boolean;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=ConventionalCommit.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConventionalCommit.d.ts","sourceRoot":"","sources":["../../src/models/ConventionalCommit.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,qBAAa,kBAAkB;IAE3B,QAAQ,CAAC,IAAI,EAAE,MAAM;IACrB,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAC7B,QAAQ,CAAC,OAAO,EAAE,MAAM;IACxB,QAAQ,CAAC,UAAU,EAAE,OAAO;gBAHnB,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,MAAM,GAAG,IAAI,EACpB,OAAO,EAAE,MAAM,EACf,UAAU,EAAE,OAAO;IAG9B,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,kBAAkB;IAY7C,IAAI,QAAQ,IAAI,cAAc,CAK7B;IAED,gBAAgB,IAAI,OAAO;IAI3B,YAAY,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO;CAG3C"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { SemVerBumpType } from './SemVerBumpType';
|
|
2
|
+
export class ConventionalCommit {
|
|
3
|
+
type;
|
|
4
|
+
scope;
|
|
5
|
+
subject;
|
|
6
|
+
isBreaking;
|
|
7
|
+
constructor(type, scope, subject, isBreaking) {
|
|
8
|
+
this.type = type;
|
|
9
|
+
this.scope = scope;
|
|
10
|
+
this.subject = subject;
|
|
11
|
+
this.isBreaking = isBreaking;
|
|
12
|
+
}
|
|
13
|
+
static parse(raw) {
|
|
14
|
+
const match = raw.match(/^(\w+)(?:\(([^)]*)\))?(!)?\s*:\s*(.+)$/);
|
|
15
|
+
if (!match) {
|
|
16
|
+
return new ConventionalCommit('unknown', null, raw, false);
|
|
17
|
+
}
|
|
18
|
+
const [, type, scope, bang, subject] = match;
|
|
19
|
+
const isBreaking = !!bang || raw.includes('BREAKING CHANGE');
|
|
20
|
+
return new ConventionalCommit(type, scope || null, subject, isBreaking);
|
|
21
|
+
}
|
|
22
|
+
get bumpType() {
|
|
23
|
+
if (this.isBreaking)
|
|
24
|
+
return SemVerBumpType.MAJOR;
|
|
25
|
+
if (this.type === 'feat')
|
|
26
|
+
return SemVerBumpType.MINOR;
|
|
27
|
+
if (this.type === 'fix' || this.type === 'perf')
|
|
28
|
+
return SemVerBumpType.PATCH;
|
|
29
|
+
return SemVerBumpType.NONE;
|
|
30
|
+
}
|
|
31
|
+
isReleaseTrigger() {
|
|
32
|
+
return this.bumpType !== SemVerBumpType.NONE;
|
|
33
|
+
}
|
|
34
|
+
matchesScope(packageName) {
|
|
35
|
+
return this.scope === packageName;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=ConventionalCommit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConventionalCommit.js","sourceRoot":"","sources":["../../src/models/ConventionalCommit.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,MAAM,OAAO,kBAAkB;IAElB;IACA;IACA;IACA;IAJX,YACW,IAAY,EACZ,KAAoB,EACpB,OAAe,EACf,UAAmB;QAHnB,SAAI,GAAJ,IAAI,CAAQ;QACZ,UAAK,GAAL,KAAK,CAAe;QACpB,YAAO,GAAP,OAAO,CAAQ;QACf,eAAU,GAAV,UAAU,CAAS;IAC3B,CAAC;IAEJ,MAAM,CAAC,KAAK,CAAC,GAAW;QACtB,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,wCAAwC,CAAC,CAAC;QAClE,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,OAAO,IAAI,kBAAkB,CAAC,SAAS,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC;QAC7D,CAAC;QAED,MAAM,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,CAAC,GAAG,KAAK,CAAC;QAC7C,MAAM,UAAU,GAAG,CAAC,CAAC,IAAI,IAAI,GAAG,CAAC,QAAQ,CAAC,iBAAiB,CAAC,CAAC;QAE7D,OAAO,IAAI,kBAAkB,CAAC,IAAI,EAAE,KAAK,IAAI,IAAI,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;IAC1E,CAAC;IAED,IAAI,QAAQ;QACV,IAAI,IAAI,CAAC,UAAU;YAAE,OAAO,cAAc,CAAC,KAAK,CAAC;QACjD,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM;YAAE,OAAO,cAAc,CAAC,KAAK,CAAC;QACtD,IAAI,IAAI,CAAC,IAAI,KAAK,KAAK,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM;YAAE,OAAO,cAAc,CAAC,KAAK,CAAC;QAC7E,OAAO,cAAc,CAAC,IAAI,CAAC;IAC7B,CAAC;IAED,gBAAgB;QACd,OAAO,IAAI,CAAC,QAAQ,KAAK,cAAc,CAAC,IAAI,CAAC;IAC/C,CAAC;IAED,YAAY,CAAC,WAAmB;QAC9B,OAAO,IAAI,CAAC,KAAK,KAAK,WAAW,CAAC;IACpC,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConventionalCommit.spec.d.ts","sourceRoot":"","sources":["../../src/models/ConventionalCommit.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { ConventionalCommit } from './ConventionalCommit';
|
|
3
|
+
import { SemVerBumpType } from './SemVerBumpType';
|
|
4
|
+
describe('ConventionalCommit', () => {
|
|
5
|
+
describe('parse', () => {
|
|
6
|
+
it('should parse feat commit with scope', () => {
|
|
7
|
+
const commit = ConventionalCommit.parse('feat(my-pkg): add feature');
|
|
8
|
+
expect(commit.type).toBe('feat');
|
|
9
|
+
expect(commit.scope).toBe('my-pkg');
|
|
10
|
+
expect(commit.subject).toBe('add feature');
|
|
11
|
+
expect(commit.isBreaking).toBe(false);
|
|
12
|
+
});
|
|
13
|
+
it('should parse fix commit without scope', () => {
|
|
14
|
+
const commit = ConventionalCommit.parse('fix: resolve crash');
|
|
15
|
+
expect(commit.type).toBe('fix');
|
|
16
|
+
expect(commit.scope).toBeNull();
|
|
17
|
+
expect(commit.subject).toBe('resolve crash');
|
|
18
|
+
});
|
|
19
|
+
it('should parse breaking change with bang', () => {
|
|
20
|
+
const commit = ConventionalCommit.parse('feat(my-pkg)!: breaking change');
|
|
21
|
+
expect(commit.isBreaking).toBe(true);
|
|
22
|
+
});
|
|
23
|
+
it('should return unknown type for non-conventional commit', () => {
|
|
24
|
+
const commit = ConventionalCommit.parse('random message');
|
|
25
|
+
expect(commit.type).toBe('unknown');
|
|
26
|
+
expect(commit.subject).toBe('random message');
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
describe('bumpType', () => {
|
|
30
|
+
it('should return MAJOR for breaking change', () => {
|
|
31
|
+
const commit = ConventionalCommit.parse('feat(pkg)!: breaking');
|
|
32
|
+
expect(commit.bumpType).toBe(SemVerBumpType.MAJOR);
|
|
33
|
+
});
|
|
34
|
+
it('should return MINOR for feat', () => {
|
|
35
|
+
const commit = ConventionalCommit.parse('feat(pkg): feature');
|
|
36
|
+
expect(commit.bumpType).toBe(SemVerBumpType.MINOR);
|
|
37
|
+
});
|
|
38
|
+
it('should return PATCH for fix', () => {
|
|
39
|
+
const commit = ConventionalCommit.parse('fix(pkg): bugfix');
|
|
40
|
+
expect(commit.bumpType).toBe(SemVerBumpType.PATCH);
|
|
41
|
+
});
|
|
42
|
+
it('should return PATCH for perf', () => {
|
|
43
|
+
const commit = ConventionalCommit.parse('perf(pkg): optimize');
|
|
44
|
+
expect(commit.bumpType).toBe(SemVerBumpType.PATCH);
|
|
45
|
+
});
|
|
46
|
+
it('should return NONE for docs', () => {
|
|
47
|
+
const commit = ConventionalCommit.parse('docs(pkg): update docs');
|
|
48
|
+
expect(commit.bumpType).toBe(SemVerBumpType.NONE);
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
describe('isReleaseTrigger', () => {
|
|
52
|
+
it('should return true for feat', () => {
|
|
53
|
+
const commit = ConventionalCommit.parse('feat(pkg): feature');
|
|
54
|
+
expect(commit.isReleaseTrigger()).toBe(true);
|
|
55
|
+
});
|
|
56
|
+
it('should return false for chore', () => {
|
|
57
|
+
const commit = ConventionalCommit.parse('chore(pkg): cleanup');
|
|
58
|
+
expect(commit.isReleaseTrigger()).toBe(false);
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
describe('matchesScope', () => {
|
|
62
|
+
it('should match when scope equals package name', () => {
|
|
63
|
+
const commit = ConventionalCommit.parse('feat(my-pkg): feature');
|
|
64
|
+
expect(commit.matchesScope('my-pkg')).toBe(true);
|
|
65
|
+
});
|
|
66
|
+
it('should not match different scope', () => {
|
|
67
|
+
const commit = ConventionalCommit.parse('feat(other-pkg): feature');
|
|
68
|
+
expect(commit.matchesScope('my-pkg')).toBe(false);
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
});
|
|
72
|
+
//# sourceMappingURL=ConventionalCommit.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConventionalCommit.spec.js","sourceRoot":"","sources":["../../src/models/ConventionalCommit.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { PackageJSON } from './PackageJSON';
|
|
2
|
+
import { Sortable } from '../sortLessDependenciesFirst';
|
|
3
|
+
export declare class NpmPackage implements Sortable {
|
|
4
|
+
readonly name: string;
|
|
5
|
+
readonly path: string;
|
|
6
|
+
readonly version: string;
|
|
7
|
+
readonly isPrivate: boolean;
|
|
8
|
+
readonly dependencies: Record<string, string>;
|
|
9
|
+
readonly devDependencies: Record<string, string>;
|
|
10
|
+
static createFromPackage(pkgJson: PackageJSON, pkgPath: string): NpmPackage;
|
|
11
|
+
constructor(name: string, path: string, version: string, isPrivate: boolean, dependencies: Record<string, string>, devDependencies: Record<string, string>);
|
|
12
|
+
filterDependencies(packageNames: Set<string>): string[];
|
|
13
|
+
hasDependency(depPkgName: string): boolean;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=NpmPackage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NpmPackage.d.ts","sourceRoot":"","sources":["../../src/models/NpmPackage.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AAExD,qBAAa,UAAW,YAAW,QAAQ;IAMvC,QAAQ,CAAC,IAAI,EAAE,MAAM;IACrB,QAAQ,CAAC,IAAI,EAAE,MAAM;IACrB,QAAQ,CAAC,OAAO,EAAE,MAAM;IACxB,QAAQ,CAAC,SAAS,EAAE,OAAO;IAC3B,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC;IAC7C,QAAQ,CAAC,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC;IAVlD,MAAM,CAAC,iBAAiB,CAAC,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,GAAG,UAAU;gBAKhE,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,MAAM,EACf,SAAS,EAAE,OAAO,EAClB,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EACpC,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC;IAGlD,kBAAkB,CAAC,YAAY,EAAE,GAAG,CAAC,MAAM,CAAC,GAAG,MAAM,EAAE;IAIvD,aAAa,CAAC,UAAU,EAAE,MAAM;CAGjC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export class NpmPackage {
|
|
2
|
+
name;
|
|
3
|
+
path;
|
|
4
|
+
version;
|
|
5
|
+
isPrivate;
|
|
6
|
+
dependencies;
|
|
7
|
+
devDependencies;
|
|
8
|
+
static createFromPackage(pkgJson, pkgPath) {
|
|
9
|
+
return new NpmPackage(pkgJson.name, pkgPath, pkgJson.version, pkgJson.private ?? false, pkgJson.dependencies ?? {}, pkgJson.devDependencies ?? {});
|
|
10
|
+
}
|
|
11
|
+
constructor(name, path, version, isPrivate, dependencies, devDependencies) {
|
|
12
|
+
this.name = name;
|
|
13
|
+
this.path = path;
|
|
14
|
+
this.version = version;
|
|
15
|
+
this.isPrivate = isPrivate;
|
|
16
|
+
this.dependencies = dependencies;
|
|
17
|
+
this.devDependencies = devDependencies;
|
|
18
|
+
}
|
|
19
|
+
filterDependencies(packageNames) {
|
|
20
|
+
return Object.keys({ ...this.dependencies, ...this.devDependencies }).filter((d) => packageNames.has(d));
|
|
21
|
+
}
|
|
22
|
+
hasDependency(depPkgName) {
|
|
23
|
+
return Object.keys(this.dependencies).includes(depPkgName);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=NpmPackage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NpmPackage.js","sourceRoot":"","sources":["../../src/models/NpmPackage.ts"],"names":[],"mappings":"AAGA,MAAM,OAAO,UAAU;IAMV;IACA;IACA;IACA;IACA;IACA;IAVX,MAAM,CAAC,iBAAiB,CAAC,OAAoB,EAAE,OAAe;QAC5D,OAAO,IAAI,UAAU,CAAC,OAAO,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,IAAI,KAAK,EAAE,OAAO,CAAC,YAAY,IAAI,EAAE,EAAE,OAAO,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC;IACrJ,CAAC;IAED,YACW,IAAY,EACZ,IAAY,EACZ,OAAe,EACf,SAAkB,EAClB,YAAoC,EACpC,eAAuC;QALvC,SAAI,GAAJ,IAAI,CAAQ;QACZ,SAAI,GAAJ,IAAI,CAAQ;QACZ,YAAO,GAAP,OAAO,CAAQ;QACf,cAAS,GAAT,SAAS,CAAS;QAClB,iBAAY,GAAZ,YAAY,CAAwB;QACpC,oBAAe,GAAf,eAAe,CAAwB;IAC/C,CAAC;IAEJ,kBAAkB,CAAC,YAAyB;QAC1C,OAAO,MAAM,CAAC,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,YAAY,EAAE,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3G,CAAC;IAED,aAAa,CAAC,UAAkB;QAC9B,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;IAC7D,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NpmPackage.spec.d.ts","sourceRoot":"","sources":["../../src/models/NpmPackage.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { NpmPackage } from './NpmPackage';
|
|
3
|
+
function makePkg(deps = {}, devDeps = {}) {
|
|
4
|
+
return new NpmPackage('pkg-a', '/repo/pkg-a', '1.0.0', false, deps, devDeps);
|
|
5
|
+
}
|
|
6
|
+
describe('NpmPackage', () => {
|
|
7
|
+
it('hasDependency returns true only for runtime deps', () => {
|
|
8
|
+
const p = makePkg({ 'lib-a': '1.0.0' }, { 'lib-b': '1.0.0' });
|
|
9
|
+
expect(p.hasDependency('lib-a')).toBe(true);
|
|
10
|
+
expect(p.hasDependency('lib-b')).toBe(false);
|
|
11
|
+
expect(p.hasDependency('missing')).toBe(false);
|
|
12
|
+
});
|
|
13
|
+
it('getDependencyNames filters to internal set', () => {
|
|
14
|
+
const p = makePkg({ 'lib-a': '1.0.0', react: '18.0.0' });
|
|
15
|
+
const names = new Set(['lib-a', 'lib-b']);
|
|
16
|
+
expect(p.filterDependencies(names)).toEqual(['lib-a']);
|
|
17
|
+
});
|
|
18
|
+
});
|
|
19
|
+
//# sourceMappingURL=NpmPackage.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NpmPackage.spec.js","sourceRoot":"","sources":["../../src/models/NpmPackage.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,SAAS,OAAO,CAAC,OAA+B,EAAE,EAAE,UAAkC,EAAE;IACtF,OAAO,IAAI,UAAU,CAAC,OAAO,EAAE,aAAa,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;AAC/E,CAAC;AAED,QAAQ,CAAC,YAAY,EAAE,GAAG,EAAE;IAC1B,EAAE,CAAC,kDAAkD,EAAE,GAAG,EAAE;QAC1D,MAAM,CAAC,GAAG,OAAO,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC,CAAC;QAC9D,MAAM,CAAC,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5C,MAAM,CAAC,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7C,MAAM,CAAC,CAAC,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE,GAAG,EAAE;QACpD,MAAM,CAAC,GAAG,OAAO,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;QACzD,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;QAC1C,MAAM,CAAC,CAAC,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;IACzD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PackageJSON.d.ts","sourceRoot":"","sources":["../../src/models/PackageJSON.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACtC,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACzC,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;CACvB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PackageJSON.js","sourceRoot":"","sources":["../../src/models/PackageJSON.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export declare enum SemVerBumpType {
|
|
2
|
+
NONE = 0,
|
|
3
|
+
PATCH = 1,
|
|
4
|
+
MINOR = 2,
|
|
5
|
+
MAJOR = 3
|
|
6
|
+
}
|
|
7
|
+
export declare function bumpTypeToString(type: SemVerBumpType): string | undefined;
|
|
8
|
+
export declare function bumpVersion(version: string, bumpType: SemVerBumpType): string;
|
|
9
|
+
//# sourceMappingURL=SemVerBumpType.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SemVerBumpType.d.ts","sourceRoot":"","sources":["../../src/models/SemVerBumpType.ts"],"names":[],"mappings":"AAAA,oBAAY,cAAc;IACxB,IAAI,IAAI;IACR,KAAK,IAAI;IACT,KAAK,IAAI;IACT,KAAK,IAAI;CACV;AAED,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,cAAc,GAAG,MAAM,GAAG,SAAS,CAczE;AAED,wBAAgB,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,cAAc,GAAG,MAAM,CAY7E"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
export var SemVerBumpType;
|
|
2
|
+
(function (SemVerBumpType) {
|
|
3
|
+
SemVerBumpType[SemVerBumpType["NONE"] = 0] = "NONE";
|
|
4
|
+
SemVerBumpType[SemVerBumpType["PATCH"] = 1] = "PATCH";
|
|
5
|
+
SemVerBumpType[SemVerBumpType["MINOR"] = 2] = "MINOR";
|
|
6
|
+
SemVerBumpType[SemVerBumpType["MAJOR"] = 3] = "MAJOR";
|
|
7
|
+
})(SemVerBumpType || (SemVerBumpType = {}));
|
|
8
|
+
export function bumpTypeToString(type) {
|
|
9
|
+
switch (type) {
|
|
10
|
+
case SemVerBumpType.MAJOR:
|
|
11
|
+
return 'major';
|
|
12
|
+
case SemVerBumpType.MINOR:
|
|
13
|
+
return 'minor';
|
|
14
|
+
case SemVerBumpType.PATCH:
|
|
15
|
+
return 'patch';
|
|
16
|
+
default:
|
|
17
|
+
return undefined;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
export function bumpVersion(version, bumpType) {
|
|
21
|
+
const [major, minor, patch] = version.split('.').map(Number);
|
|
22
|
+
switch (bumpType) {
|
|
23
|
+
case SemVerBumpType.MAJOR:
|
|
24
|
+
return `${major + 1}.0.0`;
|
|
25
|
+
case SemVerBumpType.MINOR:
|
|
26
|
+
return `${major}.${minor + 1}.0`;
|
|
27
|
+
case SemVerBumpType.PATCH:
|
|
28
|
+
return `${major}.${minor}.${patch + 1}`;
|
|
29
|
+
default:
|
|
30
|
+
return version;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=SemVerBumpType.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SemVerBumpType.js","sourceRoot":"","sources":["../../src/models/SemVerBumpType.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,cAKX;AALD,WAAY,cAAc;IACxB,mDAAQ,CAAA;IACR,qDAAS,CAAA;IACT,qDAAS,CAAA;IACT,qDAAS,CAAA;AACX,CAAC,EALW,cAAc,KAAd,cAAc,QAKzB;AAED,MAAM,UAAU,gBAAgB,CAAC,IAAoB;IACnD,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,cAAc,CAAC,KAAK;YACvB,OAAO,OAAO,CAAC;QAEjB,KAAK,cAAc,CAAC,KAAK;YACvB,OAAO,OAAO,CAAC;QAEjB,KAAK,cAAc,CAAC,KAAK;YACvB,OAAO,OAAO,CAAC;QAEjB;YACE,OAAO,SAAS,CAAC;IACrB,CAAC;AACH,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,OAAe,EAAE,QAAwB;IACnE,MAAM,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAC7D,QAAQ,QAAQ,EAAE,CAAC;QACjB,KAAK,cAAc,CAAC,KAAK;YACvB,OAAO,GAAG,KAAK,GAAG,CAAC,MAAM,CAAC;QAC5B,KAAK,cAAc,CAAC,KAAK;YACvB,OAAO,GAAG,KAAK,IAAI,KAAK,GAAG,CAAC,IAAI,CAAC;QACnC,KAAK,cAAc,CAAC,KAAK;YACvB,OAAO,GAAG,KAAK,IAAI,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;QAC1C;YACE,OAAO,OAAO,CAAC;IACnB,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SemVerBumpType.spec.d.ts","sourceRoot":"","sources":["../../src/models/SemVerBumpType.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { describe, it, expect } from "vitest";
|
|
2
|
+
import { SemVerBumpType, bumpVersion } from "./SemVerBumpType";
|
|
3
|
+
describe("bumpVersion", () => {
|
|
4
|
+
it("should bump major version", () => {
|
|
5
|
+
expect(bumpVersion("1.2.3", SemVerBumpType.MAJOR)).toBe("2.0.0");
|
|
6
|
+
});
|
|
7
|
+
it("should bump minor version", () => {
|
|
8
|
+
expect(bumpVersion("1.2.3", SemVerBumpType.MINOR)).toBe("1.3.0");
|
|
9
|
+
});
|
|
10
|
+
it("should bump patch version", () => {
|
|
11
|
+
expect(bumpVersion("1.2.3", SemVerBumpType.PATCH)).toBe("1.2.4");
|
|
12
|
+
});
|
|
13
|
+
it("should return same version for NONE", () => {
|
|
14
|
+
expect(bumpVersion("1.2.3", SemVerBumpType.NONE)).toBe("1.2.3");
|
|
15
|
+
});
|
|
16
|
+
});
|
|
17
|
+
//# sourceMappingURL=SemVerBumpType.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SemVerBumpType.spec.js","sourceRoot":"","sources":["../../src/models/SemVerBumpType.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAE/D,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;IAC3B,EAAE,CAAC,2BAA2B,EAAE,GAAG,EAAE;QACnC,MAAM,CAAC,WAAW,CAAC,OAAO,EAAE,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACnE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE,GAAG,EAAE;QACnC,MAAM,CAAC,WAAW,CAAC,OAAO,EAAE,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACnE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE,GAAG,EAAE;QACnC,MAAM,CAAC,WAAW,CAAC,OAAO,EAAE,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACnE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE,GAAG,EAAE;QAC7C,MAAM,CAAC,WAAW,CAAC,OAAO,EAAE,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAClE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ConventionalCommit } from '../models/ConventionalCommit';
|
|
2
|
+
import { NodeFileSystemService } from './NodeFileSystemService';
|
|
3
|
+
import { HandlebarsRenderService } from './HandlebarsRenderService';
|
|
4
|
+
export declare class ChangelogRenderer {
|
|
5
|
+
private readonly renderService;
|
|
6
|
+
private readonly fs;
|
|
7
|
+
private commits;
|
|
8
|
+
constructor(renderService: HandlebarsRenderService, fs: NodeFileSystemService);
|
|
9
|
+
addLog(entry: ConventionalCommit): void;
|
|
10
|
+
render(options: {
|
|
11
|
+
packageName: string;
|
|
12
|
+
packageVersion: string;
|
|
13
|
+
packagePath: string;
|
|
14
|
+
}): void;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=ChangelogRenderer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChangelogRenderer.d.ts","sourceRoot":"","sources":["../../src/services/ChangelogRenderer.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;AAChE,OAAO,EAAE,uBAAuB,EAAE,MAAM,2BAA2B,CAAC;AAEpE,qBAAa,iBAAiB;IAI1B,OAAO,CAAC,QAAQ,CAAC,aAAa;IAC9B,OAAO,CAAC,QAAQ,CAAC,EAAE;IAJrB,OAAO,CAAC,OAAO,CAA4B;gBAGxB,aAAa,EAAE,uBAAuB,EACtC,EAAE,EAAE,qBAAqB;IAG5C,MAAM,CAAC,KAAK,EAAE,kBAAkB,GAAG,IAAI;IAIvC,MAAM,CAAC,OAAO,EAAE;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,cAAc,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI;CAa5F"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
export class ChangelogRenderer {
|
|
3
|
+
renderService;
|
|
4
|
+
fs;
|
|
5
|
+
commits = [];
|
|
6
|
+
constructor(renderService, fs) {
|
|
7
|
+
this.renderService = renderService;
|
|
8
|
+
this.fs = fs;
|
|
9
|
+
}
|
|
10
|
+
addLog(entry) {
|
|
11
|
+
this.commits.push(entry);
|
|
12
|
+
}
|
|
13
|
+
render(options) {
|
|
14
|
+
if (!this.commits.length)
|
|
15
|
+
return;
|
|
16
|
+
const changelogPath = path.resolve(options.packagePath, 'CHANGELOG.md');
|
|
17
|
+
const existing = this.fs.fileExists(changelogPath) ? this.fs.readFile(changelogPath) : '';
|
|
18
|
+
const content = this.renderService.render('templates/changelog.hbs', {
|
|
19
|
+
commits: this.commits,
|
|
20
|
+
packageName: options.packageName,
|
|
21
|
+
existing,
|
|
22
|
+
});
|
|
23
|
+
this.fs.writeFile(changelogPath, content);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=ChangelogRenderer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChangelogRenderer.js","sourceRoot":"","sources":["../../src/services/ChangelogRenderer.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAK7B,MAAM,OAAO,iBAAiB;IAIT;IACA;IAJX,OAAO,GAAyB,EAAE,CAAC;IAE3C,YACmB,aAAsC,EACtC,EAAyB;QADzB,kBAAa,GAAb,aAAa,CAAyB;QACtC,OAAE,GAAF,EAAE,CAAuB;IACzC,CAAC;IAEJ,MAAM,CAAC,KAAyB;QAC9B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAED,MAAM,CAAC,OAA6E;QAClF,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM;YAAE,OAAO;QAEjC,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,WAAW,EAAE,cAAc,CAAC,CAAC;QACxE,MAAM,QAAQ,GAAG,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC1F,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,yBAAyB,EAAE;YACnE,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,QAAQ;SACT,CAAC,CAAC;QAEH,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;IAC5C,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConsoleLogger.d.ts","sourceRoot":"","sources":["../../src/services/ConsoleLogger.ts"],"names":[],"mappings":"AAAA,qBAAa,aAAa;IACZ,OAAO,CAAC,KAAK;gBAAL,KAAK,EAAE,MAAM;IAEjC,IAAI,CAAC,GAAG,IAAI,EAAE,OAAO,EAAE;CAGxB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConsoleLogger.js","sourceRoot":"","sources":["../../src/services/ConsoleLogger.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,aAAa;IACJ;IAApB,YAAoB,KAAa;QAAb,UAAK,GAAL,KAAK,CAAQ;IAAG,CAAC;IAErC,IAAI,CAAC,GAAG,IAAe;QACrB,OAAO,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;IAC3C,CAAC;CACF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ConventionalCommit } from '../models/ConventionalCommit';
|
|
2
|
+
export declare class GitService {
|
|
3
|
+
findManyCommitsSinceTag(sinceTag: string): ConventionalCommit[];
|
|
4
|
+
createTag(tagName: string): void;
|
|
5
|
+
commit(message: string): void;
|
|
6
|
+
push(includeTags: boolean): void;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=GitService.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GitService.d.ts","sourceRoot":"","sources":["../../src/services/GitService.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAElE,qBAAa,UAAU;IACrB,uBAAuB,CAAC,QAAQ,EAAE,MAAM,GAAG,kBAAkB,EAAE;IAO/D,SAAS,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAIhC,MAAM,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAK7B,IAAI,CAAC,WAAW,EAAE,OAAO,GAAG,IAAI;CAMjC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { execSync } from 'node:child_process';
|
|
2
|
+
import { ConventionalCommit } from '../models/ConventionalCommit';
|
|
3
|
+
export class GitService {
|
|
4
|
+
findManyCommitsSinceTag(sinceTag) {
|
|
5
|
+
const range = `${sinceTag}..HEAD`;
|
|
6
|
+
const output = execSync(`git log ${range} --format="%H %s"`, { encoding: 'utf-8' }).trim();
|
|
7
|
+
if (!output)
|
|
8
|
+
return [];
|
|
9
|
+
return output.split('\n').map((c) => ConventionalCommit.parse(c));
|
|
10
|
+
}
|
|
11
|
+
createTag(tagName) {
|
|
12
|
+
execSync(`git tag ${tagName}`);
|
|
13
|
+
}
|
|
14
|
+
commit(message) {
|
|
15
|
+
execSync('git add .');
|
|
16
|
+
execSync(`git commit -m ${JSON.stringify(message)}`);
|
|
17
|
+
}
|
|
18
|
+
push(includeTags) {
|
|
19
|
+
execSync('git push');
|
|
20
|
+
if (includeTags) {
|
|
21
|
+
execSync('git push --tags');
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=GitService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GitService.js","sourceRoot":"","sources":["../../src/services/GitService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAElE,MAAM,OAAO,UAAU;IACrB,uBAAuB,CAAC,QAAgB;QACtC,MAAM,KAAK,GAAG,GAAG,QAAQ,QAAQ,CAAC;QAClC,MAAM,MAAM,GAAG,QAAQ,CAAC,WAAW,KAAK,mBAAmB,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;QAC3F,IAAI,CAAC,MAAM;YAAE,OAAO,EAAE,CAAC;QACvB,OAAO,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IACpE,CAAC;IAED,SAAS,CAAC,OAAe;QACvB,QAAQ,CAAC,WAAW,OAAO,EAAE,CAAC,CAAC;IACjC,CAAC;IAED,MAAM,CAAC,OAAe;QACpB,QAAQ,CAAC,WAAW,CAAC,CAAC;QACtB,QAAQ,CAAC,iBAAiB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IACvD,CAAC;IAED,IAAI,CAAC,WAAoB;QACvB,QAAQ,CAAC,UAAU,CAAC,CAAC;QACrB,IAAI,WAAW,EAAE,CAAC;YAChB,QAAQ,CAAC,iBAAiB,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HandlebarsRenderService.d.ts","sourceRoot":"","sources":["../../src/services/HandlebarsRenderService.ts"],"names":[],"mappings":"AAIA,qBAAa,uBAAuB;IACtB,OAAO,CAAC,QAAQ;gBAAR,QAAQ,EAAE,MAAM;IAEpC,MAAM,CAAC,YAAY,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM;CAKpE"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { readFileSync } from 'node:fs';
|
|
2
|
+
import Handlebars from 'handlebars';
|
|
3
|
+
import path from 'node:path';
|
|
4
|
+
export class HandlebarsRenderService {
|
|
5
|
+
basePath;
|
|
6
|
+
constructor(basePath) {
|
|
7
|
+
this.basePath = basePath;
|
|
8
|
+
}
|
|
9
|
+
render(templatePath, data) {
|
|
10
|
+
const source = readFileSync(path.resolve(this.basePath, templatePath), 'utf-8');
|
|
11
|
+
const template = Handlebars.compile(source);
|
|
12
|
+
return template(data);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=HandlebarsRenderService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HandlebarsRenderService.js","sourceRoot":"","sources":["../../src/services/HandlebarsRenderService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACvC,OAAO,UAAU,MAAM,YAAY,CAAC;AACpC,OAAO,IAAI,MAAM,WAAW,CAAC;AAE7B,MAAM,OAAO,uBAAuB;IACd;IAApB,YAAoB,QAAgB;QAAhB,aAAQ,GAAR,QAAQ,CAAQ;IAAG,CAAC;IAExC,MAAM,CAAC,YAAoB,EAAE,IAA6B;QACxD,MAAM,MAAM,GAAG,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,YAAY,CAAC,EAAE,OAAO,CAAC,CAAC;QAChF,MAAM,QAAQ,GAAG,UAAU,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAC5C,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAC;IACxB,CAAC;CACF"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export declare class NodeFileSystemService {
|
|
2
|
+
readJson<T = unknown>(filePath: string): T;
|
|
3
|
+
writeJson(filePath: string, data: unknown): void;
|
|
4
|
+
readFile(filePath: string): string;
|
|
5
|
+
writeFile(filePath: string, content: string): void;
|
|
6
|
+
fileExists(filePath: string): boolean;
|
|
7
|
+
findManyByGlob(patterns: string[], cwd?: string): string[];
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=NodeFileSystemService.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NodeFileSystemService.d.ts","sourceRoot":"","sources":["../../src/services/NodeFileSystemService.ts"],"names":[],"mappings":"AAGA,qBAAa,qBAAqB;IAChC,QAAQ,CAAC,CAAC,GAAG,OAAO,EAAE,QAAQ,EAAE,MAAM,GAAG,CAAC;IAK1C,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,GAAG,IAAI;IAIhD,QAAQ,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM;IAIlC,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI;IAIlD,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO;IAIrC,cAAc,CAAC,QAAQ,EAAE,MAAM,EAAE,EAAE,GAAG,SAAgB,GAAG,MAAM,EAAE;CAGlE"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { existsSync, readFileSync, writeFileSync } from 'node:fs';
|
|
2
|
+
import { globSync } from 'glob';
|
|
3
|
+
export class NodeFileSystemService {
|
|
4
|
+
readJson(filePath) {
|
|
5
|
+
const content = readFileSync(filePath, 'utf-8');
|
|
6
|
+
return JSON.parse(content);
|
|
7
|
+
}
|
|
8
|
+
writeJson(filePath, data) {
|
|
9
|
+
writeFileSync(filePath, JSON.stringify(data, null, 2) + '\n', 'utf-8');
|
|
10
|
+
}
|
|
11
|
+
readFile(filePath) {
|
|
12
|
+
return readFileSync(filePath, 'utf-8');
|
|
13
|
+
}
|
|
14
|
+
writeFile(filePath, content) {
|
|
15
|
+
writeFileSync(filePath, content, 'utf-8');
|
|
16
|
+
}
|
|
17
|
+
fileExists(filePath) {
|
|
18
|
+
return existsSync(filePath);
|
|
19
|
+
}
|
|
20
|
+
findManyByGlob(patterns, cwd = process.cwd()) {
|
|
21
|
+
return patterns.flatMap((pattern) => globSync(pattern, { cwd, absolute: true }));
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=NodeFileSystemService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NodeFileSystemService.js","sourceRoot":"","sources":["../../src/services/NodeFileSystemService.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAClE,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAEhC,MAAM,OAAO,qBAAqB;IAChC,QAAQ,CAAc,QAAgB;QACpC,MAAM,OAAO,GAAG,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QAChD,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;IAC7B,CAAC;IAED,SAAS,CAAC,QAAgB,EAAE,IAAa;QACvC,aAAa,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,IAAI,EAAE,OAAO,CAAC,CAAC;IACzE,CAAC;IAED,QAAQ,CAAC,QAAgB;QACvB,OAAO,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IACzC,CAAC;IAED,SAAS,CAAC,QAAgB,EAAE,OAAe;QACzC,aAAa,CAAC,QAAQ,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;IAC5C,CAAC;IAED,UAAU,CAAC,QAAgB;QACzB,OAAO,UAAU,CAAC,QAAQ,CAAC,CAAC;IAC9B,CAAC;IAED,cAAc,CAAC,QAAkB,EAAE,GAAG,GAAG,OAAO,CAAC,GAAG,EAAE;QACpD,OAAO,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,QAAQ,CAAC,OAAO,EAAE,EAAE,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;IACnF,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PackageManager.d.ts","sourceRoot":"","sources":["../../src/services/PackageManager.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAElD,qBAAa,cAAc;IACzB,WAAW,CAAC,GAAG,EAAE,UAAU,EAAE,WAAW,EAAE,cAAc,GAAG,IAAI;CAYhE"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { execSync } from 'node:child_process';
|
|
2
|
+
import { SemVerBumpType } from '../models/SemVerBumpType';
|
|
3
|
+
export class PackageManager {
|
|
4
|
+
bumpVersion(pkg, versionBump) {
|
|
5
|
+
if (versionBump === SemVerBumpType.NONE) {
|
|
6
|
+
return;
|
|
7
|
+
}
|
|
8
|
+
const arg = versionBump === SemVerBumpType.MAJOR ? 'major' : versionBump === SemVerBumpType.MINOR ? 'minor' : 'patch';
|
|
9
|
+
execSync(`npm version ${arg} --no-git-tag-version`, {
|
|
10
|
+
cwd: pkg.path,
|
|
11
|
+
stdio: 'pipe',
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=PackageManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PackageManager.js","sourceRoot":"","sources":["../../src/services/PackageManager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAG1D,MAAM,OAAO,cAAc;IACzB,WAAW,CAAC,GAAe,EAAE,WAA2B;QACtD,IAAI,WAAW,KAAK,cAAc,CAAC,IAAI,EAAE,CAAC;YACxC,OAAO;QACT,CAAC;QAED,MAAM,GAAG,GAAG,WAAW,KAAK,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,WAAW,KAAK,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC;QAEtH,QAAQ,CAAC,eAAe,GAAG,uBAAuB,EAAE;YAClD,GAAG,EAAE,GAAG,CAAC,IAAI;YACb,KAAK,EAAE,MAAM;SACd,CAAC,CAAC;IACL,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PackageManager.spec.d.ts","sourceRoot":"","sources":["../../src/services/PackageManager.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { describe, it, expect, vi } from 'vitest';
|
|
2
|
+
vi.mock('node:child_process', () => ({ execSync: vi.fn() }));
|
|
3
|
+
import * as cp from 'node:child_process';
|
|
4
|
+
import { PackageManager } from './PackageManager';
|
|
5
|
+
import { SemVerBumpType } from '../models/SemVerBumpType';
|
|
6
|
+
import { NpmPackage } from '../models/NpmPackage';
|
|
7
|
+
function pkg(name, pkgPath) {
|
|
8
|
+
return new NpmPackage(name, pkgPath, '1.0.0', false, {}, {});
|
|
9
|
+
}
|
|
10
|
+
describe('PackageManager.bumpVersion', () => {
|
|
11
|
+
it('does not call npm for NONE', () => {
|
|
12
|
+
const pm = new PackageManager();
|
|
13
|
+
pm.bumpVersion(pkg('a', '/repo/packages/a'), SemVerBumpType.NONE);
|
|
14
|
+
expect(cp.execSync).not.toHaveBeenCalled();
|
|
15
|
+
});
|
|
16
|
+
it('calls npm version major/minor/patch in package cwd', () => {
|
|
17
|
+
const pm = new PackageManager();
|
|
18
|
+
const p = pkg('a', '/repo/packages/a');
|
|
19
|
+
pm.bumpVersion(p, SemVerBumpType.MAJOR);
|
|
20
|
+
expect(cp.execSync).toHaveBeenLastCalledWith('npm version major --no-git-tag-version', { cwd: p.path, stdio: 'pipe' });
|
|
21
|
+
pm.bumpVersion(p, SemVerBumpType.MINOR);
|
|
22
|
+
expect(cp.execSync).toHaveBeenLastCalledWith('npm version minor --no-git-tag-version', { cwd: p.path, stdio: 'pipe' });
|
|
23
|
+
pm.bumpVersion(p, SemVerBumpType.PATCH);
|
|
24
|
+
expect(cp.execSync).toHaveBeenLastCalledWith('npm version patch --no-git-tag-version', { cwd: p.path, stdio: 'pipe' });
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
|
+
//# sourceMappingURL=PackageManager.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PackageManager.spec.js","sourceRoot":"","sources":["../../src/services/PackageManager.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAClD,EAAE,CAAC,IAAI,CAAC,oBAAoB,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;AAC7D,OAAO,KAAK,EAAE,MAAM,oBAAoB,CAAC;AACzC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAElD,SAAS,GAAG,CAAC,IAAY,EAAE,OAAe;IACxC,OAAO,IAAI,UAAU,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;AAC/D,CAAC;AAED,QAAQ,CAAC,4BAA4B,EAAE,GAAG,EAAE;IAC1C,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;QACpC,MAAM,EAAE,GAAG,IAAI,cAAc,EAAE,CAAC;QAChC,EAAE,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,EAAE,kBAAkB,CAAC,EAAE,cAAc,CAAC,IAAI,CAAC,CAAC;QAClE,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oDAAoD,EAAE,GAAG,EAAE;QAC5D,MAAM,EAAE,GAAG,IAAI,cAAc,EAAE,CAAC;QAChC,MAAM,CAAC,GAAG,GAAG,CAAC,GAAG,EAAE,kBAAkB,CAAC,CAAC;QAEvC,EAAE,CAAC,WAAW,CAAC,CAAC,EAAE,cAAc,CAAC,KAAK,CAAC,CAAC;QACxC,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,wBAAwB,CAAC,wCAAwC,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;QAEvH,EAAE,CAAC,WAAW,CAAC,CAAC,EAAE,cAAc,CAAC,KAAK,CAAC,CAAC;QACxC,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,wBAAwB,CAAC,wCAAwC,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;QAEvH,EAAE,CAAC,WAAW,CAAC,CAAC,EAAE,cAAc,CAAC,KAAK,CAAC,CAAC;QACxC,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,wBAAwB,CAAC,wCAAwC,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;IACzH,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { GitService } from './GitService';
|
|
2
|
+
import { HandlebarsRenderService } from './HandlebarsRenderService';
|
|
3
|
+
export declare class ReleaseCommit {
|
|
4
|
+
private readonly vscService;
|
|
5
|
+
private readonly renderService;
|
|
6
|
+
constructor(vscService: GitService, renderService: HandlebarsRenderService);
|
|
7
|
+
commit(context: Record<string, unknown>): void;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=ReleaseCommit.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ReleaseCommit.d.ts","sourceRoot":"","sources":["../../src/services/ReleaseCommit.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,uBAAuB,EAAE,MAAM,2BAA2B,CAAC;AAEpE,qBAAa,aAAa;IAEtB,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,aAAa;gBADb,UAAU,EAAE,UAAU,EACtB,aAAa,EAAE,uBAAuB;IAGzD,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;CAG/C"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export class ReleaseCommit {
|
|
2
|
+
vscService;
|
|
3
|
+
renderService;
|
|
4
|
+
constructor(vscService, renderService) {
|
|
5
|
+
this.vscService = vscService;
|
|
6
|
+
this.renderService = renderService;
|
|
7
|
+
}
|
|
8
|
+
commit(context) {
|
|
9
|
+
this.vscService.commit(this.renderService.render('templates/release-commit-msg.hbs', context));
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=ReleaseCommit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ReleaseCommit.js","sourceRoot":"","sources":["../../src/services/ReleaseCommit.ts"],"names":[],"mappings":"AAGA,MAAM,OAAO,aAAa;IAEL;IACA;IAFnB,YACmB,UAAsB,EACtB,aAAsC;QADtC,eAAU,GAAV,UAAU,CAAY;QACtB,kBAAa,GAAb,aAAa,CAAyB;IACtD,CAAC;IAEJ,MAAM,CAAC,OAAgC;QACrC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,kCAAkC,EAAE,OAAO,CAAC,CAAC,CAAC;IACjG,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sortLessDependenciesFirst.d.ts","sourceRoot":"","sources":["../src/sortLessDependenciesFirst.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE,MAAM,CAAC;IACb,kBAAkB,CAAC,YAAY,EAAE,GAAG,CAAC,MAAM,CAAC,GAAG,MAAM,EAAE,CAAC;CACzD;AAED,wBAAgB,yBAAyB,CAAC,CAAC,SAAS,QAAQ,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,CAAC,EAAE,CA+BhF"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
// package which is dependent less from rest of package must be first (dependencies first)
|
|
2
|
+
export function sortLessDependenciesFirst(packages) {
|
|
3
|
+
// Build graph of internal dependencies (only monorepo packages)
|
|
4
|
+
const packageNames = new Set(packages.map((p) => p.name));
|
|
5
|
+
const graph = new Map();
|
|
6
|
+
for (const pkg of packages) {
|
|
7
|
+
graph.set(pkg.name, pkg.filterDependencies(packageNames));
|
|
8
|
+
}
|
|
9
|
+
// DFS-based topological sort (dependencies first)
|
|
10
|
+
const visited = new Set();
|
|
11
|
+
const visiting = new Set(); // for cycle detection
|
|
12
|
+
const order = [];
|
|
13
|
+
const visit = (name) => {
|
|
14
|
+
if (visited.has(name))
|
|
15
|
+
return;
|
|
16
|
+
if (visiting.has(name))
|
|
17
|
+
return; // cycle detected; break the cycle
|
|
18
|
+
visiting.add(name);
|
|
19
|
+
for (const dep of graph.get(name) ?? []) {
|
|
20
|
+
visit(dep);
|
|
21
|
+
}
|
|
22
|
+
visiting.delete(name);
|
|
23
|
+
visited.add(name);
|
|
24
|
+
order.push(name);
|
|
25
|
+
};
|
|
26
|
+
for (const pkg of packages) {
|
|
27
|
+
visit(pkg.name);
|
|
28
|
+
}
|
|
29
|
+
const byName = new Map(packages.map((p) => [p.name, p]));
|
|
30
|
+
return order.map((name) => byName.get(name)).filter(Boolean);
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=sortLessDependenciesFirst.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sortLessDependenciesFirst.js","sourceRoot":"","sources":["../src/sortLessDependenciesFirst.ts"],"names":[],"mappings":"AAAA,0FAA0F;AAO1F,MAAM,UAAU,yBAAyB,CAAqB,QAAa;IACzE,gEAAgE;IAChE,MAAM,YAAY,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;IAC1D,MAAM,KAAK,GAAG,IAAI,GAAG,EAAoB,CAAC;IAC1C,KAAK,MAAM,GAAG,IAAI,QAAQ,EAAE,CAAC;QAC3B,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,kBAAkB,CAAC,YAAY,CAAC,CAAC,CAAC;IAC5D,CAAC;IAED,kDAAkD;IAClD,MAAM,OAAO,GAAG,IAAI,GAAG,EAAU,CAAC;IAClC,MAAM,QAAQ,GAAG,IAAI,GAAG,EAAU,CAAC,CAAC,sBAAsB;IAC1D,MAAM,KAAK,GAAa,EAAE,CAAC;IAE3B,MAAM,KAAK,GAAG,CAAC,IAAY,EAAE,EAAE;QAC7B,IAAI,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC;YAAE,OAAO;QAC9B,IAAI,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC;YAAE,OAAO,CAAC,kCAAkC;QAClE,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACnB,KAAK,MAAM,GAAG,IAAI,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;YACxC,KAAK,CAAC,GAAG,CAAC,CAAC;QACb,CAAC;QACD,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAClB,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnB,CAAC,CAAC;IAEF,KAAK,MAAM,GAAG,IAAI,QAAQ,EAAE,CAAC;QAC3B,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAClB,CAAC;IAED,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAU,CAAC,CAAC,CAAC;IAClE,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAE,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;AAChE,CAAC"}
|
package/package.json
ADDED
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "release-monorepo-semantically",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"description": "cli commands to manage versioning of package in monorepo and generate changelog",
|
|
5
|
+
"license": "ISC",
|
|
6
|
+
"author": "",
|
|
7
|
+
"type": "module",
|
|
8
|
+
"main": "dist/index.js",
|
|
9
|
+
"bin": {
|
|
10
|
+
"monorepo-semantic-release": "dist/release.cli.js"
|
|
11
|
+
},
|
|
12
|
+
"files": [
|
|
13
|
+
"dist",
|
|
14
|
+
"templates"
|
|
15
|
+
],
|
|
16
|
+
"publishConfig": {
|
|
17
|
+
"access": "public"
|
|
18
|
+
},
|
|
19
|
+
"repository": {
|
|
20
|
+
"type": "git",
|
|
21
|
+
"url": "git+https://github.com/IgorBabkin/release-monorepo-semantically.git"
|
|
22
|
+
},
|
|
23
|
+
"scripts": {
|
|
24
|
+
"build": "tsc",
|
|
25
|
+
"dev": "tsc --watch",
|
|
26
|
+
"start": "node dist/main.js",
|
|
27
|
+
"lint": "eslint src/",
|
|
28
|
+
"test": "vitest run",
|
|
29
|
+
"prepare": "husky"
|
|
30
|
+
},
|
|
31
|
+
"dependencies": {
|
|
32
|
+
"glob": "^10.3.10",
|
|
33
|
+
"handlebars": "^4.7.8"
|
|
34
|
+
},
|
|
35
|
+
"devDependencies": {
|
|
36
|
+
"@eslint/js": "^9.39.2",
|
|
37
|
+
"@semantic-release/commit-analyzer": "^13.0.0",
|
|
38
|
+
"@semantic-release/git": "^10.0.1",
|
|
39
|
+
"@semantic-release/github": "^11.0.0",
|
|
40
|
+
"@semantic-release/npm": "^12.0.1",
|
|
41
|
+
"@semantic-release/release-notes-generator": "^14.0.0",
|
|
42
|
+
"@types/node": "^20.11.0",
|
|
43
|
+
"eslint": "^9.39.2",
|
|
44
|
+
"husky": "^9.1.7",
|
|
45
|
+
"lint-staged": "^16.2.7",
|
|
46
|
+
"prettier": "^3.8.1",
|
|
47
|
+
"semantic-release": "^24.2.0",
|
|
48
|
+
"typescript": "^5.3.3",
|
|
49
|
+
"typescript-eslint": "^8.54.0",
|
|
50
|
+
"vitest": "^4.0.18"
|
|
51
|
+
}
|
|
52
|
+
}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
# [{{entry.version}}](https://github.com/IgorBabkin/ts-ioc-container/compare/{{packageName}}@{{entry.oldVersion}}...{{packageName}}@{{entry.version}}) ({{entry.date}})
|
|
2
|
+
|
|
3
|
+
{{#if entry.breakingChanges.length}}
|
|
4
|
+
### BREAKING CHANGES
|
|
5
|
+
|
|
6
|
+
{{#each entry.breakingChanges}}
|
|
7
|
+
- **{{this.scope}}:**
|
|
8
|
+
{{this.subject}}
|
|
9
|
+
([{{this.hash}}](https://github.com/IgorBabkin/ts-ioc-container/commit/{{this.hash}}))
|
|
10
|
+
{{/each}}
|
|
11
|
+
|
|
12
|
+
{{/if}}
|
|
13
|
+
{{#if entry.features.length}}
|
|
14
|
+
### Features
|
|
15
|
+
|
|
16
|
+
{{#each entry.features}}
|
|
17
|
+
- **{{this.scope}}:**
|
|
18
|
+
{{this.subject}}
|
|
19
|
+
([{{this.hash}}](https://github.com/IgorBabkin/ts-ioc-container/commit/{{this.hash}}))
|
|
20
|
+
{{/each}}
|
|
21
|
+
|
|
22
|
+
{{/if}}
|
|
23
|
+
{{#if entry.fixes.length}}
|
|
24
|
+
### Bug Fixes
|
|
25
|
+
|
|
26
|
+
{{#each entry.fixes}}
|
|
27
|
+
- **{{this.scope}}:**
|
|
28
|
+
{{this.subject}}
|
|
29
|
+
([{{this.hash}}](https://github.com/IgorBabkin/ts-ioc-container/commit/{{this.hash}}))
|
|
30
|
+
{{/each}}
|
|
31
|
+
|
|
32
|
+
{{/if}}
|
|
33
|
+
{{#if entry.performance.length}}
|
|
34
|
+
### Performance Improvements
|
|
35
|
+
|
|
36
|
+
{{#each entry.performance}}
|
|
37
|
+
- **{{this.scope}}:**
|
|
38
|
+
{{this.subject}}
|
|
39
|
+
([{{this.hash}}](https://github.com/IgorBabkin/ts-ioc-container/commit/{{this.hash}}))
|
|
40
|
+
{{/each}}
|
|
41
|
+
|
|
42
|
+
{{/if}}
|
|
43
|
+
{{#if entry.dependencyUpdates.length}}
|
|
44
|
+
### Dependencies
|
|
45
|
+
|
|
46
|
+
{{#each entry.dependencyUpdates}}
|
|
47
|
+
- update
|
|
48
|
+
{{this.packageName}}
|
|
49
|
+
to
|
|
50
|
+
{{this.newVersion}}
|
|
51
|
+
{{/each}}
|
|
52
|
+
|
|
53
|
+
{{/if}}
|
|
54
|
+
|
|
55
|
+
{{existing}}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
release: semantic
|