aboutsummaryrefslogtreecommitdiff
path: root/ports-mgmt
diff options
context:
space:
mode:
authorRyan Steinmetz <zi@FreeBSD.org>2019-03-13 14:01:46 +0000
committerRyan Steinmetz <zi@FreeBSD.org>2019-03-13 14:01:46 +0000
commitc9e2d877b44827f65b18698b633d89b3f4e12b78 (patch)
treeb9d4be5b87f192aa46554c8ecd037ea3186b6c7c /ports-mgmt
parentca99d08fef5f18a95de6506476249008d0c9d458 (diff)
- Update to 0.8.1.2
Approved by: koobs@ (maintainer)
Notes
Notes: svn path=/head/; revision=495575
Diffstat (limited to 'ports-mgmt')
-rw-r--r--ports-mgmt/portscout/Makefile15
-rw-r--r--ports-mgmt/portscout/distinfo5
-rw-r--r--ports-mgmt/portscout/files/files-Portscout-SiteHandler-GitHub.pm175
-rw-r--r--ports-mgmt/portscout/files/files-Portscout-SiteHandler-PyPI.pm146
-rw-r--r--ports-mgmt/portscout/files/patch-Portscout_DataSrc_Ports.pm81
-rw-r--r--ports-mgmt/portscout/files/patch-Portscout_SiteHandler.pm11
-rw-r--r--ports-mgmt/portscout/files/patch-Portscout_SiteHandler_GitHub.pm38
-rw-r--r--ports-mgmt/portscout/files/patch-Portscout_SiteHandler_PyPI.pm16
-rw-r--r--ports-mgmt/portscout/files/patch-Portscout_SiteHandler_SourceForge.pm11
-rw-r--r--ports-mgmt/portscout/files/patch-portscout.conf14
-rw-r--r--ports-mgmt/portscout/files/patch-portscout.pl226
11 files changed, 8 insertions, 730 deletions
diff --git a/ports-mgmt/portscout/Makefile b/ports-mgmt/portscout/Makefile
index 11bd66f0df8d..48bf719434d6 100644
--- a/ports-mgmt/portscout/Makefile
+++ b/ports-mgmt/portscout/Makefile
@@ -2,12 +2,8 @@
# $FreeBSD$
PORTNAME= portscout
-PORTVERSION= 0.8.1
-PORTREVISION= 11
+PORTVERSION= 0.8.1.2
CATEGORIES= ports-mgmt
-MASTER_SITES= http://mirror.inerd.com/FreeBSD/distfiles/${PORTNAME}/ \
- http://www.atarininja.org/~wxs/distfiles/ \
- http://www.inerd.com/software/${PORTNAME}/
MAINTAINER= koobs@FreeBSD.org
COMMENT= Tool to scan for new versions of FreeBSD ports
@@ -23,6 +19,10 @@ RUN_DEPENDS= p5-DBI>=0:databases/p5-DBI \
p5-libwww>=0:www/p5-libwww \
p5-JSON>0:converters/p5-JSON
+USES= perl5 shebangfix
+USE_GITHUB= yes
+GH_ACCOUNT= freebsd
+
OPTIONS_DEFINE= DOCS HTTPS
OPTIONS_DEFAULT= HTTPS PGSQL
@@ -30,7 +30,6 @@ OPTIONS_MULTI= DATABASE
OPTIONS_MULTI_DATABASE= SQLITE PGSQL
DATABASE_DESC= Database Backends
-USES= perl5 shebangfix
NO_ARCH= yes
NO_BUILD= yes
@@ -57,10 +56,6 @@ pre-everything::
@${ECHO_MSG} "+-------------------------------------------------------------+"
.endif
-post-extract:
- @${CP} ${FILESDIR}/files-Portscout-SiteHandler-GitHub.pm ${WRKSRC}/Portscout/SiteHandler/GitHub.pm
- @${CP} ${FILESDIR}/files-Portscout-SiteHandler-PyPI.pm ${WRKSRC}/Portscout/SiteHandler/PyPI.pm
-
pre-install:
@${REINPLACE_CMD} -e "s#^\(templates .*\)/etc#\1/share#" \
-e "s#^prefix\( *= *\).*#prefix\1${PREFIX}#" \
diff --git a/ports-mgmt/portscout/distinfo b/ports-mgmt/portscout/distinfo
index 8604898a5d66..e69cd0933426 100644
--- a/ports-mgmt/portscout/distinfo
+++ b/ports-mgmt/portscout/distinfo
@@ -1,2 +1,3 @@
-SHA256 (portscout-0.8.1.tar.gz) = fec03f53a64e44e44debbbebe985e61f8603729145899c152286ecd5effe8b65
-SIZE (portscout-0.8.1.tar.gz) = 56079
+TIMESTAMP = 1552485071
+SHA256 (freebsd-portscout-0.8.1.2_GH0.tar.gz) = c709ec73229e6abce56dd5cee1af0aca6362552676601b386b6b3d5365b588e8
+SIZE (freebsd-portscout-0.8.1.2_GH0.tar.gz) = 57138
diff --git a/ports-mgmt/portscout/files/files-Portscout-SiteHandler-GitHub.pm b/ports-mgmt/portscout/files/files-Portscout-SiteHandler-GitHub.pm
deleted file mode 100644
index 7de8a9ecfbe7..000000000000
--- a/ports-mgmt/portscout/files/files-Portscout-SiteHandler-GitHub.pm
+++ /dev/null
@@ -1,175 +0,0 @@
-#------------------------------------------------------------------------------
-# Copyright (C) 2014, Jasper Lievisse Adriaanse <jasper@openbsd.org>
-#
-# Permission to use, copy, modify, and distribute this software for any
-# purpose with or without fee is hereby granted, provided that the above
-# copyright notice and this permission notice appear in all copies.
-#
-# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
-# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
-# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
-# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
-# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
-# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
-# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
-#
-#------------------------------------------------------------------------------
-
-package Portscout::SiteHandler::GitHub;
-
-use JSON qw(decode_json);
-use LWP::UserAgent;
-
-use Portscout::Const;
-use Portscout::Config;
-
-use strict;
-
-require 5.006;
-
-
-#------------------------------------------------------------------------------
-# Globals
-#------------------------------------------------------------------------------
-
-push @Portscout::SiteHandler::sitehandlers, __PACKAGE__;
-
-our %settings;
-
-
-#------------------------------------------------------------------------------
-# Func: new()
-# Desc: Constructor.
-#
-# Args: n/a
-#
-# Retn: $self
-#------------------------------------------------------------------------------
-
-sub new
-{
- my $self = {};
- my $class = shift;
-
- $self->{name} = 'GitHub';
-
- bless ($self, $class);
- return $self;
-}
-
-
-#------------------------------------------------------------------------------
-# Func: CanHandle()
-# Desc: Ask if this handler (package) can handle the given site.
-#
-# Args: $url - URL of site.
-#
-# Retn: $res - true/false.
-#------------------------------------------------------------------------------
-
-sub CanHandle
-{
- my $self = shift;
-
- my ($url) = @_;
-
- return ($url =~ /^https?:\/\/([^\/.]+\.)?github\.com\/(.*?)\/tar.gz/);
-}
-
-
-#------------------------------------------------------------------------------
-# Func: GetFiles()
-# Desc: Extract a list of files from the given URL. In the case of GitHub,
-# we are actually pulling the files from the project's Atom feed and
-# extract the release url, containing the tag it was based on.
-#
-# Args: $url - URL we would normally fetch from.
-# \%port - Port hash fetched from database.
-# \@files - Array to put files into.
-#
-# Retn: $success - False if file list could not be constructed; else, true.
-#------------------------------------------------------------------------------
-
-sub GetFiles
-{
- my $self = shift;
-
- my ($url, $port, $files) = @_;
- my $projname;
-
- if ($url =~ /https:\/\/github\.com\/(.*?)\/archive\//) {
- $projname = $1;
- } elsif ($url =~ /https:\/\/github.com\/downloads\/(.*)\//) {
- $projname = $1;
- }
-
- if ($projname) {
- my ($query, $ua, $response, $items, $json);
-
- # First check if there's a latest releases endpoint
- $query = 'https://api.github.com/repos/' . $projname . '/releases/latest';
-
- _debug("GET $query");
- $ua = LWP::UserAgent->new;
- $ua->agent(USER_AGENT);
- $ua->timeout($settings{http_timeout});
-
- $response = $ua->request(HTTP::Request->new(GET => $query));
-
- if (!$response->is_success || $response->status_line !~ /^2/) {
- _debug('GET failed: ' . $response->status_line);
- # Project didn't do any releases, so let's try tags instead.
- $query = 'https://api.github.com/repos/' . $projname . '/tags';
- _debug("GET $query");
- $ua = LWP::UserAgent->new;
- $ua->agent(USER_AGENT);
- $ua->timeout($settings{http_timeout});
-
- $response = $ua->request(HTTP::Request->new(GET => $query));
-
- if (!$response->is_success || $response->status_line !~ /^2/) {
- _debug('GET failed: ' . $response->status_line);
- return 0;
- }
-
- $json = decode_json($response->decoded_content);
- foreach my $tag (@$json) {
- my $tag_url = $tag->{tarball_url};
- push(@$files, $tag_url);
- }
-
- _debug('Found ' . scalar @$files . ' files');
- return 1;
- }
-
- $json = decode_json($response->decoded_content);
- push(@$files, $json->{tarball_url});
-
- _debug('Found ' . scalar @$files . ' files');
- } else {
- return 0;
- }
-
- return 1;
-}
-
-
-#------------------------------------------------------------------------------
-# Func: _debug()
-# Desc: Print a debug message.
-#
-# Args: $msg - Message.
-#
-# Retn: n/a
-#------------------------------------------------------------------------------
-
-sub _debug
-{
- my ($msg) = @_;
-
- $msg = '' if (!$msg);
-
- print STDERR "(" . __PACKAGE__ . ") $msg\n" if ($settings{debug});
-}
-
-1;
diff --git a/ports-mgmt/portscout/files/files-Portscout-SiteHandler-PyPI.pm b/ports-mgmt/portscout/files/files-Portscout-SiteHandler-PyPI.pm
deleted file mode 100644
index 071a8fabb27d..000000000000
--- a/ports-mgmt/portscout/files/files-Portscout-SiteHandler-PyPI.pm
+++ /dev/null
@@ -1,146 +0,0 @@
-#------------------------------------------------------------------------------
-# Copyright (C) 2015, Jasper Lievisse Adriaanse <jasper@openbsd.org>
-#
-# Permission to use, copy, modify, and distribute this software for any
-# purpose with or without fee is hereby granted, provided that the above
-# copyright notice and this permission notice appear in all copies.
-#
-# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
-# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
-# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
-# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
-# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
-# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
-# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
-#
-#------------------------------------------------------------------------------
-
-package Portscout::SiteHandler::PyPI;
-
-use JSON qw(decode_json);
-use LWP::UserAgent;
-
-use Portscout::Const;
-use Portscout::Config;
-
-use strict;
-
-require 5.006;
-
-
-#------------------------------------------------------------------------------
-# Globals
-#------------------------------------------------------------------------------
-
-push @Portscout::SiteHandler::sitehandlers, __PACKAGE__;
-
-our %settings;
-
-
-#------------------------------------------------------------------------------
-# Func: new()
-# Desc: Constructor.
-#
-# Args: n/a
-#
-# Retn: $self
-#------------------------------------------------------------------------------
-
-sub new
-{
- my $self = {};
- my $class = shift;
-
- $self->{name} = 'PyPI';
-
- bless ($self, $class);
- return $self;
-}
-
-
-#------------------------------------------------------------------------------
-# Func: CanHandle()
-# Desc: Ask if this handler (package) can handle the given site.
-#
-# Args: $url - URL of site.
-#
-# Retn: $res - true/false.
-#------------------------------------------------------------------------------
-
-sub CanHandle
-{
- my $self = shift;
-
- my ($url) = @_;
-
- return ($url =~ /https?:\/\/pypi\.python\.org\//);
-}
-
-
-#------------------------------------------------------------------------------
-# Func: GetFiles()
-# Desc: Extract a list of files from the given URL. Simply query the API.
-#
-# Args: $url - URL we would normally fetch from.
-# \%port - Port hash fetched from database.
-# \@files - Array to put files into.
-#
-# Retn: $success - False if file list could not be constructed; else, true.
-#------------------------------------------------------------------------------
-
-sub GetFiles
-{
- my $self = shift;
-
- my ($url, $port, $files) = @_;
-
- my ($pypi, $package, $resp, $query, $ua);
- $pypi = 'https://pypi.python.org/pypi/';
-
- # Strip all the digits at the end to keep the stem of the module.
- if ($port->{distname} =~ /(.*?)-(\d+)/) {
- $package = $1;
- }
-
- $query = $pypi . $package . '/json';
-
- _debug("GET $query");
- $ua = LWP::UserAgent->new;
- $ua->agent(USER_AGENT);
- $resp = $ua->request(HTTP::Request->new(GET => $query));
- if ($resp->is_success) {
- my ($json, $urls);
-
- $json = decode_json($resp->decoded_content);
- $urls = $json->{urls};
- foreach my $url (@$urls) {
- push(@$files, $url->{filename});
- }
- } else {
- _debug("GET failed: " . $resp->code);
- return 0;
- }
-
- return 1;
-}
-
-
-#------------------------------------------------------------------------------
-# Func: _debug()
-# Desc: Print a debug message.
-#
-# Args: $msg - Message.
-#
-# Retn: n/a
-#------------------------------------------------------------------------------
-
-sub _debug
-{
- my ($msg) = @_;
-
- $msg = '' if (!$msg);
-
- print STDERR "(" . __PACKAGE__ . ") $msg\n" if ($settings{debug});
-}
-
-1;
diff --git a/ports-mgmt/portscout/files/patch-Portscout_DataSrc_Ports.pm b/ports-mgmt/portscout/files/patch-Portscout_DataSrc_Ports.pm
deleted file mode 100644
index 867a0ab0fde9..000000000000
--- a/ports-mgmt/portscout/files/patch-Portscout_DataSrc_Ports.pm
+++ /dev/null
@@ -1,81 +0,0 @@
---- Portscout/DataSrc/Ports.pm.orig 2011-04-09 17:19:03 UTC
-+++ Portscout/DataSrc/Ports.pm
-@@ -201,7 +201,7 @@ sub BuildDB
-
- my $lastbuild = getstat('buildtime', TYPE_INT);
-
-- print "Looking for updated ports...\n\n"
-+ print "Incremental build: Looking for updated ports...\n\n"
- if ($incremental);
-
- $got_ports = 0;
-@@ -243,12 +243,15 @@ sub BuildDB
- my (@fields, $maintainer, $port);
-
- @fields = split /\|/;
-- $maintainer = $fields[5];
-+ $maintainer = lc($fields[5]);
- $port = $fields[1];
- $port =~ s/^(?:.*\/)?([^\/]+)\/([^\/]+)$/$1\/$2/;
-
-- $portsmaintok{$port} = $maintainer
-- if ($maintainers{$maintainer});
-+ if ($maintainers{$maintainer}) {
-+ $portsmaintok{$port} = $maintainer;
-+ print "Maintainer match: $maintainer $port \n"
-+ unless ($settings{quiet});
-+ }
- }
-
- close $if;
-@@ -264,7 +267,7 @@ sub BuildDB
-
- opendir my $catdir, $settings{ports_dir}."/$cat";
-
-- print "Scanning $cat...\n"
-+ print "Scanning $cat ...\n"
- unless ($settings{quiet});
-
- while (my $name = readdir $catdir) {
-@@ -276,9 +279,9 @@ sub BuildDB
- # port directory's mtime; skip if not updated.
- if ($incremental) {
- my ($updated);
--
- opendir my $portdir, $settings{ports_dir}."/$cat/$name";
--
-+ print "Scanning $cat/$name ... "
-+ unless ($settings{quiet});
- while (my $subfile = readdir $portdir) {
- my ($subfile_path, $fi);
-
-@@ -289,12 +292,18 @@ sub BuildDB
- or die "Couldn't stat $subfile_path: $!";
-
- if ($fi->mtime > $lastbuild) {
-+ print "$subfile (mtime: $fi->mtime) modified updated since last build: $lastbuild \n"
-+ if ($settings{debug});
- $updated = 1;
- last;
- }
- }
-
-- next if (!$updated);
-+ if (!$updated) {
-+ print "Not modified since last build: $lastbuild \n"
-+ if ($settings{debug});
-+ next;
-+ }
- }
-
- # Check this port is wanted by user
-@@ -307,7 +316,8 @@ sub BuildDB
- && $settings{indexfile_enable}) {
- next if (!$portsmaintok{"$cat/$name"});
- }
--
-+ print "Matched: $cat/$name\n"
-+ unless ($settings{quiet});
- push @ports, "$cat/$name";
- }
- }
diff --git a/ports-mgmt/portscout/files/patch-Portscout_SiteHandler.pm b/ports-mgmt/portscout/files/patch-Portscout_SiteHandler.pm
deleted file mode 100644
index 8eb32476632c..000000000000
--- a/ports-mgmt/portscout/files/patch-Portscout_SiteHandler.pm
+++ /dev/null
@@ -1,11 +0,0 @@
---- Portscout/SiteHandler.pm.orig 2010-04-29 01:07:51 UTC
-+++ Portscout/SiteHandler.pm
-@@ -31,6 +31,8 @@ package Portscout::SiteHandler;
- use XML::XPath;
- use XML::XPath::XMLParser;
-
-+use Portscout::SiteHandler::GitHub;
-+use Portscout::SiteHandler::PyPI;
- use Portscout::SiteHandler::SourceForge;
-
- use strict;
diff --git a/ports-mgmt/portscout/files/patch-Portscout_SiteHandler_GitHub.pm b/ports-mgmt/portscout/files/patch-Portscout_SiteHandler_GitHub.pm
deleted file mode 100644
index 57eed2ba7093..000000000000
--- a/ports-mgmt/portscout/files/patch-Portscout_SiteHandler_GitHub.pm
+++ /dev/null
@@ -1,38 +0,0 @@
---- Portscout/SiteHandler/GitHub.pm.orig 2016-01-04 10:46:49 UTC
-+++ Portscout/SiteHandler/GitHub.pm
-@@ -97,7 +97,9 @@ sub GetFiles
- my ($url, $port, $files) = @_;
- my $projname;
-
-- if ($url =~ /https:\/\/github\.com\/(.*?)\/archive\//) {
-+ if ($url =~ /https?:\/\/codeload\.github\.com\/(.*?)\/tar.gz\//) {
-+ $projname = $1;
-+ } elsif ($url =~ /https:\/\/github\.com\/(.*?)\/archive\//) {
- $projname = $1;
- } elsif ($url =~ /https:\/\/github.com\/downloads\/(.*)\//) {
- $projname = $1;
-@@ -108,7 +110,11 @@ sub GetFiles
-
- # First check if there's a latest releases endpoint
- $query = 'https://api.github.com/repos/' . $projname . '/releases/latest';
--
-+ # Add GitHub Client ID & Secret if they are set in settings
-+ # https://developer.github.com/v3/#authentication
-+ if ($settings{github_client_id} && $settings{github_client_secret}) {
-+ $query = $query . "?client_id=$settings{github_client_id}&client_secret=$settings{github_client_secret}";
-+ }
- _debug("GET $query");
- $ua = LWP::UserAgent->new;
- $ua->agent(USER_AGENT);
-@@ -120,6 +126,11 @@ sub GetFiles
- _debug('GET failed: ' . $response->status_line);
- # Project didn't do any releases, so let's try tags instead.
- $query = 'https://api.github.com/repos/' . $projname . '/tags';
-+ # Add GitHub Client ID & Secret if they are set in settings
-+ # https://developer.github.com/v3/#authentication
-+ if ($settings{github_client_id} && $settings{github_client_secret}) {
-+ $query = $query . "?client_id=$settings{github_client_id}&client_secret=$settings{github_client_secret}";
-+ }
- _debug("GET $query");
- $ua = LWP::UserAgent->new;
- $ua->agent(USER_AGENT);
diff --git a/ports-mgmt/portscout/files/patch-Portscout_SiteHandler_PyPI.pm b/ports-mgmt/portscout/files/patch-Portscout_SiteHandler_PyPI.pm
deleted file mode 100644
index bd8bd6212b82..000000000000
--- a/ports-mgmt/portscout/files/patch-Portscout_SiteHandler_PyPI.pm
+++ /dev/null
@@ -1,16 +0,0 @@
---- Portscout/SiteHandler/PyPI.pm.orig 2016-02-04 08:23:53 UTC
-+++ Portscout/SiteHandler/PyPI.pm
-@@ -109,11 +109,13 @@ sub GetFiles
- $ua->agent(USER_AGENT);
- $resp = $ua->request(HTTP::Request->new(GET => $query));
- if ($resp->is_success) {
-+ _debug("GET success: " . $resp->code);
- my ($json, $urls);
-
- $json = decode_json($resp->decoded_content);
- $urls = $json->{urls};
- foreach my $url (@$urls) {
-+ _debug("PyPi File: " . $url->{filename});
- push(@$files, $url->{filename});
- }
- } else {
diff --git a/ports-mgmt/portscout/files/patch-Portscout_SiteHandler_SourceForge.pm b/ports-mgmt/portscout/files/patch-Portscout_SiteHandler_SourceForge.pm
deleted file mode 100644
index 4d64dd903bd4..000000000000
--- a/ports-mgmt/portscout/files/patch-Portscout_SiteHandler_SourceForge.pm
+++ /dev/null
@@ -1,11 +0,0 @@
---- Portscout/SiteHandler/SourceForge.pm.orig 2010-05-05 01:54:16 UTC
-+++ Portscout/SiteHandler/SourceForge.pm
-@@ -85,7 +85,7 @@ sub CanHandle
-
- my ($url) = @_;
-
-- return ($url =~ /^http:\/\/[^\/]*?\.sourceforge\.net\/project\//);
-+ return ($url =~ /^https?:\/\/[^\/]*?\.sourceforge\.net\/project\//);
- }
-
-
diff --git a/ports-mgmt/portscout/files/patch-portscout.conf b/ports-mgmt/portscout/files/patch-portscout.conf
deleted file mode 100644
index 7b6243d77eb0..000000000000
--- a/ports-mgmt/portscout/files/patch-portscout.conf
+++ /dev/null
@@ -1,14 +0,0 @@
---- portscout.conf.orig 2015-10-25 05:00:59 UTC
-+++ portscout.conf
-@@ -172,5 +172,11 @@ db port = # Port
- #db connstr = DBI:Pg:dbname=%(db_name);host=%(db_host);port=%(db_port)
- db connstr = DBI:SQLite:dbname=/var/db/portscout.db
-
-+# GitHub site handler settings
-+# GitHub rate limits requests to its API to a very low number for unauthenticated
-+# requests, and 5000 per hour for authenticated requests.
-+
-+# github_client_id = # GitHub Client ID
-+# github_client_secret = # GitHub Client Secret
-
- # ex: ts=4 sw=4
diff --git a/ports-mgmt/portscout/files/patch-portscout.pl b/ports-mgmt/portscout/files/patch-portscout.pl
deleted file mode 100644
index 015c0a95ed45..000000000000
--- a/ports-mgmt/portscout/files/patch-portscout.pl
+++ /dev/null
@@ -1,226 +0,0 @@
---- portscout.pl.orig 2016-01-10 17:42:32 UTC
-+++ portscout.pl
-@@ -463,7 +463,7 @@ sub VersionCheck
-
- $i++;
-
-- info($k, 'Checking site: ' . strchop($site, 60));
-+ info($k, 'Checking site: ' . strchop($site, 200));
-
- # Look to see if the URL contains the distfile version.
- # This will affect our checks and guesses later on.
-@@ -493,9 +493,12 @@ sub VersionCheck
- }
-
- # Check for special handler for this site first
-+ print "Does site handler exist ... "
-+ unless ($settings{quiet});
- if (my $sh = Portscout::SiteHandler->FindHandler($site))
- {
-- info($k, $site, 'Using dedicated site handler for site.');
-+ print "Yes \n"
-+ unless ($settings{quiet});
-
- if (!$sh->GetFiles($site, $port, \@files)) {
- info($k, $site, 'SiteHandler::GetFiles() failed for ' . $site);
-@@ -506,6 +509,9 @@ sub VersionCheck
- {
- my $ftp;
-
-+ print "No. Trying FTP...\n"
-+ unless ($settings{quiet});
-+
- $ftp = Net::FTP->new(
- $site->host,
- Port => $site->port,
-@@ -609,6 +615,9 @@ sub VersionCheck
- {
- my ($ua, $response);
-
-+ print "No. Trying HTTP...\n"
-+ unless ($settings{quiet});
-+
- unless (robotsallowed($dbh, $site, $sitedata)) {
- info($k, $site, 'Ignoring site as per rules in robots.txt.');
-
-@@ -713,7 +722,8 @@ sub VersionCheck
-
- # Got a response which wasn't HTTP 4xx -> bail out
- if ($response->is_success && $response->status_line !~ /^4/) {
-- info($k, $site, 'Not doing any guessing; site is lieing to us.');
-+ print "URL: $url\n";
-+ info($k, $site, "Skip guessing: Response not 4xx to a file that shouldnt exist (". $response->status_line .")");
- $sths->{sitedata_initliecount}->execute($sitedata->{host})
- unless($settings{precious_data});
- next;
-@@ -797,7 +807,7 @@ sub VersionCheck
- $new_found = 1;
- last;
- } else {
-- info($k, $site, "Guess failed $port->{ver} -> $guess_v");
-+ info($k, $site, "Guess failed $port->{ver} -> $guess_v (". $response->status_line .")");
- }
-
- last if ($new_found);
-@@ -867,7 +877,10 @@ sub FindNewestFile
-
- foreach my $file (@$files)
- {
-- my $poss_path;
-+ my ($poss_path, $github);
-+
-+ print "FindNewest: Checking $file ... against port DISTFILES. \n"
-+ if ($settings{debug});
-
- if ($file =~ /^(.*)\/(.*?)$/) {
- # Files from SiteHandlers can come with paths
-@@ -888,6 +901,9 @@ sub FindNewestFile
-
- my $skip = 0;
-
-+ print "FindNewest: Checking DISTFILE ... $distfile (ver: $v, sufx: $s)\n"
-+ if ($settings{debug});
-+
- if ($poss_path) {
- # Do a full-URL comparison for $old_found
- # if we're dealing with paths too.
-@@ -908,14 +924,20 @@ sub FindNewestFile
- } else {
- if ($file eq $distfile) {
- $old_found = 1;
-+ print "FindNewest: File matches existing port DISTFILE. Old found. \n"
-+ if ($settings{debug});
- next;
- }
- }
-
-+ $github = 1 if ($site->clone =~ /^https?:\/\/([^\/.]+\.)?github\.com\/(.*?)\/tar.gz/);
-+
- # Skip beta versions if requested
-
- if ($port->{skipbeta}) {
- if (isbeta($file) && !isbeta($distfile)) {
-+ print "FindNewest: File is beta, skipbeta is defined. Skipping ...\n"
-+ if ($settings{debug});
- next;
- }
- }
-@@ -940,31 +962,64 @@ sub FindNewestFile
-
- # Possible candidate - extract version
-
-- if ($file =~ /^($distfile)$/ && $2)
-+ #warn "distfile = $distfile 2 = $2";
-+ if (($file =~ /^($distfile)$/ && $2) or $github)
- {
-- my $version = $2;
-- my $new_v = lc $version;
-+ my ($version, $new_v, $matchver);
-
-- # Catch a few missed cases
-+ unless ($github) {
-+ $version = $2;
-+ $new_v = lc $version;
-
-- $new_v =~ s/(?:$ext_regex)$//;
-+ # Catch a few missed cases
-+ $new_v =~ s/(?:$ext_regex)$//;
-
-- # Version is much longer than original - skip it
-+ # Version is much longer than original - skip it
-+ next if (length $new_v > (12 + length $old_v));
-
-- next if (length $new_v > (12 + length $old_v));
-+ # New version is in date format (or contains a date-like
-+ # string) - old one is not. Probably best to ignore.
-
-- # New version is in date format (or contains a date-like
-- # string) - old one is not. Probably best to ignore.
-+ next if (
-+ $new_v =~ /$date_regex/i &&
-+ $old_v !~ /$date_regex/i
-+ );
-
-- next if (
-- $new_v =~ /$date_regex/i &&
-- $old_v !~ /$date_regex/i
-- );
-+ # Skip a few strange version format change cases
-+ # (formatted -> "just a number")
-+ next if ($new_v !~ /\./ && $old_v =~ /\./);
-+ } else {
-+ # Github is "special" since the actual URI we get back from the
-+ # handler isn't the same as what is actually being retrieved.
-+ # So fall back on comparing tags instead.
-
-- # Skip a few strange version format change cases
-- # (formatted -> "just a number")
-+ $new_v = $file;
-+ $version = lc $new_v;
-
-- next if ($new_v !~ /\./ && $old_v =~ /\./);
-+ # Only match version-esque looking strings from the tag
-+ # because portscout currently only uses/stores a normalized
-+ # 'ver', not PORTVERSION or DISTVERSION{FULL} so we have nothing
-+ # canonical to compare agains. Currently the match is for digits
-+ # with any non-digit separators, without non-digit prefixes and
-+ # suffixes. This is likely the best we can get for now, without
-+ # introducing false positives.
-+
-+ ($matchver) = ($version =~ m/((?:\d+.)*\d+)/);
-+
-+ print "FindNewestFile::Github: Input: $file Matchver: $matchver \n"
-+ if ($settings{debug});
-+
-+ # Replace non-digit separators of digits with dots.
-+
-+ $matchver =~ s/[^\d+]/\./g;
-+
-+ if (defined($matchver)) {
-+ $new_v = $matchver;
-+ }
-+
-+ print "FindNewestFile::Github: Matchver: $matchver Normalized: $new_v \n"
-+ if ($settings{debug});
-+ }
-
- # Skip any specific versions if requested
-
-@@ -973,6 +1028,8 @@ sub FindNewestFile
-
- foreach (split (/\s+/, $port->{skipversions})) {
- if ($new_v eq $_) {
-+ print "FindNewest: skipversions is defined. Matched $_. Skipping...\n"
-+ if ($settings{debug});
- $skip = 1;
- last;
- }
-@@ -981,7 +1038,7 @@ sub FindNewestFile
- next if ($skip);
- }
-
-- unless ($settings{sillystrings_enable}) {
-+ unless ($settings{sillystrings_enable} or $github) {
- if ($new_v =~ /[-_.]([A-Za-z]+[A-Za-z_-]{2,})$/) {
- my $str = $1;
- next if (
-@@ -1026,12 +1083,19 @@ sub FindNewestFile
-
- # Test our new version string
-
-+ print "FindNewest: Comparing Old ($old_v) vs New ($new_v) version strings... \n"
-+ if ($settings{debug});
-+
- if ($new_v eq $old_v)
- {
-+ print "FindNewest: Old ($old_v) == New ($new_v). Old found.\n"
-+ if ($settings{debug});
- $old_found = 1;
- }
- elsif (vercompare($new_v, $old_v))
- {
-+ print "FindNewest: Old ($old_v) < New ($new_v). New found.\n"
-+ if ($settings{debug});
- $new_found = 1;
-
- # Keep going until we find the newest version