Diff for /loncom/build/distprobe between versions 1.12 and 1.23

version 1.12, 2007/04/23 20:04:52 version 1.23, 2019/07/02 19:40:31
Line 28 Line 28
 #  #
   
 my $dist='default';  my $dist='default';
 if (-e '/etc/redhat-release') {  my $unknown;
   if (-e '/etc/oracle-release') {
       open(IN,'</etc/oracle-release');
       my $versionstring=<IN>;
       chomp($versionstring);
       close(IN);
       if ($versionstring =~ /^Oracle Linux Server release (\d+)/) {
           $dist = 'oracle'.$1;
       }
   } elsif (-e '/etc/redhat-release') {
     open(IN,'</etc/redhat-release');      open(IN,'</etc/redhat-release');
     my $versionstring=<IN>;      my $versionstring=<IN>;
     chomp($versionstring);      chomp($versionstring);
Line 42  if (-e '/etc/redhat-release') { Line 51  if (-e '/etc/redhat-release') {
         } elsif ($version=~/^9/) {          } elsif ($version=~/^9/) {
             $dist='redhat9';              $dist='redhat9';
         }          }
     } elsif ($versionstring =~ /Fedora Core release ([\d\.]+) /) {      } elsif ($versionstring =~ /Fedora( Core)? release ([\d\.]+) /) {
  my $version=$1;   my $version=$2;
  if ($version - int($version) > .9) {   if ($version - int($version) > .9) {
     $dist = 'fedora'.(int($version)+1);      $dist = 'fedora'.(int($version)+1);
  } else {   } else {
Line 53  if (-e '/etc/redhat-release') { Line 62  if (-e '/etc/redhat-release') {
         $dist = 'rhes'.$1;          $dist = 'rhes'.$1;
     } elsif ($versionstring =~ /Red Hat Enterprise Linux Server release (\d+)/) {      } elsif ($versionstring =~ /Red Hat Enterprise Linux Server release (\d+)/) {
         $dist = 'rhes'.$1;          $dist = 'rhes'.$1;
       } elsif ($versionstring =~ /Red Hat Enterprise Linux release (\d+)/) {
           $dist = 'rhes'.$1;
       } elsif ($versionstring =~ /CentOS(?:| Linux) release (\d+)/) {
           $dist = 'centos'.$1;
       } elsif ($versionstring =~ /Scientific Linux (?:SL )?release ([\d.]+) /) {
           my $ver = $1;
           $ver =~ s/\.\d+$//;
           $dist = 'scientific'.$ver;
     } else {      } else {
         warn('Unable to interpret /etc/redhat-release '.          warn('Unable to interpret /etc/redhat-release '.
              'to determine system type');               'to determine system type');
     }          $unknown = 1;
 } elsif (-e '/etc/debian_version') {  
     open(IN,'</etc/debian_version');  
     my $version=<IN>;  
     chomp($version);  
     close(IN);  
     if ($version eq '2.2') {  
  $dist='debian2.2';  
     }      }
 } elsif (-e '/etc/SuSE-release') {  } elsif (-e '/etc/SuSE-release') {
     open(IN,'</etc/SuSE-release');      open(IN,'</etc/SuSE-release');
Line 79  if (-e '/etc/redhat-release') { Line 89  if (-e '/etc/redhat-release') {
     } else {      } else {
         warn('Unable to interpret /etc/SuSE-release '.          warn('Unable to interpret /etc/SuSE-release '.
              'to determine system type');               'to determine system type');
           $unknown = 1;
       }
   } elsif (-e '/etc/issue') {
       open(IN,'</etc/issue');
       my $versionstring=<IN>;
       chomp($versionstring);
       close(IN);
       if ($versionstring =~ /^Ubuntu (\d+)\.\d+/i) {
           $dist = 'ubuntu'.$1;
       } elsif ($versionstring =~ /^Debian\s+GNU\/Linux\s+(\d+)\.\d+/i) {
           $dist = 'debian'.$1;
       } elsif (-e '/etc/debian_version') {
           open(IN,'</etc/debian_version');
           my $version=<IN>;
           chomp($version);
           close(IN);
           if ($version =~  /^(\d+)\.\d+\.?\d*/) {
               $dist='debian'.$1;
           } else {
               warn('Unable to interpret /etc/debian_version '.
                    'to determine system type');
               $unknown = 1;
           }
       }
   } elsif (-e '/etc/debian_version') {
       open(IN,'</etc/debian_version');
       my $version=<IN>;
       chomp($version);
       close(IN);
       if ($version =~  /^(\d+)\.\d+\.?\d*/) {
           $dist='debian'.$1;
       } else {
           warn('Unable to interpret /etc/debian_version '.
                'to determine system type');
           $unknown = 1;
       }
   }
   if (($dist eq 'default') && (!$unknown)) {
       if (-e '/etc/os-release') {
           if (open(IN,'<','/etc/os-release')) {
               my ($id,$version);
               while(<IN>) {
                   chomp();
                   if (/^ID="(\w+)"/) {
                       $id=$1;
                   } elsif (/^VERSION_ID="([\d\.]+)"/) {
                       $version=$1;
                   }
               }
               close(IN);
               if ($id eq 'sles') {
                   my ($major,$minor) = split(/\./,$version);
                   if ($major =~ /^\d+$/) {
                       $dist = $id.$major;
                   }
               }
           }
           if ($dist eq 'default') {
               warn('Unable to interpret /etc/os-release '.
                    'to determine system type.');
               $unknown = 1;
           }
       } else {
           warn('Unknown installation: expecting a debian, ubuntu, suse, sles, redhat, fedora or scientific linux system.')."\n";
     }      }
 } else {  
     warn('Unknown installation: expecting a debian, suse, or redhat system');  
 }  }
 print $dist;  print $dist;

Removed from v.1.12  
changed lines
  Added in v.1.23


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>