aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorEuAndreh <eu@euandre.org>2023-03-31 16:32:13 -0300
committerEuAndreh <eu@euandre.org>2023-03-31 16:32:13 -0300
commite73ab3d472db46f179054b8472206e0aa1a3e142 (patch)
tree0bed3fa03a215c46a200624d36fbb965ded6e3ac /src
parentMakefile: Get URLs from JSON over duplicating it here (diff)
downloadpackage-repository-e73ab3d472db46f179054b8472206e0aa1a3e142.tar.gz
package-repository-e73ab3d472db46f179054b8472206e0aa1a3e142.tar.xz
src/bin/paku.in: Remove duplicate logic from templates, put it in paku.lock
Diffstat (limited to 'src')
-rwxr-xr-xsrc/bin/paku.in48
1 files changed, 20 insertions, 28 deletions
diff --git a/src/bin/paku.in b/src/bin/paku.in
index d2900f2..71f29c2 100755
--- a/src/bin/paku.in
+++ b/src/bin/paku.in
@@ -247,9 +247,8 @@ sub emit_nix() {
$long =~ s/^(.)/ $1/gm;
my $license = license_for 'nix', $license_mapping, $pkg->{license};
- my $suffix = $pkg->{label} eq 'latest' ? '' : "-$pkg->{label}";
print <<~EOF;
- $pkg->{name}$suffix = pkgs.stdenv.mkDerivation rec {
+ $pkg->{'full-name'} = pkgs.stdenv.mkDerivation rec {
name = "$pkg->{name}";
version = "$pkg->{vlabel}";
@@ -334,12 +333,9 @@ sub emit_guix() {
$long =~ s/^(.)/ $1/gm;
my $license = license_for 'guix', $license_mapping, $pkg->{license};
- my $name = $pkg->{name} . (
- $pkg->{label} eq 'latest' ? '' : "-$pkg->{label}"
- );
- push @pkgs, $name;
+ push @pkgs, $pkg->{'full-name'};
print <<~EOF;
- (define-public $name
+ (define-public $pkg->{'full-name'}
(package
(name "$pkg->{name}")
(version "$pkg->{vlabel}")
@@ -533,9 +529,7 @@ sub emit_alpine() {
my $date = $pkg->{date} =~ s/-//gr;
my $ver = $pkg->{label} eq 'latest' ? "0.0.1_git$date" : $pkg->{vversion};
- my $dir = "$d/$pkg->{name}" . (
- $pkg->{label} eq 'latest' ? '' : "-$pkg->{label}"
- );
+ my $dir = "$d/$pkg->{'full-name'}";
mkdir "$dir";
open(my $fh, '>', "$dir/APKBUILD");
print $fh <<~EOF;
@@ -588,9 +582,7 @@ sub emit_alpine() {
my $date = $pkg->{date} =~ s/-//gr;
my $ver = $pkg->{label} eq 'latest' ? "0.0.1_git$date" : $pkg->{vversion};
- my $recipe_dir = "src/alpine/$pkg->{name}" . (
- $pkg->{label} eq 'latest' ? '' : "-$pkg->{label}"
- ) . '/';
+ my $recipe_dir = "src/alpine/$pkg->{'full-name'}/";
my $apk_name = "$pkg->{name}-$ver-r0.apk";
my $apk_path = "\$(DIR)/alpine/REPODEST/alpine/x86_64/$apk_name";
@@ -647,11 +639,8 @@ sub emit_homebrew() {
my $d = $ARGV[0] or die 'Missing "Formula/" directory';
my $json = load_json();
for my $pkg (@{$json->{pkgs}}) {
- my $name = $pkg->{name} . (
- $pkg->{label} eq 'latest' ? '' : "-$pkg->{label}"
- );
- open(my $fh, '>', "$d/$name.rb");
- my $class_name = pascal_case $name;
+ open(my $fh, '>', "$d/$pkg->{'full-name'}.rb");
+ my $class_name = pascal_case $pkg->{'full-name'};
print $fh <<~EOF;
class $class_name < Formula
desc '$pkg->{description}'
@@ -741,19 +730,17 @@ sub emit_html() {
EOF
for my $pkg (@{$json->{pkgs}}) {
- my $guix_suffix = $pkg->{label} eq 'latest' ? '' : '@' . $pkg->{label} =~ s/-/./gr;
- my $suffix = $pkg->{label} eq 'latest' ? '' : "-$pkg->{label}";
- my $apt_suffix = $suffix =~ s/-/=/r;
+ my $guix_suffix = $pkg->{label} eq 'latest' ? '' : "\@$pkg->{version}";
+ my $apt_suffix = $pkg->{label} eq 'latest' ? '' : "=$pkg->{label}";
my $id = $pkg->{name} . (
$pkg->{label} eq 'latest' ? '' : "-$pkg->{vversion}"
);
- my $label = $pkg->{label} eq 'latest' ? 'latest' : $pkg->{vversion};
print <<~EOF;
<li id="$id">
<details>
<summary>
<a href="#$id">$pkg->{name}</a>
- ($label) - $pkg->{description}
+ ($pkg->{vname}) - $pkg->{description}
</summary>
<p>
<a href="$pkg->{homepage}">Homepage</a>
@@ -802,11 +789,11 @@ sub emit_html() {
to include this repository as an overlay, you
can launch a shell that includes this package:
</p>
- <pre><code>\$ nix-shell -p $pkg->{name}$suffix</code></pre>
+ <pre><code>\$ nix-shell -p $pkg->{'full-name'}</code></pre>
<p>
Alternatively, you can install it imperatively:
</p>
- <pre><code>\$ nix-env -i $pkg->{name}$suffix</code></pre>
+ <pre><code>\$ nix-env -i $pkg->{'full-name'}</code></pre>
</section>
<section>
<h2>Homebrew</h2>
@@ -816,7 +803,7 @@ sub emit_html() {
to include this repository as a <code>tap</code>, you can
install it with:
</p>
- <pre><code>\$ brew install $pkg->{name}$suffix</code></pre>
+ <pre><code>\$ brew install $pkg->{'full-name'}</code></pre>
</section>
</details>
</li>
@@ -1063,7 +1050,7 @@ sub emit_refresh() {
type => 'branch',
vversion => $revision,
version => $_,
- vname => $revision,
+ vname => $label,
vlabel => $revision,
label => $label,
);
@@ -1077,6 +1064,11 @@ sub emit_refresh() {
architectures => 'any',
};
+ my $full_name = $pkg->{name} . (
+ $pkg->{label} eq 'latest' ? '' : "-$pkg->{label}"
+ );
+ $pkg->{'full-name'} = $full_name;
+
my $revision = `git -C '$dir' rev-parse '$pkg->{vversion}'`;
die if $?;
chomp $revision;
@@ -1084,7 +1076,7 @@ sub emit_refresh() {
`git -C '$dir' checkout '$pkg->{vversion}'`;
die if $?;
- my $url = run_template($package->{name}, $pkg->{vname}, $out->{defaults}{templates}{tarball});
+ my $url = run_template($package->{name}, $pkg->{vversion}, $out->{defaults}{templates}{tarball});
$pkg->{url} = $url;
my $date = `git -C '$dir' log -1 --format=%cs`;