mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-09-02 00:10:31 +02:00
+ -vq parameter to show message numbers
+ -vm<x>,<y> parameter to mask messages <x> and <y> (both based on a patch submitted by Petr Kristan) * alphabetically ordered -v<x> option processing code so it's easier to see which characters are still free (not many anymore) + some tests for the -vm functionality git-svn-id: trunk@11888 -
This commit is contained in:
parent
925c119911
commit
64ddae4eff
4
.gitattributes
vendored
4
.gitattributes
vendored
@ -7735,6 +7735,10 @@ tests/test/tmath1.pp svneol=native#text/plain
|
|||||||
tests/test/tmcbool2.pp svneol=native#text/plain
|
tests/test/tmcbool2.pp svneol=native#text/plain
|
||||||
tests/test/tmmx1.pp svneol=native#text/plain
|
tests/test/tmmx1.pp svneol=native#text/plain
|
||||||
tests/test/tmove.pp svneol=native#text/plain
|
tests/test/tmove.pp svneol=native#text/plain
|
||||||
|
tests/test/tmsg1.pp svneol=native#text/plain
|
||||||
|
tests/test/tmsg2.pp svneol=native#text/plain
|
||||||
|
tests/test/tmsg3.pp svneol=native#text/plain
|
||||||
|
tests/test/tmsg4.pp svneol=native#text/plain
|
||||||
tests/test/tmt1.pp svneol=native#text/plain
|
tests/test/tmt1.pp svneol=native#text/plain
|
||||||
tests/test/tobject1.pp svneol=native#text/plain
|
tests/test/tobject1.pp svneol=native#text/plain
|
||||||
tests/test/tobject2.pp svneol=native#text/plain
|
tests/test/tobject2.pp svneol=native#text/plain
|
||||||
|
@ -52,6 +52,7 @@ type
|
|||||||
procedure ClearIdx;
|
procedure ClearIdx;
|
||||||
procedure CreateIdx;
|
procedure CreateIdx;
|
||||||
function GetPChar(nr:longint):pchar;
|
function GetPChar(nr:longint):pchar;
|
||||||
|
function ClearVerbosity(nr:longint):boolean;
|
||||||
function Get(nr:longint;const args:array of string):ansistring;
|
function Get(nr:longint;const args:array of string):ansistring;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
@ -374,6 +375,33 @@ begin
|
|||||||
GetPChar:=msgidx[nr div 1000]^[nr mod 1000];
|
GetPChar:=msgidx[nr div 1000]^[nr mod 1000];
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
function TMessage.ClearVerbosity(nr:longint):boolean;
|
||||||
|
var
|
||||||
|
hp: pchar;
|
||||||
|
i, txtbegin: longint;
|
||||||
|
begin
|
||||||
|
result:=false;
|
||||||
|
if ((nr div 1000) < low(msgidx)) or
|
||||||
|
((nr div 1000) > msgparts) then
|
||||||
|
exit;
|
||||||
|
hp := GetPChar(nr);
|
||||||
|
if (hp=nil) then
|
||||||
|
exit;
|
||||||
|
txtbegin:=-1;
|
||||||
|
for i:=0 to 4 do
|
||||||
|
begin
|
||||||
|
if hp[i]=#0 then
|
||||||
|
exit;
|
||||||
|
if hp[i]='_' then
|
||||||
|
begin
|
||||||
|
txtbegin:=i;
|
||||||
|
break;
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
for i:=0 to txtbegin-1 do
|
||||||
|
hp[i]:='_';
|
||||||
|
result:=true;
|
||||||
|
end;
|
||||||
|
|
||||||
function TMessage.Get(nr:longint;const args:array of string):ansistring;
|
function TMessage.Get(nr:longint;const args:array of string):ansistring;
|
||||||
var
|
var
|
||||||
|
@ -90,6 +90,7 @@ type
|
|||||||
ispackage,
|
ispackage,
|
||||||
islibrary : boolean;
|
islibrary : boolean;
|
||||||
{ Settings for the output }
|
{ Settings for the output }
|
||||||
|
showmsgnrs : boolean;
|
||||||
verbosity : longint;
|
verbosity : longint;
|
||||||
maxerrorcount : longint;
|
maxerrorcount : longint;
|
||||||
errorwarning,
|
errorwarning,
|
||||||
@ -337,7 +338,8 @@ begin
|
|||||||
end;
|
end;
|
||||||
|
|
||||||
{ Display line }
|
{ Display line }
|
||||||
if ((status.verbosity and (Level and V_LevelMask))=(Level and V_LevelMask)) then
|
if (Level<>V_None) and
|
||||||
|
((status.verbosity and (Level and V_LevelMask))=(Level and V_LevelMask)) then
|
||||||
begin
|
begin
|
||||||
if status.use_stderr then
|
if status.use_stderr then
|
||||||
begin
|
begin
|
||||||
@ -375,7 +377,8 @@ end;
|
|||||||
function def_CheckVerbosity(v:longint):boolean;
|
function def_CheckVerbosity(v:longint):boolean;
|
||||||
begin
|
begin
|
||||||
result:=status.use_bugreport or
|
result:=status.use_bugreport or
|
||||||
((status.verbosity and (v and V_LevelMask))=(v and V_LevelMask));
|
((v<>V_None) and
|
||||||
|
((status.verbosity and (v and V_LevelMask))=(v and V_LevelMask)));
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure def_initsymbolinfo;
|
procedure def_initsymbolinfo;
|
||||||
|
@ -39,6 +39,7 @@
|
|||||||
# c_ conditional
|
# c_ conditional
|
||||||
# d_ debug message
|
# d_ debug message
|
||||||
# x_ executable informations
|
# x_ executable informations
|
||||||
|
# o_ normal (e.g., "press enter to continue")
|
||||||
#
|
#
|
||||||
|
|
||||||
#
|
#
|
||||||
@ -2459,7 +2460,7 @@ option_using_env=11027_T_Reading options from environment $1
|
|||||||
% Options are also read from this environment string.
|
% Options are also read from this environment string.
|
||||||
option_handling_option=11028_D_Handling option "$1"
|
option_handling_option=11028_D_Handling option "$1"
|
||||||
% Debug info that an option is found and will be handled.
|
% Debug info that an option is found and will be handled.
|
||||||
option_help_press_enter=11029__*** press enter ***
|
option_help_press_enter=11029_O_*** press enter ***
|
||||||
% Message shown when help is shown page per page. When pressing the ENTER
|
% Message shown when help is shown page per page. When pressing the ENTER
|
||||||
% Key, the next page of help is shown. If you press q and then ENTER, the
|
% Key, the next page of help is shown. If you press q and then ENTER, the
|
||||||
% compiler exits.
|
% compiler exits.
|
||||||
@ -2753,7 +2754,8 @@ S*2Tlinux_Linux
|
|||||||
**2*_a : Show everything x : Executable info (Win32 only)
|
**2*_a : Show everything x : Executable info (Win32 only)
|
||||||
**2*_b : Write file names messages with full path
|
**2*_b : Write file names messages with full path
|
||||||
**2*_v : Write fpcdebug.txt with p : Write tree.log with parse tree
|
**2*_v : Write fpcdebug.txt with p : Write tree.log with parse tree
|
||||||
**2*_ lots of debugging info
|
**2*_ lots of debugging info q : Show message numbers
|
||||||
|
**2*_m<x>,<y> : Don't show messages numbered <x> and <y>
|
||||||
3*1W<x>_Target-specific options (targets)
|
3*1W<x>_Target-specific options (targets)
|
||||||
A*1W<x>_Target-specific options (targets)
|
A*1W<x>_Target-specific options (targets)
|
||||||
P*1W<x>_Target-specific options (targets)
|
P*1W<x>_Target-specific options (targets)
|
||||||
|
@ -754,7 +754,7 @@ const
|
|||||||
option_info=11024;
|
option_info=11024;
|
||||||
option_help_pages=11025;
|
option_help_pages=11025;
|
||||||
|
|
||||||
MsgTxtSize = 47219;
|
MsgTxtSize = 47307;
|
||||||
|
|
||||||
MsgIdxMax : array[1..20] of longint=(
|
MsgIdxMax : array[1..20] of longint=(
|
||||||
24,87,248,84,65,50,108,22,201,61,
|
24,87,248,84,65,50,108,22,201,61,
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
{$ifdef Delphi}
|
{$ifdef Delphi}
|
||||||
const msgtxt : array[0..000196] of string[240]=(
|
const msgtxt : array[0..000197] of string[240]=(
|
||||||
{$else Delphi}
|
{$else Delphi}
|
||||||
const msgtxt : array[0..000196,1..240] of char=(
|
const msgtxt : array[0..000197,1..240] of char=(
|
||||||
{$endif Delphi}
|
{$endif Delphi}
|
||||||
'01000_T_Compiler: $1'#000+
|
'01000_T_Compiler: $1'#000+
|
||||||
'01001_D_Compiler OS: $1'#000+
|
'01001_D_Compiler OS: $1'#000+
|
||||||
@ -823,22 +823,22 @@ const msgtxt : array[0..000196,1..240] of char=(
|
|||||||
'11026_T_Reading options from file $1'#000+
|
'11026_T_Reading options from file $1'#000+
|
||||||
'11027_T_Reading options from environment $1'#000+
|
'11027_T_Reading options from environment $1'#000+
|
||||||
'11028_D_Handling option "$1"'#000+
|
'11028_D_Handling option "$1"'#000+
|
||||||
'11029__*** press enter ***'#000+
|
'11029_O_*** press enter ***'#000+
|
||||||
'11030_H_Start of reading config file $1'#000+
|
'11030_H_Start of reading config file $1'#000+
|
||||||
'11031_H_End of reading config file $1'#000+
|
'11031_H_End of reading config file $1'#000+
|
||||||
'11032_D_interpreti','ng option "$1"'#000+
|
'11032_D_interpret','ing option "$1"'#000+
|
||||||
'11036_D_interpreting firstpass option "$1"'#000+
|
'11036_D_interpreting firstpass option "$1"'#000+
|
||||||
'11033_D_interpreting file option "$1"'#000+
|
'11033_D_interpreting file option "$1"'#000+
|
||||||
'11034_D_Reading config file "$1"'#000+
|
'11034_D_Reading config file "$1"'#000+
|
||||||
'11035_D_found source file name "$1"'#000+
|
'11035_D_found source file name "$1"'#000+
|
||||||
'11039_E_Unknown code page'#000+
|
'11039_E_Unknown code page'#000+
|
||||||
'11040_F_Config file $1 is a directory'#000+
|
'11040_F_Config file $1 is a directory'#000+
|
||||||
'11041_W_Ass','embler output selected "$1" cannot generate debug info, d'+
|
'11041_W_As','sembler output selected "$1" cannot generate debug info, d'+
|
||||||
'ebugging disabled'#000+
|
'ebugging disabled'#000+
|
||||||
'11042_W_Use of ppc386.cfg is deprecated, please use fpc.cfg instead'#000+
|
'11042_W_Use of ppc386.cfg is deprecated, please use fpc.cfg instead'#000+
|
||||||
'11023_Free Pascal Compiler version $FPCFULLVERSION [$FPCDATE] for $FPC'+
|
'11023_Free Pascal Compiler version $FPCFULLVERSION [$FPCDATE] for $FPC'+
|
||||||
'CPU'#010+
|
'CPU'#010+
|
||||||
'Copyright (c) 1993-2008',' by Florian Klaempfl'#000+
|
'Copyright (c) 1993-200','8 by Florian Klaempfl'#000+
|
||||||
'11024_Free Pascal Compiler version $FPCVERSION'#010+
|
'11024_Free Pascal Compiler version $FPCVERSION'#010+
|
||||||
#010+
|
#010+
|
||||||
'Compiler Date : $FPCDATE'#010+
|
'Compiler Date : $FPCDATE'#010+
|
||||||
@ -850,7 +850,7 @@ const msgtxt : array[0..000196,1..240] of char=(
|
|||||||
'Supported CPU instruction sets:'#010+
|
'Supported CPU instruction sets:'#010+
|
||||||
' $INSTRUCTIONSETS'#010+
|
' $INSTRUCTIONSETS'#010+
|
||||||
#010+
|
#010+
|
||||||
'Supported FPU instruction ','sets:'#010+
|
'Supported FPU instruction',' sets:'#010+
|
||||||
' $FPUINSTRUCTIONSETS'#010+
|
' $FPUINSTRUCTIONSETS'#010+
|
||||||
#010+
|
#010+
|
||||||
'Supported ABI targets:'#010+
|
'Supported ABI targets:'#010+
|
||||||
@ -863,36 +863,36 @@ const msgtxt : array[0..000196,1..240] of char=(
|
|||||||
'For more information read COPYING.FPC'#010+
|
'For more information read COPYING.FPC'#010+
|
||||||
#010+
|
#010+
|
||||||
'Report bugs,suggestions etc to:'#010+
|
'Report bugs,suggestions etc to:'#010+
|
||||||
' ',' bugs@freepascal.org'#000+
|
' ',' bugs@freepascal.org'#000+
|
||||||
'11025_**0*_Put + after a boolean switch option to enable it, - to disa'+
|
'11025_**0*_Put + after a boolean switch option to enable it, - to disa'+
|
||||||
'ble it'#010+
|
'ble it'#010+
|
||||||
'**1a_The compiler doesn'#039't delete the generated assembler file'#010+
|
'**1a_The compiler doesn'#039't delete the generated assembler file'#010+
|
||||||
'**2al_List sourcecode lines in assembler file'#010+
|
'**2al_List sourcecode lines in assembler file'#010+
|
||||||
'**2an_List node info ','in assembler file'#010+
|
'**2an_List node info',' in assembler file'#010+
|
||||||
'*L2ap_Use pipes instead of creating temporary assembler files'#010+
|
'*L2ap_Use pipes instead of creating temporary assembler files'#010+
|
||||||
'**2ar_List register allocation/release info in assembler file'#010+
|
'**2ar_List register allocation/release info in assembler file'#010+
|
||||||
'**2at_List temp allocation/release info in assembler file'#010+
|
'**2at_List temp allocation/release info in assembler file'#010+
|
||||||
'**1A<x>_Output format:'#010+
|
'**1A<x>_Output format:'#010+
|
||||||
'**2Adefault_Use d','efault assembler'#010+
|
'**2Adefault_Use ','default assembler'#010+
|
||||||
'3*2Aas_Assemble using GNU AS'#010+
|
'3*2Aas_Assemble using GNU AS'#010+
|
||||||
'3*2Anasmcoff_COFF (Go32v2) file using Nasm'#010+
|
'3*2Anasmcoff_COFF (Go32v2) file using Nasm'#010+
|
||||||
'3*2Anasmelf_ELF32 (Linux) file using Nasm'#010+
|
'3*2Anasmelf_ELF32 (Linux) file using Nasm'#010+
|
||||||
'3*2Anasmwin32_Win32 object file using Nasm'#010+
|
'3*2Anasmwin32_Win32 object file using Nasm'#010+
|
||||||
'3*2Anasmwdosx_Win32/WDOSX object file using Nasm'#010+
|
'3*2Anasmwdosx_Win32/WDOSX object file using Nasm'#010+
|
||||||
'3*2Awasm_Obj file',' using Wasm (Watcom)'#010+
|
'3*2Awasm_Obj fil','e using Wasm (Watcom)'#010+
|
||||||
'3*2Anasmobj_Obj file using Nasm'#010+
|
'3*2Anasmobj_Obj file using Nasm'#010+
|
||||||
'3*2Amasm_Obj file using Masm (Microsoft)'#010+
|
'3*2Amasm_Obj file using Masm (Microsoft)'#010+
|
||||||
'3*2Atasm_Obj file using Tasm (Borland)'#010+
|
'3*2Atasm_Obj file using Tasm (Borland)'#010+
|
||||||
'3*2Aelf_ELF (Linux) using internal writer'#010+
|
'3*2Aelf_ELF (Linux) using internal writer'#010+
|
||||||
'3*2Acoff_COFF (Go32v2) using internal writer'#010+
|
'3*2Acoff_COFF (Go32v2) using internal writer'#010+
|
||||||
'3*2Apecoff_PE-COFF (','Win32) using internal writer'#010+
|
'3*2Apecoff_PE-COFF ','(Win32) using internal writer'#010+
|
||||||
'4*2Aas_Assemble using GNU AS'#010+
|
'4*2Aas_Assemble using GNU AS'#010+
|
||||||
'6*2Aas_Unix o-file using GNU AS'#010+
|
'6*2Aas_Unix o-file using GNU AS'#010+
|
||||||
'6*2Agas_GNU Motorola assembler'#010+
|
'6*2Agas_GNU Motorola assembler'#010+
|
||||||
'6*2Amit_MIT Syntax (old GAS)'#010+
|
'6*2Amit_MIT Syntax (old GAS)'#010+
|
||||||
'6*2Amot_Standard Motorola assembler'#010+
|
'6*2Amot_Standard Motorola assembler'#010+
|
||||||
'A*2Aas_Assemble using GNU AS'#010+
|
'A*2Aas_Assemble using GNU AS'#010+
|
||||||
'P*2Aas_Assemble using GNU',' AS'#010+
|
'P*2Aas_Assemble using GN','U AS'#010+
|
||||||
'S*2Aas_Assemble using GNU AS'#010+
|
'S*2Aas_Assemble using GNU AS'#010+
|
||||||
'**1b_Generate browser info'#010+
|
'**1b_Generate browser info'#010+
|
||||||
'**2bl_Generate local symbol info'#010+
|
'**2bl_Generate local symbol info'#010+
|
||||||
@ -900,25 +900,25 @@ const msgtxt : array[0..000196,1..240] of char=(
|
|||||||
'**1C<x>_Code generation options:'#010+
|
'**1C<x>_Code generation options:'#010+
|
||||||
'**2Ca<x>_Select ABI, see fpc -i for possible values'#010+
|
'**2Ca<x>_Select ABI, see fpc -i for possible values'#010+
|
||||||
'**2Cb_Generate big-endian code'#010+
|
'**2Cb_Generate big-endian code'#010+
|
||||||
'**2Cc<x>','_Set default calling convention to <x>'#010+
|
'**2Cc<x','>_Set default calling convention to <x>'#010+
|
||||||
'**2CD_Create also dynamic library (not supported)'#010+
|
'**2CD_Create also dynamic library (not supported)'#010+
|
||||||
'**2Ce_Compilation with emulated floating point opcodes'#010+
|
'**2Ce_Compilation with emulated floating point opcodes'#010+
|
||||||
'**2Cf<x>_Select fpu instruction set to use, see fpc -i for possible va'+
|
'**2Cf<x>_Select fpu instruction set to use, see fpc -i for possible va'+
|
||||||
'lues'#010+
|
'lues'#010+
|
||||||
'**2CF<x>_Minimal floa','ting point constant precision (default, 32, 64)'+
|
'**2CF<x>_Minimal flo','ating point constant precision (default, 32, 64)'+
|
||||||
#010+
|
#010+
|
||||||
'**2Cg_Generate PIC code'#010+
|
'**2Cg_Generate PIC code'#010+
|
||||||
'**2Ch<n>_<n> bytes heap (between 1023 and 67107840)'#010+
|
'**2Ch<n>_<n> bytes heap (between 1023 and 67107840)'#010+
|
||||||
'**2Ci_IO-checking'#010+
|
'**2Ci_IO-checking'#010+
|
||||||
'**2Cn_Omit linking stage'#010+
|
'**2Cn_Omit linking stage'#010+
|
||||||
'**2Co_Check overflow of integer operations'#010+
|
'**2Co_Check overflow of integer operations'#010+
|
||||||
'**2CO_Check for possible overf','low of integer operations'#010+
|
'**2CO_Check for possible over','flow of integer operations'#010+
|
||||||
'**2Cp<x>_Select instruction set, see fpc -i for possible values'#010+
|
'**2Cp<x>_Select instruction set, see fpc -i for possible values'#010+
|
||||||
'**2CP<x>=<y>_ packing settings'#010+
|
'**2CP<x>=<y>_ packing settings'#010+
|
||||||
'**3CPPACKSET=<y>_ <y> set allocation: 0, 1 or DEFAULT or NORMAL, 2, 4 '+
|
'**3CPPACKSET=<y>_ <y> set allocation: 0, 1 or DEFAULT or NORMAL, 2, 4 '+
|
||||||
'and 8'#010+
|
'and 8'#010+
|
||||||
'**2Cr_Range checking'#010+
|
'**2Cr_Range checking'#010+
|
||||||
'**2CR_Verify object me','thod call validity'#010+
|
'**2CR_Verify object m','ethod call validity'#010+
|
||||||
'**2Cs<n>_Set stack size to <n>'#010+
|
'**2Cs<n>_Set stack size to <n>'#010+
|
||||||
'**2Ct_Stack checking'#010+
|
'**2Ct_Stack checking'#010+
|
||||||
'**2CX_Create also smartlinked library'#010+
|
'**2CX_Create also smartlinked library'#010+
|
||||||
@ -926,7 +926,7 @@ const msgtxt : array[0..000196,1..240] of char=(
|
|||||||
'**1D_Generate a DEF file'#010+
|
'**1D_Generate a DEF file'#010+
|
||||||
'**2Dd<x>_Set description to <x>'#010+
|
'**2Dd<x>_Set description to <x>'#010+
|
||||||
'**2Dv<x>_Set DLL version to <x>'#010+
|
'**2Dv<x>_Set DLL version to <x>'#010+
|
||||||
'*O2Dw_PM ap','plication'#010+
|
'*O2Dw_PM a','pplication'#010+
|
||||||
'**1e<x>_Set path to executable'#010+
|
'**1e<x>_Set path to executable'#010+
|
||||||
'**1E_Same as -Cn'#010+
|
'**1E_Same as -Cn'#010+
|
||||||
'**1fPIC_Same as -Cg'#010+
|
'**1fPIC_Same as -Cg'#010+
|
||||||
@ -934,41 +934,41 @@ const msgtxt : array[0..000196,1..240] of char=(
|
|||||||
'**2Fa<x>[,y]_(for a program) load units <x> and [y] before uses is par'+
|
'**2Fa<x>[,y]_(for a program) load units <x> and [y] before uses is par'+
|
||||||
'sed'#010+
|
'sed'#010+
|
||||||
'**2Fc<x>_Set input codepage to <x>'#010+
|
'**2Fc<x>_Set input codepage to <x>'#010+
|
||||||
'**2FC<x>_Set RC com','piler binary name to <x>'#010+
|
'**2FC<x>_Set RC co','mpiler binary name to <x>'#010+
|
||||||
'**2FD<x>_Set the directory where to search for compiler utilities'#010+
|
'**2FD<x>_Set the directory where to search for compiler utilities'#010+
|
||||||
'**2Fe<x>_Redirect error output to <x>'#010+
|
'**2Fe<x>_Redirect error output to <x>'#010+
|
||||||
'**2Ff<x>_Add <x> to framework path (Darwin only)'#010+
|
'**2Ff<x>_Add <x> to framework path (Darwin only)'#010+
|
||||||
'**2FE<x>_Set exe/unit output path to <x>'#010+
|
'**2FE<x>_Set exe/unit output path to <x>'#010+
|
||||||
'**2Fi<x>_Add <x> to i','nclude path'#010+
|
'**2Fi<x>_Add <x> to ','include path'#010+
|
||||||
'**2Fl<x>_Add <x> to library path'#010+
|
'**2Fl<x>_Add <x> to library path'#010+
|
||||||
'**2FL<x>_Use <x> as dynamic linker'#010+
|
'**2FL<x>_Use <x> as dynamic linker'#010+
|
||||||
'**2Fm<x>_Load unicode conversion table from <x>.txt in the compiler di'+
|
'**2Fm<x>_Load unicode conversion table from <x>.txt in the compiler di'+
|
||||||
'r'#010+
|
'r'#010+
|
||||||
'**2Fo<x>_Add <x> to object path'#010+
|
'**2Fo<x>_Add <x> to object path'#010+
|
||||||
'**2Fr<x>_Load error message file <x>'#010+
|
'**2Fr<x>_Load error message file <x>'#010+
|
||||||
'**2FR<x>_Set resour','ce (.res) linker to <x>'#010+
|
'**2FR<x>_Set resou','rce (.res) linker to <x>'#010+
|
||||||
'**2Fu<x>_Add <x> to unit path'#010+
|
'**2Fu<x>_Add <x> to unit path'#010+
|
||||||
'**2FU<x>_Set unit output path to <x>, overrides -FE'#010+
|
'**2FU<x>_Set unit output path to <x>, overrides -FE'#010+
|
||||||
'*g1g_Generate debug information (default format for target)'#010+
|
'*g1g_Generate debug information (default format for target)'#010+
|
||||||
'*g2gc_Generate checks for pointers'#010+
|
'*g2gc_Generate checks for pointers'#010+
|
||||||
'*g2gh_Use heaptrace unit (for memory le','ak/corruption debugging)'#010+
|
'*g2gh_Use heaptrace unit (for memory l','eak/corruption debugging)'#010+
|
||||||
'*g2gl_Use line info unit (show more info with backtraces)'#010+
|
'*g2gl_Use line info unit (show more info with backtraces)'#010+
|
||||||
'*g2go<x>_Set debug information options'#010+
|
'*g2go<x>_Set debug information options'#010+
|
||||||
'*g3godwarfsets_ Enable Dwarf set debug information (breaks gdb < 6.5)'#010+
|
'*g3godwarfsets_ Enable Dwarf set debug information (breaks gdb < 6.5)'#010+
|
||||||
'*g2gp_Preserve case in stabs symbol names'#010+
|
'*g2gp_Preserve case in stabs symbol names'#010+
|
||||||
'*g2gs_','Generate stabs debug information'#010+
|
'*g2gs','_Generate stabs debug information'#010+
|
||||||
'*g2gt_Trash local variables (to detect uninitialized uses)'#010+
|
'*g2gt_Trash local variables (to detect uninitialized uses)'#010+
|
||||||
'*g2gv_Generates programs traceable with valgrind'#010+
|
'*g2gv_Generates programs traceable with valgrind'#010+
|
||||||
'*g2gw_Generate dwarf-2 debug information (same as -gw2)'#010+
|
'*g2gw_Generate dwarf-2 debug information (same as -gw2)'#010+
|
||||||
'*g2gw2_Generate dwarf-2 debug information'#010+
|
'*g2gw2_Generate dwarf-2 debug information'#010,
|
||||||
'*','g2gw3_Generate dwarf-3 debug information'#010+
|
'*g2gw3_Generate dwarf-3 debug information'#010+
|
||||||
'**1i_Information'#010+
|
'**1i_Information'#010+
|
||||||
'**2iD_Return compiler date'#010+
|
'**2iD_Return compiler date'#010+
|
||||||
'**2iV_Return short compiler version'#010+
|
'**2iV_Return short compiler version'#010+
|
||||||
'**2iW_Return full compiler version'#010+
|
'**2iW_Return full compiler version'#010+
|
||||||
'**2iSO_Return compiler OS'#010+
|
'**2iSO_Return compiler OS'#010+
|
||||||
'**2iSP_Return compiler host processor'#010+
|
'**2iSP_Return compiler host processor'#010+
|
||||||
'**2iTO_Return target',' OS'#010+
|
'**2iTO_Return targe','t OS'#010+
|
||||||
'**2iTP_Return target processor'#010+
|
'**2iTP_Return target processor'#010+
|
||||||
'**1I<x>_Add <x> to include path'#010+
|
'**1I<x>_Add <x> to include path'#010+
|
||||||
'**1k<x>_Pass <x> to the linker'#010+
|
'**1k<x>_Pass <x> to the linker'#010+
|
||||||
@ -976,59 +976,59 @@ const msgtxt : array[0..000196,1..240] of char=(
|
|||||||
'**1M<x>_Set language mode to <x>'#010+
|
'**1M<x>_Set language mode to <x>'#010+
|
||||||
'**2Mfpc_Free Pascal dialect (default)'#010+
|
'**2Mfpc_Free Pascal dialect (default)'#010+
|
||||||
'**2Mobjfpc_FPC mode with Object Pascal support'#010+
|
'**2Mobjfpc_FPC mode with Object Pascal support'#010+
|
||||||
'**2Mdelp','hi_Delphi 7 compatibility mode'#010+
|
'**2Mdel','phi_Delphi 7 compatibility mode'#010+
|
||||||
'**2Mtp_TP/BP 7.0 compatibility mode'#010+
|
'**2Mtp_TP/BP 7.0 compatibility mode'#010+
|
||||||
'**2Mmacpas_Macintosh Pascal dialects compatibility mode'#010+
|
'**2Mmacpas_Macintosh Pascal dialects compatibility mode'#010+
|
||||||
'**1n_Do not read the default config files'#010+
|
'**1n_Do not read the default config files'#010+
|
||||||
'**1N<x>_Node tree optimizations'#010+
|
'**1N<x>_Node tree optimizations'#010+
|
||||||
'**2Nu_Unroll loops'#010+
|
'**2Nu_Unroll loops'#010+
|
||||||
'**1o<x>_Change the name ','of the executable produced to <x>'#010+
|
'**1o<x>_Change the name',' of the executable produced to <x>'#010+
|
||||||
'**1O<x>_Optimizations:'#010+
|
'**1O<x>_Optimizations:'#010+
|
||||||
'**2O-_Disable optimizations'#010+
|
'**2O-_Disable optimizations'#010+
|
||||||
'**2O1_Level 1 optimizations (quick and debugger friendly)'#010+
|
'**2O1_Level 1 optimizations (quick and debugger friendly)'#010+
|
||||||
'**2O2_Level 2 optimizations (-O1 + quick optimizations)'#010+
|
'**2O2_Level 2 optimizations (-O1 + quick optimizations)'#010+
|
||||||
'**2O3_Level 3 optimizations (-O2 + slow o','ptimizations)'#010+
|
'**2O3_Level 3 optimizations (-O2 + slow ','optimizations)'#010+
|
||||||
'**2Oa<x>=<y>_Set alignment'#010+
|
'**2Oa<x>=<y>_Set alignment'#010+
|
||||||
'**2Oo[NO]<x>_Enable or disable optimizations, see fpc -i for possible '+
|
'**2Oo[NO]<x>_Enable or disable optimizations, see fpc -i for possible '+
|
||||||
'values'#010+
|
'values'#010+
|
||||||
'**2Op<x>_Set target cpu for optimizing, see fpc -i for possible values'+
|
'**2Op<x>_Set target cpu for optimizing, see fpc -i for possible values'+
|
||||||
#010+
|
#010+
|
||||||
'**2Os_Optimize for size rather than speed'#010+
|
'**2Os_Optimize for size rather than speed'#010+
|
||||||
'**1pg_Gen','erate profile code for gprof (defines FPC_PROFILE)'#010+
|
'**1pg_Ge','nerate profile code for gprof (defines FPC_PROFILE)'#010+
|
||||||
'**1R<x>_Assembler reading style:'#010+
|
'**1R<x>_Assembler reading style:'#010+
|
||||||
'**2Rdefault_Use default assembler for target'#010+
|
'**2Rdefault_Use default assembler for target'#010+
|
||||||
'3*2Ratt_Read AT&T style assembler'#010+
|
'3*2Ratt_Read AT&T style assembler'#010+
|
||||||
'3*2Rintel_Read Intel style assembler'#010+
|
'3*2Rintel_Read Intel style assembler'#010+
|
||||||
'6*2RMOT_Read motorola style assembler'#010+
|
'6*2RMOT_Read motorola style assembler'#010+
|
||||||
'**','1S<x>_Syntax options:'#010+
|
'*','*1S<x>_Syntax options:'#010+
|
||||||
'**2S2_Same as -Mobjfpc'#010+
|
'**2S2_Same as -Mobjfpc'#010+
|
||||||
'**2Sc_Support operators like C (*=,+=,/= and -=)'#010+
|
'**2Sc_Support operators like C (*=,+=,/= and -=)'#010+
|
||||||
'**2Sa_Turn on assertions'#010+
|
'**2Sa_Turn on assertions'#010+
|
||||||
'**2Sd_Same as -Mdelphi'#010+
|
'**2Sd_Same as -Mdelphi'#010+
|
||||||
'**2Se<x>_Error options. <x> is a combination of the following:'#010+
|
'**2Se<x>_Error options. <x> is a combination of the following:'#010+
|
||||||
'**3*_<n> : Compiler halts after the',' <n> errors (default is 1)'#010+
|
'**3*_<n> : Compiler halts after th','e <n> errors (default is 1)'#010+
|
||||||
'**3*_w : Compiler also halts after warnings'#010+
|
'**3*_w : Compiler also halts after warnings'#010+
|
||||||
'**3*_n : Compiler also halts after notes'#010+
|
'**3*_n : Compiler also halts after notes'#010+
|
||||||
'**3*_h : Compiler also halts after hints'#010+
|
'**3*_h : Compiler also halts after hints'#010+
|
||||||
'**2Sg_Enable LABEL and GOTO (default in -Mtp and -Mdelphi)'#010+
|
'**2Sg_Enable LABEL and GOTO (default in -Mtp and -Mdelphi)'#010+
|
||||||
'**2Sh_Use ansistrings by def','ault instead of shortstrings'#010+
|
'**2Sh_Use ansistrings by de','fault instead of shortstrings'#010+
|
||||||
'**2Si_Turn on inlining of procedures/functions declared as "inline"'#010+
|
'**2Si_Turn on inlining of procedures/functions declared as "inline"'#010+
|
||||||
'**2Sk_Load fpcylix unit'#010+
|
'**2Sk_Load fpcylix unit'#010+
|
||||||
'**2SI<x>_Set interface style to <x>'#010+
|
'**2SI<x>_Set interface style to <x>'#010+
|
||||||
'**3SIcom_COM compatible interface (default)'#010+
|
'**3SIcom_COM compatible interface (default)'#010+
|
||||||
'**3SIcorba_CORBA compatible interface'#010+
|
'**3SIcorba_CORBA compatible interface'#010,
|
||||||
'*','*2Sm_Support macros like C (global)'#010+
|
'**2Sm_Support macros like C (global)'#010+
|
||||||
'**2So_Same as -Mtp'#010+
|
'**2So_Same as -Mtp'#010+
|
||||||
'**2Ss_Constructor name must be init (destructor must be done)'#010+
|
'**2Ss_Constructor name must be init (destructor must be done)'#010+
|
||||||
'**2St_Allow static keyword in objects'#010+
|
'**2St_Allow static keyword in objects'#010+
|
||||||
'**2Sx_Enable exception keywords (default in Delphi/ObjFPC modes)'#010+
|
'**2Sx_Enable exception keywords (default in Delphi/ObjFPC modes)'#010+
|
||||||
'**1s_Do not call ass','embler and linker'#010+
|
'**1s_Do not call as','sembler and linker'#010+
|
||||||
'**2sh_Generate script to link on host'#010+
|
'**2sh_Generate script to link on host'#010+
|
||||||
'**2st_Generate script to link on target'#010+
|
'**2st_Generate script to link on target'#010+
|
||||||
'**2sr_Skip register allocation phase (use with -alr)'#010+
|
'**2sr_Skip register allocation phase (use with -alr)'#010+
|
||||||
'**1T<x>_Target operating system:'#010+
|
'**1T<x>_Target operating system:'#010+
|
||||||
'3*2Temx_OS/2 via EMX (including EMX/RSX extender)'#010+
|
'3*2Temx_OS/2 via EMX (including EMX/RSX extender)'#010+
|
||||||
'3*2Tfree','bsd_FreeBSD'#010+
|
'3*2Tfre','ebsd_FreeBSD'#010+
|
||||||
'3*2Tgo32v2_Version 2 of DJ Delorie DOS extender'#010+
|
'3*2Tgo32v2_Version 2 of DJ Delorie DOS extender'#010+
|
||||||
'3*2Tlinux_Linux'#010+
|
'3*2Tlinux_Linux'#010+
|
||||||
'3*2Tnetbsd_NetBSD'#010+
|
'3*2Tnetbsd_NetBSD'#010+
|
||||||
@ -1036,7 +1036,7 @@ const msgtxt : array[0..000196,1..240] of char=(
|
|||||||
'3*2Tnetwlibc_Novell Netware Module (libc)'#010+
|
'3*2Tnetwlibc_Novell Netware Module (libc)'#010+
|
||||||
'3*2Topenbsd_OpenBSD'#010+
|
'3*2Topenbsd_OpenBSD'#010+
|
||||||
'3*2Tos2_OS/2 / eComStation'#010+
|
'3*2Tos2_OS/2 / eComStation'#010+
|
||||||
'3*2Tsunos_SunOS/','Solaris'#010+
|
'3*2Tsunos_SunOS','/Solaris'#010+
|
||||||
'3*2Tsymbian_Symbian OS'#010+
|
'3*2Tsymbian_Symbian OS'#010+
|
||||||
'3*2Twatcom_Watcom compatible DOS extender'#010+
|
'3*2Twatcom_Watcom compatible DOS extender'#010+
|
||||||
'3*2Twdosx_WDOSX DOS extender'#010+
|
'3*2Twdosx_WDOSX DOS extender'#010+
|
||||||
@ -1046,7 +1046,7 @@ const msgtxt : array[0..000196,1..240] of char=(
|
|||||||
'6*2Tamiga_Commodore Amiga'#010+
|
'6*2Tamiga_Commodore Amiga'#010+
|
||||||
'6*2Tatari_Atari ST/STe/TT'#010+
|
'6*2Tatari_Atari ST/STe/TT'#010+
|
||||||
'6*2Tlinux_Linux/m68k'#010+
|
'6*2Tlinux_Linux/m68k'#010+
|
||||||
'6*2','Tmacos_Macintosh m68k (not supported)'#010+
|
'6*','2Tmacos_Macintosh m68k (not supported)'#010+
|
||||||
'6*2Tpalmos_PalmOS'#010+
|
'6*2Tpalmos_PalmOS'#010+
|
||||||
'A*2Tlinux_Linux'#010+
|
'A*2Tlinux_Linux'#010+
|
||||||
'A*2Twince_Windows CE'#010+
|
'A*2Twince_Windows CE'#010+
|
||||||
@ -1054,77 +1054,79 @@ const msgtxt : array[0..000196,1..240] of char=(
|
|||||||
'P*2Tdarwin_Darwin and Mac OS X on PowerPC'#010+
|
'P*2Tdarwin_Darwin and Mac OS X on PowerPC'#010+
|
||||||
'P*2Tlinux_Linux on PowerPC'#010+
|
'P*2Tlinux_Linux on PowerPC'#010+
|
||||||
'P*2Tmacos_Mac OS (classic) on PowerPC'#010+
|
'P*2Tmacos_Mac OS (classic) on PowerPC'#010+
|
||||||
'P*2Tmorphos','_MorphOS'#010+
|
'P*2Tmorpho','s_MorphOS'#010+
|
||||||
'S*2Tlinux_Linux'#010+
|
'S*2Tlinux_Linux'#010+
|
||||||
'**1u<x>_Undefines the symbol <x>'#010+
|
'**1u<x>_Undefines the symbol <x>'#010+
|
||||||
'**1U_Unit options:'#010+
|
'**1U_Unit options:'#010+
|
||||||
'**2Un_Do not check where the unit name matches the file name'#010+
|
'**2Un_Do not check where the unit name matches the file name'#010+
|
||||||
'**2Ur_Generate release unit files (never automatically recompiled)'#010+
|
'**2Ur_Generate release unit files (never automatically recompiled)'#010+
|
||||||
'**2Us_Compile a system unit'#010+
|
'**2Us_Compile a system unit'#010+
|
||||||
'**1v<x>','_Be verbose. <x> is a combination of the following letters:'#010+
|
'**1v<x','>_Be verbose. <x> is a combination of the following letters:'#010+
|
||||||
'**2*_e : Show errors (default) 0 : Show nothing (except errors)'#010+
|
'**2*_e : Show errors (default) 0 : Show nothing (except errors)'#010+
|
||||||
'**2*_w : Show warnings u : Show unit info'#010+
|
'**2*_w : Show warnings u : Show unit info'#010+
|
||||||
'**2*_n : Show notes t : Show tried/us','ed files'#010+
|
'**2*_n : Show notes t : Show tried/u','sed files'#010+
|
||||||
'**2*_h : Show hints c : Show conditionals'#010+
|
'**2*_h : Show hints c : Show conditionals'#010+
|
||||||
'**2*_i : Show general info d : Show debug info'#010+
|
'**2*_i : Show general info d : Show debug info'#010+
|
||||||
'**2*_l : Show linenumbers r : Rhide/GCC compatibility mode'#010+
|
'**2*_l : Show linenumbers r : Rhide/GCC compatibility mode'#010+
|
||||||
'**2*_a : Show everything x : Exec','utable info (Win32 only'+
|
'**2*_a : Show everything x : Exe','cutable info (Win32 only'+
|
||||||
')'#010+
|
')'#010+
|
||||||
'**2*_b : Write file names messages with full path'#010+
|
'**2*_b : Write file names messages with full path'#010+
|
||||||
'**2*_v : Write fpcdebug.txt with p : Write tree.log with parse tre'+
|
'**2*_v : Write fpcdebug.txt with p : Write tree.log with parse tre'+
|
||||||
'e'#010+
|
'e'#010+
|
||||||
'**2*_ lots of debugging info'#010+
|
'**2*_ lots of debugging info q : Show message numbers'#010+
|
||||||
|
'**2*_m<x>,<y> : Don'#039't show mes','sages numbered <x> and <y>'#010+
|
||||||
'3*1W<x>_Target-specific options (targets)'#010+
|
'3*1W<x>_Target-specific options (targets)'#010+
|
||||||
'A*1W<x>_Target-spec','ific options (targets)'#010+
|
'A*1W<x>_Target-specific options (targets)'#010+
|
||||||
'P*1W<x>_Target-specific options (targets)'#010+
|
'P*1W<x>_Target-specific options (targets)'#010+
|
||||||
'3*2Wb_Create a bundle instead of a library (Darwin)'#010+
|
'3*2Wb_Create a bundle instead of a library (Darwin)'#010+
|
||||||
'P*2Wb_Create a bundle instead of a library (Darwin)'#010+
|
'P*2Wb_Create a bundle instead of a ','library (Darwin)'#010+
|
||||||
'p*2Wb_Create a bundle instead of a library (Darwin)'#010+
|
'p*2Wb_Create a bundle instead of a library (Darwin)'#010+
|
||||||
'3*2WB_Create a relo','catable image (Windows)'#010+
|
'3*2WB_Create a relocatable image (Windows)'#010+
|
||||||
'A*2WB_Create a relocatable image (Windows, Symbian)'#010+
|
'A*2WB_Create a relocatable image (Windows, Symbian)'#010+
|
||||||
'3*2WC_Specify console type application (EMX, OS/2, Windows)'#010+
|
'3*2WC_Specify console type application (EMX, OS/2, Windows)'#010+
|
||||||
'A*2WC_Specify console type application (Windows)'#010+
|
'A*2WC_Specify co','nsole type application (Windows)'#010+
|
||||||
'P*2WC_Specify console type application (Classic Mac OS)',#010+
|
'P*2WC_Specify console type application (Classic Mac OS)'#010+
|
||||||
'3*2WD_Use DEFFILE to export functions of DLL or EXE (Windows)'#010+
|
'3*2WD_Use DEFFILE to export functions of DLL or EXE (Windows)'#010+
|
||||||
'A*2WD_Use DEFFILE to export functions of DLL or EXE (Windows)'#010+
|
'A*2WD_Use DEFFILE to export functions of DLL or EXE (Windows)'#010+
|
||||||
'3*2We_Use external resources (Darwin)'#010+
|
'3*2We_Use external resource','s (Darwin)'#010+
|
||||||
'P*2We_Use external resources (Darwin)'#010+
|
'P*2We_Use external resources (Darwin)'#010+
|
||||||
'p*2We_Use external resources (Darwin)'#010+
|
'p*2We_Use external resources (Darwin)'#010+
|
||||||
'3','*2WF_Specify full-screen type application (EMX, OS/2)'#010+
|
'3*2WF_Specify full-screen type application (EMX, OS/2)'#010+
|
||||||
'3*2WG_Specify graphic type application (EMX, OS/2, Windows)'#010+
|
'3*2WG_Specify graphic type application (EMX, OS/2, Windows)'#010+
|
||||||
'A*2WG_Specify graphic type application (Windows)'#010+
|
'A*2WG_Specify graphic type application',' (Windows)'#010+
|
||||||
'P*2WG_Specify graphic type application (Classic Mac OS)'#010+
|
'P*2WG_Specify graphic type application (Classic Mac OS)'#010+
|
||||||
'3*2Wi_Use internal re','sources (Darwin)'#010+
|
'3*2Wi_Use internal resources (Darwin)'#010+
|
||||||
'P*2Wi_Use internal resources (Darwin)'#010+
|
'P*2Wi_Use internal resources (Darwin)'#010+
|
||||||
'p*2Wi_Use internal resources (Darwin)'#010+
|
'p*2Wi_Use internal resources (Darwin)'#010+
|
||||||
'3*2WN_Do not generate relocation code, needed for debugging (Windows)'#010+
|
'3*2WN_Do not generate relocation code, needed for debugging',' (Windows'+
|
||||||
|
')'#010+
|
||||||
'A*2WN_Do not generate relocation code, needed for debugging (Windows)'#010+
|
'A*2WN_Do not generate relocation code, needed for debugging (Windows)'#010+
|
||||||
'3*2WR_G','enerate relocation code (Windows)'#010+
|
'3*2WR_Generate relocation code (Windows)'#010+
|
||||||
'A*2WR_Generate relocation code (Windows)'#010+
|
'A*2WR_Generate relocation code (Windows)'#010+
|
||||||
'P*2WT_Specify MPW tool type application (Classic Mac OS)'#010+
|
'P*2WT_Specify MPW tool type application (Classic Mac OS)'#010+
|
||||||
'**1X_Executable options:'#010+
|
'**1X_Executable opti','ons:'#010+
|
||||||
'**2Xc_Pass --shared/-dynamic to the linker (BeOS, Darwin, FreeBSD, Lin'+
|
'**2Xc_Pass --shared/-dynamic to the linker (BeOS, Darwin, FreeBSD, Lin'+
|
||||||
'ux)'#010+
|
'ux)'#010+
|
||||||
'**2Xd_Do ','not use standard library search path (needed for cross comp'+
|
'**2Xd_Do not use standard library search path (needed for cross compil'+
|
||||||
'ile)'#010+
|
'e)'#010+
|
||||||
'**2Xe_Use external linker'#010+
|
'**2Xe_Use external linker'#010+
|
||||||
'**2Xg_Create debuginfo in a separate file and add a debuglink section '+
|
'**2Xg_Create debuginfo in a separate file and add a debuglink ','sectio'+
|
||||||
'to executable'#010+
|
'n to executable'#010+
|
||||||
'**2XD_Try to link units dynamically (defines FPC_LINK_DYNAMIC',')'#010+
|
'**2XD_Try to link units dynamically (defines FPC_LINK_DYNAMIC)'#010+
|
||||||
'**2Xi_Use internal linker'#010+
|
'**2Xi_Use internal linker'#010+
|
||||||
'**2Xm_Generate link map'#010+
|
'**2Xm_Generate link map'#010+
|
||||||
'**2XM<x>_Set the name of the '#039'main'#039' program routine (default i'+
|
'**2XM<x>_Set the name of the '#039'main'#039' program routine (default i'+
|
||||||
's '#039'main'#039')'#010+
|
's '#039'main'#039')'#010+
|
||||||
'**2XP<x>_Prepend the binutils names with the prefix <x>'#010+
|
'**2XP<x>_Prepend the binutil','s names with the prefix <x>'#010+
|
||||||
'**2Xr<x>_Set library search path to <x> (needed for cross co','mpile) ('+
|
'**2Xr<x>_Set library search path to <x> (needed for cross compile) (Be'+
|
||||||
'BeOS, Linux)'#010+
|
'OS, Linux)'#010+
|
||||||
'**2XR<x>_Prepend <x> to all linker search paths (BeOS, Darwin, FreeBSD'+
|
'**2XR<x>_Prepend <x> to all linker search paths (BeOS, Darwin, FreeBSD'+
|
||||||
', Linux, Mac OS, Solaris)'#010+
|
', Linux, Mac OS, Solaris)'#010+
|
||||||
'**2Xs_Strip all symbols from executable'#010+
|
'**2Xs_Strip all symbols from execut','able'#010+
|
||||||
'**2XS_Try to link units statically (default, defines FPC_LINK_STATIC)'#010+
|
'**2XS_Try to link units statically (default, defines FPC_LINK_STATIC)'#010+
|
||||||
'**2Xt_Link wi','th static libraries (-static is passed to linker)'#010+
|
'**2Xt_Link with static libraries (-static is passed to linker)'#010+
|
||||||
'**2XX_Try to smartlink units (defines FPC_LINK_SMART)'#010+
|
'**2XX_Try to smartlink units (defines FPC_LINK_SMART)'#010+
|
||||||
'**1*_'#010+
|
'**1*_'#010+
|
||||||
'**1?_Show this help'#010+
|
'**1?_Show this help'#010+
|
||||||
'**1h_Shows this help without waiting'#000
|
'**1h_Shows',' this help without waiting'#000
|
||||||
);
|
);
|
||||||
|
@ -120,7 +120,6 @@ implementation
|
|||||||
uses
|
uses
|
||||||
comphook,fmodule,constexp,globals;
|
comphook,fmodule,constexp,globals;
|
||||||
|
|
||||||
|
|
||||||
{****************************************************************************
|
{****************************************************************************
|
||||||
Extra Handlers for default compiler
|
Extra Handlers for default compiler
|
||||||
****************************************************************************}
|
****************************************************************************}
|
||||||
@ -178,6 +177,31 @@ implementation
|
|||||||
end;
|
end;
|
||||||
|
|
||||||
|
|
||||||
|
function ClearMessageVerbosity(s: string; var i: integer): boolean;
|
||||||
|
var
|
||||||
|
tok : string;
|
||||||
|
code : longint;
|
||||||
|
msgnr: longint;
|
||||||
|
begin
|
||||||
|
{ delete everything up to and including 'm' }
|
||||||
|
delete(s,1,i);
|
||||||
|
{ the rest of the string must be message numbers }
|
||||||
|
inc(i,length(s)+1);
|
||||||
|
result:=false;
|
||||||
|
repeat
|
||||||
|
tok:=GetToken(s,',');
|
||||||
|
if (tok='') then
|
||||||
|
break;
|
||||||
|
val(tok, msgnr, code);
|
||||||
|
if (code<>0) then
|
||||||
|
exit;
|
||||||
|
if not msg^.clearverbosity(msgnr) then
|
||||||
|
exit;
|
||||||
|
until false;
|
||||||
|
result:=true;
|
||||||
|
end;
|
||||||
|
|
||||||
|
|
||||||
function CheckVerbosity(v:longint):boolean;
|
function CheckVerbosity(v:longint):boolean;
|
||||||
begin
|
begin
|
||||||
result:=do_checkverbosity(v);
|
result:=do_checkverbosity(v);
|
||||||
@ -214,6 +238,7 @@ implementation
|
|||||||
{ handle switch }
|
{ handle switch }
|
||||||
case c of
|
case c of
|
||||||
{ Special cases }
|
{ Special cases }
|
||||||
|
'0' : status.verbosity:=V_Default;
|
||||||
'A' : status.verbosity:=V_All;
|
'A' : status.verbosity:=V_All;
|
||||||
'B' : begin
|
'B' : begin
|
||||||
if inverse then
|
if inverse then
|
||||||
@ -221,13 +246,24 @@ implementation
|
|||||||
else
|
else
|
||||||
status.print_source_path:=true;
|
status.print_source_path:=true;
|
||||||
end;
|
end;
|
||||||
'0' : status.verbosity:=V_Default;
|
'M' : if inverse or
|
||||||
|
not ClearMessageVerbosity(s, i) then
|
||||||
|
begin
|
||||||
|
result:=false;
|
||||||
|
exit
|
||||||
|
end;
|
||||||
'P' : begin
|
'P' : begin
|
||||||
if inverse then
|
if inverse then
|
||||||
paraprintnodetree:=0
|
paraprintnodetree:=0
|
||||||
else
|
else
|
||||||
paraprintnodetree:=1;
|
paraprintnodetree:=1;
|
||||||
end;
|
end;
|
||||||
|
'Q' : begin
|
||||||
|
if inverse then
|
||||||
|
status.showmsgnrs:=false
|
||||||
|
else
|
||||||
|
status.showmsgnrs:=true;
|
||||||
|
end;
|
||||||
'R' : begin
|
'R' : begin
|
||||||
if inverse then
|
if inverse then
|
||||||
begin
|
begin
|
||||||
@ -240,6 +276,7 @@ implementation
|
|||||||
status.use_stderr:=true;
|
status.use_stderr:=true;
|
||||||
end;
|
end;
|
||||||
end;
|
end;
|
||||||
|
'V' : PrepareReport;
|
||||||
'Z' : begin
|
'Z' : begin
|
||||||
if inverse then
|
if inverse then
|
||||||
status.use_stderr:=false
|
status.use_stderr:=false
|
||||||
@ -247,38 +284,6 @@ implementation
|
|||||||
status.use_stderr:=true;
|
status.use_stderr:=true;
|
||||||
end;
|
end;
|
||||||
{ Normal cases - do an or }
|
{ Normal cases - do an or }
|
||||||
'E' : if inverse then
|
|
||||||
status.verbosity:=status.verbosity and (not V_Error)
|
|
||||||
else
|
|
||||||
status.verbosity:=status.verbosity or V_Error;
|
|
||||||
'I' : if inverse then
|
|
||||||
status.verbosity:=status.verbosity and (not V_Info)
|
|
||||||
else
|
|
||||||
status.verbosity:=status.verbosity or V_Info;
|
|
||||||
'W' : if inverse then
|
|
||||||
status.verbosity:=status.verbosity and (not V_Warning)
|
|
||||||
else
|
|
||||||
status.verbosity:=status.verbosity or V_Warning;
|
|
||||||
'N' : if inverse then
|
|
||||||
status.verbosity:=status.verbosity and (not V_Note)
|
|
||||||
else
|
|
||||||
status.verbosity:=status.verbosity or V_Note;
|
|
||||||
'H' : if inverse then
|
|
||||||
status.verbosity:=status.verbosity and (not V_Hint)
|
|
||||||
else
|
|
||||||
status.verbosity:=status.verbosity or V_Hint;
|
|
||||||
'L' : if inverse then
|
|
||||||
status.verbosity:=status.verbosity and (not V_Status)
|
|
||||||
else
|
|
||||||
status.verbosity:=status.verbosity or V_Status;
|
|
||||||
'U' : if inverse then
|
|
||||||
status.verbosity:=status.verbosity and (not V_Used)
|
|
||||||
else
|
|
||||||
status.verbosity:=status.verbosity or V_Used;
|
|
||||||
'T' : if inverse then
|
|
||||||
status.verbosity:=status.verbosity and (not V_Tried)
|
|
||||||
else
|
|
||||||
status.verbosity:=status.verbosity or V_Tried;
|
|
||||||
'C' : if inverse then
|
'C' : if inverse then
|
||||||
status.verbosity:=status.verbosity and (not V_Conditional)
|
status.verbosity:=status.verbosity and (not V_Conditional)
|
||||||
else
|
else
|
||||||
@ -287,15 +292,46 @@ implementation
|
|||||||
status.verbosity:=status.verbosity and (not V_Debug)
|
status.verbosity:=status.verbosity and (not V_Debug)
|
||||||
else
|
else
|
||||||
status.verbosity:=status.verbosity or V_Debug;
|
status.verbosity:=status.verbosity or V_Debug;
|
||||||
'X' : if inverse then
|
'E' : if inverse then
|
||||||
status.verbosity:=status.verbosity and (not V_Executable)
|
status.verbosity:=status.verbosity and (not V_Error)
|
||||||
else
|
else
|
||||||
status.verbosity:=status.verbosity or V_Executable;
|
status.verbosity:=status.verbosity or V_Error;
|
||||||
|
'H' : if inverse then
|
||||||
|
status.verbosity:=status.verbosity and (not V_Hint)
|
||||||
|
else
|
||||||
|
status.verbosity:=status.verbosity or V_Hint;
|
||||||
|
'I' : if inverse then
|
||||||
|
status.verbosity:=status.verbosity and (not V_Info)
|
||||||
|
else
|
||||||
|
status.verbosity:=status.verbosity or V_Info;
|
||||||
|
'L' : if inverse then
|
||||||
|
status.verbosity:=status.verbosity and (not V_Status)
|
||||||
|
else
|
||||||
|
status.verbosity:=status.verbosity or V_Status;
|
||||||
|
'N' : if inverse then
|
||||||
|
status.verbosity:=status.verbosity and (not V_Note)
|
||||||
|
else
|
||||||
|
status.verbosity:=status.verbosity or V_Note;
|
||||||
'S' : if inverse then
|
'S' : if inverse then
|
||||||
status.verbosity:=status.verbosity and (not V_TimeStamps)
|
status.verbosity:=status.verbosity and (not V_TimeStamps)
|
||||||
else
|
else
|
||||||
status.verbosity:=status.verbosity or V_TimeStamps;
|
status.verbosity:=status.verbosity or V_TimeStamps;
|
||||||
'V' : PrepareReport;
|
'T' : if inverse then
|
||||||
|
status.verbosity:=status.verbosity and (not V_Tried)
|
||||||
|
else
|
||||||
|
status.verbosity:=status.verbosity or V_Tried;
|
||||||
|
'U' : if inverse then
|
||||||
|
status.verbosity:=status.verbosity and (not V_Used)
|
||||||
|
else
|
||||||
|
status.verbosity:=status.verbosity or V_Used;
|
||||||
|
'W' : if inverse then
|
||||||
|
status.verbosity:=status.verbosity and (not V_Warning)
|
||||||
|
else
|
||||||
|
status.verbosity:=status.verbosity or V_Warning;
|
||||||
|
'X' : if inverse then
|
||||||
|
status.verbosity:=status.verbosity and (not V_Executable)
|
||||||
|
else
|
||||||
|
status.verbosity:=status.verbosity or V_Executable;
|
||||||
end;
|
end;
|
||||||
inc(i);
|
inc(i);
|
||||||
end;
|
end;
|
||||||
@ -520,7 +556,7 @@ implementation
|
|||||||
{Parse options}
|
{Parse options}
|
||||||
idx:=pos('_',s);
|
idx:=pos('_',s);
|
||||||
if idx=0 then
|
if idx=0 then
|
||||||
v:=V_Normal
|
v:=V_None
|
||||||
else
|
else
|
||||||
if (idx >= 1) And (idx <= 5) then
|
if (idx >= 1) And (idx <= 5) then
|
||||||
begin
|
begin
|
||||||
@ -587,31 +623,33 @@ implementation
|
|||||||
Delete(s,1,idx);
|
Delete(s,1,idx);
|
||||||
{ check verbosity level }
|
{ check verbosity level }
|
||||||
if not CheckVerbosity(v) then
|
if not CheckVerbosity(v) then
|
||||||
begin
|
begin
|
||||||
doqueue := onqueue <> nil;
|
doqueue := onqueue <> nil;
|
||||||
if not doqueue then
|
if not doqueue then
|
||||||
exit;
|
exit;
|
||||||
end;
|
end;
|
||||||
if (v and V_LineInfoMask)<>0 then
|
if (v and V_LineInfoMask)<>0 then
|
||||||
v:=v or V_LineInfo;
|
v:=v or V_LineInfo;
|
||||||
{ fix status }
|
{ fix status }
|
||||||
UpdateStatus;
|
UpdateStatus;
|
||||||
{ Fix replacements }
|
{ Fix replacements }
|
||||||
DefaultReplacements(s);
|
DefaultReplacements(s);
|
||||||
|
if status.showmsgnrs then
|
||||||
|
s:='('+tostr(w)+') '+s;
|
||||||
if doqueue then
|
if doqueue then
|
||||||
begin
|
begin
|
||||||
onqueue(s,v,w);
|
onqueue(s,v,w);
|
||||||
exit;
|
exit;
|
||||||
end;
|
end;
|
||||||
{ show comment }
|
{ show comment }
|
||||||
if do_comment(v,s) or dostop then
|
if do_comment(v,s) or dostop then
|
||||||
raise ECompilerAbort.Create;
|
raise ECompilerAbort.Create;
|
||||||
if (status.errorcount>=status.maxerrorcount) and not status.skip_error then
|
if (status.errorcount>=status.maxerrorcount) and not status.skip_error then
|
||||||
begin
|
begin
|
||||||
Message1(unit_f_errors_in_unit,tostr(status.errorcount));
|
Message1(unit_f_errors_in_unit,tostr(status.errorcount));
|
||||||
status.skip_error:=true;
|
status.skip_error:=true;
|
||||||
raise ECompilerAbort.Create;
|
raise ECompilerAbort.Create;
|
||||||
end;
|
end;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
|
||||||
@ -820,16 +858,16 @@ implementation
|
|||||||
end;
|
end;
|
||||||
|
|
||||||
|
|
||||||
procedure FlushOutput;
|
procedure FlushOutput;
|
||||||
begin
|
begin
|
||||||
if not (Status.Use_StdErr) then (* StdErr is flushed after every line *)
|
if not (Status.Use_StdErr) then (* StdErr is flushed after every line *)
|
||||||
begin
|
begin
|
||||||
if Status.Use_Redir then
|
if Status.Use_Redir then
|
||||||
Flush(Status.RedirFile)
|
Flush(Status.RedirFile)
|
||||||
else
|
else
|
||||||
Flush(Output);
|
Flush(Output);
|
||||||
end;
|
end;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
|
||||||
{*****************************************************************************
|
{*****************************************************************************
|
||||||
|
7
tests/test/tmsg1.pp
Normal file
7
tests/test/tmsg1.pp
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
{ %fail }
|
||||||
|
{ %opt=-vm20999999 }
|
||||||
|
|
||||||
|
{ illegal message number }
|
||||||
|
|
||||||
|
begin
|
||||||
|
end.
|
7
tests/test/tmsg2.pp
Normal file
7
tests/test/tmsg2.pp
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
{ %fail }
|
||||||
|
{ %opt=-vm123 }
|
||||||
|
|
||||||
|
{ non-existent message }
|
||||||
|
|
||||||
|
begin
|
||||||
|
end.
|
7
tests/test/tmsg3.pp
Normal file
7
tests/test/tmsg3.pp
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
{ %fail }
|
||||||
|
{ %opt=-vm5024,a,05027 }
|
||||||
|
|
||||||
|
{ invalid characted amidst message numbers }
|
||||||
|
|
||||||
|
begin
|
||||||
|
end.
|
10
tests/test/tmsg4.pp
Normal file
10
tests/test/tmsg4.pp
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
{ %opt=-vh -vm05024 -Seh }
|
||||||
|
|
||||||
|
procedure test(l: longint);
|
||||||
|
begin
|
||||||
|
writeln('l is unused, but that hint has been suppressed');
|
||||||
|
end;
|
||||||
|
|
||||||
|
begin
|
||||||
|
test(5);
|
||||||
|
end.
|
Loading…
Reference in New Issue
Block a user