"platform" ---  実行中プラットフォームの固有情報を参照する
**********************************************************

**ソースコード:** Lib/platform.py

======================================================================

注釈:

  プラットフォーム毎にアルファベット順に並べています。Linuxについては
  Unixセクションを参照してください。


クロスプラットフォーム
======================

platform.architecture(executable=sys.executable, bits='', linkage='')

   *executable* で指定した実行可能ファイル（省略時はPythonインタープリ
   タのバイナリ）の各種アーキテクチャ情報を調べます。

   戻り値はタプル "(bits, linkage)" で、アーキテクチャのビット数と実行
   可能ファイルのリンク形式を示します。どちらの値も文字列で返ります。

   値を決定できない場合はパラメータプリセットから与えられる値を返しま
   す。bits に "''" を与えた場合、サポートされているポインタサイズを知
   るために "sizeof(pointer)" (Python バージョン < 1.5.2 では
   "sizeof(long)") が使用されます。

   この関数は、システムの "file" コマンドを使用します。 "file" はほと
   んどのUnixプラットフォームと一部の非Unixプラットフォームで利用可能
   ですが、 "file" コマンドが利用できず、かつ *executable* が Pythonイ
   ンタープリタでない場合には適切なデフォルト値が返ります。

   注釈:

     macOS (とひょっとすると他のプラットフォーム) では、実行可能ファイ
     ルは複数のアーキテクチャを含んだユニバーサル形式かもしれません。
     現在のインタプリタが "64-bit" であるかどうかを調べるには、
     "sys.maxsize" の方が信頼できます:

        is_64bits = sys.maxsize > 2**32

platform.machine()

   "'i386'" のような、機種を返します。不明な場合は空文字列を返します。

platform.node()

   コンピュータのネットワーク名を返します。ネットワーク名は完全修飾名
   とは限りません。不明な場合は空文字列を返します。

platform.platform(aliased=0, terse=0)

   実行中プラットフォームを識別する文字列を返します。この文字列には、
   有益な情報をできるだけ多く付加しています。

   戻り値は機械で処理しやすい形式ではなく、*人間にとって読みやすい* 形
   式となっています。異なったプラットフォームでは異なった戻り値となる
   ようになっています。

   *aliased* が真なら、システムの名称として一般的な名称ではなく、別名
   を使用して結果を返します。たとえば、SunOS は Solaris となります。こ
   の機能は "system_alias()" で実装されています。

   *terse* が真なら、プラットフォームを特定するために最低限必要な情報
   だけを返します。

   バージョン 3.8 で変更: macOSでは、 "mac_ver()" が空でないリリース文
   字列を返すとき、darwin のバージョンではなく macOS のバージョンを取
   得するために、この関数は "mac_ver()" を使うようになりました。

platform.processor()

   "'amdk6'" のような、（現実の）プロセッサ名を返します。

   不明な場合は空文字列を返します。NetBSDのようにこの情報を提供しない
   、または "machine()" と同じ値しか返さないプラットフォームも多く存在
   しますので、注意してください。

platform.python_build()

   Pythonのビルド番号と日付を、"(buildno, builddate)" のタプルで返しま
   す。

platform.python_compiler()

   Pythonをコンパイルする際に使用したコンパイラを示す文字列を返します
   。

platform.python_branch()

   Python実装のバージョン管理システム上のブランチを特定する文字列を返
   します。

platform.python_implementation()

   Python実装を指定する文字列を返します。戻り値は: 'CPython',
   'IronPython', 'Jython', 'PyPy' のいずれかです。

platform.python_revision()

   Python実装のバージョン管理システム上のリビジョンを特定する文字列を
   返します。

platform.python_version()

   Python のバージョンを、"'major.minor.patchlevel'" 形式の文字列で返
   します。

   "sys.version" と異なり、patchlevel（デフォルトでは0)も必ず含まれて
   います。

platform.python_version_tuple()

   Pythonのバージョンを、文字列のタプル "(major, minor, patchlevel)"
   で返します。

   "sys.version" と異なり、patchlevel（デフォルトでは "'0'")も必ず含ま
   れています。

platform.release()

   Returns the system's release, e.g. "'2.2.0'" or "'NT'". An empty
   string is returned if the value cannot be determined.

platform.system()

   "'Linux'" 、 "'Darwin'" 、 "'Java'" 、 "'Windows'" のような、システ
   ム/OS 名を返します。不明な場合は空文字列を返します。

platform.system_alias(system, release, version)

   マーケティング目的で使われる一般的な別名に変換して "(system,
   release, version)" を返します。混乱を避けるために、情報を並べなおす
   場合があります。

platform.version()

   "'#3 on degas'" のような、システムのリリース情報を返します。不明な
   場合は空文字列を返します。

platform.uname()

   極めて可搬性の高い uname インターフェースです。 "system", "node",
   "release", "version", "machine", "processor" の6つの属性を持った
   "namedtuple()" を返します。

   この関数が "os.uname()" の結果には含まれない 6番目の属性
   ("processor") を追加することに注意してください。さらに、最初の2つの
   属性については属性名が異なります; "os.uname()" はそれらを "sysname"
   と "nodename" と命名します。

   不明な項目は "''" となります。

   バージョン 3.3 で変更: Result changed from a tuple to a
   "namedtuple()".


Java プラットフォーム
=====================

platform.java_ver(release='', vendor='', vminfo=('', '', ''), osinfo=('', '', ''))

   Jython用のバージョンインターフェースです。

   タプル "(release, vendor, vminfo, osinfo)" を返します。*vminfo* は
   タプル "(vm_name, vm_release, vm_vendor)"、*osinfo* はタプル
   "(os_name, os_version, os_arch)" です。不明な項目は引数で指定した値
   (デフォルトは "''") となります。


Windows プラットフォーム
========================

platform.win32_ver(release='', version='', csd='', ptype='')

   Get additional version information from the Windows Registry and
   return a tuple "(release, version, csd, ptype)" referring to OS
   release, version number, CSD level (service pack) and OS type
   (multi/single processor). Values which cannot be determined are set
   to the defaults given as parameters (which all default to an empty
   string).

   参考: *ptype* はシングルプロセッサのNT上では "'Uniprocessor Free'"
   、マルチプロセッサでは "'Multiprocessor Free'" となります。*'Free'*
   がついている場合はデバッグ用のコードが含まれていないことを示し、
   *'Checked'* がついていれば引数や範囲のチェックなどのデバッグ用コー
   ドが含まれていることを示します。

platform.win32_edition()

   Returns a string representing the current Windows edition, or
   "None" if the value cannot be determined.  Possible values include
   but are not limited to "'Enterprise'", "'IoTUAP'",
   "'ServerStandard'", and "'nanoserver'".

   バージョン 3.8 で追加.

platform.win32_is_iot()

   "win32_edition()" によって返された Windows のエディションが IoT エ
   ディションの時 "True" を返します。

   バージョン 3.8 で追加.


macOS Platform
==============

platform.mac_ver(release='', versioninfo=('', '', ''), machine='')

   Get macOS version information and return it as tuple "(release,
   versioninfo, machine)" with *versioninfo* being a tuple "(version,
   dev_stage, non_release_version)".

   不明な項目は "''" となります。タプルの要素は全て文字列です。


Unix プラットフォーム
=====================

platform.libc_ver(executable=sys.executable, lib='', version='', chunksize=16384)

   executableで指定したファイル（省略時はPythonインタープリタ）がリン
   クしているlibcバージョンの取得を試みます。戻り値は文字列のタプル
   "(lib, version)" で、不明な項目は引数で指定した値となります。

   この関数は、実行形式に追加されるシンボルの細かな違いによって、libc
   のバージョンを特定します。この違いは **gcc** でコンパイルされた実行
   可能ファイルでのみ有効だと思われます。

   *chunksize* にはファイルから情報を取得するために読み込むバイト数を
   指定します。
