2.2.3 ソースファイルをコンパイルする
JP1イベントを発行および取得するには,コーディングしたソースファイルをコンパイル・リンクする必要があります。
- [コンパイル時に必要なファイル]
-
-
ヘッダーファイル(JP1/Baseインストール時にインストールされます)
-
CまたはC++で作成したソースファイル(ユーザーが作成するものです)
ヘッダーファイルの格納先は次のとおりです。
Windows:インストール先フォルダ\include\JevApi.h
UNIX:/opt/jp1base/include/JevApi.h
-
- [リンク時に必要なファイル]
-
必要となるライブラリーは,各OS,コンパイラーによって異なるため,注意が必要です。各OSで必要なライブラリーを次の表に示します。
表2‒4 各OSで必要なライブラリー OS
必要なライブラリー
Windows XP Professional
Windows Vista
Windows Server 2003
Windows Server 2008
Windows 7
Windows 8
Windows 8.1
Windows Server 2012
インストール先フォルダ\lib\libJevApiA.lib(32bitマルチスレッド用)
Solaris
AIX
Linux 5(x86)
Linux 6(x86)
/opt/jp1base/lib/libJevApiAst.a(32bitシングルスレッド用)
/opt/jp1base/lib/libJevApiAmt.a(32bitマルチスレッド用)
HP-UX(IPF)
/opt/jp1base/lib/libJevApiAst32.a(32bitシングルスレッド用)
/opt/jp1base/lib/libJevApiAmt32.a(32bitマルチスレッド用)
/opt/jp1base/lib/libJevApiAst64.a(64bitシングルスレッド用)
/opt/jp1base/lib/libJevApiAmt64.a(64bitマルチスレッド用)
各OSでのコンパイル,リンク時に指定するオプションを次の表に示します。
- 注意事項
-
WindowsのVisual Studio統合開発環境(GUI)上でコンパイルやリンクをする場合,次の表に示すコンパイルオプションやリンクオプションから,該当するオプションを使用して環境を設定してください。
- 注意事項
-
-
JP1/Baseが提供するライブラリーは,スタティックライブラリー(UNIXの場合はアーカイブ)です。DLL用のインポートライブラリーや共有ライブラリーではありません。
-
JP1/Baseが提供するライブラリーは,JP1/Baseに同梱されているDLL(UNIXの場合は共有ライブラリー)をダイナミックロードします。このため,JP1/Baseがインストールされていない環境でも,作成されたプログラムは動作しますが,その場合,関数がJEV_NO_LIBRARYで失敗します。
-
Windows用のJP1/Base提供ライブラリーからダイナミックロードされるDLLは,Side by sideアセンブリーでパッケージ化されたライブラリーとの依存関係がないため,マニフェストは提供していません。
-
UNIXでJP1/Base提供ライブラリーをリンクするときは,-lオプションでリンクしないでください。
-
UNIXでリンクするときは,ldではなく,コンパイラーと同じリンケージエディター(ccなど)を使用することを推奨します。ldでリンクする場合は,コンパイラーが自動的にldに引き渡すオプションと同じものを同じ順序で指定してください。
-
x64版のLinux環境でコンパイルする場合,コンパイルオプションおよびリンクオプションに「-m32」を追加してください。
-