COBOL2002 ユーザーズガイド

[目次][用語][索引][前へ][次へ]

35.5.3 コンパイラオプションの優先順位

複数のコンパイラオプションを指定した場合の,各オプションの優先順位を次に示します。

<この項の構成>
(1) 指定個所による優先順位
(2) オプション間の優先順位
(3) 同じオプションを重複して指定した場合の規則
(4) オプションの打ち消し指定

(1) 指定個所による優先順位

コンパイラオプションを指定した個所によって,優先順位が高くなります。

ccbl2002コマンドの場合
次の順序で,コンパイラオプションの優先順位が高くなります。
優先度 指定個所 オプションの形式
1 ccbl2002のコマンド行に指定したオプション 新形式
2 環境変数CBLCOPT2002に指定したオプション 新形式

ccblコマンドの場合
次の順序で,コンパイラオプションの優先順位が高くなります。
優先度 指定個所 オプションの形式
1 ccblのコマンド行に指定したオプション 旧形式
2 環境変数CBLCOPTに指定したオプション 旧形式
3 ccblコマンドで暗黙的に仮定されるオプション 新形式

環境変数CBLCOPT2002,CBLCOPTについては,「35.6 コンパイラ環境変数」を参照してください。

(2) オプション間の優先順位

コンパイラオプションには,オプション同士が背反の関係となっていたり,あるオプションを指定するとほかのオプションが仮定されたりするものがあります。このようなオプション間の優先順位を,次に示します。

(a) あとに指定した方のオプションが有効となる場合

次のオプションを同時に指定した場合,あとに指定した方のオプションが有効となります。

(b) オプションを指定すると,ほかのオプションが無効となる場合

次のコンパイラオプションを指定した場合,無効となるオプションがあります。

指定したオプション 無効となるオプション
-MainNotCBL
  • -Main
-Dll
  • -Main
  • -SimSub
-OleServer,Dll
  • -Main
  • -Dll,Cdecl
  • -Lib,CUI
  • -SimMain
  • -BigEndian
  • -Bin1Byte
  • -EquivRule
  • -V3Rec
  • -V3RecFCSpace
  • -V3RecEased
  • -MultiThread
-OleServer,Exe
  • -Main
  • -Lib,CUI
  • -SimMain
  • -BigEndian
  • -Bin1Byte
  • -EquivRule
  • -V3Rec
  • -V3RecFCSpace
  • -V3RecEased
  • -MultiThread
-Compile
  • -OutputFile
  • -ManifestFileExt
-Compile,CheckOnly
  • -DebugInf
  • -DebugCompati
  • -DebugData
  • -TDInf
  • -CVInf
  • -DebugRange
  • -TestCmd
-StdMIA
-Std85
-Std2002

  • -V3Spec
  • -StdVersion
  • -CompatiM7
  • -CompatiV3
  • -H8Switch
  • -Cblctr
  • -IgnoreLCC
  • -JPN
  • -CmDol
  • -Comp5
  • -NumAccept
  • -V3Rec
  • -V3RecFCSpace
  • -V3RecEased
  • -EquivRule,NotAny
  • -SQL
  • -SQLDisp
  • -BinExtend
  • -MaxDigits38
  • -IntResult,DecFloat40
  • -LiteralExtend
  • -EUR,FormOutput
-StdMIA
  • -EquivRule,StdCode
  • -Bin1Byte
-V3Spec
  • -Comp5
  • -CmAster
  • -BinExtend
  • -CBLVALUE
  • -Bin1Byte
  • -CompatiM7
  • -NumAccept
  • -CmDol
  • -MaxDigits38
  • -IntResult,DecFloat40
  • -LiteralExtend
  • -EUR,FormOutput
  • -V3RecEased
-Compati85,Syntax
  • -LiteralExtend
-Repository,Gen
  • -Compile
  • -OleServer
-UniObjGen
  • -JPN
  • -CompatiV3
  • -V3Rec
  • -V3RecFCSpace
  • -V3RecEased
-IntResult,DecFloat40
  • -Compati85,Power(-Compati85,All指定時も含む)
-CompatiV3
  • -LiteralExtend
-SimMain
-SimSub
-SimIdent

  • -LiteralExtend

注※
コンパイラ環境変数CBLV3UNICODEにYESを指定した場合,無効になりません。

(c) 仕様チェックオプションを複数指定した場合

-StdMIAオプション,-Std85オプション,-Std2002オプションは,同時に指定できません。同時に指定した場合,警告のメッセージが出力され,次の優先順位で有効となります。

  1. -Std2002オプション
  2. -Std85オプション
  3. -StdMIAオプション
(d) オプションを指定することによって,仮定されるオプション

次のコンパイラオプションを指定した場合,仮定されるオプションがあります。

指定したオプション 仮定されるオプション
-OleServer,Dll
  • -Dll,Stdcall
-OleServer,Exe
  • -MainNotCBL
-V3Spec
  • -V3Rec,Variable※1
-CompatiV3
  • -JPN,Alnum※2 ※3
  • -V3Rec,Variable
-DebugCompati
  • -DebugInf
-DebugData
  • -DebugInf
-DebugRange
  • -DebugInf
  • -DebugCompati
-TestCmd
  • -DebugInf
  • -TDInf
-TDInf
  • -DebugInf
-TDInfと-Optimize,3を同時に指定
  • -Optimize,2
    (-Optimize,3を指定しても-Optimize,2が仮定される)
-CVInf
  • -DebugInf
-StdMIA,14
  • -StdMIA,13
-MaxDigits38および-IntResult,DecFloat40と-Optimize,3を同時に指定
  • -Optimize,2
    (-Optimize,3を指定しても-Optimize,2が仮定される)
-SpaceAsZeroと-Optimize,3を同時に指定
  • -Optimize,2
    (-Optimize,3を指定しても-Optimize,2が仮定される)

注※1
-V3Specオプションと-UniObjGenオプションを同時に指定した場合,-V3Rec,Variableオプションは仮定されません。

注※2
コンパイラ環境変数CBLV3UNICODEにYESを指定し,-UniObjGenオプションを指定した場合は,-CompatiV3オプションを指定しても-JPN,Alnumオプションは仮定されません。

注※3
-CompatiV3オプションと-JPN,V3JPNオプションまたは-JPN,V3JPNSpaceオプションを同時に指定した場合,-JPN,Alnumオプションは仮定されません。

(e) ほかのオプションの指定を必要とするオプション

次のコンパイラオプションは,同時に指定する必要があるオプションを指定しない場合,無視されます。

指定したオプション 同時に指定する必要があるオプション
-SQLDisp -SQL,ODBC
-UniEndian -UniObjGen
-V3RecFCSpace -V3Rec
-DllInit -Dllまたは,-OleServer,Dll
-V3RecEased -V3Rec

次のコンパイラオプションは,同時に指定する必要があるオプションを指定しない場合,コンパイルエラーとなります。

指定したオプション 同時に指定する必要があるオプション
-IntResult,DecFloat40 -MaxDigits38
-MaxDigits38 -IntResult,DecFloat40
-SpaceAsZero -Compati85,All
-VOSCBL,OccursKey -CompatiV3
-VOSCBL,ReportControl -CompatiV3
-JPN,V3JPNSpace -CompatiV3

(3) 同じオプションを重複して指定した場合の規則

同じオプションを重複して指定した場合,次の規則に従ってオプションが決定されます。なお,オプションごとのサブオプションの指定規則については,「35.5.4 コンパイラオプションの一覧」を参照してください。

(a) 背反関係にあるサブオプション同士を指定した場合

最後に指定されたオプションが有効となります。

(例)
-Compile,{CheckOnly|NoLink}
に対して
-Compile,CheckOnly -Compile,NoLink
と指定した場合,-Compile,NoLinkが有効となります。

ただし,次の場合は,特定のサブオプションが有効となります。

(b) 省略可能なサブオプション同士,または複数選択できるサブオプション同士を指定した場合

前に指定したサブオプションの指定を引き継ぎ,あとに指定したサブオプションの指定が追加で有効となります。

(例)
-BigEndian {,Bin|,Float}+
に対して
-BigEndian,Bin -BigEndian,Float
と指定した場合,BinサブオプションとFloatサブオプションの両方が有効となります。これは,「-BigEndian,Bin,Float」を指定した場合と同じです。

(4) オプションの打ち消し指定

デフォルト設定や環境変数などで指定済みのオプションを,コンパイル時に打ち消したい場合は,プリフィクス'no'の付いたコンパイラオプションを使用します。

例えば,環境変数CBLCOPT2002でオプション「-Details」が指定されている場合,コマンドラインで「ccbl2002 -noDetails …」と指定すると,環境変数CBLCOPT2002で設定済みのオプション「-Details」を打ち消せます。

規則
  • オプションにデフォルト値の設定がある場合,プリフィクス'no'は指定できません。この場合,オプションのデフォルト値を指定することで,オプションを打ち消します。
    例えば,環境変数CBLCOPT2002でオプション「-Lib,CUI」が指定されている場合,デフォルト値に戻したいときは,コマンドラインで「-Lib,GUI」を指定します。
  • 通常のオプションと打ち消しのオプションを同時に指定した場合は,あとに指定したオプションが有効となります。
  • 打ち消しのオプションは,コマンドラインや環境変数CBLCOPT2002に指定したオプションを打ち消し,オプション指定によって仮定されるオプションは打ち消しません。

注意事項
コンパイルリストに出力されるオプション一覧や,-Detailsオプションを指定した場合にコマンドラインへ出力されるコンパイラオプションの詳細情報表示では,no指定のコンパイラオプションは表示されません。コンパイラオプションとして有効となったオプションだけが表示されます。