]> Sergey Matveev's repositories - public-inbox.git/commitdiff
www: make coderepo URL generation more consistent
authorEric Wong <e@80x24.org>
Wed, 4 Jan 2023 10:34:05 +0000 (10:34 +0000)
committerEric Wong <e@80x24.org>
Thu, 5 Jan 2023 09:59:00 +0000 (09:59 +0000)
WwwStream and WwwText basically show the same thing, except the
latter relies on Linkify to create links.

lib/PublicInbox/WwwStream.pm
lib/PublicInbox/WwwText.pm

index f5b4df9fe061886b08bca636052b5e02b8f9472f..59edad5de5bd4238212b45f06c2b174f4e6ed7ae 100644 (file)
@@ -90,24 +90,22 @@ sub coderepos ($) {
        my ($ctx) = @_;
        $ctx->{ibx} // return inboxes($ctx);
        my $cr = $ctx->{ibx}->{coderepo} // return ();
-       my $cfg = $ctx->{www}->{pi_cfg};
        my $upfx = ($ctx->{-upfx} // ''). '../';
        my $pfx = $ctx->{base_url} //= $ctx->base_url;
        my $up = $upfx =~ tr!/!/!;
        $pfx =~ s!/[^/]+\z!/! for (1..$up);
-       my @ret = ('<a id=code>' .
+       $pfx .= '/' if substr($pfx, -1, 1) ne '/';
+       my $buf = '<a id=code>' .
                'Code repositories for project(s) associated with this '.
-               $ctx->{ibx}->thing_type . "\n");
-       my $objs = $cfg->repo_objs($ctx->{ibx});
-       for my $git (@$objs) {
-               my @urls = $git->pub_urls($ctx->{env});
-               for (@urls) {
-                       my $u = m!\A(?:[a-z\+]+:)?//! ? $_ : $pfx.$_;
+               $ctx->{ibx}->thing_type . "\n";
+       for my $git (@{$ctx->{www}->{pi_cfg}->repo_objs($ctx->{ibx})}) {
+               for ($git->pub_urls($ctx->{env})) {
+                       my $u = m!\A(?:[a-z\+]+:)?//!i ? $_ : $pfx.$_;
                        $u = ascii_html(prurl($ctx->{env}, $u));
-                       $ret[0] .= qq(\n\t<a\nhref="$u">$u</a>);
+                       $buf .= qq(\n\t<a\nhref="$u">$u</a>);
                }
        }
-       @ret; # may be empty, this sub is called as an arg for join()
+       ($buf);
 }
 
 sub _html_end {
index 224fed5ce7d570b8c0d6457e0a0f2b16bebe104a..c31a7f86ecd37fa4b1a13a599af6f0a79ca87bd1 100644 (file)
@@ -250,21 +250,15 @@ sub coderepos_raw ($$) {
        my ($ctx, $top_url) = @_;
        my $cr = $ctx->{ibx}->{coderepo} // return ();
        my $cfg = $ctx->{www}->{pi_cfg};
-       my @ret = ('Code repositories for project(s) associated with this '.
-               $ctx->{ibx}->thing_type . "\n");
-       for my $cr_name (@$cr) {
-               my $urls = $cfg->get_all("coderepo.$cr_name.cgiturl");
-               if ($urls) {
-                       for (@$urls) {
-                               my $u = m!\A(?:[a-z\+]+:)?//!i ? $_ :
-                                       $top_url.$_;
-                               $ret[0] .= "\n\t" . prurl($ctx->{env}, $u);
-                       }
-               } else {
-                       $ret[0] .= qq[\n\t$cr_name.git (no URL configured)];
+       my $buf = 'Code repositories for project(s) associated with this '.
+               $ctx->{ibx}->thing_type . "\n";
+       for my $git (@{$ctx->{www}->{pi_cfg}->repo_objs($ctx->{ibx})}) {
+               for ($git->pub_urls($ctx->{env})) {
+                       my $u = m!\A(?:[a-z\+]+:)?//!i ? $_ : $top_url.$_;
+                       $buf .= "\n\t" . prurl($ctx->{env}, $u);
                }
        }
-       @ret; # may be empty, this sub is called as an arg for join()
+       ($buf);
 }
 
 sub _add_non_http_urls ($$) {