blob: 1925616fb9286dbdd87ec88f44b8fe0cfb3c4288 [file] [log] [blame]
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<!--
Copyright (c) 2009, 2014, Oracle and/or its affiliates. All rights reserved.
-->
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<meta name="author" content="alexander.simon@oracle.com">
<meta name="description" content="A short guide to modify or create a new tool collection for C/C++ in NetBeans IDE 8.0. Most content
also applies to Oracle Solaris Studio IDE.">
<meta name="keywords" content="NetBeans, Oracle Solaris Studio, Sun Studio, Solaris Studio, IDE, tool collection,
tutorial, guide, user, documentation, open source, C, C++, make, dbx, gdb">
<link rel="stylesheet" type="text/css" href="../../../netbeans.css">
<title>C/C++ツール・コレクション・ディスクリプタの使用 - NetBeans IDEチュートリアル</title>
</head><body style="padding: 2px;">
<h1>C/C++ツール・コレクション・ディスクリプタの使用 - NetBeans IDEチュートリアル</h1>
<div class="articledate" style="margin-left: 0px;font-style:italic;">
<p><em>執筆: <a href="mailto:alexander.simon@oracle.com"><i>Alexander Simon</i></a><!-- maintained by susan.morgan@oracle.com --><br>2014年3月</em> [リビジョン番号: V8.0-1]</div>
<p><b>目次</b></p>
<img alt="このページの内容は、NetBeans IDE 8.0に適用されます" class="stamp" src="../../../images_www/articles/80/netbeans-stamp.png" title="このページの内容は、NetBeans IDE 8.0に適用されます">
<ul class="toc">
<li><a href="#intro">概要</a></li>
<li><a href="#tool">ツール・コレクション</a></li>
<li><a href="#community">コミュニティ貢献ツール・コレクション</a></li>
<li><a href="#edit">ツール・コレクション・ディスクリプタの編集</a></li>
<li><a href="#create">カスタム・ツール・コレクションの作成</a></li>
<li><a href="#details">ツール・コレクションXMLファイルの詳細</a></li>
<li><a href="#provider">カスタム・コンパイラ・プロバイダの作成</a></li>
<li><a href="#errorhandler">カスタム・コンパイラのエラー・ハンドラの作成</a></li>
</ul>
<p><b>このチュートリアルに従うには、次のソフトウェアが必要です。</b></p>
<table class="b-none vatop" cellpadding="0" cellspacing="0">
<tbody>
<tr>
<th class="tblheader" scope="col">ソフトウェア</th>
<th class="tblheader" scope="col">必須バージョン</th>
</tr>
<tr>
<td class="tbltd1">NetBeans IDE (C/C++のサポートを含む)</td>
<td class="tbltd1"><a href="https://netbeans.org/downloads/index.html">バージョン8.0</a></td>
</tr>
<tr>
<td class="tbltd1">Java Development Kit (JDK)</td>
<td class="tbltd1"><a href="http://www.oracle.com/technetwork/java/javase/downloads/index.html">バージョン7または8</a> </td>
</tr>
</tbody>
</table>
<br>
<p>必要なソフトウェアのダウンロードとインストールについては、<a href="../../../community/releases/80/install.html">NetBeans IDEのインストール手順</a>および<a HREF="../../../community/releases/80/cpp-setup-instructions.html">C/C++/Fortran向けのNetBeans IDEの構成</a>を参照してください。</p>
<a id="intro"></a>
<h2>概要</h2>
<p>このチュートリアルでは、NetBeans IDE 8.0で既存のツール・コレクションを編集する方法と、既存のツール・コレクションのカスタム・バージョンを作成する方法を示します。</p>
<p>ここで示す例はOracle SolarisおよびLinuxのGNUツール・コレクションに適用されますが、この概念はWindowsおよびMacにも適用されます。この情報を使用して、次の操作の方法を学習できます。
</p>
<ul>
<li>IDEでC/C++ファイルをコンパイルするときにデフォルトで使用されるコンパイラ・フラグの変更</li>
<li>IDEでサポートされていないコンパイラの追加</li>
</ul>
<h2><a name="tool"></a>ツール・コレクション</h2>
<p>ツール・コレクションは、コンパイラ、makeユーティリティおよびデバッガのセットで、<em>ツール・コレクション・ディスクリプタ</em>によってIDEで指定されます。コードのコンパイル、makeまたはデバッグを行うたびに、プロジェクトで使用するように構成されているツール・コレクションに対する、ツール・コレクション・ディスクリプタに記述された実行可能ファイルをIDEは実行します。コード支援機能では、ツール・コレクション・ディスクリプタから取得したインクルード・パスとマクロが使用されます。</p>
<p>ツール・コレクション・ディスクリプタは、フォルダ<tt>org/netbeans/modules/cnd/toolchain/resources/toolchaindefinition/</tt>内のモジュール<tt><em>IDE_HOME</em>/cnd/modules/org-netbeans-modules-cnd-toolchain.jar</tt>にあるXMLファイルです。これらの元のIDEツール・ディスクリプタXMLファイルは編集しないでください。 </p>
<p>この記事では、編集可能なツール・ディスクリプタの複製ファイルをNetBeansユーザー・ディレクトリ内に作成する方法について説明します。IDEでは、元のバージョンのかわりに、ユーザー・ディレクトリ内にあるツール・コレクション・ディスクリプタの情報が使用されるようになります。 </p>
<h2><a name="community"></a>コミュニティ貢献ツール・コレクション</h2>
<p>ツール・コレクションの一部のプラグインは、NetBeansコミュニティ内のユーザーによって提供されています。</p>
<ul><li><a href="http://plugins.netbeans.org/plugin/36176/cuda-plugin">Cuda</a></li>
<li><a href="http://plugins.netbeans.org/plugin/27033/msp430-toolchain">TI msp430 microcontroller toolchain</a></li>
<li><a href="http://plugins.netbeans.org/plugin/42519/">Visual Studio</a></li>
</ul>
<p>これらのプラグインは正式にサポートされていませんが、独自のプラグインの作成に役立つ場合は、ここで参照されます。</p>
<p>Windowsユーザーには、NetBeansコミュニティのユーザーによる次の記事も役立つ場合があります: <a href="http://minghuasweblog.wordpress.com/2012/09/27/netbeans-setup-and-gnu-cross-toolchain-configuration-for-arm-developmen/">NetBeans Setup and GNU Cross-Toolchain Configuration for ARM Development</a>
</p>
<h2><a name="edit"></a>ツール・コレクション・ディスクリプタの編集</h2>
<p>NetBeans IDEにはディスクリプタを編集するGUIがないため、ツール・コレクション・ディスクリプタを編集するには多少のコツが必要です。この項では、IDEによるツールの使用方法を変更するために編集可能な、ツール・コレクション・ディスクリプタの「シャドウ」の複製コピーを作成する方法について説明します。 </p>
<ol>
<li>IDEが実行中の場合は終了します。</li>
<li>ファイル<tt><em>IDE-HOME</em>/etc/netbeans.conf</tt>を編集します。<tt><em>IDE-HOME</em></tt>はNetBeansインストール・ディレクトリを表します。</li>
<li>次のフラグを<tt>netbeans_default_options</tt>エントリに追加します。
<pre>-J-Dcnd.toolchain.personality.create_shadow=true</pre>
</li>
<li>
IDEを起動して「ツール」>「オプション」を選択し、「オプション」ウィンドウの上のペインで「C/C++」を選択します。 <br>
<p>ツール・コレクション・ディスクリプタの「シャドウ」バージョンが含まれるディレクトリがNetBeansユーザー・ディレクトリ内に作成されます。 </p>
<pre><em>userdir</em>/config/CND/ToolChain</pre>
<p class="note">NetBeansユーザー・ディレクトリの場所は、使用しているオペレーティング・システムによって変わります。<tt><em>userdir</em>/config/CND/ToolChain</tt>ディレクトリの場所の例を次に示します。</p>
<ul>
<li>Windows: <tt>C:\Documents and Settings\<em>username</em>\Application Data\NetBeans\<em>version</em>\config\CND\ToolChain</tt></li>
<li>Mac: <tt>/Users/<em>username</em>/Library/Application Support/NetBeans/<em>version</em>/config/CND/ToolChain</tt></li>
<li>LinuxおよびSolaris: <tt>/home/<em>username</em>/.netbeans/<em>version</em>/config/CND/ToolChain</tt></li>
</ul>
<p>
作成されたディスクリプタのリストは、次のようになります。</p>
<pre>CLang.xml SunStudio.xml
CLang_mac.xml SunStudio_10.xml
CLang_solaris.xml SunStudio_11.xml
Cygwin.xml SunStudio_12.1_solaris-sparc.xml
Cygwin_4.x.xml SunStudio_12.1_solaris-x86_linux.xml
GNU.xml SunStudio_12.2_linuxCompatGNU.xml
GNU_mac.xml SunStudio_12.2_solaris-sparc.xml
GNU_solaris.xml SunStudio_12.2_solaris-x86_linux.xml
Intel.xml SunStudio_12.3_linuxCompatGNU.xml
Interix.xml SunStudio_12.3_solaris-sparc.xml
MinGW.xml SunStudio_12.3_solaris-x86_linux.xml
MinGW_TDM.xml SunStudio_12.xml
OSS_linuxCompatGNU.xml SunStudio_8.xml
OSS_solaris-sparc.xml SunStudio_9.xml
OSS_solaris-x86_linux.xml WinAVR.xml
OracleSolarisStudio.xml
</pre>
<p>使用しているtoolchainのディスクリプタを編集できます。たとえば、SolarisでGNUを使用している場合は<tt>GNU_solaris.xml</tt>ファイルを編集し、WindowsでMinGWを使用している場合は<tt>MinGW.xml</tt>ファイルを編集する必要があります。 </p>
<p>これらのディスクリプタXMLファイルで使用されるタグの詳細は、<a href="#details">ツール・コレクションXMLファイルの詳細</a>を参照してください。タグの値を変更することで、IDEでのツールの動作を変更できます。</p>
<p>このディレクトリのディスクリプタは、<em>IDE-HOME</em>ディレクトリ内の正式バージョンよりも優先されます。IDEで使用しないユーザー・ディレクトリ内のツール・ディスクリプタは削除する必要があります。</p></li>
<li><tt>-J-Dcnd.toolchain.personality.create_shadow=true</tt>フラグを<tt><em>IDE-HOME</em>/etc/netbeans.conf</tt>から削除して、IDEがシャドウ・ディスクリプタを再度作成しないようにします。</li>
<li>変更作業が終了したら、変更されたツール・ディスクリプタが使用されるようにするため、IDEを再起動します。 </li>
</ol>
<h2><a name="create"></a>カスタム・ツール・コレクションの作成</h2>
<p>この項では、デバッグ用にコンパイラ・フラグを一部変更した、GNUツール・コレクションに基づくツール・コレクションを作成する方法について説明します。この例では、新規ツール・コレクションが含まれる新規NetBeansモジュールを作成するための手順が示されます。これによってツール・コレクションを共有、またはIDEの別のインスタンスで使用することが可能になります。</p>
<p>NetBeansモジュール作成の概要については、<a href="http://platform.netbeans.org/tutorials/nbm-google.html">NetBeansプラグインのクイック・スタート</a>を参照してください。</p>
<br><b>カスタム・ツール・コレクションを作成するには:</b>
<ol>
<li>NetBeansインストールにNetBeansプラグイン開発モジュールが含まれていることを確認してください。<br><br>「ツール」>「プラグイン」と選択して、「インストール済み」タブをクリックします。NetBeansプラグイン開発モジュールがインストールされていない場合は、「使用可能なプラグイン」タブをクリックして、モジュールをインストールします。検索ボックスに「プラグイン」と入力すると、すばやく探すことができます。</li>
<li>「ファイル」>「新規プロジェクト」を選択して、新規NetBeansモジュールを作成します。新規プロジェクト・ウィザードのプロジェクトを選択ページで、ウィザードの最初のステップとして、カテゴリに「NetBeansモジュール」、プロジェクトに「モジュール」を選択します。「次」をクリックします。
</li>
<li>名前と場所ページで、プロジェクト名を入力し(「<tt>mytoolchain</tt>」など)、その他のフィールドはそのままにします。「次」をクリックします。</li>
<li>「基本モジュール構成」ページで、「コード名ベース」に<tt>org.myhome.mytoolchain</tt>と入力します。これは、作成中のモジュールを識別する一意の文字列を定義します。コード名ベースは、モジュールのメイン・パッケージとしても使用されます。 </li>
<li>OSGiではなくデフォルトのNetBeansモジュール・システムを使用することになるため、「OSGiバンドルを生成」チェックボックスは選択しないでください。</li>
<li>「終了」をクリックします。IDEではmytoolchainという新規プロジェクトが作成されます。</li>
<li>「プロジェクト」タブで、mytoolchainプロジェクト・ノードを右クリックし、「新規」>「その他」を選択します。 </li>
<li>新規ファイル・ウィザードで、カテゴリ「モジュールの開発」およびファイル・タイプ「XMLレイヤー」を選択してから、「次」をクリックして「終了」をクリックします。<br><br>IDEでは、メイン・パッケージ<tt>org.myhome.mytoolchain</tt>内のソース・パッケージ・ノードの下に<tt>layer.xml</tt>が作成され、エディタで<tt>layer.xml</tt>が開かれます。</li>
<li>ファイルに<tt>&lt;filesystem/></tt>タグが含まれている場合は、そのタグを開始および終了の<tt>filesystem</tt>タグに置き換えます。<pre><tt>&lt;filesystem&gt;</tt>
<tt>&lt;/filesystem&gt;</tt></pre></li>
<li><tt>filesystem</tt>タグ内に、<tt>layer.xml</tt>の次のテキストをコピーして貼り付けます。
<pre>
&lt;folder name="CND"&gt;
&lt;folder name="Tool"&gt;
&lt;file name="GNU_tuned_flavor" url="toolchain/GNU_tuned_flavor.xml"&gt;
&lt;attr name="extends" stringvalue="GNU_flavor"/&gt;
&lt;/file&gt;
&lt;file name="GNU_tuned_cpp" url="toolchain/GNU_tuned_cpp.xml"&gt;
&lt;attr name="extends" stringvalue="GNU_cpp"/&gt;
&lt;/file&gt;
&lt;/folder&gt;
&lt;folder name="ToolChains"&gt;
&lt;folder name="GNU_tuned"&gt;
&lt;attr name="position" intvalue="5000"/&gt;
&lt;attr name="SystemFileSystem.localizingBundle" stringvalue="org.myhome.mytoolchain.Bundle"/&gt;
&lt;file name="flavor.shadow"&gt;
&lt;attr name="originalFile" stringvalue="CND/Tool/GNU_tuned_flavor"/&gt;
&lt;/file&gt;
&lt;file name="c.shadow"&gt;
&lt;attr name="originalFile" stringvalue="CND/Tool/GNU_c"/&gt;
&lt;/file&gt;
&lt;file name="cpp.shadow"&gt;
&lt;attr name="originalFile" stringvalue="CND/Tool/GNU_tuned_cpp"/&gt;
&lt;/file&gt;
&lt;file name="fortran.shadow"&gt;
&lt;attr name="originalFile" stringvalue="CND/Tool/GNU_fortran"/&gt;
&lt;/file&gt;
&lt;file name="assembler.shadow"&gt;
&lt;attr name="originalFile" stringvalue="CND/Tool/GNU_assembler"/&gt;
&lt;/file&gt;
&lt;file name="scanner.shadow"&gt;
&lt;attr name="originalFile" stringvalue="CND/Tool/GNU_scanner"/&gt;
&lt;/file&gt;
&lt;file name="linker.shadow"&gt;
&lt;attr name="originalFile" stringvalue="CND/Tool/GNU_linker"/&gt;
&lt;/file&gt;
&lt;file name="make.shadow"&gt;
&lt;attr name="originalFile" stringvalue="CND/Tool/GNU_make"/&gt;
&lt;/file&gt;
&lt;file name="debugger.shadow"&gt;
&lt;attr name="originalFile" stringvalue="CND/Tool/GNU_debugger"/&gt;
&lt;/file&gt;
&lt;file name="qmake.shadow"&gt;
&lt;attr name="originalFile" stringvalue="CND/Tool/GNU_qmake"/&gt;
&lt;/file&gt;
&lt;file name="cmake.shadow"&gt;
&lt;attr name="originalFile" stringvalue="CND/Tool/GNU_cmake"/&gt;
&lt;/file&gt;
&lt;/folder&gt;
&lt;/folder&gt;
&lt;/folder&gt;
</pre>
</li>
<li><tt>Bundle.properties</tt>ファイルを開き、次の文字列を追加します。<br><tt>CND/ToolChains/GNU_tuned=My GNU Tuned Tool Collection</tt></li>
<li>ソース・パッケージの下の<tt>org.myhome.mytoolchain</tt>パッケージを右クリックし、「新規」>「Javaパッケージ」を選択してサブパッケージ<tt>toolchain</tt>を作成します。デフォルト・パッケージ名の<tt>newpackage</tt><tt>toolchain</tt>に置き換えて、「終了」をクリックします。IDEではサブパッケージ<tt>org.myhome.mytoolchain.toolchain</tt>が作成されます。 </li>
<li><tt>org.myhome.mytoolchain.toolchain</tt>サブパッケージを右クリックして「新規」>「空のファイル」を選択することで、新規ファイルを作成します。ファイルに<tt>GNU_tuned_flavor.xml</tt>という名前を付けて、「終了」をクリックします。
<p class="notes">「空のファイル」がオプションとして表示されない場合、「その他」を選択してから新規ファイル・ウィザードで、カテゴリ「その他」およびファイル・タイプ「空のファイル」を選択して「次」をクリックします。</p>
<p>このファイルは、新規ツール・コレクションのツール・コレクション・ディスクリプタです。</p></li>
<li><tt>GNU_tuned_flavor.xml</tt>内に、次のテキストをコピーして貼り付けます。
<pre>&lt;?xml version="1.0" encoding="UTF-8"?&gt;
&lt;toolchaindefinition xmlns="https://netbeans.org/ns/cnd-toolchain-definition/1"&gt;
&lt;toolchain name="GNU_tuned_flavor" display="GNU_tuned" family="GNU" qmakespec="${os}-g++"/&gt;
&lt;platforms stringvalue="linux,sun_intel,sun_sparc"/&gt;
&lt;/toolchaindefinition&gt;
</pre>
</li>
<li><tt>org.myhome.mytoolchain.toolchain</tt>サブパッケージを右クリックして「新規」>「空のファイル」を選択することで、別のファイルを作成します。ファイルに<tt>GNU_tuned_cpp.xml</tt>という名前を付けて、「次」をクリックします。
<li><tt>GNU_tuned_cpp.xml</tt>内に、次のテキストをコピーして貼り付けます。
<pre>
&lt;?xml version="1.0" encoding="UTF-8"?&gt;
&lt;toolchaindefinition xmlns="https://netbeans.org/ns/cnd-toolchain-definition/1"&gt;
&lt;cpp&gt;
&lt;compiler name="g++"/&gt;
&lt;development_mode&gt;
&lt;fast_build flags=""/&gt;
&lt;debug flags="-g3 -gdwarf-2" default="true"/&gt;
&lt;performance_debug flags="-g -O"/&gt;
&lt;test_coverage flags="-g"/&gt;
&lt;diagnosable_release flags="-g -O2"/&gt;
&lt;release flags="-O2"/&gt;
&lt;performance_release flags="-O3"/&gt;
&lt;/development_mode&gt;
&lt;/cpp&gt;
&lt;/toolchaindefinition&gt;
</pre>
<p>デバッグ・フラグは、デフォルトのGNUツール・コレクションの記述に設定されているフラグと異なり、-g3および -gdwarf-2に設定されています。</p>
<p>プロジェクト・ツリーは次のようになります。</p>
<img alt="プロジェクト・ツリーのスクリーンショット" class="margin-around b-all" src="../../../images_www/articles/73/cnd/toolchain/project.png" title="プロジェクト・ツリー">
<p>「単体テスト」フォルダが存在しない場合があります。</p>
</li>
<li>「プロジェクト」ウィンドウで、「<tt>mytoolchain</tt>」プロジェクト・ノードを右クリックし、「実行」を選択します。モジュールがビルドされ、IDEの新しいインスタンス(モジュールのデフォルト・ターゲット・プラットフォーム)にインストールされます。ターゲット・プラットフォームが開き、新規モジュールを試すことができます。</li>
<li>実行中のモジュールで、「ツール」>「オプション」を選択し、「オプション」ウィンドウの上ペインで「C/C++」を選択して、「ビルド・ツール」タブを選択します。</li>
<li>新規ツール・コレクション(GNU_tuned)が表示されない場合は、「デフォルトに戻す」をクリックします。環境を再スキャンするように求められた場合、「はい」をクリックして続行します。
<p>新規ツール・コレクションが表示されます。</p>
<img alt="「オプション」ウィンドウのスクリーンショット" class="margin-around b-all" src="../../../images_www/articles/73/cnd/toolchain/options.png" title="オプション・パネル">
</li>
<li>「ファイル」>「新規プロジェクト」>「サンプル」>「C/C++」>「Welcome」を選択して、新規C/C++サンプル・プロジェクト<tt>Welcome</tt>を作成します。
<li>プロジェクト・ノードを右クリックし、「プロパティ」を選択します。「プロジェクト・プロパティ」ダイアログ・ボックスで「ビルド」ノードを選択し、「ツール・コレクション」をGNU_tunedツール・コレクションに設定して、「OK」をクリックします。 </li>
<li>プロジェクトをビルドします。コンパイラに<tt>-g3 -gdwarf-2</tt>というフラグがあります。
<pre class="examplecode">g++ -c -g3 -gdwarf-2 -MMD -MP -MF build/Debug/GNU_tuned-Solaris-x86/welcome.o.d -o build/Debug/GNU_tuned-Solaris-x86/welcome.o welcome.cc</pre>
</li>
<li>「プロジェクト・プロパティ」ダイアログ・ボックスでGNUツール・コレクションを選択して、「OK」をクリックします。</li>
<li>プロジェクトを再ビルドし、「出力」ウィンドウでコンパイル行を比較します。
<pre class ="examplecode">g++ -c -g -MMD -MP -MF build/Debug/GNU-Solaris-x86/welcome.o.d -o build/Debug/GNU-Solaris-x86/welcome.o welcome.cc</pre>
</li>
</ol>
<p>GNU_tunedツール・コレクションにはデバッグ用の異なるコンパイラ・フラグ、GNUコンパイラの開発モードがあることを参照できる必要があります。</p>
<p class="notes">通常のIDEでGNU_tunedツール・コレクション用の新規モジュールを使用する場合は、バイナリ(..nbmファイル)を作成してプラグインとして追加できます。</p>
<ol><li>mytoolchainモジュール・プロジェクトを右クリックして「NBMを作成」を選択します。「ファイル」タブで、プロジェクトのbuildサブディレクトリを確認すると、.nbmファイルが作成されています。</li>
<li>「ツール」>「プラグイン」を選択し、「プラグイン」ダイアログ・ボックスで「ダウンロード済」タブをクリックします。
</li>
<li>「プラグインの追加」をクリックして、buildディレクトリに移動し、モジュール .nbmファイルを選択して「開く」をクリックします。プラグイン・モジュールが「ダウンロード済」タブの一覧に追加されます。</li>
<li>「ダウンロード済」タブでチェックボックスをクリックしてモジュールを選択し、「インストール」ボタンをクリックします。NetBeansプラグイン・インストーラが開きます。
</li>
<li>「次」をクリックして、インストールが終了するまで、インストーラ画面を先に進めます。</li>
<li>IDEを再起動して「ツール」>「オプション」を選択し、「オプション」ウィンドウの上ペインで「C/C++」を選択して、「ビルド・ツール」タブを選択します。</li>
<li>新規ツール・コレクション(GNU_tuned)が表示されない場合は、「デフォルトに戻す」をクリックします。環境を再スキャンするように求められた場合、「はい」をクリックして続行します。
</li></ol>
<h3><a name="details"></a>ツール・コレクションXMLファイルの詳細</h3>
<p>ここでは、ツール・コレクションXMLファイルで最も重要なタグについて説明します。
</p>
<p class="tips">ツールチェーンXMLファイルでサポートされるすべてのタグと属性のスキームについては、<a href="http://hg.netbeans.org/cnd-main">NetBeans IDEのソース・ツリー</a>内にあるファイル<tt>toolchaindefinition.xsd</tt>を検索できます。</p>
<h4>ツール・コレクション定義タグ</h4>
<table>
<tbody>
<tr>
<th class="tblheader" scope="col">タグ</th>
<th class="tblheader" scope="col">属性</th>
<th class="tblheader" scope="col">説明</th>
</tr>
<tr>
<td class="tbltd1">toolchain</td>
<td class="tbltd1"></td>
<td class="tbltd1">ツール・コレクションの名前</td>
</tr>
<tr>
<td class="tbltd1"></td>
<td class="tbltd1">name</td>
<td class="tbltd1">ツール・コレクションの名前</td>
</tr>
<tr>
<td class="tbltd1"></td>
<td class="tbltd1">display</td>
<td class="tbltd1">ツール・コレクションの表示名</td>
</tr>
<tr>
<td class="tbltd1"></td>
<td class="tbltd1">family</td>
<td class="tbltd1">ツール・コレクションのグループ名</td>
</tr>
<tr>
<td class="tbltd1">platforms</td>
<td class="tbltd1"></td>
<td class="tbltd1">サポート対象のプラットフォーム</td>
</tr>
<tr>
<td class="tbltd1"></td>
<td class="tbltd1">stringvalue</td>
<td class="tbltd1">サポート対象プラットフォームのカンマ区切りのリスト。<br>可能な値は次のとおりです。
<ul>
<li>linux</li>
<li>unix</li>
<li>sun_intel</li>
<li>sun_sparc</li>
<li>windows</li>
<li>mac</li>
<li>none</li>
</ul>
</td>
</tr>
<tr>
<td class="tbltd1">makefile_writer</td>
<td class="tbltd1"></td>
<td class="tbltd1">カスタムMakefileライター。</td>
</tr>
<tr>
<td class="tbltd1"></td>
<td class="tbltd1">class</td>
<td class="tbltd1">カスタムMakefileライターのクラス名。org.netbeans.modules.cnd.makeproject.spi.configurations.MakefileWriter<br>を実装しています。</td>
<tr>
<td class="tbltd1">drive_letter_prefix</td>
<td class="tbltd1"></td>
<td class="tbltd1">ファイル名の特別な接頭辞</td>
</tr>
<tr>
<td class="tbltd1"></td>
<td class="tbltd1">stringvalue</td>
<td class="tbltd1">UNIXの場合は、「/」<br>Windowsのcygwinの場合は、「/cygdrive/」</td>
</tr>
<tr>
<td class="tbltd1">base_folders</td>
<td class="tbltd1"></td>
<td class="tbltd1">base_folderタグのコンテナ。<br> 1つのbase_foldersタグには1つ以上のbase_folderタグが含まれています。 </td>
</tr>
<tr>
<td class="tbltd1">base_folder</td>
<td class="tbltd1"></td>
<td class="tbltd1">コンパイラのベース・ディレクトリの説明。<br>このタグには、次のタグを含めることができます。</td></tr>
<tr>
<td class="tbltd1"></td>
<td class="tbltd1">regestry</td>
<td class="tbltd1">ツールのWindowsレジストリ・キー。これはミススペルですが、XMLタグには「regestry」と記述する必要があります。 </td>
</tr>
<tr>
<td class="tbltd1"></td>
<td class="tbltd1">pattern</td>
<td class="tbltd1">NetBeans IDEがレジストリ内のコンパイラを検索できるようにする正規表現</td>
</tr>
<tr>
<td class="tbltd1"></td>
<td class="tbltd1">suffix</td>
<td class="tbltd1">実行可能ファイルを含むフォルダ</td>
</tr>
<tr>
<td class="tbltd1"></td>
<td class="tbltd1">path_patern</td>
<td class="tbltd1">NetBeans IDEがパスをスキャンしてコンパイラを検索できるようにする正規表現。これはミススペルですが、XMLタグには「path_patern」と記述する必要があります。</td>
</tr>
<tr>
<td class="tbltd1">command_folders</td>
<td class="tbltd1"></td>
<td class="tbltd1">command_folderタグのコンテナ。<br> 1つのcommand_foldersタグには1つ以上のcommander_folderタグが含まれています。 </td>
</tr>
<tr>
<td class="tbltd1">command_folder</td>
<td class="tbltd1"></td>
<td class="tbltd1">UNIX系のコマンドが格納されているディレクトリを記述。<br> Windows上のMinGWコンパイラにのみ必要。command_folderタグには、次のタグを含めることができます。</td></tr>
<tr>
<td class="tbltd1"></td>
<td class="tbltd1">regestry</td>
<td class="tbltd1">コマンドのWindowsレジストリ・キー。これはミススペルですが、XMLタグには「regestry」と記述する必要があります。</td>
</tr>
<tr>
<td class="tbltd1"></td>
<td class="tbltd1">pattern</td>
<td class="tbltd1">NetBeans IDEがレジストリ内のコマンド・フォルダを検索できるようにする正規表現</td>
</tr>
<tr>
<td class="tbltd1"></td>
<td class="tbltd1">suffix</td>
<td class="tbltd1">実行可能ファイルを含むフォルダ</td>
</tr>
<tr>
<td class="tbltd1"></td>
<td class="tbltd1">path_patern</td>
<td class="tbltd1">NetBeans IDEがコマンドを検索できるようにする正規表現。これはミススペルですが、XMLタグには「path_patern」と記述する必要があります。
</td>
</tr>
<tr>
<td class="tbltd1">scanner</td>
<td class="tbltd1"></td>
<td class="tbltd1">エラー・パーサー・サービスの名前。<a href="#errorhandler">カスタム・コンパイラのエラー・ハンドラの作成</a>を参照してください。 </td>
</tr>
<tr>
<td class="tbltd1"></td>
<td class="tbltd1">id</td>
<td class="tbltd1">エラー・パーサー・サービスの名前</td>
</tr>
</tbody>
</table>
<h4>コンパイラ・フラグ</h4>
<p>この表では、コンパイラの記述とツールチェーンのコンパイラ・フラグの指定に使用されるタグの一覧を示します。</p>
<table>
<tbody>
<tr>
<th class="tblheader" scope="col">タグ</th>
<th class="tblheader" scope="col">説明</th>
<th class="tblheader" scope="col">GNUコンパイラの例</th>
</tr>
<tr>
<td class="tbltd1">c,cpp</td>
<td class="tbltd1">次のサブノードに配置されているコンパイラ・フラグのセット</td>
<td class="tbltd1"></td>
</tr>
<tr>
<td class="tbltd1">recognizer</td>
<td class="tbltd1">IDEでコンパイラを検索できるようにする正規表現</td>
<td class="tbltd1">Windowsのcygwin下のGNU用<br>.*[\\/].*cygwin.*[\\/]bin[\\/]?$</td>
</tr>
<tr>
<td class="tbltd1">compiler</td>
<td class="tbltd1">コンパイラ名(実行可能ファイルの名前)</td>
<td class="tbltd1">gccまたはg++</td>
</tr>
<tr>
<td class="tbltd1">version</td>
<td class="tbltd1">バージョン・フラグ</td>
<td class="tbltd1">--version</td>
</tr>
<tr>
<td class="tbltd1">system_include_paths</td>
<td class="tbltd1">システム・インクルード・パスを取得するフラグ</td>
<td class="tbltd1">-x c -E -v</td>
</tr>
<tr>
<td class="tbltd1">system_macros</td>
<td class="tbltd1">システム・マクロを取得するフラグ</td>
<td class="tbltd1">-x c -E -dM</td>
</tr>
<tr>
<td class="tbltd1">user_include</td>
<td class="tbltd1">ユーザー・インクルード・パスを追加するフラグ</td>
<td class="tbltd1">-I</td>
</tr>
<tr>
<td class="tbltd1">user_file</td>
<td class="tbltd1"><i>file</i>のコンテンツを他のファイルの前に入れるフラグ </td>
<td class="tbltd1">-include <i>file</i></td>
</tr>
<tr>
<td class="tbltd1">user_macro</td>
<td class="tbltd1">ユーザー・マクロを追加するフラグ</td>
<td class="tbltd1">-D</td>
</tr>
<tr>
<td class="tbltd1">development_mode</td>
<td class="tbltd1">各種開発モードのフラグのグループ</td>
<td class="tbltd1"></td>
</tr>
<tr>
<td class="tbltd1">warning_level</td>
<td class="tbltd1">各種警告レベルのフラグのグループ</td>
<td class="tbltd1"></td>
</tr>
<tr>
<td class="tbltd1">architecture</td>
<td class="tbltd1">各種アーキテクチャのフラグのグループ</td>
<td class="tbltd1"></td>
</tr>
<tr>
<td class="tbltd1">strip</td>
<td class="tbltd1">デバッグ情報を取り除くフラグ</td>
<td class="tbltd1">-s</td>
</tr>
<tr>
<td class="tbltd1">c_standard</td>
<td class="tbltd1">C標準で使用するフラグを指定します。c89タグ、c99およびc11タグとともに使用します。</td>
<td class="tbltd1"> c89 flags="-std=c89"<br> c99 flags="-std=c99"<br> c11 flags="-std=c11"</td>
</tr>
<tr>
<td class="tbltd1">cpp_standard</td>
<td class="tbltd1">C++標準で使用するフラグを指定します。cpp98タグおよびcpp11タグとともに使用します。</td>
<td class="tbltd1"> cpp98 flags="-std=c++98"<br> cpp11 flags="-std=c++11"<br> cpp11 flags="-std=gnu++0x"</td>
</tr>
<tr>
<td class="tbltd1">output_object_file</td>
<td class="tbltd1">オブジェクト・ファイルを指定するフラグ</td>
<td class="tbltd1">-o <i>(-oの後ろのスペースが必要です)</i></td>
</tr>
<tr>
<td class="tbltd1">dependency_generation</td>
<td class="tbltd1">依存性生成のフラグ</td>
<td class="tbltd1">-MMD -MP -MF $@.d</td>
</tr>
<tr>
<td class="tbltd1">precompiled_header</td>
<td class="tbltd1">再コンパイルされたヘッダーのフラグ</td>
<td class="tbltd1">-o $@</td>
</tr>
<tr>
<td class="tbltd1">important_flags</td>
<td class="tbltd1">デフォルト・システムのインクルード・パスおよびコード支援用の事前定義マクロを変更するコンパイラ・フラグを指定する正規表現 </td>
<td class="tbltd1">-O1|-O2|-O3|-O4|-O5|-Ofast|-Og|-Os|-ansi|-fPIC|-fPIE|-fasynchronous-unwind-tables|-fbuilding-libgcc|-fexceptions|-ffast-math|-ffinite-math-only|-ffreestanding|-fgnu-tm|-fhandle-exceptions|-fleading-underscore|-fno-exceptions|-fno-rtti|-fnon-call-exceptions|-fnon-call-exceptions|-fopenmp|-fpic|-fpie|-fsanitize=address|-fshort-double|-fshort-wchar|-fsignaling-nans|-fstack-protector(\W|$|-)|-fstack-protector-all|-funsigned-char|-funwind-tables|-g(\W|$|-)|-ggdb|-gsplit-dwarf|-gtoggle|-m128bit-long-double|-m3dnow|-m64|-mabm|-madx|-maes|-march=.*|-mavx|-mavx2|-mbmi|-mbmi2|-mf16c|-mfma(\W|$|-)|-mfma4|-mfsgsbase|-mlong-double-64|-mlwp|-mlzcnt|-mpclmul|-mpopcnt|-mprfchw|-mrdrnd|-mrdseed|-mrtm|-msse3|-msse4(\W|$|-)|-msse4.1|-msse4.2|-msse4a|-msse5|-mssse3|-mtbm|-mtune=.*|-mx32|-mxop|-mxsave|-mxsaveopt|-pthreads|-std=.*|-xc($|\+\+$) </td>
</tr>
<tr>
<td class="tbltd1">multithreading</td>
<td class="tbltd1">マルチスレッドのサポートのフラグのグループ</td>
<td class="tbltd1">Oracle Solaris Studioツール・コレクションのみに適用され、GNUベースのツール・コレクションでは使用されない</td>
</tr>
<tr>
<td class="tbltd1">standard</td>
<td class="tbltd1">各種言語標準のフラグのグループ</td>
<td class="tbltd1">Oracle Solaris Studioツール・コレクションのみに適用され、GNUベースのツール・コレクションでは使用されない</td>
</tr>
<tr>
<td class="tbltd1">language_extension</td>
<td class="tbltd1">各種言語拡張のフラグのグループ</td>
<td class="tbltd1">Oracle Solaris Studioツール・コレクションのみに適用され、GNUベースのツール・コレクションでは使用されない</td>
</tr>
</tbody>
</table>
<h2><a name="provider"></a>カスタム・コンパイラ・プロバイダの作成</h2>
<p>NetBeans IDEには、次のデフォルトのコンパイラ・プロバイダがあります。<br> org.netbeans.modules.cnd.toolchain.compilers.MakeProjectCompilerProvider<br>このプロバイダは、ほとんどのtoolchainで適切に動作しますが、独自のプロバイダを作成することもできます。</p>
<p>
<b>独自のコンパイラ・プロバイダを作成するには:</b></p>
<ul>
<li>抽象クラスorg.netbeans.modules.cnd.api.compilers.CompilerProviderを拡張します。
</li>
<li>次のように、クラスをサービスとして定義し、デフォルト・プロバイダの前に挿入します。
<pre>
@org.openide.util.lookup.ServiceProvider(service = org.netbeans.modules.cnd.spi.toolchain.CompilerProvider.class,
position=500)
public class CustomCompilerProvider extends CompilerProvider {
...
}
</pre>
position=500属性は、カスタム・プロバイダがデフォルト・プロバイダの前に呼び出されることを保証します。カスタム・プロバイダは、「createCompiler()」メソッドで、ツールのオーバーライド用にNULLでない「Tool」を返す必要があります。
</li>
</ul>
<h2><a name="errorhandler"></a>カスタム・コンパイラのエラー・ハンドラの作成</h2>
<p>NetBeans IDEには、デフォルトのコンパイラ・エラー・ハンドラが2つあります。</p>
<ul><li>GNUコンパイラ用</li>
<li>Sun Studioコンパイラ用</li>
</ul>
<p>GNUコンパイラ・ハンドラは、どのようなGNUコンパイラに対しても適切に動作しますが、必要に応じて独自のコンパイラ・エラー・ハンドラを定義することもできます。</p>
<p>
<b>独自のコンパイラ・エラー・ハンドラを作成するには:</b>
</p>
<ul><li>抽象クラスorg.netbeans.modules.cnd.spi.toolchain.CompilerProviderを拡張します
</li>
<li>クラスをサービスとして定義します:
<pre>@org.openide.util.lookup.ServiceProvider(service = org.netbeans.modules.cnd.spi.toolchain.CompilerProvider.class)
public class CustomCompilerProvider extends ErrorParserProvider {
...
@Override
public String getID() {
return "MyParser"; // NOI18N
}
}</pre>
</li>
<li>エラー・スキャナとツール・コレクションの記述を、IDでリンクします:
<pre>&lt;/scanner id="MyParser"&gt;
...
&lt;/scanner&gt;</pre>
</li>
</ul>
<h2>関連項目</h2>
<p>NetBeans IDEでのC/C++/Fortranを使用した開発に関する詳細な記事は、<a href="https://netbeans.org/kb/trails/cnd.html">C/C++の学習</a>を参照してください。</p>
<div class="feedback-box"><a href="mailto:users@cnd.netbeans.org?subject=Feedback:Using%20the%20C/C++%20Tool%20Collection%20Descriptors%20-%20NetBeans%20IDE%208.0%20Tutorial">このチュートリアルに関するご意見をお寄せください</a></div>
<br style="clear: both;">
</body></html>