-
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathChangelogNextVersionCommand.php
More file actions
123 lines (111 loc) · 4.03 KB
/
ChangelogNextVersionCommand.php
File metadata and controls
123 lines (111 loc) · 4.03 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
<?php
declare(strict_types=1);
/**
* Fast Forward Development Tools for PHP projects.
*
* This file is part of fast-forward/dev-tools project.
*
* @author Felipe Sayão Lobato Abreu <github@mentordosnerds.com>
* @license https://opensource.org/licenses/MIT MIT License
*
* @see https://github.com/php-fast-forward/
* @see https://github.com/php-fast-forward/dev-tools
* @see https://github.com/php-fast-forward/dev-tools/issues
* @see https://php-fast-forward.github.io/dev-tools/
* @see https://datatracker.ietf.org/doc/html/rfc2119
*/
namespace FastForward\DevTools\Console\Command;
use FastForward\DevTools\Console\Command\Traits\LogsCommandResults;
use Throwable;
use Composer\Command\BaseCommand;
use FastForward\DevTools\Changelog\Manager\ChangelogManagerInterface;
use FastForward\DevTools\Console\Input\HasJsonOption;
use FastForward\DevTools\Filesystem\FilesystemInterface;
use Psr\Log\LoggerInterface;
use Symfony\Component\Console\Attribute\AsCommand;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface;
/**
* Infers the next semantic version from changelog content.
*/
#[AsCommand(
name: 'changelog:next-version',
description: 'Infers the next semantic version from the Unreleased changelog section.'
)]
final class ChangelogNextVersionCommand extends BaseCommand implements LoggerAwareCommandInterface
{
use HasJsonOption;
use LogsCommandResults;
/**
* @param FilesystemInterface $filesystem
* @param ChangelogManagerInterface $changelogManager
* @param LoggerInterface $logger
*/
public function __construct(
private readonly FilesystemInterface $filesystem,
private readonly ChangelogManagerInterface $changelogManager,
private readonly LoggerInterface $logger,
) {
parent::__construct();
}
/**
* Configures version inference options.
*/
protected function configure(): void
{
$this->setHelp(
'This command inspects Unreleased changelog categories and prints the next semantic version inferred'
. ' from the current changelog state.'
);
$this->addJsonOption()
->addOption(
name: 'file',
mode: InputOption::VALUE_REQUIRED,
description: 'Path to the changelog file.',
default: 'CHANGELOG.md',
)
->addOption(
name: 'current-version',
mode: InputOption::VALUE_REQUIRED,
description: 'Explicit current version to use as the bump base.',
);
}
/**
* Prints the inferred next semantic version.
*
* @param InputInterface $input
* @param OutputInterface $output
*/
protected function execute(InputInterface $input, OutputInterface $output): int
{
try {
$path = $this->filesystem->getAbsolutePath($input->getOption('file'));
$currentVersion = $input->getOption('current-version');
$nextVersion = $this->changelogManager->inferNextVersion($path, $currentVersion);
// This command is consumed via shell capture in changelog.yml, so
// plain-text mode MUST keep emitting the raw version string.
if (! $this->isJsonOutput($input)) {
$output->writeln($nextVersion);
return self::SUCCESS;
}
return $this->success(
$nextVersion,
$input,
[
'current_version' => $currentVersion,
'next_version' => $nextVersion,
],
);
} catch (Throwable $throwable) {
return $this->failure(
'Unable to infer the next changelog version.',
$input,
[
'exception_message' => $throwable->getMessage(),
],
(string) $input->getOption('file'),
);
}
}
}