summaryrefslogtreecommitdiffstats
path: root/knetworkconf/backends/platform.pl.in
diff options
context:
space:
mode:
Diffstat (limited to 'knetworkconf/backends/platform.pl.in')
-rw-r--r--knetworkconf/backends/platform.pl.in732
1 files changed, 0 insertions, 732 deletions
diff --git a/knetworkconf/backends/platform.pl.in b/knetworkconf/backends/platform.pl.in
deleted file mode 100644
index 2d0534a..0000000
--- a/knetworkconf/backends/platform.pl.in
+++ /dev/null
@@ -1,732 +0,0 @@
-#!/usr/bin/env perl
-#-*- Mode: perl; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
-
-# Determine the platform we're running on.
-#
-# Copyright (C) 2000-2001 Ximian, Inc.
-#
-# Authors: Arturo Espinosa <arturo@ximian.com>
-# Hans Petter Jansson <hpj@ximian.com>
-#
-# This program is free software; you can redistribute it and/or modify
-# it under the terms of the GNU Library General Public License as published
-# by the Free Software Foundation; either version 2 of the License, or
-# (at your option) any later version.
-#
-# This program is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU Library General Public License for more details.
-#
-# You should have received a copy of the GNU Library General Public License
-# along with this program; if not, write to the Free Software
-# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
-
-
-# --- System guessing --- #
-
-
-$SCRIPTSDIR = "@scriptsdir@";
-if ($SCRIPTSDIR =~ /^@scriptsdir[@]/)
-{
- $SCRIPTSDIR = ".";
- $DOTIN = ".in";
-}
-
-require "$SCRIPTSDIR/parse.pl$DOTIN";
-require "$SCRIPTSDIR/xml.pl$DOTIN";
-
-
-$PLATFORM_INFO = {
- "debian-2.2" => "Debian GNU/Linux 2.2 Potato",
- "debian-3.0" => "Debian GNU/Linux 3.0 Woody",
- "debian-3.1" => "Debian GNU/Linux 3.1 Sarge",
- "debian-4.0" => "Debian GNU/Linux 4.0 Etch",
- "debian-5.0" => "Debian GNU/Linux 5.0 Lenny",
- "debian-6.0" => "Debian GNU/Linux 6.0 Squeeze",
- "debian-7.0" => "Debian GNU/Linux 7.0 Wheezy",
- "debian-testing" => "Debian GNU/Linux Testing/Unstable",
- "ubuntu-5.04" => "Kubuntu 5.04, Hoary Hedgehog",
- "ubuntu-5.10" => "Kubuntu 5.10, Breezy Badger",
- "ubuntu-6.06" => "Kubuntu 6.06, Dapper Drake",
- "ubuntu-6.10" => "Kubuntu 6.10, Edgy Eft",
- "ubuntu-7.04" => "Kubuntu 7.04, Feisty Fawn",
- "ubuntu-7.10" => "Kubuntu 7.10, Gutsy Gibbon",
- "ubuntu-8.04" => "Kubuntu 8.04, Hardy Heron",
- "ubuntu-8.10" => "Kubuntu 8.10, Intrepid Ibex",
- "ubuntu-9.04" => "Kubuntu 9.04, Jaunty Jackalope",
- "ubuntu-9.10" => "Kubuntu 9.10, Karmic Koala",
- "ubuntu-10.04" => "Kubuntu 10.04, Lucid Lynx",
- "ubuntu-10.10" => "Kubuntu 10.10, Maverick Meerkat",
- "ubuntu-11.04" => "Kubuntu 11.04, Natty Narwhal",
- "ubuntu-11.10" => "Kubuntu 11.10, Oneiric Ocelot",
- "ubuntu-12.04" => "Kubuntu 12.04, Precise Pangolin",
- "redhat-5.2" => "Red Hat Linux 5.2 Apollo",
- "redhat-6.0" => "Red Hat Linux 6.0 Hedwig",
- "redhat-6.1" => "Red Hat Linux 6.1 Cartman",
- "redhat-6.2" => "Red Hat Linux 6.2 Zoot",
- "redhat-7.0" => "Red Hat Linux 7.0 Guinness",
- "redhat-7.1" => "Red Hat Linux 7.1 Seawolf",
- "redhat-7.2" => "Red Hat Linux 7.2 Enigma",
- "redhat-7.3" => "Red Hat Linux 7.3 Valhalla",
- "redhat-8.0" => "Red Hat Linux 8.0 Psyche",
- "redhat-9" => "Red Hat Linux 9.0 Shrike",
- "rhel-5" => "Enterprise Linux 5",
- "rhel-6" => "Enterprise Linux 6",
- "openna-1.0" => "OpenNA Linux 1.0 VSLC",
- "mandrake-7.1" => "Linux Mandrake 7.1",
- "mandrake-7.2" => "Linux Mandrake 7.2 Odyssey",
- "mandrake-8.0" => "Linux Mandrake 8.0 Traktopel",
- "mandrake-9.0" => "Linux Mandrake 9.0 Dolphin",
- "mandrake-9.1" => "Linux Mandrake 9.1 Bamboo",
- "mandrake-9.2" => "Linux Mandrake 9.2 FiveStar",
- "mandrake-10.0" => "Linux Mandrake 10.0",
- "mandrake-10.1" => "Linux Mandrake 10.1",
- "mandrake-10.2" => "Linux Mandrake 2005 LE",
- "mandriva-2006.0" => "Mandriva Linux 2006.0",
- "mandriva-2006.1" => "Mandriva Linux 2006.1",
- "mandriva-2007.0" => "Mandriva Linux 2007.0",
- "mandriva-2007.1" => "Mandriva Linux 2007.1",
- "yoper-2.2" => "Yoper Linux 2.2",
- "blackpanther-4.0" => "Black Panther OS 4.0",
- "conectiva-9" => "Conectiva Linux 9",
- "conectiva-10" => "Conectiva Linux 10",
- "suse-7.0" => "SuSE Linux 7.0",
- "suse-9.0" => "SuSE Linux 9.0",
- "suse-9.1" => "SuSE Linux 9.1",
- "turbolinux-7.0" => "Turbolinux 7.0",
- "slackware-8.0.0" => "Slackware 8.0.0",
- "slackware-8.1" => "Slackware 8.1",
- "slackware-9.0.0" => "Slackware 9.0.0",
- "slackware-9.1.0" => "Slackware 9.1.0",
- "slackware-10.0.0" => "Slackware 10.0.0",
- "slackware-10.1.0" => "Slackware 10.1.0",
- "slackware-10.2.0" => "Slackware 10.2.0",
- "slackware-11.0.0" => "Slackware 11.0.0",
- "slackware-12.0.0" => "Slackware 12.0.0",
- "slackware-12.1.0" => "Slackware 12.1.0",
- "slackware-12.2.0" => "Slackware 12.2.0",
- "slackware-13.0.0" => "Slackware 13.0.0",
- "slackware-13.1.0" => "Slackware 13.1.0",
- "slackware-13.37.0" => "Slackware 13.37.0",
- "slackware-14.0.0" => "Slackware 14.0.0",
- "freebsd-4" => "FreeBSD 4",
- "freebsd-5" => "FreeBSD 5",
- "freebsd-6" => "FreeBSD 6",
- "gentoo" => "Gentoo Linux",
- "vlos-1.2" => "Vida Linux OS 1.2",
- "archlinux" => "Arch Linux",
- "pld-1.0" => "PLD 1.0 Ra",
- "pld-1.1" => "PLD 1.1 Ra",
- "pld-1.99" => "PLD 1.99 Ac-pre",
- "vine-3.0" => "Vine Linux 3.0",
- "vine-3.1" => "Vine Linux 3.1",
- "fedora-1" => "Fedora Core 1 (Yarrow)",
- "fedora-2" => "Fedora Core 2 (Tettnang)",
- "fedora-3" => "Fedora Core 3 (Heidelberg)",
- "fedora-4" => "Fedora Core 4 (Stentz)",
- "fedora-5" => "Fedora Core 5 (Bordeaux)",
- "fedora-15" => "Fedora 15 (LoveLock)",
- "fedora-16" => "Fedora 16 (Verne)",
- "fedora-17" => "Fedora 17 (Beefy Miracle)",
- "rpath" => "rPath Linux",
- "ark" => "Ark Linux",
-};
-
-sub check_lsb
-{
- my ($ver, $dist);
-# my %vermap =
-# ("3.0" => "woody");
-
- my %distmap =
- ("Debian" => "debian"),
- ("Mandrake" => "mandrake"),
- ("Conectiva" => "conectiva"),
- ("Blackpanther" => "blackpanther");
-
- # gst_prefix not required here: parse already does that for us.
- $dist = lc (&gst_parse_sh ("/etc/lsb-release", "DISTRIB_ID"));
- $ver = lc (&gst_parse_sh ("/etc/lsb-release", "DISTRIB_RELEASE"));
-
-# $ver = $vermap{$ver} if exists $vermap{$ver};
- $dist = $distmap{$dist} if exists $dirmap{$dir};
-
- return -1 if ($dist eq "") || ($ver eq "");
- return "$dist-$ver";
-}
-
-sub check_debian
-{
- my ($ver, $i);
- my %vermap =
- ("testing/unstable" => "testing",
- "lenny/sid" => "testing",
- "3.1" => "sarge",
- "4.0" => "etch",
- "5.0" => "lenny");
-
- open DEBIAN, "$gst_prefix/etc/debian_version" or return -1;
- chomp ($ver = <DEBIAN>);
- close DEBIAN;
-
- #if $ver is not found, we will assume it is testing
- if($ver and exists $vermap{$ver}) {
- $ver = $vermap{$ver};
- } else {
- $ver = "testing";
- }
-
- return "debian-$ver";
-}
-
-
-sub check_redhat
-{
- open RELEASE, "$gst_prefix/etc/redhat-release" or return -1;
- while (<RELEASE>)
- {
- chomp;
- if (/^Red Hat Linux.*\s+([0-9.]+)\s+.*/)
- {
- close RELEASE;
- return "redhat-$1";
- }
- }
- close RELEASE;
- return -1;
-}
-
-sub check_rhel
-{
- open RELEASE, "$gst_prefix/etc/redhat-release" or return -1;
- while (<RELEASE>)
- {
- chomp;
- if (
- (/^CentOS release (\d)([\d\.]+)\s+.*/)
- or (/^Scientific Linux release (\d)([\d\.]+)\s+.*/)
- or (/^Red Hat Enterprise Linux \w release (\d)([\d\.]+)\s+.*/)
- )
- {
- close RELEASE;
- return "rhel-$1";
- }
- }
- close RELEASE;
- return -1;
-}
-
-
-sub check_openna
-{
- open OPENNA, "$gst_prefix/etc/openna-release" or return -1;
- while (<OPENNA>)
- {
- chomp;
- if (/^OpenNA*/)
- {
- close OPENNA;
- return "openna-$1";
- }
- }
- close OPENNA;
- return -1;
-}
-
-sub check_caldera
-{
- open INSTALLED, "$gst_prefix/etc/.installed" or return -1;
- while (<INSTALLED>)
- {
- chomp;
- if (/^OpenLinux-(.*)-.*/)
- {
- close INSTALLED;
- return "caldera-$1";
- }
- }
- close INSTALLED;
- return -1;
-}
-
-
-sub check_suse
-{
- open RELEASE, "$gst_prefix/etc/SuSE-release" or return -1;
- while (<RELEASE>)
- {
- chomp;
- if (/^VERSION\s*=\s*(\S+)/)
- {
- close RELEASE;
- return "suse-$1";
- }
- }
- close RELEASE;
- return -1;
-}
-
-sub check_mandrake
-{
- open MANDRAKE, "$gst_prefix/etc/mandrake-release" or return -1;
- while (<MANDRAKE>)
- {
- $ver = $_;
- chomp ($ver);
- if ($ver =~ /^Linux Mandrake release (\S+)/)
- {
- close MANDRAKE;
- return "mandrake-$1";
- }
- elsif ($ver =~ /^Mandrake( L|l)inux release ([\d\.]+)/i)
- {
- close MANDRAKE;
- return "mandrake-$2";
- }
- }
- close MANDRAKE;
- return -1;
-}
-
-sub check_mandriva
-{
- open MANDRIVA, "$gst_prefix/etc/mandriva-release" or return -1;
- while (<MANDRIVA>)
- {
- $ver = $_;
- chomp ($ver);
- if ($ver =~ /^Linux Mandriva release (\S+)/)
- {
- close MANDRIVA;
- return "mandriva-$1";
- }
- elsif ($ver =~ /^Mandriva( L|l)inux release ([\d\.]+)/i)
- {
- close MANDRIVA;
- return "mandriva-$2";
- }
- }
- close MANDRIVA;
- return -1;
-}
-
-sub check_yoper
-{
- open YOPER, "$gst_prefix/etc/yoper-release" or return -1;
- while (<YOPER>)
- {
- $ver = $_;
- chomp ($ver);
- if ($ver =~ m/Yoper (\S+)/)
- {
- close YOPER;
- # find the first digit of our release
- $mystring= ~m/(\d)/;
- #store it in $fdigit
- $fdigit= $1;
- # the end of the release is marked with -2 so find the -
- $end = index($ver,"-");
- $start = index($ver,$fdigit);
- # extract the substring into $newver
- $newver= substr($ver,$start,$end-$start);
- print $newver;
- return "yoper-$newver";
- }
- }
- close YOPER;
- return -1;
-}
-
-sub check_blackpanther
-{
- open BLACKPANTHER, "$gst_prefix/etc/blackPanther-release" or return -1;
-
- while (<BLACKPANTHER>)
- {
- $ver = $_;
- chomp ($ver);
- if ($ver =~ /^Linux Black Panther release (\S+)/)
- {
- close BLACKPANTHER;
- return "blackPanther-$1";
- }
- elsif ($ver =~ /^Black Panther ( L|l)inux release ([\d\.]+)/i)
- {
- close BLACKPANTHER;
- return "blackPanther-$2";
- }
- }
-
- close BLACKPANTHER;
- return -1;
-}
-
-sub check_fedora
-{
- open FEDORA, "$gst_prefix/etc/fedora-release" or return -1;
- while (<FEDORA>)
- {
- $ver = $_;
- chomp ($ver);
-
- if (
- ($ver =~ /^Fedora Core release (\S+)/)
- or ($ver =~ /^Fedora release (\S+)/)
- )
- {
- close FEDORA;
- return "fedora-$1";
- }
- }
-
- close FEDORA;
- return -1;
-}
-
-sub check_rpath
-{
- open RPATH, "$gst_prefix/etc/distro-release" or return -1;
-
- while (<RPATH>)
- {
- $ver = $_;
- chomp ($ver);
-
- if ($ver =~ /^rPath Linux/)
- {
- close RPATH;
- return "rpath";
- }
- if ($ver =~ /Foresight/)
- {
- close RPATH;
- return "rpath";
- }
- }
-
- close RPATH;
- return -1;
-}
-
-sub check_conectiva
-{
- open RELEASE, "$gst_prefix/etc/conectiva-release" or return -1;
-
- while (<RELEASE>)
- {
- chomp;
-
- if (/^Conectiva Linux (\S+)/)
- {
- close RELEASE;
- return "conectiva-$1";
- }
- }
-
- close RELEASE;
- return -1;
-}
-
-sub check_turbolinux
-{
- open RELEASE, "$gst_prefix/etc/turbolinux-release" or return -1;
- while (<RELEASE>)
- {
- chomp;
- if (/^Turbolinux\s.*\s([0-9.]+)\s.*/)
- {
- close RELEASE;
- return "turbolinux-$1";
- }
- }
- close RELEASE;
- return -1;
-}
-
-sub check_slackware
-{
- open RELEASE, "$gst_prefix/etc/slackware-version" or return -1;
- while (<RELEASE>)
- {
- chomp;
- if (/^Slackware ([0-9.]+)/)
- {
- close RELEASE;
- return "slackware-$1";
- }
- }
- close RELEASE;
- return -1;
-}
-
-sub check_gentoo
-{
- return "gentoo" if stat ("$gst_prefix/usr/portage");
- return -1;
-}
-
-sub check_vlos
-{
- open RELEASE, "$gst_prefix/etc/vlos-release" or return -1;
- while (<RELEASE>)
- {
- chomp;
- if (/^VLOS.*\s+([0-9.]+)/)
- {
- close RELEASE;
- return "vlos-$1";
- }
- }
- close RELEASE;
- return -1;
-}
-
-sub check_archlinux
-{
- # Since Arch stores gnome in /opt/gnome, use full dir
- return "archlinux" if stat ("/etc/arch-release");
- return -1;
-}
-
-sub check_linuxppc
-{
- open RELEASE, "$gst_prefix/etc/redhat-release" or return -1;
- while (<RELEASE>)
- {
- chomp;
- if (/^LinuxPPC\s+(\S+)/)
- {
- close RELEASE;
- return "linuxppc-$1";
- }
- }
- close RELEASE;
- return -1;
-}
-
-sub check_pld
-{
- open RELEASE, "$gst_prefix/etc/pld-release" or return -1;
- while (<RELEASE>)
- {
- chomp;
- if(/^([0-9.]+) PLD Linux/)
- {
- close RELEASE;
- return "pld-$1";
- }
- }
- close RELEASE;
- return -1;
-}
-
-sub check_vine
-{
- open RELEASE, "$gst_prefix/etc/vine-release" or return -1;
- while (<RELEASE>)
- {
- chomp;
- if(/^Vine Linux ([0-9.]+)\s+.*/)
- {
- close RELEASE;
- return "vine-$1";
- }
- }
- close RELEASE;
- return -1;
-}
-
-sub check_ark
-{
- open ARK, "$gst_prefix/etc/ark-release" or return -1;
- while (<ARK>)
- {
- $ver = $_;
- chomp ($ver);
-
- if ($ver =~ /^Ark Linux/)
- {
- close ARK;
- return "ark";
- }
- }
-
- close ARK;
- return -1;
-}
-
-sub check_freebsd
-{
- my ($sysctl_cmd, @output);
-
- $sysctl_cmd = &gst_file_locate_tool ("sysctl");
- @output = (readpipe("$sysctl_cmd -n kern.version"));
- foreach (@output)
- {
- chomp;
- if (/^FreeBSD\s([0-9]+)\.\S+.*/)
- {
- return "freebsd-$1";
- }
- }
- return -1;
-}
-
-sub check_solaris
-{
- my ($fd, $dist);
-
- #
- # The file /etc/release is present for solaris-2.6
- # solaris 2.5 does not have the file. Solaris-7.0 and 8.0 have not
- # been checked
- #
- # uname output
- # Solaris 2.5: 5.5(.1)
- # Solaris 2.6: 5.6
- # Solaris 7: unknown, assume 7.0
- # Solaris 8: unknown, assume 8.0
- #
- $fd = &gst_file_run_pipe_read ("uname -r");
- return -1 if $fd eq undef;
- chomp ($dist = <$fd>);
- &gst_file_close ($fd);
-
- if ($dist =~ /^5\.(\d)/) { return "solaris-2.$1" }
- else { if ($dist =~ /^([78])\.\d/) { return "solaris-$1.0" } }
- return -1;
-}
-
-sub gst_platform_get_system
-{
- my ($tool) = @_;
-
- # get the output of 'uname -s', it returns the system we are running
- $$tool{"system"} = &gst_file_run_backtick ("uname -s");
- chomp ($$tool{"system"});
-}
-
-sub gst_platform_guess
-{
- my ($tool) = @_;
-
- my %check = (
- # Red Hat check must run after Vine, Mandrake and Fedora, and Mandrake after BlackPanther
- "Linux" => [ \&check_lsb, \&check_debian, \&check_caldera, \&check_suse, \&check_blackpanther, \&check_vine,
- \&check_fedora, \&check_mandrake, \&check_mandriva, \&check_conectiva, \&check_linuxppc, \&check_rhel, \&check_redhat, \&check_openna,
- \&check_turbolinux, \&check_slackware, \&check_vlos, \&check_gentoo, \&check_pld, \&check_rpath, \&check_archlinux, \&check_ark ],
- "FreeBSD" => [ \&check_freebsd ],
- "SunOS" => [ \&check_solaris ]
- );
- my $plat;
-
- # Fool-the-backend hack.
- if (exists $ENV{"GST_DIST"})
- {
- $$tool{"platform"} = $gst_dist = $ENV{"GST_DIST"};
- return;
- }
-
- foreach $plat (keys %check)
- {
- if ($$tool{"system"} =~ /$plat/)
- {
- my ($check, $dist);
-
- foreach $check (@{$check{$plat}})
- {
- $dist = &$check ();
- if ($dist != -1)
- {
- $$tool{"platform"} = $gst_dist = $dist;
- return;
- }
- }
- }
- }
-
- $$tool{"platform"} = $gst_dist = "unknown";
-}
-
-
-# gst_platform_ensure_supported
-#
-# Takes a list of supported platforms and sees if the one detected is found in
-# this list. If not, will report a list of supported platforms and fail.
-
-sub gst_platform_ensure_supported
-{
- my ($tool, @supported) = @_;
-
- $$tool{"platforms"} = [ @supported ];
-
- foreach $platform (@supported)
- {
- if ($platform eq $$tool{"platform"})
- {
- &gst_report ("platform_success", $platform, $$PLATFORM_INFO{$platform});
- return;
- }
- }
-
- # Not supported.
- if (exists $$tool{"platform"})
- {
- &gst_report ("platform_unsup", $$tool{"platform"});
- }
- else
- {
- &gst_report ("platform_undet");
- }
-}
-
-
-# A directive handler that sets the currently selected platform.
-sub gst_platform_set
-{
- my ($tool, $platform) = @_;
- my ($p);
-
- foreach $p (@{ $$tool{"platforms"}})
- {
- if ($p eq $platform)
- {
- $$tool{"platform"} = $gst_dist = $platform;
- &gst_report ("platform_success", $platform, $$PLATFORM_INFO{$platform});
- &gst_report_end ();
- return;
- }
- }
-
- &gst_report ("platform_unsup", $platform);
- &gst_report_end ();
-}
-
-sub gst_platform_print_list
-{
- my ($platforms) = @_;
- my ($platform, $name);
-
- &gst_xml_print_begin ("platforms");
- foreach $platform (sort @$platforms)
- {
- $name = $$PLATFORM_INFO{$platform};
-
- &gst_xml_container_enter ("platform");
- &gst_xml_print_line ("<key>$platform</key>");
- &gst_xml_print_line ("<name>$name</name>");
- &gst_xml_container_leave ();
- }
- &gst_xml_print_end ("platforms");
-}
-
-sub gst_platform_list
-{
- my ($tool) = @_;
-
- &gst_report_end ();
- &gst_platform_print_list ($$tool{"platforms"});
-}
-
-1;