Visual Studio CodeでCode Runningを用いて、C++実行環境を作成してみた。
Visual Studio CodeとCode Running使用の調査記録
調査背景
Visual Studio for mac ではC#とF#のプロジェクトしかできなかった。WindowsではワークロードからダウンロードできるがVS for macではできない...なんて不便なんだ。
でもmacでGUIでC++を動かす環境はないだろうかと探したところVS Codeの拡張機能を使用するとVS Code上でgccを通して実行できるとのこと。よって、その使用法を調べたのが始まりである。
Vs codeとは
VS codeはプログラムのテキストエディタである。さまざまな拡張機能用いることによって、IDEのようなものとして使用できる。
使用環境
ディバイス:MAC book pro
OS:Catelina 10.15.6
インストール手順
Visual Studio Codeのインストール
公式のダウンロードサイトからmac版をダウンロードする。
するとすでにアプリケーションがインストールされた状態でダウンロードフォルダーにあるからそのままアプリケーションのフォルダーにドラックしていれるといい。
C++に関する拡張機能のインストール
そしたらアプリを開く。すると拡張機能追加の項目の検索欄で「C++」と検索すると、C++関連の拡張パッケージがでるので「C/C++」と「C/C++ Clang Command Adapter」をインストールする。
また「Japanese Language Pack for Visual Studio Code」をインストールするとVS Codeが日本語に対応すると便利である。入れた場合再起動を要求される。
パソコン側の事前準備
Mac側に事前にgccのコンパイラをインストールしておく。(結構時間かかります) macに最初からあるgccはなんか良くなく、brewでインストールするgccが本物のgccらしいと聞いた。
$ brew install gcc
Homebrew自体のセットアップは省略する。以下のurlを参照してください。
Mac Homebrewインストール手順 | Awesome Blog
ワークスペースの作成
C++用のワークスペースを作成する。
メニューバーのファイル→開く→新規フォルダ で任意の名前を入力する。
今回はC++用なので例として「VScodes」などの名前にすると良い。
最後に「開く」でワークスペース作成完了。
c_cpp_properties.json を設定する。
code runnnerで実行する場合Mac側のコンパイラーとインクルードを使用するためそれぞれのデータパスをc_cpp_properties.jsonに登録する必要がある。
手順はC++用のワークスペースを開いた状態で、以下の手順を行う。
1.Ctr+Shift+Pでコマンドパレットを開く
2.C/Cpp:Edit configurations...を選択
3.c_pp_properties.jsonがワークスペース内に作成される。
3.c_pp_c_pp_properties.jsonを編集する。
c_pp_c_pp_properties.jsonの"includePath"のところに自分のディバイスのgccのインクルードパスを確認し、このパスのうち~/includeまでをコピペする。デフォルトであるパスはワークスペース内のヘッダファイルのインクルードに必要で、任意で別のヘッダファイルをワークスペース内に入れとくとそのインクルードも行ってくれるという意味である。
gccのインクルードパス確認方法
$ gcc -v
この行のパスを確認してコピペ --with-gxx-include-dir=/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include/c++/4.2.1
コンパイルパスはしなくてもデフォで実行できたので多分大丈夫だと思います。
設定方法は以下のサイト参照。
C++で始める競プロ / VSCodeの環境構築(Mac) - Qiita
codeコマンドのインストール
ターミナルからワークスペースを開くことができる。
事前にVScodeのコマンドパレットを開き「シェルコマンド:PATH内に'code'コマンドをインストールします。(Shell Command:Install 'code' command in PATH)を選択する。
次にターミナルに以下のコマンドを実行することによって、ワークショップを簡単に開ける。
$ code ワークショップのフォルダ名
標準入力に対応させる
プログラム中に値をユーザーが入力し、処理を行うことを標準入力という。
code runnnerではデフォルトではこの標準入力ができないが、settings.jsonにこの二行を追加すると標準入力が可能になる。
"code-runner.clearPreviousOutput": true,
"code-runner.runInTerminal": true,
参照:VS Codeのsettings.jsonの開き方 - Qiita
実証
試しにhelloworld.cppを作成し、動かしてみよう。
helloworld.cppを作成する手順。
- メニューバーのファイルから新規ファイルでhelloword.cppを作成
- 次のサンプルコードをhelloword.cppにコピペ
#include <iostream>
using namespace std;
int main(){
cout << "Hello world." << endl;
return 0;
}
- エディター内のcppのコードをすべて選択した状態で右上にある再生ボタンを押すと実行されターミナルに結果がでる。
プログラムをすべて選択しないと実行できなかったので注意。再生ボタンを押す前に、「ctr+A」を忘れずに。
まとめ
VScodeはいろんな拡張機能があるので、さまざまな言語で同じことができるかもしれません。
しかしmac専用のCodeRunnerが存在するのでそっちを入れたほうがやりやすいかもしれないです。
macのCodeRunnerのURL:https://apps.apple.com/jp/app/coderunner-3/id955297617?mt=12
Author And Source
この問題について(Visual Studio CodeでCode Runningを用いて、C++実行環境を作成してみた。), 我々は、より多くの情報をここで見つけました https://qiita.com/TaiseiYamana/items/6f5c045bec7fef6d03c8著者帰属:元の著者の情報は、元のURLに含まれています。著作権は原作者に属する。
Content is automatically searched and collected through network algorithms . If there is a violation . Please contact us . We will adjust (correct author information ,or delete content ) as soon as possible .