Skip to content

Commit

Permalink
Fix issue #232: fix automated version check
Browse files Browse the repository at this point in the history
Modified to match recent changes to docs/download.pod
Modified to make revision optional. (i.e. 3.0 R1). If revision
is not present then don't print "revision unknown".
Updated syntax to eliminate perl warnings
  • Loading branch information
Michael Stovenour committed Jul 14, 2013
1 parent 4009e98 commit d96571b
Showing 1 changed file with 15 additions and 13 deletions.
28 changes: 15 additions & 13 deletions code/common/mh_release.pl
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,11 @@
sub parse_version {
my ($maj,$min) = $Version =~ /(\d)\.(\d*)/;
my ($rev) = $Version =~ /R(\d*)/;
return ($maj, $min, $rev);
$maj = $Version unless($maj);
my $version_str = $maj;
$version_str .= ".$min" unless($min eq '');
$version_str .= " (revision $rev)" if($rev);
return ($maj, $min, $version_str);
}

sub calc_age {
Expand All @@ -57,14 +61,13 @@ sub calc_age {

if (said $v_version) {

my ($maj,$min,$revision) = &parse_version();
$revision = "unknown" unless $revision;
my ($maj,$min,$version_str) = &parse_version();

if (($Save{mhdl_maj} > $maj) or (($Save{mhdl_maj} == $maj) and ($Save{mhdl_min} > $min))) {
respond "app=control I am version $maj.$min (revision $revision) and $Save{mhdl_maj}.$Save{mhdl_min} was released " . &calc_age($Save{mhdl_date}) . '.';
respond("app=control I am version $version_str and $Save{mhdl_maj}.$Save{mhdl_min} was released " . &calc_age($Save{mhdl_date}) . '.');
}
else {
respond "app=control I am version $maj.$min (revision $revision), released " . &calc_age($Save{mhdl_date}) . '.';
respond("app=control I am version $version_str.");
}
}

Expand All @@ -74,7 +77,7 @@ sub calc_age {

if (&net_connect_check) {
$msg = 'Checking version...';
print_log "Retrieving download page";
print_log("Retrieving download page");
start $p_mhdl_page;
}
else {
Expand All @@ -86,10 +89,10 @@ sub calc_age {


if (done_now $p_mhdl_page) {
my @html = file_head($mhdl_file,16);
print_log "Download page retrieved";
my @html = file_read($mhdl_file);
print_log("Download page retrieved");
foreach(@html) {
next unless /^<p>Version (\d+)\.(\d+) released on (.*):/i;
next unless /Version (\d+)\.(\d+).*released on (\d+\/\d+\/\d+)/;
$Save{mhdl_maj} = $1;
$Save{mhdl_min} = $2;
$Save{mhdl_date} = $3;
Expand All @@ -98,14 +101,13 @@ sub calc_age {


if (defined $Save{mhdl_maj} and defined $Save{mhdl_min}) {
my ($maj,$min,$revision) = &parse_version();
$revision = "unknown" unless $revision;
my ($maj,$min,$version_str) = &parse_version();
if (($Save{mhdl_maj} > $maj) or (($Save{mhdl_maj} == $maj) and ($Save{mhdl_min} > $min))) {
$v_mhdl_page->respond("important=1 connected=0 app=control I am version $maj.$min (revision $revision) and version $Save{mhdl_maj}.$Save{mhdl_min} was released " . &calc_age($Save{mhdl_date} . '.'));
$v_mhdl_page->respond("important=1 connected=0 app=control I am version $version_str and version $Save{mhdl_maj}.$Save{mhdl_min} was released " . &calc_age($Save{mhdl_date} . '.'));
}
else {
# Voice command is only code to start this process, so check its set_by
$v_mhdl_page->respond("connected=0 app=control Version $Save{mhdl_maj}.$Save{mhdl_min} is current.");
$v_mhdl_page->respond("connected=0 app=control Version $version_str is current.");
}
}

Expand Down

0 comments on commit d96571b

Please sign in to comment.