* bugs 494-496 fixed

This commit is contained in:
florian 1999-07-26 09:41:59 +00:00
parent 49f7b705a6
commit 9cbaac5beb
9 changed files with 171 additions and 137 deletions

View File

@ -690,13 +690,19 @@ do_jmp:
var
finallylabel,noreraiselabel : pasmlabel;
oldaktexitlabel : pasmlabel;
oldaktexit2label : pasmlabel;
begin
{ we modify EAX }
usedinproc:=usedinproc or ($80 shr byte(R_EAX));
getlabel(finallylabel);
getlabel(noreraiselabel);
oldaktexitlabel:=aktexitlabel;
oldaktexit2label:=aktexit2label;
aktexitlabel:=finallylabel;
aktexit2label:=finallylabel;
push_int(1); { Type of stack-frame must be pushed}
emitcall('FPC_PUSHEXCEPTADDR');
exprasmlist^.concat(new(pai386,
@ -727,6 +733,8 @@ do_jmp:
emitcall('FPC_RERAISE');
emitlab(noreraiselabel);
emitcall('FPC_POPADDRSTACK');
aktexitlabel:=oldaktexitlabel;
aktexit2label:=oldaktexit2label;
end;
@ -752,7 +760,10 @@ do_jmp:
end.
{
$Log$
Revision 1.41 1999-07-05 20:13:09 peter
Revision 1.42 1999-07-26 09:41:59 florian
* bugs 494-496 fixed
Revision 1.41 1999/07/05 20:13:09 peter
* removed temp defines
Revision 1.40 1999/06/14 00:43:35 peter

View File

@ -60,7 +60,7 @@ unit cresstr;
begin
hash:=0;
For I:=0 to Len-1 do // 0 terminated
For I:=0 to Len-1 do { 0 terminated }
begin
hash:=hash shl 4;
inc(Hash,Ord(p[i]));
@ -228,7 +228,10 @@ unit cresstr;
end.
{
$Log$
Revision 1.6 1999-07-25 19:27:15 michael
Revision 1.7 1999-07-26 09:42:00 florian
* bugs 494-496 fixed
Revision 1.6 1999/07/25 19:27:15 michael
+ Fixed hash computing, now compatible with gnu .mo file
Revision 1.5 1999/07/24 18:35:41 michael

View File

@ -764,6 +764,9 @@ parser_e_cant_use_inittable_here=E_Data types which requires initialization/fina
% code which is implicitly generated by the compiler. Such data types
% can't be used in the variant part of a record.
parser_e_resourcestring_only_sg=E_Resourcestrings can be only static or global
parser_e_exit_with_argument_not__possible=E_Exit with argument can't be used here
% an exit statement with an argument for the return value can't be used here, this
% can happen e.g. in \var{try..except} or \var{try..finally} blocks
% \end{description}
#
# Type Checking

View File

@ -204,6 +204,7 @@ type tmsgconst=(
parser_e_no_object_override,
parser_e_cant_use_inittable_here,
parser_e_resourcestring_only_sg,
parser_e_exit_with_argument_not__possible,
type_e_mismatch,
type_e_incompatible_types,
type_e_not_equal_types,

View File

@ -217,225 +217,226 @@ const msgtxt : array[0..000098,1..240] of char=(
'E_Data types which requires initialization/finalization can'#039't be u'+
'sed in variant records'#000+
'E_Resourcestrings can be only static or global'#000+
'E_Type mismatch'#000+
'E_Incompatible types: got "$1','" expected "$2"'#000+
'E_Exit with argument can'#039't be used here'#000+
'E_Typ','e mismatch'#000+
'E_Incompatible types: got "$1" expected "$2"'#000+
'E_Type mismatch between $1 and $2'#000+
'E_Integer expression expected'#000+
'E_Ordinal expression expected'#000+
'E_Type identifier expected'#000+
'E_Variable identifier expected'#000+
'E_pointer type expected'#000+
'E_class type expected'#000+
'E_Variable or type indenti','fier expected'#000+
'E_class ','type expected'#000+
'E_Variable or type indentifier expected'#000+
'E_Can'#039't evaluate constant expression'#000+
'E_Set elements are not compatible'#000+
'E_Operation not implemented for sets'#000+
'W_Automatic type conversion from floating type to COMP which is an int'+
'eger type'#000+
'H_use DIV instead to get an integer re','sult'#000+
'eger typ','e'#000+
'H_use DIV instead to get an integer result'#000+
'E_string types doesn'#039't match, because of $V+ mode'#000+
'E_succ or pred on enums with assignments not possible'#000+
'E_Can'#039't read or write variables of this type'#000+
'E_Type conflict between set elements'#000+
'W_lo/hi(dword/qword) returns the upper/lower word','/dword'#000+
'W_lo/hi(d','word/qword) returns the upper/lower word/dword'#000+
'E_Integer or real expression expected'#000+
'E_Wrong type in array constructor'#000+
'E_Incompatible type for arg no. $1: Got $2, expected $3'#000+
'E_Method (variable) and Procedure (variable) are not compatible'#000+
'E_Illegal constant passed to internal mat','h function'#000+
'E','_Illegal constant passed to internal math function'#000+
'E_Can'#039't get the address of constants'#000+
'E_Argument must be l-value'#000+
'E_Identifier not found $1'#000+
'F_Internal Error in SymTableStack()'#000+
'E_Duplicate identifier $1'#000+
'H_Identifier already defined in $1 at line $2'#000+
'H_Identifier already defined in $1 at',' line $2'#000+
'E_Unknown identifier $1'#000+
'E_Forwa','rd declaration not solved $1'#000+
'E_Forward declaration not solved $1'#000+
'F_Identifier type already defined as type'#000+
'E_Error in type definition'#000+
'E_Type identifier not defined'#000+
'E_Forward type not resolved $1'#000+
'E_Only static variables can be used in static methods or outside metho'+
'ds'#000+
'E_Invali','d call to tvarsym.mangledname()'#000+
'E_Only static variables can be used in st','atic methods or outside met'+
'hods'#000+
'E_Invalid call to tvarsym.mangledname()'#000+
'F_record or class type expected'#000+
'E_Instances of classes or objects with an abstract method are not allo'+
'wed'#000+
'W_Label not defined $1'#000+
'E_Illegal label declaration'#000+
'E_GOTO and LABEL are not supported (use switch -Sg)',#000+
'E_GOTO and ','LABEL are not supported (use switch -Sg)'#000+
'E_Label not found'#000+
'E_identifier isn'#039't a label'#000+
'E_label already defined'#000+
'E_illegal type declaration of set elements'#000+
'E_Forward class definition not resolved $1'#000+
'H_Parameter not used $1'#000+
'N_Local variable not used $1'#000+
'N_Local variable not',' used $1'#000+
'E_Set type expected'#000+
'W_Function ','result does not seem to be set'#000+
'W_Function result does not seem to be set'#000+
'E_Unknown record field identifier $1'#000+
'W_Local variable $1 does not seem to be initialized'#000+
'W_Variable $1 does not seem to be initialized'#000+
'E_identifier idents no member $1'#000+
'B_Found declaration: $1'#000+
'E_BREAK not allow','ed'#000+
'B','_Found declaration: $1'#000+
'E_BREAK not allowed'#000+
'E_CONTINUE not allowed'#000+
'E_Expression too complicated - FPU stack overflow'#000+
'E_Illegal expression'#000+
'E_Invalid integer expression'#000+
'E_Illegal qualifier'#000+
'E_High range limit < low range limit'#000+
'E_Illegal counter variable'#000+
'E_Can'#039't determine which overlo','aded function to call'#000+
'E_Illegal counter',' variable'#000+
'E_Can'#039't determine which overloaded function to call'#000+
'E_Parameter list size exceeds 65535 bytes'#000+
'E_Illegal type conversion'#000+
'D_Conversion between ordinals and pointers is not portable across plat'+
'forms'#000+
'E_File types must be var parameters'#000+
'E_The use of a far pointer isn'#039't allow','ed there'#000+
'E_File types must be var parameter','s'#000+
'E_The use of a far pointer isn'#039't allowed there'#000+
'E_illegal call by reference parameters'#000+
'E_EXPORT declared functions can'#039't be called'#000+
'W_Possible illegal call of constructor or destructor (doesn'#039't matc'+
'h to this context)'#000+
'N_Inefficient code'#000+
'W_unreachable code'#000+
'E_procedure call with sta','ckframe ESP/SP'#000+
'W_un','reachable code'#000+
'E_procedure call with stackframe ESP/SP'#000+
'E_Abstract methods can'#039't be called directly'#000+
'F_Internal Error in getfloatreg(), allocation failure'#000+
'F_Unknown float type'#000+
'F_SecondVecn() base defined twice'#000+
'F_Extended cg68k not supported'#000+
'F_32-bit unsigned not supported in MC6800','0 mode'#000+
'F','_32-bit unsigned not supported in MC68000 mode'#000+
'F_Internal Error in secondinline()'#000+
'D_Register $1 weight $2 $3'#000+
'E_Stack limit excedeed in local routine'#000+
'D_Stack frame is omitted'#000+
'E_Object or class methods can'#039't be inline.'#000+
'E_Procvar calls can'#039't be inline.'#000+
'E_No code for inline procedure',' stored'#000+
'E_Procvar calls can'#039't b','e inline.'#000+
'E_No code for inline procedure stored'#000+
'E_Element zero of an ansi/wide- or longstring can'#039't be accessed, u'+
'se (set)length instead'#000+
'E_Include and exclude not implemented in this case'#000+
'E_Constructors or destructors can not be called inside a '#039'with'#039+
'E_Constructors or destructors can not be called insi','de a '#039'with'#039+
' clause'#000+
'E_Cannot call message',' handler method directly'#000+
'E_Cannot call message handler method directly'#000+
'D_Starting $1 styled assembler parsing'#000+
'D_Finished $1 styled assembler parsing'#000+
'E_Non-label pattern contains @'#000+
'W_Override operator not supported'#000+
'E_Error building record offset'#000+
'E_OFFSET used without identifier'#000+
'E_Cannot',' use local variable or parameters here'#000+
'E','_OFFSET used without identifier'#000+
'E_Cannot use local variable or parameters here'#000+
'E_need to use OFFSET here'#000+
'E_Cannot use multiple relocatable symbols'#000+
'E_Relocatable symbol can only be added'#000+
'E_Invalid constant expression'#000+
'E_Relocatable symbol is not allowed'#000+
'E_Relocatable symbol is ','not allowed'#000+
'E_Invalid reference syntax'#000+
'E','_Local symbols not allowed as references'#000+
'E_Local symbols not allowed as references'#000+
'E_Invalid base and index register usage'#000+
'E_Wrong scale factor specified'#000+
'E_Multiple index register usage'#000+
'E_Invalid operand type'#000+
'E_Invalid string as opcode operand: $1'#000+
'E_Invalid string as opcode operan','d: $1'#000+
'W_@CODE and @DATA not supported'#000+
'E_','Null label references are not allowed'#000+
'E_Null label references are not allowed'#000+
'F_Divide by zero in asm evaluator'#000+
'F_Evaluator stack overflow'#000+
'F_Evaluator stack underflow'#000+
'F_Invalid numeric format in asm evaluator'#000+
'F_Invalid Operator in asm evaluator'#000+
'F_Invalid Operator in asm evalu','ator'#000+
'E_escape sequence ignored: $1'#000+
'E_Inv','alid symbol reference'#000+
'E_Invalid symbol reference'#000+
'W_Fwait can cause emulation problems with emu387'#000+
'W_Calling an overload function in assembler'#000+
'E_Unsupported symbol type for operand'#000+
'E_Constant value out of bounds'#000+
'E_Error converting decimal $1'#000+
'E_Error converting octal $','1'#000+
'E_Error converti','ng decimal $1'#000+
'E_Error converting octal $1'#000+
'E_Error converting binary $1'#000+
'E_Error converting hexadecimal $1'#000+
'H_$1 translated to $2'#000+
'W_$1 is associated to an overloaded function'#000+
'E_Cannot use SELF outside a method'#000+
'E_Cannot use OLDEBP outside a nested procedure'#000+
'W_Functions with void retu','rn value can'#039't return any value in asm'+
' code'#000+
'E_Cannot use OLDEBP outside a nes','ted procedure'#000+
'W_Functions with void return value can'#039't return any value in asm c'+
'ode'#000+
'E_SEG not supported'#000+
'E_Size suffix and destination or source size do not match'#000+
'W_Size suffix and destination or source size do not match'#000+
'E_Assembler syntax error'#000+
'E_Invalid combination of opcode and',' operands'#000+
'E_Assembler syntax e','rror'#000+
'E_Invalid combination of opcode and operands'#000+
'E_Assemler syntax error in operand'#000+
'E_Assemler syntax error in constant'#000+
'E_Invalid String expression'#000+
'32bit constant created for address'#000+
'E_Invalid or missing opcode'#000+
'E_Invalid combination of prefix and opcode: $1'#000+
'E_Invalid combination',' of override and opcode: $1'#000+
'E_Invalid combination of pre','fix and opcode: $1'#000+
'E_Invalid combination of override and opcode: $1'#000+
'E_Too many operands on line'#000+
'W_NEAR ignored'#000+
'W_FAR ignored'#000+
'E_Duplicate local symbol $1'#000+
'E_Undefined local symbol $1'#000+
'E_Unknown label identifier $1'#000+
'E_Invalid floating point register name'#000+
'E_Invalid floating point regi','ster name'#000+
'E_NOR not supported'#000+
'W_Modulo n','ot supported'#000+
'W_Modulo not supported'#000+
'E_Invalid floating point constant $1'#000+
'E_Invalid floating point expression'#000+
'E_Wrong symbol type'#000+
'E_Cannot index a local var or parameter with a register'#000+
'E_Invalid segment override expression'#000+
'E_Invalid segment override expression'#000,
'W_Identifier $1 supposed external'#000+
'E_Stri','ngs not allowed as constants'#000+
'E_Strings not allowed as constants'#000+
'No type of variable specified'#000+
'E_assembler code not returned to text section'#000+
'E_Not a directive or local symbol $1'#000+
'E_Using a defined name as a local label'#000+
'F_Too many assembler files'#000+
'F_Selected assembler output not',' supported'#000+
'F_Too many assembl','er files'#000+
'F_Selected assembler output not supported'#000+
'F_Comp not supported'#000+
'F_Direct not support for binary writers'#000+
'E_Allocating of data is only allowed in bss section'#000+
'F_No binary writer selected'#000+
'E_Asm: Opcode $1 not in table'#000+
'E_Asm: $1 invalid combination of opcode and operands'#000+
'E_Asm',': 16 Bit references not supported'#000+
'E_Asm: $1 invalid ','combination of opcode and operands'#000+
'E_Asm: 16 Bit references not supported'#000+
'E_Asm: Invalid effective address'#000+
'E_Asm: Immediate or reference expected'#000+
'E_Asm: $1 value exceeds bounds $2'#000+
'E_Asm: Short jump is out of range $1'#000+
'W_Source operating system redefined'#000+
'W_Source operating syst','em redefined'#000+
'I_Assembling (pipe) $1'#000+
'E_Ca','n'#039't create assember file $1'#000+
'E_Can'#039't create assember file $1'#000+
'W_Assembler $1 not found, switching to external assembling'#000+
'T_Using assembler: $1'#000+
'W_Error while assembling exitcode $1'#000+
'W_Can'#039't call the assembler, error $1 switching to external assembl'+
'ing'#000+
'W_Can'#039't call the assembler, error $1 switching to exte','rnal assem'+
'bling'#000+
'I_Assembling $1'#000+
'I_Assemb','ling smartlink $1'#000+
'I_Assembling smartlink $1'#000+
'W_Linker $1 not found, switching to external linking'#000+
'T_Using linker: $1'#000+
'W_Object $1 not found, Linking may fail !'#000+
'W_Library $1 not found, Linking may fail !'#000+
'W_Error while linking'#000+
'W_Can'#039't call the linker, switching to exter','nal linking'#000+
'W_C','an'#039't call the linker, switching to external linking'#000+
'I_Linking $1'#000+
'W_binder not found, switching to external binding'#000+
'W_ar not found, switching to external ar'#000+
'E_Dynamic Libraries not supported'#000+
'I_Closing script $1'#000+
'W_resource compiler not found, switching to external mode'#000+
'I_Compiling ','resource $1'#000+
'W_resource compiler not found,',' switching to external mode'#000+
'I_Compiling resource $1'#000+
'F_Can'#039't post process executable $1'#000+
'F_Can'#039't open executable $1'#000+
'X_Size of Code: $1 bytes'#000+
'X_Size of initialized data: $1 bytes'#000+
'X_Size of uninitialized data: $1 bytes'#000+
'X_Stack space reserved: $1 bytes'#000+
'X_Stack space commited: $1 bytes',#000+
'X_Stack space reserved: $','1 bytes'#000+
'X_Stack space commited: $1 bytes'#000+
'T_Unitsearch: $1'#000+
'T_PPU Loading $1'#000+
'U_PPU Name: $1'#000+
@ -445,8 +446,8 @@ const msgtxt : array[0..000098,1..240] of char=(
'U_PPU File too short'#000+
'U_PPU Invalid Header (no PPU at the begin)'#000+
'U_PPU Invalid Version $1'#000+
'U_PPU is compiled for an other processor'#000+
'U_PPU is compil','ed for an other target'#000+
'U_PPU is compile','d for an other processor'#000+
'U_PPU is compiled for an other target'#000+
'U_PPU Source: $1'#000+
'U_Writing $1'#000+
'F_Can'#039't Write PPU-File'#000+
@ -454,75 +455,75 @@ const msgtxt : array[0..000098,1..240] of char=(
'F_unexpected end of PPU-File'#000+
'F_Invalid PPU-File entry: $1'#000+
'F_PPU Dbx count problem'#000+
'E_Illegal unit name: $1'#000+
'E_Illegal unit name: $1',#000+
'F_Too much units'#000+
'F_Circular unit refere','nce between $1 and $2'#000+
'F_Circular unit reference between $1 and $2'#000+
'F_Can'#039't compile unit $1, no sources available'#000+
'F_Can'#039't find unit $1'#000+
'W_Compiling the system unit requires the -Us switch'#000+
'F_There were $1 errors compiling module, stopping'#000+
'U_Load from $1 ($2) unit $3'#000+
'U_Recompiling $1, che','cksum changed for $2'#000+
'U_Load fr','om $1 ($2) unit $3'#000+
'U_Recompiling $1, checksum changed for $2'#000+
'U_Recompiling $1, source found only'#000+
'U_Recompiling unit, static lib is older than ppufile'#000+
'U_Recompiling unit, shared lib is older than ppufile'#000+
'U_Recompiling unit, obj and asm are older than ppufile'#000+
'U_Recompiling unit, ob','j is older than asm'#000+
'U_Recompiling unit, obj and asm are o','lder than ppufile'#000+
'U_Recompiling unit, obj is older than asm'#000+
'U_Parsing interface of $1'#000+
'U_Parsing implementation of $1'#000+
'U_Second load for unit $1'#000+
'U_PPU Check file $1 time $2'#000+
'$1 [options] <inputfile> [options]'#000+
'W_Only one source file supported'#000+
'W_DEF file can be created only for OS/2'#000+
'E','_nested response files are not supported'#000+
'W','_DEF file can be created only for OS/2'#000+
'E_nested response files are not supported'#000+
'F_No source file name in command line'#000+
'E_Illegal parameter: $1'#000+
'H_-? writes help pages'#000+
'F_Too many config files nested'#000+
'F_Unable to open file $1'#000+
'N_Reading further options from $1'#000+
'W_Target is already set ','to: $1'#000+
'N_Reading further ','options from $1'#000+
'W_Target is already set to: $1'#000+
'W_Shared libs not supported on DOS platform, reverting to static'#000+
'F_too many IF(N)DEFs'#000+
'F_too many ENDIFs'#000+
'F_open conditional at the end of the file'#000+
'W_Debug information generation is not supported by this executable'#000+
'H_Try recompiling wi','th -dGDB'#000+
'W_Debug information generation is not supported',' by this executable'#000+
'H_Try recompiling with -dGDB'#000+
'E_You are using the obsolete switch $1'#000+
'E_You are using the obsolete switch $1, please use $2'#000+
'N_Switching assembler to default source writing assembler'#000+
'Free Pascal Compiler version $FPCVER [$FPCDATE] for $FPCTARGET'#000+
'Copyright (c) 199','3-98 by Florian Klaempfl'#000+
'Free Pascal Compiler version $FPCVER [$F','PCDATE] for $FPCTARGET'#000+
'Copyright (c) 1993-98 by Florian Klaempfl'#000+
'Free Pascal Compiler version $FPCVER'#000+
#000+
'Compiler Date : $FPCDATE'#000+
'Compiler Target: $FPCTARGET'#000+
#000+
'This program comes under the GNU General Public Licence'#000+
'For more information read COPYING.FPC'#000+
'For more information read ','COPYING.FPC'#000+
#000+
'Report bugs,suggestions etc',' to:'#000+
'Report bugs,suggestions etc to:'#000+
' fpc-devel@vekoll.saturnus.vein.hu'#000+
'**0*_put + after a boolean switch option to enable it, - to disable it'+
#000+
'**1a_the compiler doesn'#039't delete the generated assembler file'#000+
'**2al_list sourcecode lines in assembler file'#000+
'**2ar','_list register allocation/release info in assembler file'#000+
'**2al_list ','sourcecode lines in assembler file'#000+
'**2ar_list register allocation/release info in assembler file'#000+
'**2at_list temp allocation/release info in assembler file'#000+
'**1b_generate browser info'#000+
'**2bl_generate local symbol info'#000+
'**1B_build all modules'#000+
'**1C<x>_code generation options:'#000+
'3*2CD_cre','ate dynamic library'#000+
'**','1C<x>_code generation options:'#000+
'3*2CD_create dynamic library'#000+
'**2Ch<n>_<n> bytes heap (between 1023 and 67107840)'#000+
'**2Ci_IO-checking'#000+
'**2Cn_omit linking stage'#000+
'**2Co_check overflow of integer operations'#000+
'**2Cr_range checking'#000+
'**2Cs<n>_set stack size to <n>'#000+
'**2Cs<n>_set stack si','ze to <n>'#000+
'**2Ct_stack checking'#000+
'3*2CS_cre','ate static library'#000+
'3*2CS_create static library'#000+
'3*2Cx_use smartlinking'#000+
'**1d<x>_defines the symbol <x>'#000+
'*O1D_generate a DEF file'#000+
@ -530,120 +531,120 @@ const msgtxt : array[0..000098,1..240] of char=(
'*O2Dw_PM application'#000+
'**1e<x>_set path to executable'#000+
'**1E_same as -Cn'#000+
'**1F<x>_set file names and paths:'#000+
'**2FD<x','>_sets the directory where to search for compiler utilities'#000+
'*','*1F<x>_set file names and paths:'#000+
'**2FD<x>_sets the directory where to search for compiler utilities'#000+
'**2Fe<x>_redirect error output to <x>'#000+
'**2FE<x>_set exe/unit output path to <x>'#000+
'**2Fi<x>_adds <x> to include path'#000+
'**2Fl<x>_adds <x> to library path'#000+
'*L2FL<x>_uses <x> as dynamic link','er'#000+
'**2Fl<x>_adds <x> to librar','y path'#000+
'*L2FL<x>_uses <x> as dynamic linker'#000+
'**2Fo<x>_adds <x> to object path'#000+
'**2Fr<x>_load error message file <x>'#000+
'**2Fu<x>_adds <x> to unit path'#000+
'**2FU<x>_set unit output path to <x>, overrides -FE'#000+
'*g1g<x>_generate debugger information:'#000+
'*g2gg_use gsym'#000+
'*g2gg','_use gsym'#000+
'*g2gd_use dbx'#000+
'*g2gh_use heap t','race unit'#000+
'*g2gh_use heap trace unit'#000+
'*g2gc_generate checks for pointers'#000+
'**1i_information'#000+
'**2iD_return compiler date'#000+
'**2iV_return compiler version'#000+
'**2iSO_return compiler OS'#000+
'**2iSP_return compiler processor'#000+
'**2iTO_return target OS'#000+
'**2iTO_return target O','S'#000+
'**2iTP_return target processor'#000+
'**1I<x>','_adds <x> to include path'#000+
'**1I<x>_adds <x> to include path'#000+
'**1k<x>_Pass <x> to the linker'#000+
'**1l_write logo'#000+
'**1n_don'#039't read the default config file'#000+
'**1o<x>_change the name of the executable produced to <x>'#000+
'**1pg_generate profile code for gprof'#000+
'*L1P_use pipes instead of creat','ing temporary assembler files'#000+
'**1pg_generate profile code f','or gprof'#000+
'*L1P_use pipes instead of creating temporary assembler files'#000+
'**1S<x>_syntax options:'#000+
'**2S2_switch some Delphi 2 extensions on'#000+
'**2Sc_supports operators like C (*=,+=,/= and -=)'#000+
'**2Sd_tries to be Delphi compatible'#000+
'**2Se<x>_compiler stops after the <x> errors (default is 1)',#000+
'**2Se<x>_compiler s','tops after the <x> errors (default is 1)'#000+
'**2Sg_allow LABEL and GOTO'#000+
'**2Sh_Use ansistrings'#000+
'**2Si_support C++ styled INLINE'#000+
'**2Sm_support macros like C (global)'#000+
'**2So_tries to be TP/BP 7.0 compatible'#000+
'**2Sp_tries to be gpc compatible'#000+
'**2Ss_constructor name must be init (destructor m','ust be done)'#000+
'**2Ss_con','structor name must be init (destructor must be done)'#000+
'**2St_allow static keyword in objects'#000+
'**1s_don'#039't call assembler and linker (only with -a)'#000+
'**1u<x>_undefines the symbol <x>'#000+
'**1U_unit options:'#000+
'**2Un_don'#039't check the unit name'#000+
'**2Us_compile a system unit'#000+
'**1v<x>_Be verbose. <x> i','s a combination of the following letters:'#000+
'**2Us_compile',' a system unit'#000+
'**1v<x>_Be verbose. <x> is a combination of the following letters:'#000+
'**2*_e : Show errors (default) d : Show debug info'#000+
'**2*_w : Show warnings u : Show unit info'#000+
'**2*_n : Show notes t : Show tried/used files'#000+
'**2*_h : Show hints ',' m : Show defined macros'#000+
'**2*_n : Show notes t : Show',' tried/used files'#000+
'**2*_h : Show hints m : Show defined macros'#000+
'**2*_i : Show general info p : Show compiled procedures'#000+
'**2*_l : Show linenumbers c : Show conditionals'#000+
'**2*_a : Show everything 0 : Show nothing (except errors)'#000+
'**2*_b',' : Show all procedure r : Rhide/GCC compatibility mod'+
'e'#000+
'**2*_a : Show everything ',' 0 : Show nothing (except errors'+
')'#000+
'**2*_b : Show all procedure r : Rhide/GCC compatibility mode'#000+
'**2*_ declarations if an error x : Executable info (Win32 only)'#000+
'**2*_ occurs'#000+
'**1X_executable options:'#000+
'*L2Xc_link with the c library'#000+
'**2XD_link with dynamic libraries (','defines FPC_LINK_DYNAMIC)'#000+
'*L2Xc_link with the c lib','rary'#000+
'**2XD_link with dynamic libraries (defines FPC_LINK_DYNAMIC)'#000+
'**2Xs_strip all symbols from executable'#000+
'**2XS_link with static libraries (defines FPC_LINK_STATIC)'#000+
'**0*_Processor specific options:'#000+
'3*1A<x>_output format:'#000+
'3*2Aas_assemble using GNU AS'#000+
'3*2Aasaout_assemble using GNU ','AS for aout (Go32v1)'#000+
'3*2Aas_assemble usi','ng GNU AS'#000+
'3*2Aasaout_assemble using GNU AS for aout (Go32v1)'#000+
'3*2Anasmcoff_coff (Go32v2) file using Nasm'#000+
'3*2Anasmelf_elf32 (Linux) file using Nasm'#000+
'3*2Anasmobj_obj file using Nasm'#000+
'3*2Amasm_obj file using Masm (Microsoft)'#000+
'3*2Atasm_obj file using Tasm (Borland)'#000+
'3*2Acoff_coff (Go32v2)',' using internal writer'#000+
'3*2Atasm_obj file usi','ng Tasm (Borland)'#000+
'3*2Acoff_coff (Go32v2) using internal writer'#000+
'3*2Apecoff_pecoff (Win32) using internal writer'#000+
'3*1R<x>_assembler reading style:'#000+
'3*2Ratt_read AT&T style assembler'#000+
'3*2Rintel_read Intel style assembler'#000+
'3*2Rdirect_copy assembler text directly to assembler file'#000+
'3*1O<x>','_optimizations:'#000+
'3*2Rdirect_copy assembler',' text directly to assembler file'#000+
'3*1O<x>_optimizations:'#000+
'3*2Og_generate smaller code'#000+
'3*2OG_generate faster code (default)'#000+
'3*2Or_keep certain variables in registers (still BUGGY!!!)'#000+
'3*2Ou_enable uncertain optimizations (see docs)'#000+
'3*2O1_level 1 optimizations (quick optimizations)'#000+
'3*','2O2_level 2 optimizations (-O1 + slower optimizations)'#000+
'3*2O1_level ','1 optimizations (quick optimizations)'#000+
'3*2O2_level 2 optimizations (-O1 + slower optimizations)'#000+
'3*2O3_level 3 optimizations (same as -O2u)'#000+
'3*2Op<x>_target processor:'#000+
'3*3Op1_set target processor to 386/486'#000+
'3*3Op2_set target processor to Pentium/PentiumMMX (tm)'#000+
'3*3Op3_set target pro','cessor to PPro/PII/c6x86/K6 (tm)'#000+
'3*3Op2_set target processor to Penti','um/PentiumMMX (tm)'#000+
'3*3Op3_set target processor to PPro/PII/c6x86/K6 (tm)'#000+
'3*1T<x>_Target operating system:'#000+
'3*2TGO32V1_version 1 of DJ Delorie DOS extender'#000+
'3*2TGO32V2_version 2 of DJ Delorie DOS extender'#000+
'3*2TLINUX_Linux'#000+
'3*2TOS2_OS/2 2.x'#000+
'3*2TWin32_Windows 32 Bit'#000+
'6*1A<x>_output forma','t'#000+
'3*2TW','in32_Windows 32 Bit'#000+
'6*1A<x>_output format'#000+
'6*2Aas_Unix o-file using GNU AS'#000+
'6*2Agas_GNU Motorola assembler'#000+
'6*2Amit_MIT Syntax (old GAS)'#000+
'6*2Amot_Standard Motorola assembler'#000+
'6*1O_optimizations:'#000+
'6*2Oa_turn on the optimizer'#000+
'6*2Og_generate smaller code'#000+
'6*2OG_generate faster code (defaul','t)'#000+
'6*2Og_generate smaller',' code'#000+
'6*2OG_generate faster code (default)'#000+
'6*2Ox_optimize maximum (still BUGGY!!!)'#000+
'6*2O2_set target processor to a MC68020+'#000+
'6*1R<x>_assembler reading style:'#000+
'6*2RMOT_read motorola style assembler'#000+
'6*1T<x>_Target operating system:'#000+
'6*2TAMIGA_Commodore Amiga'#000+
'6*2TATARI_Atari ST/STe/TT'#000,
'6*2TAMIGA_Co','mmodore Amiga'#000+
'6*2TATARI_Atari ST/STe/TT'#000+
'6*2TMACOS_Macintosh m68k'#000+
'6*2TLINUX_Linux-68k'#000+
'**1*_'#000+

View File

@ -55,9 +55,6 @@ unit pbase;
{ true, if only routine headers should be parsed }
parse_only : boolean;
{ true, if we are in a except block }
in_except_block : boolean;
{ true, if we should ignore an equal in const x : 1..2=2 }
ignore_equal : boolean;
@ -202,7 +199,10 @@ end.
{
$Log$
Revision 1.21 1999-04-28 06:02:05 florian
Revision 1.22 1999-07-26 09:42:10 florian
* bugs 494-496 fixed
Revision 1.21 1999/04/28 06:02:05 florian
* changes of Bruessel:
+ message handler can now take an explicit self
* typinfo fixed: sometimes the type names weren't written

View File

@ -1258,7 +1258,6 @@ unit pmodules;
{ reset }
procprefix:='';
in_except_block:=false;
{The program intialization needs an alias, so it can be called
from the bootstrap code.}
@ -1352,7 +1351,10 @@ unit pmodules;
end.
{
$Log$
Revision 1.133 1999-07-24 00:13:25 peter
Revision 1.134 1999-07-26 09:42:11 florian
* bugs 494-496 fixed
Revision 1.133 1999/07/24 00:13:25 peter
* also number units for program
Revision 1.132 1999/07/23 11:37:48 peter

View File

@ -666,6 +666,8 @@ unit pstatmnt;
begin
p:=comp_expr(true);
consume(RKLAMMER);
if in_except_block then
Message(parser_e_exit_with_argument_not__possible);
if procinfo.retdef=pdef(voiddef) then
Message(parser_e_void_function)
else
@ -1276,7 +1278,10 @@ unit pstatmnt;
end.
{
$Log$
Revision 1.91 1999-06-30 22:16:22 florian
Revision 1.92 1999-07-26 09:42:14 florian
* bugs 494-496 fixed
Revision 1.91 1999/06/30 22:16:22 florian
* use of is_ordinal checked: often a qword/int64 isn't allowed (case/for ...)
* small qword problems fixed

View File

@ -59,6 +59,9 @@ uses
{$endif GDB}
{$ifdef i386}
,i386base,i386asm
{$ifdef dummy}
end { avoid the stupid highlighting of the TP IDE }
{$endif dummy}
,tgeni386,cgai386
{$ifndef NoOpt}
,aopt386
@ -538,8 +541,10 @@ begin
else
begin
consume(COLON);
inc(testcurobject);
aktprocsym^.definition^.retdef:=single_type(hs);
aktprocsym^.definition^.test_if_fpu_result;
dec(testcurobject);
end;
end;
_PROCEDURE : begin
@ -1836,7 +1841,10 @@ end.
{
$Log$
Revision 1.4 1999-07-11 20:10:24 peter
Revision 1.5 1999-07-26 09:42:15 florian
* bugs 494-496 fixed
Revision 1.4 1999/07/11 20:10:24 peter
* merged
Revision 1.3 1999/07/02 13:02:24 peter