11
19

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

VSCodeでC言語プログラミング事始め HelloWorldがnmakeできるまで

Last updated at Posted at 2024-02-15

はじめに

諸般の流れからC言語を使う機会が増えてきたので、あらためてVSCodeでC言語プログラミングができる環境構築を再確認しておきます。諸般の事情でWindows+MSCです。今回はmakefileを使ってHelloWorldがビルドできる状況を確認します。HelloWorld単体をビルドするのにmakefileを使うことはあまり意味のないことかもしれませんが、シンプルな環境でなにか見えてくるものもあるかもしれないということで。

前提条件

VSCodeはなんらかのバージョンが既にインストールされていることが前提です。
MSCもなんらかのバージョンのVisualStudioのVisualC++がインストールされていることが前提です。
今回は具体的には下記のバージョンを想定してお話が進みます。前回の記事でtasks.jsonとlaunch.jsonを生成して通常の[実行とデバッグ]からデバッグ開始できるようになったところからお話が進みます。

Windows11 Pro 22H2
VSCode(Visual Studo Code) 1.86.1
Microsoft Visual C++ 2008 Express Edition
Microsoft Visual C++ 2022 Community

VSCodeの拡張機能

VSCodeの拡張機能も下記の通り入っていることが前提です。

C/C++ for Visual Studio Code 1.18.5 Microsoft
C/C++ Extension Pack 1.3.0 Microsoft
C/C++ Extension UI Themes 2.0.0 Microsoft
VS Code Makefile Tools 0.8.22 Microsoft

この記事に直接触れなくとも、はいっちゃっていますという意味で記載しているものもあります。

参考情報

前回の状態からVSCodeを起動

前回の記事の作業で下図のようになっているhelloworldにVisual Studio 2008 command promptを起動して移動します。

C:\DEVELOPMENTS\VSCODE
└─helloworld
   │  helloworld.c
   │  helloworld.exe
   │  helloworld.ilk
   │  helloworld.obj
   │  helloworld.pdb
   │  vc90.pdb
   │
   └─.vscode
           tasks.json
           launch.json

developer command prompt for vs 2022などでも基本はいっしょですがtasks.jsonなどに記述されたcl.exeなどの起動するバージョンが変化します。

Setting environment for using Microsoft Visual Studio 2008 x86 tools.

C:\Program Files (x86)\Microsoft Visual Studio 9.0\VC>cd C:\developments\vscode\helloworld

C:\developments\vscode\helloworld>code .

helloworldがカレントディレクトリの状態からVSCodeを起動します。codeのあとに半角空白はさんでピリオド。下図のような状態のVSCodeが起動します。

vscodec7.png

Makefile

下図のようなmakefileをhelloworldフォルダに作成します。変数名は少しわたしの趣味がはいります。

makefile
# コンパイラ・コンパイラオプションの指定
CC = cl
CFLAGS =/Zi /EHsc /nologo
# ターゲット・ソース・オブジェクトの指定
EXEC = helloworld.exe
SRCS = helloworld.c
OBJS = $(SRCS:.c=.obj)
# ターゲットファイル生成
$(EXEC): $(OBJS)
	$(CC) $(CFLAGS) $(OBJS) /Fe$(EXEC) 
# オブジェクトファイル生成
$(OBJS): $(SRCS)
	$(CC) $(CFLAGS) /c $(SRCS) /Fo$(OBJS) 
# all
all: $(OBJS) $(EXEC)
# clean
clean:
	rm -f $(OBJS) $(EXEC) *.d

VS Code Makefile Tools

VS Code Makefile Toolsを構成していきます。
VS Codeの[ファイル]メニューから[ユーザー設定]-[設定]の順にクリックし、[拡張機能]の[makefile]を選択します。

今回はmakefileはプロジェクトルートにあるため、とくにパス指定は行っていません。MakeツールがMSのnmake.exeになりますので、そこは書き換える必要があります。

下図ではフルパスで書いてしまっていますが、開発者コマンドプロンプトのバージョンを変えて起動したとき、そのバージョンのnmakeを起動するためには実行ファイル名だけを記述します。

vscodec8.png

続いて、コマンドパレットを開いて、makefileとタイプします。するといくつか候補が表示されますが、最初に出てくる「メイクファイル:クリーン構成」を選択するとなんだか構成が中途半端な感じとなります。

なにかを見たわけではないのですが、コマンド名を読んでみた感じいけそうでしたので選択するとよかったのは「メイクファイル:メイクファイル ツール拡張機能ワークスペースの状態をリセットする(トラブルシューティング)」です。

vscodec9.png

「メイクファイル:メイクファイル ツール拡張機能ワークスペースの状態をリセットする(トラブルシューティング)」を選択するとVSCodeが再起動して、下図のような[Makefile Tools]ビューが追加されます。

vscodec10.png

Make実行

[Makefile Tools]ビューで、「ターゲットのビルド」をクリックすると「all」が選択できますので、それを選択します。

[Makefile Tools]ビューのツールバーの左端の↓が凹にささっているみたいなアイコンをクリックするとmakeが開始されます。

ちょっとスクショが小さくて見づらいですが、下記のようにターミナルに出力されています。

ターミナル
Microsoft(R) Program Maintenance Utility Version 9.00.30729.01
Copyright (C) Microsoft Corporation.  All rights reserved.

        cl /Zi /EHsc /nologo /c helloworld.c /Fohelloworld.obj
helloworld.c
        cl /Zi /EHsc /nologo helloworld.obj /Fehelloworld.exe
 *  ターミナルはタスクで再利用されます、閉じるには任意のキーを押してください。

出力は下記のようになっています。

出力
Saving opened files before build.
Building target "all" with command: 'nmake.exe all'
Target "all" built successfully.

つづく

今日はここまで。いちおうつづきがあります。

11
19
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
11
19

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?