diff --git a/.gitattributes b/.gitattributes index dc41913377..dad12e52a5 100644 --- a/.gitattributes +++ b/.gitattributes @@ -7735,6 +7735,10 @@ tests/test/tmath1.pp svneol=native#text/plain tests/test/tmcbool2.pp svneol=native#text/plain tests/test/tmmx1.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/tobject1.pp svneol=native#text/plain tests/test/tobject2.pp svneol=native#text/plain diff --git a/compiler/cmsgs.pas b/compiler/cmsgs.pas index 9a204345d1..81e084b866 100644 --- a/compiler/cmsgs.pas +++ b/compiler/cmsgs.pas @@ -52,6 +52,7 @@ type procedure ClearIdx; procedure CreateIdx; function GetPChar(nr:longint):pchar; + function ClearVerbosity(nr:longint):boolean; function Get(nr:longint;const args:array of string):ansistring; end; @@ -374,6 +375,33 @@ begin GetPChar:=msgidx[nr div 1000]^[nr mod 1000]; 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; var diff --git a/compiler/comphook.pas b/compiler/comphook.pas index fc00160c04..c972b3dc99 100644 --- a/compiler/comphook.pas +++ b/compiler/comphook.pas @@ -90,6 +90,7 @@ type ispackage, islibrary : boolean; { Settings for the output } + showmsgnrs : boolean; verbosity : longint; maxerrorcount : longint; errorwarning, @@ -337,7 +338,8 @@ begin end; { 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 if status.use_stderr then begin @@ -375,7 +377,8 @@ end; function def_CheckVerbosity(v:longint):boolean; begin 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; procedure def_initsymbolinfo; diff --git a/compiler/msg/errore.msg b/compiler/msg/errore.msg index 9d8f97df9e..a9d9e354c4 100644 --- a/compiler/msg/errore.msg +++ b/compiler/msg/errore.msg @@ -39,6 +39,7 @@ # c_ conditional # d_ debug message # 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. option_handling_option=11028_D_Handling option "$1" % 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 % Key, the next page of help is shown. If you press q and then ENTER, the % compiler exits. @@ -2753,7 +2754,8 @@ S*2Tlinux_Linux **2*_a : Show everything x : Executable info (Win32 only) **2*_b : Write file names messages with full path **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, : Don't show messages numbered and 3*1W_Target-specific options (targets) A*1W_Target-specific options (targets) P*1W_Target-specific options (targets) diff --git a/compiler/msgidx.inc b/compiler/msgidx.inc index 97f4e32c22..c0eda938e5 100644 --- a/compiler/msgidx.inc +++ b/compiler/msgidx.inc @@ -754,7 +754,7 @@ const option_info=11024; option_help_pages=11025; - MsgTxtSize = 47219; + MsgTxtSize = 47307; MsgIdxMax : array[1..20] of longint=( 24,87,248,84,65,50,108,22,201,61, diff --git a/compiler/msgtxt.inc b/compiler/msgtxt.inc index f2cd772bd8..4edc19f4b1 100644 --- a/compiler/msgtxt.inc +++ b/compiler/msgtxt.inc @@ -1,7 +1,7 @@ {$ifdef Delphi} -const msgtxt : array[0..000196] of string[240]=( +const msgtxt : array[0..000197] of string[240]=( {$else Delphi} -const msgtxt : array[0..000196,1..240] of char=( +const msgtxt : array[0..000197,1..240] of char=( {$endif Delphi} '01000_T_Compiler: $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+ '11027_T_Reading options from environment $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+ '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+ '11033_D_interpreting file option "$1"'#000+ '11034_D_Reading config file "$1"'#000+ '11035_D_found source file name "$1"'#000+ '11039_E_Unknown code page'#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+ '11042_W_Use of ppc386.cfg is deprecated, please use fpc.cfg instead'#000+ '11023_Free Pascal Compiler version $FPCFULLVERSION [$FPCDATE] for $FPC'+ '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+ #010+ 'Compiler Date : $FPCDATE'#010+ @@ -850,7 +850,7 @@ const msgtxt : array[0..000196,1..240] of char=( 'Supported CPU instruction sets:'#010+ ' $INSTRUCTIONSETS'#010+ #010+ - 'Supported FPU instruction ','sets:'#010+ + 'Supported FPU instruction',' sets:'#010+ ' $FPUINSTRUCTIONSETS'#010+ #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+ #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'+ 'ble it'#010+ '**1a_The compiler doesn'#039't delete the generated 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+ '**2ar_List register allocation/release info in assembler file'#010+ '**2at_List temp allocation/release info in assembler file'#010+ '**1A_Output format:'#010+ - '**2Adefault_Use d','efault assembler'#010+ + '**2Adefault_Use ','default assembler'#010+ '3*2Aas_Assemble using GNU AS'#010+ '3*2Anasmcoff_COFF (Go32v2) file using Nasm'#010+ '3*2Anasmelf_ELF32 (Linux) file using Nasm'#010+ '3*2Anasmwin32_Win32 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*2Amasm_Obj file using Masm (Microsoft)'#010+ '3*2Atasm_Obj file using Tasm (Borland)'#010+ '3*2Aelf_ELF (Linux) 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+ '6*2Aas_Unix o-file using GNU AS'#010+ '6*2Agas_GNU Motorola assembler'#010+ '6*2Amit_MIT Syntax (old GAS)'#010+ '6*2Amot_Standard Motorola assembler'#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+ '**1b_Generate browser info'#010+ '**2bl_Generate local symbol info'#010+ @@ -900,25 +900,25 @@ const msgtxt : array[0..000196,1..240] of char=( '**1C_Code generation options:'#010+ '**2Ca_Select ABI, see fpc -i for possible values'#010+ '**2Cb_Generate big-endian code'#010+ - '**2Cc','_Set default calling convention to '#010+ + '**2Cc_Set default calling convention to '#010+ '**2CD_Create also dynamic library (not supported)'#010+ '**2Ce_Compilation with emulated floating point opcodes'#010+ '**2Cf_Select fpu instruction set to use, see fpc -i for possible va'+ 'lues'#010+ - '**2CF_Minimal floa','ting point constant precision (default, 32, 64)'+ + '**2CF_Minimal flo','ating point constant precision (default, 32, 64)'+ #010+ '**2Cg_Generate PIC code'#010+ '**2Ch_ bytes heap (between 1023 and 67107840)'#010+ '**2Ci_IO-checking'#010+ '**2Cn_Omit linking stage'#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_Select instruction set, see fpc -i for possible values'#010+ '**2CP=_ packing settings'#010+ '**3CPPACKSET=_ set allocation: 0, 1 or DEFAULT or NORMAL, 2, 4 '+ 'and 8'#010+ '**2Cr_Range checking'#010+ - '**2CR_Verify object me','thod call validity'#010+ + '**2CR_Verify object m','ethod call validity'#010+ '**2Cs_Set stack size to '#010+ '**2Ct_Stack checking'#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+ '**2Dd_Set description to '#010+ '**2Dv_Set DLL version to '#010+ - '*O2Dw_PM ap','plication'#010+ + '*O2Dw_PM a','pplication'#010+ '**1e_Set path to executable'#010+ '**1E_Same as -Cn'#010+ '**1fPIC_Same as -Cg'#010+ @@ -934,41 +934,41 @@ const msgtxt : array[0..000196,1..240] of char=( '**2Fa[,y]_(for a program) load units and [y] before uses is par'+ 'sed'#010+ '**2Fc_Set input codepage to '#010+ - '**2FC_Set RC com','piler binary name to '#010+ + '**2FC_Set RC co','mpiler binary name to '#010+ '**2FD_Set the directory where to search for compiler utilities'#010+ '**2Fe_Redirect error output to '#010+ '**2Ff_Add to framework path (Darwin only)'#010+ '**2FE_Set exe/unit output path to '#010+ - '**2Fi_Add to i','nclude path'#010+ + '**2Fi_Add to ','include path'#010+ '**2Fl_Add to library path'#010+ '**2FL_Use as dynamic linker'#010+ '**2Fm_Load unicode conversion table from .txt in the compiler di'+ 'r'#010+ '**2Fo_Add to object path'#010+ '**2Fr_Load error message file '#010+ - '**2FR_Set resour','ce (.res) linker to '#010+ + '**2FR_Set resou','rce (.res) linker to '#010+ '**2Fu_Add to unit path'#010+ '**2FU_Set unit output path to , overrides -FE'#010+ '*g1g_Generate debug information (default format for target)'#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+ '*g2go_Set debug information options'#010+ '*g3godwarfsets_ Enable Dwarf set debug information (breaks gdb < 6.5)'#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+ '*g2gv_Generates programs traceable with valgrind'#010+ '*g2gw_Generate dwarf-2 debug information (same as -gw2)'#010+ - '*g2gw2_Generate dwarf-2 debug information'#010+ - '*','g2gw3_Generate dwarf-3 debug information'#010+ + '*g2gw2_Generate dwarf-2 debug information'#010, + '*g2gw3_Generate dwarf-3 debug information'#010+ '**1i_Information'#010+ '**2iD_Return compiler date'#010+ '**2iV_Return short compiler version'#010+ '**2iW_Return full compiler version'#010+ '**2iSO_Return compiler OS'#010+ '**2iSP_Return compiler host processor'#010+ - '**2iTO_Return target',' OS'#010+ + '**2iTO_Return targe','t OS'#010+ '**2iTP_Return target processor'#010+ '**1I_Add to include path'#010+ '**1k_Pass to the linker'#010+ @@ -976,59 +976,59 @@ const msgtxt : array[0..000196,1..240] of char=( '**1M_Set language mode to '#010+ '**2Mfpc_Free Pascal dialect (default)'#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+ '**2Mmacpas_Macintosh Pascal dialects compatibility mode'#010+ '**1n_Do not read the default config files'#010+ '**1N_Node tree optimizations'#010+ '**2Nu_Unroll loops'#010+ - '**1o_Change the name ','of the executable produced to '#010+ + '**1o_Change the name',' of the executable produced to '#010+ '**1O_Optimizations:'#010+ '**2O-_Disable optimizations'#010+ '**2O1_Level 1 optimizations (quick and debugger friendly)'#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=_Set alignment'#010+ '**2Oo[NO]_Enable or disable optimizations, see fpc -i for possible '+ 'values'#010+ '**2Op_Set target cpu for optimizing, see fpc -i for possible values'+ #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_Assembler reading style:'#010+ '**2Rdefault_Use default assembler for target'#010+ '3*2Ratt_Read AT&T style assembler'#010+ '3*2Rintel_Read Intel style assembler'#010+ '6*2RMOT_Read motorola style assembler'#010+ - '**','1S_Syntax options:'#010+ + '*','*1S_Syntax options:'#010+ '**2S2_Same as -Mobjfpc'#010+ '**2Sc_Support operators like C (*=,+=,/= and -=)'#010+ '**2Sa_Turn on assertions'#010+ '**2Sd_Same as -Mdelphi'#010+ '**2Se_Error options. is a combination of the following:'#010+ - '**3*_ : Compiler halts after the',' errors (default is 1)'#010+ + '**3*_ : Compiler halts after th','e errors (default is 1)'#010+ '**3*_w : Compiler also halts after warnings'#010+ '**3*_n : Compiler also halts after notes'#010+ '**3*_h : Compiler also halts after hints'#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+ '**2Sk_Load fpcylix unit'#010+ '**2SI_Set interface style to '#010+ '**3SIcom_COM compatible interface (default)'#010+ - '**3SIcorba_CORBA compatible interface'#010+ - '*','*2Sm_Support macros like C (global)'#010+ + '**3SIcorba_CORBA compatible interface'#010, + '**2Sm_Support macros like C (global)'#010+ '**2So_Same as -Mtp'#010+ '**2Ss_Constructor name must be init (destructor must be done)'#010+ '**2St_Allow static keyword in objects'#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+ '**2st_Generate script to link on target'#010+ '**2sr_Skip register allocation phase (use with -alr)'#010+ '**1T_Target operating system:'#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*2Tlinux_Linux'#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*2Topenbsd_OpenBSD'#010+ '3*2Tos2_OS/2 / eComStation'#010+ - '3*2Tsunos_SunOS/','Solaris'#010+ + '3*2Tsunos_SunOS','/Solaris'#010+ '3*2Tsymbian_Symbian OS'#010+ '3*2Twatcom_Watcom compatible 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*2Tatari_Atari ST/STe/TT'#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+ 'A*2Tlinux_Linux'#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*2Tlinux_Linux on PowerPC'#010+ 'P*2Tmacos_Mac OS (classic) on PowerPC'#010+ - 'P*2Tmorphos','_MorphOS'#010+ + 'P*2Tmorpho','s_MorphOS'#010+ 'S*2Tlinux_Linux'#010+ '**1u_Undefines the symbol '#010+ '**1U_Unit options:'#010+ '**2Un_Do not check where the unit name matches the file name'#010+ '**2Ur_Generate release unit files (never automatically recompiled)'#010+ '**2Us_Compile a system unit'#010+ - '**1v','_Be verbose. is a combination of the following letters:'#010+ + '**1v_Be verbose. is a combination of the following letters:'#010+ '**2*_e : Show errors (default) 0 : Show nothing (except errors)'#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*_i : Show general info d : Show debug info'#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+ '**2*_b : Write file names messages with full path'#010+ '**2*_v : Write fpcdebug.txt with p : Write tree.log with parse tre'+ 'e'#010+ - '**2*_ lots of debugging info'#010+ + '**2*_ lots of debugging info q : Show message numbers'#010+ + '**2*_m, : Don'#039't show mes','sages numbered and '#010+ '3*1W_Target-specific options (targets)'#010+ - 'A*1W_Target-spec','ific options (targets)'#010+ + 'A*1W_Target-specific options (targets)'#010+ 'P*1W_Target-specific options (targets)'#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+ - '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+ '3*2WC_Specify console type application (EMX, OS/2, Windows)'#010+ - 'A*2WC_Specify console type application (Windows)'#010+ - 'P*2WC_Specify console type application (Classic Mac OS)',#010+ + 'A*2WC_Specify co','nsole type application (Windows)'#010+ + 'P*2WC_Specify console type application (Classic Mac OS)'#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+ - '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+ - '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+ - '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+ - '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+ - '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+ - '3*2WR_G','enerate relocation code (Windows)'#010+ + '3*2WR_Generate relocation code (Windows)'#010+ 'A*2WR_Generate relocation code (Windows)'#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'+ 'ux)'#010+ - '**2Xd_Do ','not use standard library search path (needed for cross comp'+ - 'ile)'#010+ + '**2Xd_Do not use standard library search path (needed for cross compil'+ + 'e)'#010+ '**2Xe_Use external linker'#010+ - '**2Xg_Create debuginfo in a separate file and add a debuglink section '+ - 'to executable'#010+ - '**2XD_Try to link units dynamically (defines FPC_LINK_DYNAMIC',')'#010+ + '**2Xg_Create debuginfo in a separate file and add a debuglink ','sectio'+ + 'n to executable'#010+ + '**2XD_Try to link units dynamically (defines FPC_LINK_DYNAMIC)'#010+ '**2Xi_Use internal linker'#010+ '**2Xm_Generate link map'#010+ '**2XM_Set the name of the '#039'main'#039' program routine (default i'+ 's '#039'main'#039')'#010+ - '**2XP_Prepend the binutils names with the prefix '#010+ - '**2Xr_Set library search path to (needed for cross co','mpile) ('+ - 'BeOS, Linux)'#010+ + '**2XP_Prepend the binutil','s names with the prefix '#010+ + '**2Xr_Set library search path to (needed for cross compile) (Be'+ + 'OS, Linux)'#010+ '**2XR_Prepend to all linker search paths (BeOS, Darwin, FreeBSD'+ ', 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+ - '**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+ '**1*_'#010+ '**1?_Show this help'#010+ - '**1h_Shows this help without waiting'#000 + '**1h_Shows',' this help without waiting'#000 ); diff --git a/compiler/verbose.pas b/compiler/verbose.pas index b7f6e96ba4..16f5c96564 100644 --- a/compiler/verbose.pas +++ b/compiler/verbose.pas @@ -120,7 +120,6 @@ implementation uses comphook,fmodule,constexp,globals; - {**************************************************************************** Extra Handlers for default compiler ****************************************************************************} @@ -178,6 +177,31 @@ implementation 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; begin result:=do_checkverbosity(v); @@ -214,6 +238,7 @@ implementation { handle switch } case c of { Special cases } + '0' : status.verbosity:=V_Default; 'A' : status.verbosity:=V_All; 'B' : begin if inverse then @@ -221,13 +246,24 @@ implementation else status.print_source_path:=true; end; - '0' : status.verbosity:=V_Default; + 'M' : if inverse or + not ClearMessageVerbosity(s, i) then + begin + result:=false; + exit + end; 'P' : begin if inverse then paraprintnodetree:=0 else paraprintnodetree:=1; end; + 'Q' : begin + if inverse then + status.showmsgnrs:=false + else + status.showmsgnrs:=true; + end; 'R' : begin if inverse then begin @@ -240,6 +276,7 @@ implementation status.use_stderr:=true; end; end; + 'V' : PrepareReport; 'Z' : begin if inverse then status.use_stderr:=false @@ -247,38 +284,6 @@ implementation status.use_stderr:=true; end; { 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 status.verbosity:=status.verbosity and (not V_Conditional) else @@ -287,15 +292,46 @@ implementation status.verbosity:=status.verbosity and (not V_Debug) else status.verbosity:=status.verbosity or V_Debug; - 'X' : if inverse then - status.verbosity:=status.verbosity and (not V_Executable) + 'E' : if inverse then + status.verbosity:=status.verbosity and (not V_Error) 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 status.verbosity:=status.verbosity and (not V_TimeStamps) else 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; inc(i); end; @@ -520,7 +556,7 @@ implementation {Parse options} idx:=pos('_',s); if idx=0 then - v:=V_Normal + v:=V_None else if (idx >= 1) And (idx <= 5) then begin @@ -587,31 +623,33 @@ implementation Delete(s,1,idx); { check verbosity level } if not CheckVerbosity(v) then - begin - doqueue := onqueue <> nil; - if not doqueue then - exit; - end; + begin + doqueue := onqueue <> nil; + if not doqueue then + exit; + end; if (v and V_LineInfoMask)<>0 then v:=v or V_LineInfo; { fix status } UpdateStatus; { Fix replacements } DefaultReplacements(s); + if status.showmsgnrs then + s:='('+tostr(w)+') '+s; if doqueue then - begin - onqueue(s,v,w); - exit; - end; + begin + onqueue(s,v,w); + exit; + end; { show comment } if do_comment(v,s) or dostop then raise ECompilerAbort.Create; if (status.errorcount>=status.maxerrorcount) and not status.skip_error then - begin - Message1(unit_f_errors_in_unit,tostr(status.errorcount)); - status.skip_error:=true; - raise ECompilerAbort.Create; - end; + begin + Message1(unit_f_errors_in_unit,tostr(status.errorcount)); + status.skip_error:=true; + raise ECompilerAbort.Create; + end; end; @@ -820,16 +858,16 @@ implementation end; -procedure FlushOutput; -begin - if not (Status.Use_StdErr) then (* StdErr is flushed after every line *) - begin - if Status.Use_Redir then - Flush(Status.RedirFile) - else - Flush(Output); - end; -end; + procedure FlushOutput; + begin + if not (Status.Use_StdErr) then (* StdErr is flushed after every line *) + begin + if Status.Use_Redir then + Flush(Status.RedirFile) + else + Flush(Output); + end; + end; {***************************************************************************** diff --git a/tests/test/tmsg1.pp b/tests/test/tmsg1.pp new file mode 100644 index 0000000000..192eff3680 --- /dev/null +++ b/tests/test/tmsg1.pp @@ -0,0 +1,7 @@ +{ %fail } +{ %opt=-vm20999999 } + +{ illegal message number } + +begin +end. diff --git a/tests/test/tmsg2.pp b/tests/test/tmsg2.pp new file mode 100644 index 0000000000..111de82963 --- /dev/null +++ b/tests/test/tmsg2.pp @@ -0,0 +1,7 @@ +{ %fail } +{ %opt=-vm123 } + +{ non-existent message } + +begin +end. diff --git a/tests/test/tmsg3.pp b/tests/test/tmsg3.pp new file mode 100644 index 0000000000..6af484ca78 --- /dev/null +++ b/tests/test/tmsg3.pp @@ -0,0 +1,7 @@ +{ %fail } +{ %opt=-vm5024,a,05027 } + +{ invalid characted amidst message numbers } + +begin +end. diff --git a/tests/test/tmsg4.pp b/tests/test/tmsg4.pp new file mode 100644 index 0000000000..f651ad1502 --- /dev/null +++ b/tests/test/tmsg4.pp @@ -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.