cmd.exe

cmd.exeOS/2NT系WindowsWindows CEに搭載されているコマンドラインインタプリタである。英語版のショートカットには「Command Prompt」、日本語版のショートカットには「コマンド プロンプト」という名称が付けられている[1]MS-DOSからWindows 9xに渡って用いられたCOMMAND.COM(およびDOSプロンプト)と類似の機能を持つ。Win32コンソールAPIを利用して実装されている。

cmd.exe
Microsoft Windows コンポーネント
詳細
標準提供Windows NT 3.1 以降
Windows CE
OS/2
関連コンポーネント
COMMAND.COM
Windows PowerShell

64ビット版Windowsでは、64ビットのcmd.exeと、WOW64で実行される32ビットのcmd.exeがインストールされている。Windows 9x系のDOSプロンプトがMS-DOS仮想マシン上で動く16bitプログラムなのに対して、cmd.exeは32bitもしくは64bitで動作するコンソールプログラムである。

cmd.exeはCOMMAND.COMと比べ、相当に機能向上が図られている。一旦はエスケープシーケンスの機能が削られたが、Windows 10 1607で復活[2]し、VT100互換のエスケープシーケンスが使用できるようになった。

新機能

WindowsにおいてコマンドプロンプトはCOMMAND.COMとある程度の互換性を持つが、次の拡張が施されている。

  • COMMAND.COMでの「コマンドまたはファイル名が違います。」よりも詳細なメッセージを出力するようになった。OS/2ではシステムで選択された言語でエラーが表示され、そのメッセージは「システムメッセージファイル」より取得される。
  • 矢印キーを使ったコマンド履歴のスクロールをサポート。この機能はCOMMAND.COMでは外部コマンドのDOSKEYでサポートされていた。
  • ファイルやフォルダーパスのコマンドライン補完をサポート(既定では Tabキーに割り当てられている)
  • 「^」をエスケープ文字として扱う。つまり、次のコマンドプロンプトで特別な意味を持つ文字の前にキャレットを付けることで、リテラルとして扱うことができる。(例:<, >, *, ?, |
  • バッチ処理において変数の遅延展開をサポート(Windows 2000以降)

また、内部コマンドが次のように改善されている。

  • DelTreeコマンド(ディレクトリとそれ以下のファイル・ディレクトリを削除)はRDコマンドに/Sスイッチとして統合。
  • SetLocalコマンドやEndLocalコマンドで環境のスコープを限定。例えば、SetLocalコマンド後にバッチファイルなどにより変更された環境変数は、EndLocalコマンドを実行するとSetLocalコマンド実行前の状態に復元される。
  • Callコマンドでバッチファイル内のサブルーチンの呼び出しをサポートした。COMMAND.COMでは外部バッチファイルの呼び出しのみをサポートしていた。
  • C Shellと互換性があるファイル名修飾子(%fなど)
  • カレントディレクトリを変更した後から過去のカレントディレクトリに戻ることができる、PushDPopDコマンド
  • IFコマンドで大文字・小文字を区別した文字列比較、数値比較、ブロック記述をサポート。
  • SETコマンドで数値の演算代入をサポート
  • REMがコメントになった。COMMAND.COMでは何もしないコマンドだった。

後継および将来性

cmd.exeの後継は.NET Framework/.NET Coreをベースにオブジェクト指向言語として再構築されたPowerShellであり、Windowsコマンドと比べて高い柔軟性と記述性を持つ。いくつかのWindowsコマンドに関して互換エイリアスが用意されているなど、ある程度の互換性も持っているが、完全な上位互換ではなく、コマンドプロンプトとは依然として共存関係にある。マイクロソフトはcmd.exe廃止の噂に関しては全面否定しており、例えばWindows自身をビルド&テストするために自動化されたシステムにおいてcmd.exeに依存した多数のスクリプトが利用されていることなどから、将来的にWindowsから取り除かれることはないとしている[3]

Windowsエクスプローラーとの統合

Windows 7エクスプローラーでは、Shiftキーを押しながらコンテキストメニューを表示すると、「コマンド ウィンドウをここで開く」というメニューコマンドが出現する[4]。このコマンドを実行することで、指定フォルダーをカレントディレクトリに設定した状態でコマンドプロンプトを起動することができる。

Windows 8.1ではスタートボタンを右クリックする、またはWindowsキーを押しながらXキーを押すことでシステムコマンドメニューが表示され、コマンドプロンプトを通常権限または管理者権限で起動することができる。

Windows 10 Creators Update (バージョン1703) では、既定のコマンドシェルがPowerShellに置き換えられ、エクスプローラー上でShiftキーを押しながらコンテキストメニューを表示すると「PowerShell ウィンドウをここに開く」というメニューコマンドが出現するようになり、またシステムコマンドメニューにはコマンドプロンプトの代わりにPowerShellが表示されるようになった。ただし設定変更により従来通りコマンドプロンプトをシステムコマンドメニューに表示させることも可能である[5]

文字コード

コマンドプロンプトの文字コード

コマンドプロンプト(cmd.exe)自体が使用している文字コードはUnicode (UTF-16) であり、(コマンドからの出力がUnicodeでありフォントがあれば)Unicode特有の文字を問題なく画面に表示することができる。ただしバッチファイルCOMMAND.COMとの互換性維持の観点から、Windowsのシステムロケール設定(「Unicode対応ではないプログラムの言語」のこと、表示言語とは異なる)と同じ「ANSIコードページ」でエンコードされているという前提で解釈される。例えばシステムロケール設定が日本語の場合、既定でMicrosoftコードページ932 (CP932, Shift_JIS) が使われる。ただしバッチファイルからコマンドを実行して画面に出力する場合に文字コード変換が行われることはない。コマンドプロンプトで使用するANSIコードページはシステムロケール設定を変更する他、chcpコマンドによってコマンドプロンプトごとに一時的に変更することが可能であり、例えばコードページ65001に設定するとUTF-8として解釈される。UTF-16LE(コードページ1200)はANSIコードページと互換性がないためサポートされない。

内部コマンドの文字コード

コマンドプロンプトに内蔵されている内部コマンドtypedirなど)はUnicode出力とANSIコードページ出力の両方に対応しており、単独で実行して画面に表示する場合はUnicodeで出力される。ただし内部コマンドの出力先が画面以外(リダイレクトパイプ)である場合は、現在のANSIコードページに変換して出力する。この挙動はcmd.exeのデフォルト(/Aオプション)設定時の動作であり、/U オプションを付けて起動することでUTF-16出力に変更することが可能[6]である。バイト順マーク (BOM) はテキストとして保存した場合に必要なものであるため付与されない。

外部コマンドの文字コード

Windowsではアプリケーションソフトウェアの一形態として、コマンドラインインターフェイス (CLI) を持つ「コンソールアプリケーション」があり、これは単独で動作させることができるだけでなくコマンドプロンプト上で動作させることもできる。これにより、ユーザーが外部コマンドとして独自のコマンドを開発し、リダイレクトパイプを駆使してバッチ処理に応用することができる。

外部コマンドが出力する文字コードはその外部コマンドの実装によって異なり、一般にコマンド開発者はCLIコマンドの出力をUnicodeモードで行なうか、MBCSモードで行なうかを選ぶことができる。例えばC言語の場合は_setmode()関数[7]を呼び出すことで設定できる。.NET Frameworkの場合はSystem.Console.OutputEncodingプロパティで設定できる。_setmode()で設定可能なUnicodeモードは更に_O_U16TEXTモード、_O_U8TEXTモード、_O_WTEXTモードに細分化されるが、いずれであってもコマンドプロンプトはそれらを正しく解釈し、現在のコードページに関係なくUnicode出力として扱い正しく画面に表示する。MBCSモードで出力した場合は現在のコードページの設定に従って内部的にUnicodeに変換され画面に表示される。

なお、ipconfigなど、Windowsに標準搭載されている外部コマンドは入出力をMBCSモードで行なっている。ただしシステムロケール設定に応じて表示言語を切り替えている。

仮にコマンドプロンプト上でUnicode入出力を行なう独自コマンドを開発する場合は、入出力をUnicodeモードで行なうことで実現できる。またバッチファイルによる読み取りを考慮する場合は、コマンドの入出力をUTF-8とし、バッチファイルをUTF-8で記述し、コードページをchcp 65001によってUTF-8に変更することでUnicodeの入出力に対応することができる。

脚注

関連項目

外部リンク