The Perl and Raku Conference 2025: Greenville, South Carolina - June 27-29 Learn more

# $Id: CheckOS.pm,v 1.13 2007/10/04 20:15:05 drhyde Exp $
use strict;
use vars qw($VERSION @ISA @EXPORT_OK %EXPORT_TAGS);
$VERSION = '1.2';
# localising prevents the warningness leaking out of this module
local $^W = 1; # use warnings is a 5.6-ism
@ISA = qw(Exporter);
@EXPORT_OK = qw(os_is os_isnt die_if_os_is die_if_os_isnt die_unsupported list_platforms);
%EXPORT_TAGS = (
all => \@EXPORT_OK,
booleans => [qw(os_is os_isnt die_unsupported)],
fatal => [qw(die_if_os_is die_if_os_isnt)]
);
=head1 NAME
Devel::CheckOS - check what OS we're running on
=head1 DESCRIPTION
Devel::CheckOS provides a more friendly interface to $^O, and also lets
you check for various OS "families" such as "Unix", which includes things
like Linux, Solaris, AIX etc.
=head1 SYNOPSIS
use Devel::CheckOS;
print "Hey, I know this, it's a Unix system\n" if(os_is('Unix'));
=head1 FUNCTIONS
Devel::CheckOS implements the following functions, which load subsidiary
OS-specific modules on demand to do the real work. They can be exported
by listing their names after C<use Devel::CheckOS>. You can also export
groups of functions thus:
use Devel::CheckOS qw(:booleans); # export the boolean functions
# and 'die_unsupported'
use Devel::CheckOS qw(:fatal); # export those that die on no match
use Devel::CheckOS qw(:all); # export everything
=head2 Boolean functions
=head3 os_is
Takes a list of OS names. If the current platform matches any of them,
it returns true, otherwise it returns false. The names can be a mixture
of OSes and OS families, eg ...
os_is(qw(Unix VMS)); # Unix is a family, VMS is an OS
=cut
sub os_is {
my @targets = @_;
foreach my $target (@targets) {
die("Devel::CheckOS: $target isn't a legal OS name\n")
unless($target =~ /^\w+$/);
eval "use Devel::AssertOS::$target";
if(!$@) {
no strict 'refs';
return 1 if(&{"Devel::AssertOS::${target}::os_is"}());
}
}
return 0;
}
=head3 os_isnt
If the current platform matches any of the parameters it returns false,
otherwise it returns true.
=cut
sub os_isnt {
my @targets = @_;
foreach my $target (@targets) {
return 0 if(os_is($target));
}
return 1;
}
=head2 Fatal functions
=head3 die_if_os_isnt
As C<os_is()>, except that it dies instead of returning false. The die()
message matches what the CPAN-testers look for to determine if a module
doesn't support a particular platform.
=cut
sub die_if_os_isnt {
os_is(@_) ? 1 : die_unsupported();
}
=head3 die_if_os_is
As C<os_isnt()>, except that it dies instead of returning false.
=cut
sub die_if_os_is {
os_isnt(@_) ? 1 : die_unsupported();
}
=head2 And some utility functions ...
=head3 die_unsupported
This function simply dies with the message "OS unsupported", which is what
the CPAN testers look for to figure out whether a platform is supported or
not.
=cut
sub die_unsupported { die("OS unsupported\n"); }
=head3 list_platforms
Return a list of all the platforms for which the corresponding
Devel::AssertOS::* module is available. This includes both OSes and OS
families, and both those bundled with this module and any third-party
add-ons you have installed.
Unfortunately, on some platforms this list may have file case
broken. eg, some platforms might return 'freebsd' instead of 'FreeBSD'.
This is because they have case-insensitive filesystems so things
should Just Work anyway.
=cut
sub list_platforms {
eval " # only load these if needed
";
die($@) if($@);
return sort { $a cmp $b } map {
s/^.*\///g;
s/\.pm$//gi;
$_;
} File::Find::Rule->file()->name('*.pm')->in(
grep { -d }
map { File::Spec->catdir($_, qw(Devel AssertOS)) }
@INC
);
}
=head1 PLATFORMS SUPPORTED
To see the list of platforms for which information is available, run this:
perl -MDevel::CheckOS -e 'print join(", ", Devel::CheckOS::list_platforms())'
Note that capitalisation is important. These are the names of the
underlying Devel::AssertOS::* modules
which do the actual platform detection, so they have to
be 'legal' filenames and module names, which unfortunately precludes
funny characters, so platforms like OS/2 are mis-spelt deliberately.
Sorry.
Also be aware that not all of them have been properly tested. I don't
have access to most of them and have had to work from information
gleaned from L<perlport> and a few other places.
The following OS 'families' are supported 'out of the box':
Apple (Mac OS, both classic and OS X)
DEC
MicrosoftWindows (this matches either MSWin32 or Cygwin)
Sun
Unix
If you want to add your own OSes or families, see L<Devel::AssertOS::Extending>
and please feel free to upload the results to the CPAN.
=head1 BUGS and FEEDBACK
I welcome feedback about my code, including constructive criticism.
Bug reports should be made using L<http://rt.cpan.org/> or by email.
You will need to include in your bug report the exact value of $^O, what
the OS is called (eg Windows Vista 64 bit Ultimate Home Edition), and,
if relevant, what "OS family" it should be in and who wrote it.
If you are feeling particularly generous you can encourage me in my
open source endeavours by buying me something from my wishlist:
=head1 SEE ALSO
$^O in L<perlvar>
L<perlport>
L<Devel::AssertOS>
L<Devel::AssertOS::Extending>
=head1 AUTHOR
David Cantrell E<lt>F<david@cantrell.org.uk>E<gt>
Thanks to David Golden for the name and ideas about the interface, and
to the cpan-testers-discuss mailing list for prompting me to write it
in the first place.
Thanks to Ken Williams, from whose L<Module::Build> I lifted some of the
information about what should be in the Unix family.
Thanks to Billy Abbott for finding some bugs for me on VMS.
=head1 COPYRIGHT and LICENCE
Copyright 2007 David Cantrell
This module is free-as-in-speech software, and may be used, distributed,
and modified under the same conditions as perl itself.
=head1 CONSPIRACY
This module is also free-as-in-mason software.
=cut
$^O;