Skip to main content

Detect OS/platforms

Project description

A platform detection library for Python. It uses various methods to attempt to determine the operating system, distribution, release, version, etc., to aid callers in making platform-specific decisions.

lionshead was originally written for “platform-specific wheels” that were a solution to the Linux wheel problem before the creation of manylinux. Rather than be wasted effort, it’s been spun in to a separate library (which would’ve been necessary anyway to be consumed by both pip and wheel).

The development repository can be found at https://github.com/natefoo/lionshead

Documentation is available at http://lionshead.readthedocs.io

The package is published to PyPI at https://pypi.python.org/pypi/lionshead

Quick start

On Debian stretch/sid:

>>> from lionshead import *
>>> get_specific_platform()
SpecificPlatform(dist='debian', major_vers='stretch/sid', full_vers='stretch/sid', stability='unstable')
>>> get_specific_platform_string()
'debian-stretch_sid'
>>> get_platform_stability_string()
'unstable'

On CentOS 7:

>>> from lionshead import *
>>> get_specific_platform()
SpecificPlatform(dist='centos', major_vers='7', full_vers='7', stability='stable')
>>> get_specific_platform_string()
'centos-7'
>>> get_platform_stability_string()
'stable'

Installation of the module also installs lionshead-platform and lionshead-stability commands that return the output of get_specific_platform_string and get_platform_stability_string, respectively.

FAQ

How can I help?

See if your OS/distribution is listed and/or correct in this gist, and if not, follow the instructions and create an issue with your findings.

Does this work on anything other than Linux?

Not currently, but as an avid illumos fan, I plan to add support for other operating systems such as illumos and the BSDs. Here’s the data collection I did for Ansible’s illumos detection to get started.

What is a “stable” vs. “unstable” platform?

“Stable” platforms are operating system releases which commit to a defined, non-changing ABI for the lifetime of the release. This means that the ABI remains consisntent even after OS updates (this typically means that all software is maintained at a specific version). Examples of “stable” releases include:

  • Red Hat Enterprise Linux and derivatives

  • Ubuntu

  • Debian (stable and past stable releases)

  • SUSE Linux Enterprise Server

  • openSUSE (releases)

Conversely, “unstable” platforms are operating systems that use a “rolling release” model where software versions can change with each OS update. Examples of “unstable” releases include:

  • Debian (testing/sid)

  • openSUSE (tumbleweed)

  • Arch

What’s with the name?

The name is a reference to Indiana Jones and the Last Crusade, specifically the scene where Indy takes the “leap of faith” on to the invisible bridge in the Temple of the Sun.

“Only in the leap from the lion’s head will he prove his worth.”

The leap detects the (presence of the) platform underneath… get it? ;P

Code of Conduct

Everyone interacting in the lionshead project’s codebases, issue trackers, chat rooms, and mailing lists is expected to follow the PyPA Code of Conduct.

History

0.1.1 (2017-01-07)

  • Fix detection of Amazon Linux

0.1 (2017-01-03)

  • Yanked platform module out of my pip/wheel forks and adapted as a standalone module for initial version.

  • Wrote a bit of documentation.

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

lionshead-0.1.1.tar.gz (6.7 kB view details)

Uploaded Source

Built Distribution

lionshead-0.1.1-py2-none-any.whl (10.0 kB view details)

Uploaded Python 2

File details

Details for the file lionshead-0.1.1.tar.gz.

File metadata

  • Download URL: lionshead-0.1.1.tar.gz
  • Upload date:
  • Size: 6.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for lionshead-0.1.1.tar.gz
Algorithm Hash digest
SHA256 f44e241fa259ac9101dd21125b9ba16d3e22ac29ca112f1d6736fd12c7b18aa6
MD5 2551cb240ae1cf951e8961514202175c
BLAKE2b-256 f31abf9a377aa5a8b88be7c9e6869e27e8d717d113cf3986a735103a59893d25

See more details on using hashes here.

File details

Details for the file lionshead-0.1.1-py2-none-any.whl.

File metadata

File hashes

Hashes for lionshead-0.1.1-py2-none-any.whl
Algorithm Hash digest
SHA256 14b8368a092cf8b22e0fb564de4cd4549267e71c50df93c40d556fa9701822c0
MD5 e88e4c25f2a9f570141ed9abe05f7dc5
BLAKE2b-256 d8f27009e6dc18ccdac6c4c58866c4c2912def69d3b3edf29b5f114d2352cd88

See more details on using hashes here.

Supported by

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