mirror of
https://code.mensbeam.com/MensBeam/Arsse.git
synced 2025-01-18 17:10:33 +00:00
Integrate RPM packaging into tasks
The packages themselves are not ready yet. Also adds RPM changelog
This commit is contained in:
parent
45d419f82f
commit
bc93dca240
3 changed files with 46 additions and 60 deletions
78
RoboFile.php
78
RoboFile.php
|
@ -244,7 +244,10 @@ class RoboFile extends \Robo\Tasks {
|
||||||
}
|
}
|
||||||
// establish which commit to package
|
// establish which commit to package
|
||||||
[$commit, $version] = $this->commitVersion($commit);
|
[$commit, $version] = $this->commitVersion($commit);
|
||||||
$archVersion = preg_replace('/^([^-]+)-(\d+)-(\w+)$/', "$1.r$2.$3", $version);
|
preg_match('/^([^-]+)(?:-(\d+)-(\w+))?$/', $version, $m);
|
||||||
|
$archVersion = $m[1].($m[2] ? ".r$m[2].$m[3]" : "");
|
||||||
|
$baseVersion = $m[1];
|
||||||
|
$release = $m[2];
|
||||||
// name the generic release tarball
|
// name the generic release tarball
|
||||||
$tarball = BASE."release/$version/arsse-$version.tar.gz";
|
$tarball = BASE."release/$version/arsse-$version.tar.gz";
|
||||||
// start a collection
|
// start a collection
|
||||||
|
@ -257,17 +260,30 @@ class RoboFile extends \Robo\Tasks {
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
if (file_exists($dir."dist/debian")) {
|
// Perform Arch-specific tasks
|
||||||
// generate the Debian changelog; this also validates our original changelog
|
|
||||||
$debianChangelog = $this->changelogDebian($this->changelogParse(file_get_contents($dir."CHANGELOG"), $version), $version);
|
|
||||||
// save the Debian-format changelog
|
|
||||||
$t->addTask($this->taskWriteToFile($dir."dist/debian/changelog")->text($debianChangelog));
|
|
||||||
}
|
|
||||||
if (file_exists($dir."dist/arch")) {
|
if (file_exists($dir."dist/arch")) {
|
||||||
// patch the Arch PKGBUILD file with the correct version string
|
// patch the Arch PKGBUILD file with the correct version string
|
||||||
$t->addTask($this->taskReplaceInFile($dir."dist/arch/PKGBUILD")->regex('/^pkgver=.*$/m')->to("pkgver=$archVersion"));
|
$t->addTask($this->taskReplaceInFile($dir."dist/arch/PKGBUILD")->regex('/^pkgver=.*$/m')->to("pkgver=$archVersion"));
|
||||||
// patch the Arch PKGBUILD file with the correct source file
|
// patch the Arch PKGBUILD file with the correct source file
|
||||||
$t->addTask($this->taskReplaceInFile($dir."dist/arch/PKGBUILD")->regex('/^source=\("arsse-[^"]+"\)$/m')->to('source=("'.basename($tarball).'")'));
|
$t->addTask($this->taskReplaceInFile($dir."dist/arch/PKGBUILD")->regex('/^source=\("arsse-[^"]+"\)$/m')->to('source=("'.basename($tarball).'")'));
|
||||||
|
// perform Debian-specific tasks
|
||||||
|
if (file_exists($dir."dist/debian")) {
|
||||||
|
// generate the Debian changelog; this also validates our original changelog
|
||||||
|
$changelog = $this->changelogParse(file_get_contents($dir."CHANGELOG"), $version);
|
||||||
|
$debianChangelog = $this->changelogDebian($changelog, $version);
|
||||||
|
// save the Debian-format changelog
|
||||||
|
$t->addTask($this->taskWriteToFile($dir."dist/debian/changelog")->text($debianChangelog));
|
||||||
|
// perform RPM-specific tasks
|
||||||
|
if (file_exists($dir."dist/rpm")) {
|
||||||
|
// patch the spec file with the correct version and release
|
||||||
|
$t->addTask($this->taskReplaceInFile($dir."dist/rpm/arsse.spec")->regex('/^Version: .*$/m')->to("Version: $baseVersion"));
|
||||||
|
$t->addTask($this->taskReplaceInFile($dir."dist/rpm/arsse.spec")->regex('/^Release: .*$/m')->to("Release: $release"));
|
||||||
|
// patch the spec file with the correct tarball name
|
||||||
|
$t->addTask($this->taskReplaceInFile($dir."dist/rpm/arsse.spec")->regex('/^Source0: .*$/m')->to("Source0: arsse-$version.tar.gz"));
|
||||||
|
// append the RPM changelog to the spec file
|
||||||
|
$t->addTask($this->taskWriteToFile($dir."dist/rpm/arsse.spec")->append(true)->text("\n\n%changelog\n".$this->changelogRPM($changelog, $version)));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// save commit description to VERSION file for reference
|
// save commit description to VERSION file for reference
|
||||||
$t->addTask($this->taskWriteToFile($dir."VERSION")->text($version));
|
$t->addTask($this->taskWriteToFile($dir."VERSION")->text($version));
|
||||||
|
@ -336,40 +352,6 @@ class RoboFile extends \Robo\Tasks {
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Packages a given commit of the software into an Arch package
|
|
||||||
*
|
|
||||||
* The commit to package may be any Git tree-ish identifier: a tag, a branch,
|
|
||||||
* or any commit hash. If none is provided on the command line, Robo will prompt
|
|
||||||
* for a commit to package; the default is "HEAD".
|
|
||||||
*
|
|
||||||
* The Arch base-devel group should be installed for this.
|
|
||||||
*/
|
|
||||||
public function packageArch(string $commit = null): Result {
|
|
||||||
if (!$this->toolExists("git", "makepkg", "updpkgsums")) {
|
|
||||||
throw new \Exception("Git, makepkg, and updpkgsums are required in PATH to produce Arch packages");
|
|
||||||
}
|
|
||||||
// establish which commit to package
|
|
||||||
[$commit, $version] = $this->commitVersion($commit);
|
|
||||||
$tarball = BASE."release/$version/arsse-$version.tar.gz";
|
|
||||||
$dir = dirname($tarball).\DIRECTORY_SEPARATOR;
|
|
||||||
// start a collection
|
|
||||||
$t = $this->collectionBuilder();
|
|
||||||
// build the generic release tarball if it doesn't exist
|
|
||||||
if (!file_exists($tarball)) {
|
|
||||||
$t->addTask($this->taskExec(BASE."robo package:generic $commit"));
|
|
||||||
}
|
|
||||||
// extract the PKGBUILD from the tarball
|
|
||||||
$t->addCode(function() use ($tarball, $dir) {
|
|
||||||
// because Robo doesn't support extracting a single file we have to do it ourselves
|
|
||||||
(new \Archive_Tar($tarball))->extractList("arsse/dist/arch/PKGBUILD", $dir, "arsse/dist/arch/", false);
|
|
||||||
// perform a do-nothing filesystem operation since we need a Robo task result
|
|
||||||
return $this->taskFilesystemStack()->chmod($dir."PKGBUILD", 0644)->run();
|
|
||||||
})->completion($this->taskFilesystemStack()->remove($dir."PKGBUILD"));
|
|
||||||
// build the package
|
|
||||||
$t->addTask($this->taskExec("makepkg -Ccf")->dir($dir));
|
|
||||||
return $t->run();
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Packages a release tarball into a Debian source package
|
/** Packages a release tarball into a Debian source package
|
||||||
*
|
*
|
||||||
* The commit to package may be any Git tree-ish identifier: a tag, a branch,
|
* The commit to package may be any Git tree-ish identifier: a tag, a branch,
|
||||||
|
@ -628,16 +610,12 @@ class RoboFile extends \Robo\Tasks {
|
||||||
}
|
}
|
||||||
$out = "";
|
$out = "";
|
||||||
foreach ($log as $entry) {
|
foreach ($log as $entry) {
|
||||||
// normalize the version string
|
$out .= "* ";
|
||||||
preg_match('/^(\d+(?:\.\d+)*(?:-\d+)?).+$/D', $entry['version'], $m);
|
$out .= DateTimeImmutable::createFromFormat("!Y-m-d", $entry['date'], new \DateTimeZone("UTC"))->format("D M d Y");
|
||||||
$version = $m[1];
|
$out .= " ";
|
||||||
// output the entry
|
|
||||||
$out .= "-------------------------------------------------------------------\n";
|
|
||||||
$out .= DateTimeImmutable::createFromFormat("!Y-m-d", $entry['date'], new \DateTimeZone("UTC"))->format("D, M d 00:00:00 \U\T\C Y");
|
|
||||||
$out .= " - ";
|
|
||||||
$out .= "J. King <jking@jkingweb.ca>";
|
$out .= "J. King <jking@jkingweb.ca>";
|
||||||
$out .= " - ";
|
$out .= " ";
|
||||||
$out .= "$version\n\n";
|
$out .= "{$entry['version']}\n";
|
||||||
foreach ($entry['features'] as $item) {
|
foreach ($entry['features'] as $item) {
|
||||||
$out .= "- ".trim(preg_replace("/^/m", " ", $item))."\n";
|
$out .= "- ".trim(preg_replace("/^/m", " ", $item))."\n";
|
||||||
}
|
}
|
||||||
|
|
4
dist/rpm/arsse.spec
vendored
4
dist/rpm/arsse.spec
vendored
|
@ -110,10 +110,10 @@ install -m 644 dist/sysuser.conf %{buildroot}%{_sysusersdir}/system-user-arsse.c
|
||||||
%{_sysusersdir}/system-user-arsse.conf
|
%{_sysusersdir}/system-user-arsse.conf
|
||||||
|
|
||||||
%pre
|
%pre
|
||||||
%service_add_pre arsse.service demo1.service
|
%service_add_pre arsse.service arsse.service
|
||||||
|
|
||||||
%post
|
%post
|
||||||
%service_add_post arsse.service demo1.service
|
%service_add_post arsse.service arsse.service
|
||||||
|
|
||||||
%preun
|
%preun
|
||||||
%service_del_preun arsse.service
|
%service_del_preun arsse.service
|
||||||
|
|
|
@ -16,4 +16,12 @@ return [
|
||||||
'recipe' => "*.dsc",
|
'recipe' => "*.dsc",
|
||||||
'output' => "/usr/src/packages/DEBS/*.deb",
|
'output' => "/usr/src/packages/DEBS/*.deb",
|
||||||
],
|
],
|
||||||
|
'suse' => [
|
||||||
|
'type' => "rpm",
|
||||||
|
'repos' => ["http://mirror.csclub.uwaterloo.ca/opensuse/distribution/leap/15.3/repo/oss/"],
|
||||||
|
'keys' => ["gpg-pubkey-39db7c82-5f68629b", "gpg-pubkey-65176565-5d94a381", "gpg-pubkey-307e3d54-5aaa90a5", "gpg-pubkey-3dbdc284-53674dd4"],
|
||||||
|
'dist' => "sl15.3",
|
||||||
|
'recipe' => "arsse.spec",
|
||||||
|
'output' => "/home/abuild/rpmbuild/RPMS/noarch/*.rpm",
|
||||||
|
],
|
||||||
];
|
];
|
||||||
|
|
Loading…
Add table
Reference in a new issue