NAME

OSType - Map operating system names to generic types or families

SYNOPSIS

use OSType ':all';

$current_type = os_type();
$other_type = os_type('dragonfly'); # gives 'Unix'

$is_sun = is_os_family("Sun");

DESCRIPTION

Modules that provide OS-specific behaviors often need to know if the current operating system matches a more generic type or family of operating systems. For example, 'linux' is a type of 'Unix' operating system and so is 'freebsd'.

This module provides a mapping between an operating system name as given by $^O and a more generic type. The initial version is based on the OS type mappings provided in Module::Build and ExtUtils::CBuilder. (Thus, Microsoft operating systems are given the type 'Windows' rather than 'Win32'.)

OS Families

Devel::CheckOS introduced the notion of OS families, which do not necessarily correspond to types. An operating system can belong to multiple families. Supported families include the following (descriptions are taken nearly verbatim from Devel::CheckOS):

  • Unix

    Broadly speaking, these are platforms where:

    • Devices are represented as pseudo-files in the filesystem

    • Symlinks and hardlinks are supported in at least some filesystems

    • "Unix-style" permissions are supported; That is, there are seperate read/write/execute permissions for file owner, group and anyone. This implies the presence of multiple user accounts and user groups. Permissions may not be supported on all filesystems.

    • The filesystem has a single root

    • The C API for the operating system is largely POSIX-compatible

  • Apple, DEC, Sun

    These include any OS written by, respectively, Apple, DEC, and Sun. They exist because, while, eg, Mac OS Classic and Mac OS X are very different platforms, they do support some unique features - such as AppleScript. Vendor families may also have similar known issues or incompatibilities, such as with Sun's 'tar' program.

  • MicrosoftWindows

    This includes any version of Windows and also includes things like Cygwin which run on top of it.

  • Realtime

    This is for all real-time OSes. So far, it only includes QNX.

USAGE

No functions are exported by default. The export tag ":all" will export all functions listed below.

os_type()

$os_type = ostype();
$os_type = ostype('MSWin32');

Returns a single, generic OS type for a given operating system name. With no arguments, returns the OS type for the current value of $^O. If the operating system is not recognized, the function will return the empty string.

is_os_type()

$is_windows = is_os_type('Windows');
$is_unix    = is_os_type('Unix', 'dragonfly');

Given an OS type and OS name, returns true or false if the OS name is of the given type. As with os_type, it will use the current operating system as a default if no OS name is provided.

os_family()

@names = os_family('Apple');

Given an OS family, returns a list of OS names (as they would appear in $^O) that belong to the given family. If the family name is not known, the function will return an empty list.

is_os_family()

$is_realtime  = is_os_family('Realtime');
$is_sun       = is_os_family('Sun', 'solaris');

Given an OS family and an OS name, returns true or false if the OS name is in the given family. As with os_type, it will use the current operating system as a default if no OS name is provided.

SEE ALSO

AUTHOR

David Golden, <dagolden@cpan.org>

COPYRIGHT AND LICENSE

Copyright (C) 2009 by David Golden

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.10.0 or, at your option, any later version of Perl 5 you may have available.