Skip to main content

๐Ÿ”Ž Detect architectures, platforms, shells, terminals, CI systems and agents, grouped by family

Project description

Extra Platforms

Last release Python versions Downloads Unittests status Coverage status Documentation status DOI

What is Extra Platforms?

Extra Platforms detects the runtime architecture, operating system (including Linux distribution), shell, terminal, CI environment & AI coding agents, and exposes rich, cacheable metadata (version, codename, icon, canonical URL). It also groups them into reusable families.

  • Accurate detection of architecture, OS/distribution, shell, terminal, and CI systems using lightweight, cacheable heuristics.
  • Rich metadata for platforms: version, codename, icon, canonical URL, and "like" relationships.
  • Grouping and API primitives: predefined families, is_*() predicates, current_*() accessors, and Group membership helpers.
  • Testing helpers: Pytest decorators and markers such as @skip_<id> and @unless_<id> for concise platform-aware tests.
  • Extensible and CI-friendly: designed to be lightweight, easy to extend, and suitable for CI-aware workflows.
  • Built-in Linux distribution detection via /etc/os-release, with no external dependencies.

Quick start

Quickly inspect your current environment without installing anything, thanks to uvx:

$ uvx extra-platforms
extra-platforms 9.0.1

โ”€โ”€ Architecture โ”€โ”€ ๐Ÿ“ฑ ARM64 (AArch64) โ”€โ”€[AARCH64]โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
            id: aarch64
          (...)

โ”€โ”€ Platform โ”€โ”€ ๐ŸŽ macOS โ”€โ”€[MACOS]โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
            id: macos
          (...)

โ”€โ”€ Shell โ”€โ”€ โ„ค Zsh โ”€โ”€[ZSH]โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
            id: zsh
          (...)

โ”€โ”€ Terminal โ”€โ”€ ๐Ÿ Apple Terminal โ”€โ”€[APPLE_TERMINAL]โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
            id: apple_terminal
          (...)

โ”€โ”€ CI โ”€โ”€ โ“ Unknown CI โ”€โ”€[UNKNOWN_CI]โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
          (...)

โ”€โ”€ Agent โ”€โ”€ โœด๏ธ Claude Code โ”€โ”€[CLAUDE_CODE]โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€
          (...)

The same output is available via python -m extra_platforms.

Or if you want to explore usage of the library in a Python REPL:

$ uvx --with extra-platforms python
>>> import extra_platforms
>>> extra_platforms.__version__
'9.0.1'

Examples

Get the current platform, from which you can access lots of metadata:

>>> from extra_platforms import current_platform
>>> my_os = current_platform()
>>> my_os
Platform(id='macos', name='macOS')
>>> my_os.id
'macos'
>>> my_os.name
'macOS'
>>> my_os.icon
'๐ŸŽ'
>>> my_os.info()
{
    'id': 'macos',
    'name': 'macOS',
    'icon': '๐ŸŽ',
    'url': 'https://apple.com/macos/',
    'current': True,
    'distro_id': None,
    'version': '26.2',
    'version_parts': {'major': '26', 'minor': '2', 'build_number': None},
    'like': None,
    'codename': 'Tahoe',
}

Check if a platform is a specific system:

>>> from extra_platforms import is_gentoo
>>> is_gentoo()
False

Use groups to check if the current platform is part of a specific family:

>>> from extra_platforms import current_platform, BSD, UNIX, LINUX
>>> current_platform()
Platform(id='macos', name='macOS')
>>> current_platform() in BSD
True
>>> current_platform() in UNIX
True
>>> current_platform() in LINUX
False

Or directly use the detection functions returning a boolean that is associated with each group:

>>> from extra_platforms import is_bsd, is_unix, is_linux
>>> is_bsd()
True
>>> is_unix()
True
>>> is_linux()
False

List all platforms of a family:

>>> from extra_platforms import LINUX
>>> LINUX.members
mappingproxy({
    'altlinux': Platform(id='altlinux', name='ALT Linux'),
    'amzn': Platform(id='amzn', name='Amazon Linux'),
    'android': Platform(id='android', name='Android'),
    'arch': Platform(id='arch', name='Arch Linux'),
    'buildroot': Platform(id='buildroot', name='Buildroot'),
    'cachyos': Platform(id='cachyos', name='CachyOS'),
    'centos': Platform(id='centos', name='CentOS'),
    'cloudlinux': Platform(id='cloudlinux', name='CloudLinux OS'),
    'debian': Platform(id='debian', name='Debian'),
    'exherbo': Platform(id='exherbo', name='Exherbo Linux'),
    'fedora': Platform(id='fedora', name='Fedora'),
    'gentoo': Platform(id='gentoo', name='Gentoo Linux'),
    'guix': Platform(id='guix', name='Guix System'),
    'ibm_powerkvm': Platform(id='ibm_powerkvm', name='IBM PowerKVM'),
    'kvmibm': Platform(id='kvmibm', name='KVM for IBM z Systems'),
    'linuxmint': Platform(id='linuxmint', name='Linux Mint'),
    'mageia': Platform(id='mageia', name='Mageia'),
    'mandriva': Platform(id='mandriva', name='Mandriva Linux'),
    'nobara': Platform(id='nobara', name='Nobara'),
    'opensuse': Platform(id='opensuse', name='openSUSE'),
    'oracle': Platform(id='oracle', name='Oracle Linux'),
    'parallels': Platform(id='parallels', name='Parallels'),
    'pidora': Platform(id='pidora', name='Pidora'),
    'raspbian': Platform(id='raspbian', name='Raspbian'),
    'rhel': Platform(id='rhel', name='RedHat Enterprise Linux'),
    'rocky': Platform(id='rocky', name='Rocky Linux'),
    'scientific': Platform(id='scientific', name='Scientific Linux'),
    'slackware': Platform(id='slackware', name='Slackware'),
    'sles': Platform(id='sles', name='SUSE Linux Enterprise Server'),
    'tumbleweed': Platform(id='tumbleweed', name='openSUSE Tumbleweed'),
    'tuxedo': Platform(id='tuxedo', name='Tuxedo OS'),
    'ubuntu': Platform(id='ubuntu', name='Ubuntu'),
    'ultramarine': Platform(id='ultramarine', name='Ultramarine'),
    'nixos': Platform(id='nixos', name='NixOS'),
    'void': Platform(id='void', name='Void Linux'),
    'generic_linux': Platform(id='generic_linux', name='Generic Linux'),
    'xenserver': Platform(id='xenserver', name='XenServer'),
})
>>> LINUX.member_ids
frozenset({'centos', 'mageia', 'generic_linux', 'ultramarine', 'tuxedo', 'arch', 'buildroot', 'android', 'exherbo', 'nixos', 'void', 'mandriva', 'fedora', 'slackware', 'parallels', 'xenserver', 'kvmibm', 'nobara', 'amzn', 'guix', 'debian', 'oracle', 'cachyos', 'altlinux', 'rhel', 'ibm_powerkvm', 'rocky', 'scientific', 'sles', 'linuxmint', 'tumbleweed', 'ubuntu', 'pidora', 'cloudlinux', 'gentoo', 'raspbian', 'opensuse'})
>>> print("\n".join([p.name for p in LINUX]))
ALT Linux
Amazon Linux
Android
Arch Linux
Buildroot
CachyOS
CentOS
CloudLinux OS
Debian
Exherbo Linux
Fedora
Gentoo Linux
Guix System
IBM PowerKVM
KVM for IBM z Systems
Linux Mint
Mageia
Mandriva Linux
Nobara
openSUSE
Oracle Linux
Parallels
Pidora
Raspbian
RedHat Enterprise Linux
Rocky Linux
Scientific Linux
Slackware
SUSE Linux Enterprise Server
openSUSE Tumbleweed
Tuxedo OS
Ubuntu
Ultramarine
NixOS
Void Linux
Generic Linux
XenServer

Reduce a disparate collection of groups and platforms into a minimal descriptive set, by grouping all platforms into families:

>>> from extra_platforms import AIX, MACOS, SOLARIS, reduce
>>> reduce([AIX, MACOS])
frozenset({
    Platform(id='macos', name='macOS'),
    Platform(id='aix', name='IBM AIX'),
})
>>> reduce([AIX, MACOS, SOLARIS])
frozenset({
    Group(id='system_v', name='AT&T System Five'),
    Platform(id='macos', name='macOS'),
})

Architectures

All recognized architectures and how they're grouped:

---
config: {"mindmap": {"padding": 5}}
---
mindmap
    ((๐Ÿ›๏ธ ALL_ARCHITECTURES))
        )๐˜… X86(
            (๐—ถ I386)
            (๐—ถ I586)
            (๐—ถ I686)
            (๐Ÿ–ฅ๏ธ X86_64)
        )๐ŸŒ WEBASSEMBLY(
            (๐ŸŒ WASM32)
            (๐ŸŒ WASM64)
        )โ…ค RISCV(
            (โ…ค RISCV32)
            (โ…ค RISCV64)
        )โšก POWERPC(
            (โšก PPC)
            (โšก PPC64)
            (โšก PPC64LE)
        )๐Ÿ‰ LOONGARCH(
            (๐Ÿ‰ LOONGARCH64)
        )๐Ÿข IBM_MAINFRAME(
            (๐Ÿข S390X)
        )โ˜€๏ธ ALL_SPARC(
            (โ˜€๏ธ SPARC)
            (โ˜€๏ธ SPARC64)
        )๐Ÿ”ฒ ALL_MIPS(
            (๐Ÿ”ฒ MIPS)
            (๐Ÿ”ฒ MIPS64)
            (๐Ÿ”ฒ MIPS64EL)
            (๐Ÿ”ฒ MIPSEL)
        )๐Ÿ“ฑ ALL_ARM(
            (๐Ÿ“ฑ AARCH64)
            (๐Ÿ“ฑ ARM)
            (๐Ÿ“ฑ ARMV5TEL)
            (๐Ÿ“ฑ ARMV6L)
            (๐Ÿ“ฑ ARMV7L)
            (๐Ÿ“ฑ ARMV8L)

Platforms

All recognized platforms and how they're grouped:

---
config: {"mindmap": {"padding": 5}}
---
mindmap
    ((โš™๏ธ ALL_PLATFORMS))
        )โ‰› UNIX_LAYERS(
            (ฯพ CYGWIN)
        )๐• SYSTEM_V(
            (โžฟ AIX)
            (๐Ÿ”ฅ ILLUMOS)
            (๐ŸŒž SOLARIS)
        )๐Ÿ…Ÿ OTHER_POSIX(
            (๐Ÿ‚ HAIKU)
            (๐Ÿฆฌ HURD)
        )โ‰š LINUX_LAYERS(
            (โŠž WSL1)
            (โŠž WSL2)
        )๐Ÿง LINUX(
            (๐Ÿ”๏ธ ALPINE)
            (ฮ” ALTLINUX)
            (โคป AMZN)
            (๐Ÿค– ANDROID)
            (๐ŸŽ—๏ธ ARCH)
            (โ›‘๏ธ BUILDROOT)
            (โŒฌ CACHYOS)
            (๐Ÿ’  CENTOS)
            (๊ฉœ CLOUDLINUX)
            (๐ŸŒ€ DEBIAN)
            (๐Ÿฝ EXHERBO)
            (๐ŸŽฉ FEDORA)
            (๐Ÿฅš GENERIC_LINUX)
            (๐Ÿ—œ๏ธ GENTOO)
            (๐Ÿƒ GUIX)
            (๐Ÿคน IBM_POWERKVM)
            (๐Ÿ”ฑ KALI)
            (๐Ÿคน KVMIBM)
            (๐ŸŒฟ LINUXMINT)
            (โฅ MAGEIA)
            (๐Ÿ’ซ MANDRIVA)
            (โ–ฒ MANJARO)
            (โ„๏ธ NIXOS)
            (๏Ž€ NOBARA)
            (๐ŸฆŽ OPENSUSE)
            (๐Ÿ“ถ OPENWRT)
            (๐Ÿฆด ORACLE)
            (โˆฅ PARALLELS)
            (๐Ÿ“ PIDORA)
            (๐Ÿ“ RASPBIAN)
            (๐ŸŽฉ RHEL)
            (โ›ฐ๏ธ ROCKY)
            (โš›๏ธ SCIENTIFIC)
            (๐Ÿšฌ SLACKWARE)
            (๐ŸฆŽ SLES)
            (โ†ป TUMBLEWEED)
            (๐Ÿคต TUXEDO)
            (๐ŸŽฏ UBUNTU)
            (๐ŸŒŠ ULTRAMARINE)
            (โˆ… VOID)
            (โ“ XENSERVER)
        )โ’ท BSD(
            (๐Ÿชฐ DRAGONFLY_BSD)
            (๐Ÿ˜ˆ FREEBSD)
            (๐ŸŽ MACOS)
            (๐ŸŒ˜ MIDNIGHTBSD)
            (๐Ÿšฉ NETBSD)
            (๐Ÿก OPENBSD)
            (๐ŸŒ… SUNOS)
        )๐ŸชŸ ALL_WINDOWS(
            (๐ŸชŸ WINDOWS)

[!TIP] More groups exist beyond those shown in the diagram, and more utilities are available for each platform. See the platform documentation for details.

Shells

All recognized shells:

---
config: {"mindmap": {"padding": 5}}
---
mindmap
    ((๐Ÿš ALL_SHELLS))
        )โŒจ๏ธ WINDOWS_SHELLS(
            (โ–ถ CMD)
            (๐Ÿ”ท POWERSHELL)
        )โ—‡ OTHER_SHELLS(
            (๐ŸŸ FISH)
            (๐œˆ NUSHELL)
            (๐Ÿ XONSH)
        )๐Ÿ…ฒ C_SHELLS(
            (๐‚ CSH)
            (๐“ TCSH)
        )๐Ÿ’ฒ BOURNE_SHELLS(
            (๐Ÿชถ ASH)
            (๏ผƒ BASH)
            (๐Ÿ’จ DASH)
            (๐Š KSH)
            (โ„ค ZSH)

Terminals

All recognized terminals:

---
config: {"mindmap": {"padding": 5}}
---
mindmap
    ((๐Ÿ’ป ALL_TERMINALS))
        )โฌข WEB_TERMINALS(
            (โฌก HYPER)
            (๐Ÿˆ TABBY)
            (๐Ÿ”ต VSCODE_TERMINAL)
        )โ–ฆ NATIVE_TERMINALS(
            (๐Ÿ APPLE_TERMINAL)
            (๐† GNOME_TERMINAL)
            (โฌ› ITERM2)
            (๐Ÿ’Ž KONSOLE)
            (๐Ÿ”€ TILIX)
            (โŠก WINDOWS_TERMINAL)
            (๐— XTERM)
        )โง‰ MULTIPLEXERS(
            (๐Ÿ“บ GNU_SCREEN)
            (๐Ÿ“Ÿ TMUX)
            (๐Ÿชต ZELLIJ)
        )๐ŸŽฎ GPU_TERMINALS(
            (๐Ÿ”ณ ALACRITTY)
            (โ—ฐ CONTOUR)
            (๐Ÿฆถ FOOT)
            (๐Ÿ‘ป GHOSTTY)
            (๐Ÿฑ KITTY)
            (๐Ÿž๏ธ RIO)
            (๐Ÿ”ก WEZTERM)

CI systems

All recognized CI systems:

---
config: {"mindmap": {"padding": 5}}
---
mindmap
    ((โ™บ ALL_CI))
        (โ• AZURE_PIPELINES)
        (โŸฒ BAMBOO)
        (๐Ÿช BUILDKITE)
        (โชพ CIRCLE_CI)
        (โ‰‹ CIRRUS_CI)
        (แš™ CODEBUILD)
        (๐Ÿ™ GITHUB_CI)
        (๐ŸฆŠ GITLAB_CI)
        (โฅ HEROKU_CI)
        (๐Ÿ™๏ธ TEAMCITY)
        (๐Ÿ‘ท TRAVIS_CI)

Agents

All recognized AI coding agents:

---
config: {"mindmap": {"padding": 5}}
---
mindmap
    ((๐Ÿง  ALL_AGENTS))
        (โœด๏ธ CLAUDE_CODE)
        (๐Ÿ‘พ CLINE)
        (โžค CURSOR)

Used in

Check these projects to get real-life examples of extra-platforms usage:

Feel free to send a PR to add your project in this list if you are relying on Extra Platforms in any way.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

extra_platforms-11.1.0.tar.gz (69.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

extra_platforms-11.1.0-py3-none-any.whl (72.6 kB view details)

Uploaded Python 3

File details

Details for the file extra_platforms-11.1.0.tar.gz.

File metadata

  • Download URL: extra_platforms-11.1.0.tar.gz
  • Upload date:
  • Size: 69.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for extra_platforms-11.1.0.tar.gz
Algorithm Hash digest
SHA256 3045d722cab2b422a8fcbcba7f52026c33523cb147616d99fc50947f8e952375
MD5 22ff7fb37be28ee17e7f2b1708f72927
BLAKE2b-256 7c7b0049f8a7817ac4eb6ad1af72c7938fff3e2677d55468c87de792208e068c

See more details on using hashes here.

File details

Details for the file extra_platforms-11.1.0-py3-none-any.whl.

File metadata

  • Download URL: extra_platforms-11.1.0-py3-none-any.whl
  • Upload date:
  • Size: 72.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for extra_platforms-11.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5d4476774e5d639813060c239b40481a714f785515db66bcbb19a7b3881debc1
MD5 edff385710094f1fb1e632410d6d3568
BLAKE2b-256 38755985d4b10248cc03f5d0ef03026f3cc69a427baa77b6b07fe26a674bba1a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page