mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-08-16 09:59:17 +02:00
* a couple of interface related fixes
This commit is contained in:
parent
925ae63afb
commit
030eae46de
@ -41,6 +41,7 @@ unit cpupara;
|
|||||||
ti386paramanager = class(tparamanager)
|
ti386paramanager = class(tparamanager)
|
||||||
function getintparaloc(nr : longint) : tparalocation;override;
|
function getintparaloc(nr : longint) : tparalocation;override;
|
||||||
procedure create_param_loc_info(p : tabstractprocdef);override;
|
procedure create_param_loc_info(p : tabstractprocdef);override;
|
||||||
|
function getselflocation(p : tabstractprocdef) : tparalocation;override;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
implementation
|
implementation
|
||||||
@ -60,13 +61,22 @@ unit cpupara;
|
|||||||
}
|
}
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
function ti386paramanager.getselflocation(p : tabstractprocdef) : tparalocation;
|
||||||
|
begin
|
||||||
|
getselflocation.loc:=LOC_REFERENCE;
|
||||||
|
getselflocation.reference.index:=R_ESP;
|
||||||
|
getselflocation.reference.offset:=4;
|
||||||
|
end;
|
||||||
|
|
||||||
begin
|
begin
|
||||||
paramanager:=ti386paramanager.create;
|
paramanager:=ti386paramanager.create;
|
||||||
end.
|
end.
|
||||||
{
|
{
|
||||||
$Log$
|
$Log$
|
||||||
Revision 1.2 2002-07-11 14:41:32 florian
|
Revision 1.3 2002-08-09 07:33:04 florian
|
||||||
|
* a couple of interface related fixes
|
||||||
|
|
||||||
|
Revision 1.2 2002/07/11 14:41:32 florian
|
||||||
* start of the new generic parameter handling
|
* start of the new generic parameter handling
|
||||||
|
|
||||||
Revision 1.1 2002/07/07 09:52:33 florian
|
Revision 1.1 2002/07/07 09:52:33 florian
|
||||||
|
@ -107,15 +107,6 @@ procedure ti386classheader.cgintfwrapper(asmlist: TAAsmoutput; procdef: tprocdef
|
|||||||
Internalerror(200006139);
|
Internalerror(200006139);
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure adjustselfvalue(ioffset: longint);
|
|
||||||
var
|
|
||||||
href : treference;
|
|
||||||
begin
|
|
||||||
{ sub $ioffset,offset(%esp) }
|
|
||||||
reference_reset_base(href,R_ESP,getselfoffsetfromsp(procdef));
|
|
||||||
emit_const_ref(A_SUB,S_L,ioffset,href);
|
|
||||||
end;
|
|
||||||
|
|
||||||
procedure getselftoeax(offs: longint);
|
procedure getselftoeax(offs: longint);
|
||||||
var
|
var
|
||||||
href : treference;
|
href : treference;
|
||||||
@ -183,7 +174,7 @@ begin
|
|||||||
exprasmList.concat(Tai_symbol.Createname(labelname,0));
|
exprasmList.concat(Tai_symbol.Createname(labelname,0));
|
||||||
|
|
||||||
{ set param1 interface to self }
|
{ set param1 interface to self }
|
||||||
adjustselfvalue(ioffset);
|
adjustselfvalue(procdef,ioffset);
|
||||||
|
|
||||||
{ case 1 or 2 }
|
{ case 1 or 2 }
|
||||||
if (po_clearstack in procdef.procoptions) then
|
if (po_clearstack in procdef.procoptions) then
|
||||||
@ -197,7 +188,7 @@ begin
|
|||||||
else { case 1 }
|
else { case 1 }
|
||||||
cg.a_call_name(exprasmlist,procdef.mangledname);
|
cg.a_call_name(exprasmlist,procdef.mangledname);
|
||||||
{ restore param1 value self to interface }
|
{ restore param1 value self to interface }
|
||||||
adjustselfvalue(-ioffset);
|
adjustselfvalue(procdef,-ioffset);
|
||||||
end
|
end
|
||||||
{ case 3 }
|
{ case 3 }
|
||||||
else if [po_virtualmethod,po_saveregisters]*procdef.procoptions=[po_virtualmethod,po_saveregisters] then
|
else if [po_virtualmethod,po_saveregisters]*procdef.procoptions=[po_virtualmethod,po_saveregisters] then
|
||||||
@ -237,7 +228,10 @@ initialization
|
|||||||
end.
|
end.
|
||||||
{
|
{
|
||||||
$Log$
|
$Log$
|
||||||
Revision 1.12 2002-07-16 15:34:21 florian
|
Revision 1.13 2002-08-09 07:33:04 florian
|
||||||
|
* a couple of interface related fixes
|
||||||
|
|
||||||
|
Revision 1.12 2002/07/16 15:34:21 florian
|
||||||
* exit is now a syssym instead of a keyword
|
* exit is now a syssym instead of a keyword
|
||||||
|
|
||||||
Revision 1.11 2002/07/01 18:46:33 peter
|
Revision 1.11 2002/07/01 18:46:33 peter
|
||||||
|
@ -1233,6 +1233,9 @@ sym_b_param_list=05039_B_Found declaration: $1
|
|||||||
% listed, with their parameter lists.
|
% listed, with their parameter lists.
|
||||||
sym_e_segment_too_large=05040_E_Data segment too large (max. 2GB)
|
sym_e_segment_too_large=05040_E_Data segment too large (max. 2GB)
|
||||||
% You get this when you declare an array whose size exceeds the 2GB limit.
|
% You get this when you declare an array whose size exceeds the 2GB limit.
|
||||||
|
sym_e_no_matching_implementation_found=05041_E_No matching implementation for interface method "$1" found
|
||||||
|
% There was no matching method found which could implement the interface
|
||||||
|
% method. Check argument types and result type of the methods.
|
||||||
% \end{description}
|
% \end{description}
|
||||||
#
|
#
|
||||||
# Codegenerator
|
# Codegenerator
|
||||||
|
@ -344,6 +344,7 @@ const
|
|||||||
sym_e_id_no_member=05038;
|
sym_e_id_no_member=05038;
|
||||||
sym_b_param_list=05039;
|
sym_b_param_list=05039;
|
||||||
sym_e_segment_too_large=05040;
|
sym_e_segment_too_large=05040;
|
||||||
|
sym_e_no_matching_implementation_found=05041;
|
||||||
cg_e_break_not_allowed=06000;
|
cg_e_break_not_allowed=06000;
|
||||||
cg_e_continue_not_allowed=06001;
|
cg_e_continue_not_allowed=06001;
|
||||||
cg_e_too_complex_expr=06002;
|
cg_e_too_complex_expr=06002;
|
||||||
@ -608,9 +609,9 @@ const
|
|||||||
option_info=11024;
|
option_info=11024;
|
||||||
option_help_pages=11025;
|
option_help_pages=11025;
|
||||||
|
|
||||||
MsgTxtSize = 34117;
|
MsgTxtSize = 34184;
|
||||||
|
|
||||||
MsgIdxMax : array[1..20] of longint=(
|
MsgIdxMax : array[1..20] of longint=(
|
||||||
17,62,184,42,41,41,98,17,35,42,
|
17,62,184,42,42,41,98,17,35,42,
|
||||||
31,1,1,1,1,1,1,1,1,1
|
31,1,1,1,1,1,1,1,1,1
|
||||||
);
|
);
|
||||||
|
@ -386,454 +386,456 @@ const msgtxt : array[0..000142,1..240] of char=(
|
|||||||
'05038_E_identifier idents no member "$1"'#000+
|
'05038_E_identifier idents no member "$1"'#000+
|
||||||
'05039_B_Found declaration: $1'#000+
|
'05039_B_Found declaration: $1'#000+
|
||||||
'05040_E_Data segment too large (m','ax. 2GB)'#000+
|
'05040_E_Data segment too large (m','ax. 2GB)'#000+
|
||||||
|
'05041_E_No matching implementation for interface method "$1" found'#000+
|
||||||
'06000_E_BREAK not allowed'#000+
|
'06000_E_BREAK not allowed'#000+
|
||||||
'06001_E_CONTINUE not allowed'#000+
|
'06001_E_CONTINUE not allowed'#000+
|
||||||
'06002_E_Expression too complicated - FPU stack overflow'#000+
|
'06002_E_Expression too complicated - FPU stack overflow'#000+
|
||||||
'06003_E_Illegal expression'#000+
|
'06003_E_Illegal expression'#000+
|
||||||
'06004_E_Invalid integer expression'#000+
|
'06004_E_Invalid integer ex','pression'#000+
|
||||||
'06005_E_Illegal qualifier'#000+
|
'06005_E_Illegal qualifier'#000+
|
||||||
'06006_E_High range limit < low r','ange limit'#000+
|
'06006_E_High range limit < low range limit'#000+
|
||||||
'06007_E_Illegal counter variable'#000+
|
'06007_E_Illegal counter variable'#000+
|
||||||
'06008_E_Can'#039't determine which overloaded function to call'#000+
|
'06008_E_Can'#039't determine which overloaded function to call'#000+
|
||||||
'06009_E_Parameter list size exceeds 65535 bytes'#000+
|
'06009_E_Parameter list size exceeds 65535 bytes'#000+
|
||||||
'06010_E_Illegal type conversion'#000+
|
'06010_E_Illegal type co','nversion'#000+
|
||||||
'06011_D_Conversion between ordinals and pointers is not po','rtable acr'+
|
'06011_D_Conversion between ordinals and pointers is not portable acros'+
|
||||||
'oss platforms'#000+
|
's platforms'#000+
|
||||||
'06012_E_File types must be var parameters'#000+
|
'06012_E_File types must be var parameters'#000+
|
||||||
'06013_E_The use of a far pointer isn'#039't allowed there'#000+
|
'06013_E_The use of a far pointer isn'#039't allowed there'#000+
|
||||||
'06014_E_illegal call by reference parameters'#000+
|
'06014_E_illegal call by reference parameters'#000+
|
||||||
'06015_E_EXPORT declared functions can'#039't be called'#000+
|
'06015_E_E','XPORT declared functions can'#039't be called'#000+
|
||||||
'06016_W_Possible illegal c','all of constructor or destructor (doesn'#039+
|
'06016_W_Possible illegal call of constructor or destructor (doesn'#039't'+
|
||||||
't match to this context)'#000+
|
' match to this context)'#000+
|
||||||
'06017_N_Inefficient code'#000+
|
'06017_N_Inefficient code'#000+
|
||||||
'06018_W_unreachable code'#000+
|
'06018_W_unreachable code'#000+
|
||||||
'06019_E_procedure call with stackframe ESP/SP'#000+
|
'06019_E_procedure call with stackframe ESP/SP'#000+
|
||||||
'06020_E_Abstract methods can'#039't be called directly'#000+
|
'06020_E_Abst','ract methods can'#039't be called directly'#000+
|
||||||
'06021_F_Internal Error in get','floatreg(), allocation failure'#000+
|
'06021_F_Internal Error in getfloatreg(), allocation failure'#000+
|
||||||
'06022_F_Unknown float type'#000+
|
'06022_F_Unknown float type'#000+
|
||||||
'06023_F_SecondVecn() base defined twice'#000+
|
'06023_F_SecondVecn() base defined twice'#000+
|
||||||
'06024_F_Extended cg68k not supported'#000+
|
'06024_F_Extended cg68k not supported'#000+
|
||||||
'06025_F_32-bit unsigned not supported in MC68000 mode'#000+
|
'06025_F_32-bit unsigned not supported ','in MC68000 mode'#000+
|
||||||
'06026_F_Internal Error in secondinline()'#000+
|
'06026_F_Internal Error in secondinline()'#000+
|
||||||
'06027_D_Re','gister $1 weight $2 $3'#000+
|
'06027_D_Register $1 weight $2 $3'#000+
|
||||||
'06028_E_Stack limit excedeed in local routine'#000+
|
'06028_E_Stack limit excedeed in local routine'#000+
|
||||||
'06029_D_Stack frame is omitted'#000+
|
'06029_D_Stack frame is omitted'#000+
|
||||||
'06031_E_Object or class methods can'#039't be inline.'#000+
|
'06031_E_Object or class methods can'#039't be inline.'#000+
|
||||||
'06032_E_Procvar calls can'#039't be inline.'#000+
|
'06032_E_Procvar calls ca','n'#039't be inline.'#000+
|
||||||
'06033_E_No code for inline procedure stored'#000+
|
'06033_E_No code for inline procedure stored'#000+
|
||||||
'06034_E_','Direct call of interrupt procedure "$1" is not possible'#000+
|
'06034_E_Direct call of interrupt procedure "$1" is not possible'#000+
|
||||||
'06035_E_Element zero of an ansi/wide- or longstring can'#039't be acces'+
|
'06035_E_Element zero of an ansi/wide- or longstring can'#039't be acces'+
|
||||||
'sed, use (set)length instead'#000+
|
'sed, use (set)length instead'#000+
|
||||||
'06036_E_Include and exclude not implemented in this case'#000+
|
'06036_E_Include and ex','clude not implemented in this case'#000+
|
||||||
'06037_E_Constructors or destruct','ors can not be called inside a '#039'w'+
|
'06037_E_Constructors or destructors can not be called inside a '#039'wi'+
|
||||||
'ith'#039' clause'#000+
|
'th'#039' clause'#000+
|
||||||
'06038_E_Cannot call message handler method directly'#000+
|
'06038_E_Cannot call message handler method directly'#000+
|
||||||
'06039_E_Jump in or outside of an exception block'#000+
|
'06039_E_Jump in or outside of an exception block'#000+
|
||||||
'06040_E_Control flow statements aren'#039't allowed in a finally block'#000+
|
'06040_E_Control flow statem','ents aren'#039't allowed in a finally bloc'+
|
||||||
'07000_D_Starting $1 styled a','ssembler parsing'#000+
|
'k'#000+
|
||||||
|
'07000_D_Starting $1 styled assembler parsing'#000+
|
||||||
'07001_D_Finished $1 styled assembler parsing'#000+
|
'07001_D_Finished $1 styled assembler parsing'#000+
|
||||||
'07002_E_Non-label pattern contains @'#000+
|
'07002_E_Non-label pattern contains @'#000+
|
||||||
'07003_W_Override operator not supported'#000+
|
'07003_W_Override operator not supported'#000+
|
||||||
'07004_E_Error building record offset'#000+
|
'07004_E_Error building record offs','et'#000+
|
||||||
'07005_E_OFFSET used without identifier'#000+
|
'07005_E_OFFSET used without identifier'#000+
|
||||||
'07006_E_TYPE used without',' identifier'#000+
|
'07006_E_TYPE used without identifier'#000+
|
||||||
'07007_E_Cannot use local variable or parameters here'#000+
|
'07007_E_Cannot use local variable or parameters here'#000+
|
||||||
'07008_E_need to use OFFSET here'#000+
|
'07008_E_need to use OFFSET here'#000+
|
||||||
'07009_E_need to use $ here'#000+
|
'07009_E_need to use $ here'#000+
|
||||||
'07010_E_Cannot use multiple relocatable symbols'#000+
|
'07010_E_Cannot use multiple relocatable symbols'#000+
|
||||||
'07011_E_Relocatable symbol can only be added'#000+
|
'0','7011_E_Relocatable symbol can only be added'#000+
|
||||||
'07012_E_Invalid constan','t expression'#000+
|
'07012_E_Invalid constant expression'#000+
|
||||||
'07013_E_Relocatable symbol is not allowed'#000+
|
'07013_E_Relocatable symbol is not allowed'#000+
|
||||||
'07014_E_Invalid reference syntax'#000+
|
'07014_E_Invalid reference syntax'#000+
|
||||||
'07015_E_You can not reach $1 from that code'#000+
|
'07015_E_You can not reach $1 from that code'#000+
|
||||||
'07016_E_Local symbols/labels aren'#039't allowed as references'#000+
|
'07016_E_Local symbols/labels aren'#039't allow','ed as references'#000+
|
||||||
'07017_E_Invalid base and index register usage'#000+
|
'07017_E_Invalid base and index register usage'#000+
|
||||||
'0701','8_W_Possible error in object field handling'#000+
|
'07018_W_Possible error in object field handling'#000+
|
||||||
'07019_E_Wrong scale factor specified'#000+
|
'07019_E_Wrong scale factor specified'#000+
|
||||||
'07020_E_Multiple index register usage'#000+
|
'07020_E_Multiple index register usage'#000+
|
||||||
'07021_E_Invalid operand type'#000+
|
'07021_E_Invalid operand type'#000+
|
||||||
'07022_E_Invalid string as opcode operand: $1'#000+
|
'07022_E_Invalid string as',' opcode operand: $1'#000+
|
||||||
'07023_W_@CODE and @DATA not supported'#000+
|
'07023_W_@CODE and @DATA not supported'#000+
|
||||||
'07024_E_N','ull label references are not allowed'#000+
|
'07024_E_Null label references are not allowed'#000+
|
||||||
'07025_E_Divide by zero in asm evaluator'#000+
|
'07025_E_Divide by zero in asm evaluator'#000+
|
||||||
'07026_E_Illegal expression'#000+
|
'07026_E_Illegal expression'#000+
|
||||||
'07027_E_escape sequence ignored: $1'#000+
|
'07027_E_escape sequence ignored: $1'#000+
|
||||||
'07028_E_Invalid symbol reference'#000+
|
'07028_E_Invalid symbol reference'#000,
|
||||||
'07029_W_Fwait can cause emulation problems with emu387'#000+
|
'07029_W_Fwait can cause emulation problems with emu387'#000+
|
||||||
'07030_W_$1 w','ithout operand translated into $1P'#000+
|
'07030_W_$1 without operand translated into $1P'#000+
|
||||||
'07031_W_ENTER instruction is not supported by Linux kernel'#000+
|
'07031_W_ENTER instruction is not supported by Linux kernel'#000+
|
||||||
'07032_W_Calling an overload function in assembler'#000+
|
'07032_W_Calling an overload function in assembler'#000+
|
||||||
'07033_E_Unsupported symbol type for operand'#000+
|
'07033_E_Unsupported symbol ty','pe for operand'#000+
|
||||||
'07034_E_Constant value out of bounds'#000+
|
'07034_E_Constant value out of bounds'#000+
|
||||||
'07035_E_Error c','onverting decimal $1'#000+
|
'07035_E_Error converting decimal $1'#000+
|
||||||
'07036_E_Error converting octal $1'#000+
|
'07036_E_Error converting octal $1'#000+
|
||||||
'07037_E_Error converting binary $1'#000+
|
'07037_E_Error converting binary $1'#000+
|
||||||
'07038_E_Error converting hexadecimal $1'#000+
|
'07038_E_Error converting hexadecimal $1'#000+
|
||||||
'07039_H_$1 translated to $2'#000+
|
'07039_H_$1 translated to $2'#000+
|
||||||
'07040_W_$1 is associated to an overloaded function'#000+
|
'07040_W_$1 is a','ssociated to an overloaded function'#000+
|
||||||
'07041_E_Cannot use SELF outside',' a method'#000+
|
'07041_E_Cannot use SELF outside a method'#000+
|
||||||
'07042_E_Cannot use OLDEBP outside a nested procedure'#000+
|
'07042_E_Cannot use OLDEBP outside a nested procedure'#000+
|
||||||
'07043_W_Procedures can'#039't return any value in asm code'#000+
|
'07043_W_Procedures can'#039't return any value in asm code'#000+
|
||||||
'07044_E_SEG not supported'#000+
|
'07044_E_SEG not supported'#000+
|
||||||
'07045_E_Size suffix and destination or source size do not match'#000+
|
'07045_E_Size suffix and destin','ation or source size do not match'#000+
|
||||||
'07046_W_Size suffix and destinati','on or source size do not match'#000+
|
'07046_W_Size suffix and destination or source size do not match'#000+
|
||||||
'07047_E_Assembler syntax error'#000+
|
'07047_E_Assembler syntax error'#000+
|
||||||
'07048_E_Invalid combination of opcode and operands'#000+
|
'07048_E_Invalid combination of opcode and operands'#000+
|
||||||
'07049_E_Assembler syntax error in operand'#000+
|
'07049_E_Assembler syntax error in operand'#000+
|
||||||
'07050_E_Assembler syntax error in constant'#000+
|
'07050_E_Assembler ','syntax error in constant'#000+
|
||||||
'07051_E_Invalid String expression'#000+
|
'07051_E_Invalid String expression'#000+
|
||||||
'07052_W_','constant with symbol $1 for not 32bit address'#000+
|
'07052_W_constant with symbol $1 for not 32bit address'#000+
|
||||||
'07053_E_Unrecognized opcode $1'#000+
|
'07053_E_Unrecognized opcode $1'#000+
|
||||||
'07054_E_Invalid or missing opcode'#000+
|
'07054_E_Invalid or missing opcode'#000+
|
||||||
'07055_E_Invalid combination of prefix and opcode: $1'#000+
|
'07055_E_Invalid combination of prefix and opcode: $1'#000+
|
||||||
'07056_E_Invalid combination of override and opcode: $1'#000+
|
'07056_E_I','nvalid combination of override and opcode: $1'#000+
|
||||||
'07057_E_Too many oper','ands on line'#000+
|
'07057_E_Too many operands on line'#000+
|
||||||
'07058_W_NEAR ignored'#000+
|
'07058_W_NEAR ignored'#000+
|
||||||
'07059_W_FAR ignored'#000+
|
'07059_W_FAR ignored'#000+
|
||||||
'07060_E_Duplicate local symbol $1'#000+
|
'07060_E_Duplicate local symbol $1'#000+
|
||||||
'07061_E_Undefined local symbol $1'#000+
|
'07061_E_Undefined local symbol $1'#000+
|
||||||
'07062_E_Unknown label identifier $1'#000+
|
'07062_E_Unknown label identifier $1'#000+
|
||||||
'07063_E_Invalid register name'#000+
|
'07063_E_Invalid',' register name'#000+
|
||||||
'07064_E_Invalid floating point register name'#000+
|
'07064_E_Invalid floating point register name'#000+
|
||||||
'07065_E','_NOR not supported'#000+
|
'07065_E_NOR not supported'#000+
|
||||||
'07066_W_Modulo not supported'#000+
|
'07066_W_Modulo not supported'#000+
|
||||||
'07067_E_Invalid floating point constant $1'#000+
|
'07067_E_Invalid floating point constant $1'#000+
|
||||||
'07068_E_Invalid floating point expression'#000+
|
'07068_E_Invalid floating point expression'#000+
|
||||||
'07069_E_Wrong symbol type'#000+
|
'07069_E_Wrong symbol type'#000+
|
||||||
'07070_E_Cannot index a local var or parameter with a register'#000+
|
'07070_E_Cannot',' index a local var or parameter with a register'#000+
|
||||||
'07071_E_Invalid seg','ment override expression'#000+
|
'07071_E_Invalid segment override expression'#000+
|
||||||
'07072_W_Identifier $1 supposed external'#000+
|
'07072_W_Identifier $1 supposed external'#000+
|
||||||
'07073_E_Strings not allowed as constants'#000+
|
'07073_E_Strings not allowed as constants'#000+
|
||||||
'07074_No type of variable specified'#000+
|
'07074_No type of variable specified'#000+
|
||||||
'07075_E_assembler code not returned to text section'#000+
|
'07075_E_assembler code not retu','rned to text section'#000+
|
||||||
'07076_E_Not a directive or local symbol $1'#000+
|
'07076_E_Not a directive or local symbol $1'#000+
|
||||||
'070','77_E_Using a defined name as a local label'#000+
|
'07077_E_Using a defined name as a local label'#000+
|
||||||
'07078_E_Dollar token is used without an identifier'#000+
|
'07078_E_Dollar token is used without an identifier'#000+
|
||||||
'07079_W_32bit constant created for address'#000+
|
'07079_W_32bit constant created for address'#000+
|
||||||
'07080_N_.align is target specific, use .balign or .p2align'#000+
|
'07080_N_.align is target specific, u','se .balign or .p2align'#000+
|
||||||
'07081_E_Can'#039't access fields directly for par','ameters'#000+
|
'07081_E_Can'#039't access fields directly for parameters'#000+
|
||||||
'07082_E_Can'#039't access fields of objects/classes directly'#000+
|
'07082_E_Can'#039't access fields of objects/classes directly'#000+
|
||||||
'07083_E_No size specified and unable to determine the size of the oper'+
|
'07083_E_No size specified and unable to determine the size of the oper'+
|
||||||
'ands'#000+
|
'ands'#000+
|
||||||
'07084_E_Cannot use RESULT in this function'#000+
|
'07084_E_Cannot use RESULT in this ','function'#000+
|
||||||
'07085_H_RESULT is register $1'#000+
|
'07085_H_RESULT is register $1'#000+
|
||||||
'07086_W_"$1" without operand',' translated into "$1 %st,%st(1)"'#000+
|
'07086_W_"$1" without operand translated into "$1 %st,%st(1)"'#000+
|
||||||
'07087_W_"$1 %st(n)" translated into "$1 %st,%st(n)"'#000+
|
'07087_W_"$1 %st(n)" translated into "$1 %st,%st(n)"'#000+
|
||||||
'07088_W_"$1 %st(n)" translated into "$1 %st(n),%st"'#000+
|
'07088_W_"$1 %st(n)" translated into "$1 %st(n),%st"'#000+
|
||||||
'07089_E_Char < not allowed here'#000+
|
'07089_E_Char < not allowed here'#000+
|
||||||
'07090_E_Char > not allowed here'#000+
|
'0709','0_E_Char > not allowed here'#000+
|
||||||
'07091_W_XDEF not supported'#000+
|
'07091_W_XDEF not supported'#000+
|
||||||
'07092_E_Inva','lid XDEF syntax'#000+
|
'07092_E_Invalid XDEF syntax'#000+
|
||||||
'07093_W_ALIGN not supported'#000+
|
'07093_W_ALIGN not supported'#000+
|
||||||
'07094_E_Inc and Dec cannot be together'#000+
|
'07094_E_Inc and Dec cannot be together'#000+
|
||||||
'07095_E_Invalid reglist for movem'#000+
|
'07095_E_Invalid reglist for movem'#000+
|
||||||
'07096_E_Reglist invalid for opcode'#000+
|
'07096_E_Reglist invalid for opcode'#000+
|
||||||
'07097_E_68020 mode required'#000+
|
'07097_E_68020 mode re','quired'#000+
|
||||||
'08000_F_Too many assembler files'#000+
|
'08000_F_Too many assembler files'#000+
|
||||||
'08001_F_Selected assembler ','output not supported'#000+
|
'08001_F_Selected assembler output not supported'#000+
|
||||||
'08002_F_Comp not supported'#000+
|
'08002_F_Comp not supported'#000+
|
||||||
'08003_F_Direct not support for binary writers'#000+
|
'08003_F_Direct not support for binary writers'#000+
|
||||||
'08004_E_Allocating of data is only allowed in bss section'#000+
|
'08004_E_Allocating of data is only allowed in bss section'#000+
|
||||||
'08005_F_No binary writer selected'#000+
|
'08005_F_No binary wri','ter selected'#000+
|
||||||
'08006_E_Asm: Opcode $1 not in table'#000+
|
'08006_E_Asm: Opcode $1 not in table'#000+
|
||||||
'08007_E_Asm: $1 in','valid combination of opcode and operands'#000+
|
'08007_E_Asm: $1 invalid combination of opcode and operands'#000+
|
||||||
'08008_E_Asm: 16 Bit references not supported'#000+
|
'08008_E_Asm: 16 Bit references not supported'#000+
|
||||||
'08009_E_Asm: Invalid effective address'#000+
|
'08009_E_Asm: Invalid effective address'#000+
|
||||||
'08010_E_Asm: Immediate or reference expected'#000+
|
'08010_E_Asm: Immediate or reference expected'#000+
|
||||||
'08011_E_Asm: $1 value exceeds bounds $2'#000+
|
'080','11_E_Asm: $1 value exceeds bounds $2'#000+
|
||||||
'08012_E_Asm: Short jump is out',' of range $1'#000+
|
'08012_E_Asm: Short jump is out of range $1'#000+
|
||||||
'08013_E_Asm: Undefined label $1'#000+
|
'08013_E_Asm: Undefined label $1'#000+
|
||||||
'08014_E_Asm: Comp type not supported for this target'#000+
|
'08014_E_Asm: Comp type not supported for this target'#000+
|
||||||
'08015_E_Asm: Extended type not supported for this target'#000+
|
'08015_E_Asm: Extended type not supported for this target'#000+
|
||||||
'08016_E_Asm: Duplicate label $1'#000+
|
'08016_E_Asm: Dupli','cate label $1'#000+
|
||||||
'09000_W_Source operating system redefined'#000+
|
'09000_W_Source operating system redefined'#000+
|
||||||
'09001_I_Ass','embling (pipe) $1'#000+
|
'09001_I_Assembling (pipe) $1'#000+
|
||||||
'09002_E_Can'#039't create assember file: $1'#000+
|
'09002_E_Can'#039't create assember file: $1'#000+
|
||||||
'09003_E_Can'#039't create object file: $1'#000+
|
'09003_E_Can'#039't create object file: $1'#000+
|
||||||
'09004_E_Can'#039't create archive file: $1'#000+
|
'09004_E_Can'#039't create archive file: $1'#000+
|
||||||
'09005_E_Assembler $1 not found, switching to external assembling'#000+
|
'09005_E_Assembler $1 not found, switching',' to external assembling'#000+
|
||||||
'09006_T_Using assembler: $1'#000+
|
'09006_T_Using assembler: $1'#000+
|
||||||
'09007_E_Error w','hile assembling exitcode $1'#000+
|
'09007_E_Error while assembling exitcode $1'#000+
|
||||||
'09008_E_Can'#039't call the assembler, error $1 switching to external a'+
|
'09008_E_Can'#039't call the assembler, error $1 switching to external a'+
|
||||||
'ssembling'#000+
|
'ssembling'#000+
|
||||||
'09009_I_Assembling $1'#000+
|
'09009_I_Assembling $1'#000+
|
||||||
'09010_I_Assembling smartlink $1'#000+
|
'09010_I_Assembling smartlink $1'#000+
|
||||||
'09011_W_Object $1 not found, Linking may fail !'#000+
|
'09011_W_Object ','$1 not found, Linking may fail !'#000+
|
||||||
'09012_W_Library $1 not found, Link','ing may fail !'#000+
|
'09012_W_Library $1 not found, Linking may fail !'#000+
|
||||||
'09013_E_Error while linking'#000+
|
'09013_E_Error while linking'#000+
|
||||||
'09014_E_Can'#039't call the linker, switching to external linking'#000+
|
'09014_E_Can'#039't call the linker, switching to external linking'#000+
|
||||||
'09015_I_Linking $1'#000+
|
'09015_I_Linking $1'#000+
|
||||||
'09016_E_Util $1 not found, switching to external linking'#000+
|
'09016_E_Util $1 not found, switching to external l','inking'#000+
|
||||||
'09017_T_Using util $1'#000+
|
'09017_T_Using util $1'#000+
|
||||||
'09018_E_Creation of Executables not su','pported'#000+
|
'09018_E_Creation of Executables not supported'#000+
|
||||||
'09019_E_Creation of Dynamic/Shared Libraries not supported'#000+
|
'09019_E_Creation of Dynamic/Shared Libraries not supported'#000+
|
||||||
'09020_I_Closing script $1'#000+
|
'09020_I_Closing script $1'#000+
|
||||||
'09021_E_resource compiler not found, switching to external mode'#000+
|
'09021_E_resource compiler not found, switching to external mode'#000+
|
||||||
'09022_I_Compiling resource $1'#000+
|
'09022_I_Compilin','g resource $1'#000+
|
||||||
'09023_T_unit $1 can'#039't be static linked, switching to ','smart linki'+
|
'09023_T_unit $1 can'#039't be static linked, switching to smart linking'+
|
||||||
'ng'#000+
|
#000+
|
||||||
'09024_T_unit $1 can'#039't be smart linked, switching to static linking'+
|
'09024_T_unit $1 can'#039't be smart linked, switching to static linking'+
|
||||||
#000+
|
#000+
|
||||||
'09025_T_unit $1 can'#039't be shared linked, switching to static linkin'+
|
'09025_T_unit $1 can'#039't be shared linked, switching to static linkin'+
|
||||||
'g'#000+
|
'g'#000+
|
||||||
'09026_E_unit $1 can'#039't be smart or static linked'#000+
|
'09026_E_unit $1 can'#039't be',' smart or static linked'#000+
|
||||||
'09027_E_unit $1 can'#039't be shared or static l','inked'#000+
|
'09027_E_unit $1 can'#039't be shared or static linked'#000+
|
||||||
'09028_F_Can'#039't post process executable $1'#000+
|
'09028_F_Can'#039't post process executable $1'#000+
|
||||||
'09029_F_Can'#039't open executable $1'#000+
|
'09029_F_Can'#039't open executable $1'#000+
|
||||||
'09030_X_Size of Code: $1 bytes'#000+
|
'09030_X_Size of Code: $1 bytes'#000+
|
||||||
'09031_X_Size of initialized data: $1 bytes'#000+
|
'09031_X_Size of initialized data: $1 bytes'#000+
|
||||||
'09032_X_Size of uninitialized data: $1 bytes'#000+
|
'09032_X_Size of uni','nitialized data: $1 bytes'#000+
|
||||||
'09033_X_Stack space reserved: $1 bytes'#000+
|
'09033_X_Stack space reserved: $1 bytes'#000+
|
||||||
'09','034_X_Stack space commited: $1 bytes'#000+
|
'09034_X_Stack space commited: $1 bytes'#000+
|
||||||
'10000_T_Unitsearch: $1'#000+
|
'10000_T_Unitsearch: $1'#000+
|
||||||
'10001_T_PPU Loading $1'#000+
|
'10001_T_PPU Loading $1'#000+
|
||||||
'10002_U_PPU Name: $1'#000+
|
'10002_U_PPU Name: $1'#000+
|
||||||
'10003_U_PPU Flags: $1'#000+
|
'10003_U_PPU Flags: $1'#000+
|
||||||
'10004_U_PPU Crc: $1'#000+
|
'10004_U_PPU Crc: $1'#000+
|
||||||
'10005_U_PPU Time: $1'#000+
|
'10005_U_PPU Time: $1'#000+
|
||||||
'10006_U_PPU File too short'#000+
|
'10006_','U_PPU File too short'#000+
|
||||||
'10007_U_PPU Invalid Header (no PPU at the begi','n)'#000+
|
'10007_U_PPU Invalid Header (no PPU at the begin)'#000+
|
||||||
'10008_U_PPU Invalid Version $1'#000+
|
'10008_U_PPU Invalid Version $1'#000+
|
||||||
'10009_U_PPU is compiled for an other processor'#000+
|
'10009_U_PPU is compiled for an other processor'#000+
|
||||||
'10010_U_PPU is compiled for an other target'#000+
|
'10010_U_PPU is compiled for an other target'#000+
|
||||||
'10011_U_PPU Source: $1'#000+
|
'10011_U_PPU Source: $1'#000+
|
||||||
'10012_U_Writing $1'#000+
|
'10012_U_Writing $1'#000+
|
||||||
'10013_F_Can'#039't Write PPU-File'#000+
|
'10013_','F_Can'#039't Write PPU-File'#000+
|
||||||
'10014_F_Error reading PPU-File'#000+
|
'10014_F_Error reading PPU-File'#000+
|
||||||
'10015_F_unexp','ected end of PPU-File'#000+
|
'10015_F_unexpected end of PPU-File'#000+
|
||||||
'10016_F_Invalid PPU-File entry: $1'#000+
|
'10016_F_Invalid PPU-File entry: $1'#000+
|
||||||
'10017_F_PPU Dbx count problem'#000+
|
'10017_F_PPU Dbx count problem'#000+
|
||||||
'10018_E_Illegal unit name: $1'#000+
|
'10018_E_Illegal unit name: $1'#000+
|
||||||
'10019_F_Too much units'#000+
|
'10019_F_Too much units'#000+
|
||||||
'10020_F_Circular unit reference between $1 and $2'#000+
|
'10020_F_Circular unit reference b','etween $1 and $2'#000+
|
||||||
'10021_F_Can'#039't compile unit $1, no sources availabl','e'#000+
|
'10021_F_Can'#039't compile unit $1, no sources available'#000+
|
||||||
'10022_F_Can'#039't find unit $1'#000+
|
'10022_F_Can'#039't find unit $1'#000+
|
||||||
'10023_W_Unit $1 was not found but $2 exists'#000+
|
'10023_W_Unit $1 was not found but $2 exists'#000+
|
||||||
'10024_F_Unit $1 searched but $2 found'#000+
|
'10024_F_Unit $1 searched but $2 found'#000+
|
||||||
'10025_W_Compiling the system unit requires the -Us switch'#000+
|
'10025_W_Compiling the system unit requires the -Us switch'#000+
|
||||||
'10026_F_There were $1 errors compiling module, stopping'#000+
|
'1002','6_F_There were $1 errors compiling module, stopping'#000+
|
||||||
'10027_U_Load fr','om $1 ($2) unit $3'#000+
|
'10027_U_Load from $1 ($2) unit $3'#000+
|
||||||
'10028_U_Recompiling $1, checksum changed for $2'#000+
|
'10028_U_Recompiling $1, checksum changed for $2'#000+
|
||||||
'10029_U_Recompiling $1, source found only'#000+
|
'10029_U_Recompiling $1, source found only'#000+
|
||||||
'10030_U_Recompiling unit, static lib is older than ppufile'#000+
|
'10030_U_Recompiling unit, static lib is older than ppufile'#000+
|
||||||
'10031_U_Recompiling unit, shared lib is older than ppufile'#000+
|
'10031','_U_Recompiling unit, shared lib is older than ppufile'#000+
|
||||||
'10032_U_Recom','piling unit, obj and asm are older than ppufile'#000+
|
'10032_U_Recompiling unit, obj and asm are older than ppufile'#000+
|
||||||
'10033_U_Recompiling unit, obj is older than asm'#000+
|
'10033_U_Recompiling unit, obj is older than asm'#000+
|
||||||
'10034_U_Parsing interface of $1'#000+
|
'10034_U_Parsing interface of $1'#000+
|
||||||
'10035_U_Parsing implementation of $1'#000+
|
'10035_U_Parsing implementation of $1'#000+
|
||||||
'10036_U_Second load for unit $1'#000+
|
'10036_U_','Second load for unit $1'#000+
|
||||||
'10037_U_PPU Check file $1 time $2'#000+
|
'10037_U_PPU Check file $1 time $2'#000+
|
||||||
'10038_H_C','onditional $1 was not set at startup in last compilation of'+
|
'10038_H_Conditional $1 was not set at startup in last compilation of $'+
|
||||||
' $2'#000+
|
'2'#000+
|
||||||
'10039_H_Conditional $1 was set at startup in last compilation of $2'#000+
|
'10039_H_Conditional $1 was set at startup in last compilation of $2'#000+
|
||||||
'10040_W_Can'#039't recompile unit $1, but found modifed include files'#000+
|
'10040_W_Can'#039't recompile unit $1, but found',' modifed include files'+
|
||||||
'10041_H_File $1 is newer than Release PPU fi','le $2'#000+
|
#000+
|
||||||
|
'10041_H_File $1 is newer than Release PPU file $2'#000+
|
||||||
'11000_$1 [options] <inputfile> [options]'#000+
|
'11000_$1 [options] <inputfile> [options]'#000+
|
||||||
'11001_W_Only one source file supported'#000+
|
'11001_W_Only one source file supported'#000+
|
||||||
'11002_W_DEF file can be created only for OS/2'#000+
|
'11002_W_DEF file can be created only for OS/2'#000+
|
||||||
'11003_E_nested response files are not supported'#000+
|
'11003_E_nested response files are not sup','ported'#000+
|
||||||
'11004_F_No source file name in command line'#000+
|
'11004_F_No source file name in command line'#000+
|
||||||
'11005_N_No optio','n inside $1 config file'#000+
|
'11005_N_No option inside $1 config file'#000+
|
||||||
'11006_E_Illegal parameter: $1'#000+
|
'11006_E_Illegal parameter: $1'#000+
|
||||||
'11007_H_-? writes help pages'#000+
|
'11007_H_-? writes help pages'#000+
|
||||||
'11008_F_Too many config files nested'#000+
|
'11008_F_Too many config files nested'#000+
|
||||||
'11009_F_Unable to open file $1'#000+
|
'11009_F_Unable to open file $1'#000+
|
||||||
'11010_D_Reading further options from $1'#000+
|
'11010_D_Reading furthe','r options from $1'#000+
|
||||||
'11011_W_Target is already set to: $1'#000+
|
'11011_W_Target is already set to: $1'#000+
|
||||||
'11012_W_Shar','ed libs not supported on DOS platform, reverting to stat'+
|
'11012_W_Shared libs not supported on DOS platform, reverting to static'+
|
||||||
'ic'#000+
|
#000+
|
||||||
'11013_F_too many IF(N)DEFs'#000+
|
'11013_F_too many IF(N)DEFs'#000+
|
||||||
'11014_F_too many ENDIFs'#000+
|
'11014_F_too many ENDIFs'#000+
|
||||||
'11015_F_open conditional at the end of the file'#000+
|
'11015_F_open conditional at the end of the file'#000+
|
||||||
'11016_W_Debug information generation is not supported by this executab'+
|
'11016_W_Debug i','nformation generation is not supported by this execut'+
|
||||||
'le'#000+
|
'able'#000+
|
||||||
'11017_H_T','ry recompiling with -dGDB'#000+
|
'11017_H_Try recompiling with -dGDB'#000+
|
||||||
'11018_E_You are using the obsolete switch $1'#000+
|
'11018_E_You are using the obsolete switch $1'#000+
|
||||||
'11019_E_You are using the obsolete switch $1, please use $2'#000+
|
'11019_E_You are using the obsolete switch $1, please use $2'#000+
|
||||||
'11020_N_Switching assembler to default source writing assembler'#000+
|
'11020_N_Switching assembler to default sou','rce writing assembler'#000+
|
||||||
'11021_W_Assembler output selected "$1" is not',' compatible with "$2"'#000+
|
'11021_W_Assembler output selected "$1" is not compatible with "$2"'#000+
|
||||||
'11022_W_"$1" assembler use forced'#000+
|
'11022_W_"$1" assembler use forced'#000+
|
||||||
'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__','*** press enter ***'#000+
|
||||||
'11030_E_Unknown code page'#000+
|
'11030_E_Unknown code page'#000+
|
||||||
'11023_Free Pascal Com','piler version $FPCVER [$FPCDATE] for $FPCTARGET'+
|
'11023_Free Pascal Compiler version $FPCVER [$FPCDATE] for $FPCTARGET'#010+
|
||||||
#010+
|
|
||||||
'Copyright (c) 1993-2002 by Florian Klaempfl'#000+
|
'Copyright (c) 1993-2002 by Florian Klaempfl'#000+
|
||||||
'11024_Free Pascal Compiler version $FPCVER'#010+
|
'11024_Free Pascal Compiler version $FPCVER'#010+
|
||||||
#010+
|
#010+
|
||||||
'Compiler Date : $FPCDATE'#010+
|
'Compiler Date : $FPCDATE'#010+
|
||||||
'Compiler Target: $FPCTARGET'#010+
|
'Compiler Ta','rget: $FPCTARGET'#010+
|
||||||
#010+
|
#010+
|
||||||
'Supported targets:'#010+
|
'Supported targets:'#010+
|
||||||
' $OSTARGETS'#010+
|
' $OSTARGETS'#010+
|
||||||
#010+
|
#010+
|
||||||
'This program com','es under the GNU General Public Licence'#010+
|
'This program comes under the GNU General Public Licence'#010+
|
||||||
'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+
|
||||||
' bugrep@freepascal.org'#000+
|
' bugrep@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 di'+
|
||||||
'ble it'#010+
|
'sable it'#010+
|
||||||
'**1a_the comp','iler 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+
|
||||||
'**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+
|
||||||
'**1b_generate browser inf','o'#010+
|
'**1b_generate browser info'#010+
|
||||||
'**2bl_generate local symbol info'#010+
|
'**2bl_generate local symbol info'#010+
|
||||||
'**1B_build all modules'#010+
|
'**1B_build all modules'#010+
|
||||||
'**1C<x>_code generation options:'#010+
|
'**1C<x>_code generation options:'#010+
|
||||||
'**2CD_create also dynamic library (not supported)'#010+
|
'**2CD_create also dynamic library (not supported)'#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+
|
||||||
'**2C','o_check overflow of integer operations'#010+
|
'**2Co_check overflow of integer operations'#010+
|
||||||
'**2Cr_range checking'#010+
|
'**2Cr_range checking'#010+
|
||||||
'**2CR_verify object method call validity'#010+
|
'**2CR_verify object method 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 sm','artlinked library'#010+
|
||||||
'**1d<x>_defines the symbol <x>'#010+
|
'**1d<x>_defines the symbol <x>'#010+
|
||||||
'*O1D_generate a DE','F file'#010+
|
'*O1D_generate a DEF file'#010+
|
||||||
'*O2Dd<x>_set description to <x>'#010+
|
'*O2Dd<x>_set description to <x>'#010+
|
||||||
'*O2Dw_PM application'#010+
|
'*O2Dw_PM application'#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+
|
||||||
'**1F<x>_set file names and paths:'#010+
|
'**1F<x>_set file names and paths:'#010+
|
||||||
'**2FD<x>_sets the directory where to search for compiler utilities'#010+
|
'**2FD<x>_sets the directory whe','re to search for compiler utilities'#010+
|
||||||
'**2Fe<x>_redirect error output ','to <x>'#010+
|
'**2Fe<x>_redirect error output to <x>'#010+
|
||||||
'**2FE<x>_set exe/unit output path to <x>'#010+
|
'**2FE<x>_set exe/unit output path to <x>'#010+
|
||||||
'**2Fi<x>_adds <x> to include path'#010+
|
'**2Fi<x>_adds <x> to include path'#010+
|
||||||
'**2Fl<x>_adds <x> to library path'#010+
|
'**2Fl<x>_adds <x> to library path'#010+
|
||||||
'*L2FL<x>_uses <x> as dynamic linker'#010+
|
'*L2FL<x>_uses <x> as dynamic linker'#010+
|
||||||
'**2Fo<x>_adds <x> to object path'#010+
|
'**2Fo<x>_adds <x> to ','object path'#010+
|
||||||
'**2Fr<x>_load error message file <x>'#010+
|
'**2Fr<x>_load error message file <x>'#010+
|
||||||
'**2Fu<x>_adds <x> ','to unit path'#010+
|
'**2Fu<x>_adds <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 debugger information:'#010+
|
'*g1g_generate debugger information:'#010+
|
||||||
'*g2gg_use gsym'#010+
|
'*g2gg_use gsym'#010+
|
||||||
'*g2gd_use dbx'#010+
|
'*g2gd_use dbx'#010+
|
||||||
'*g2gh_use heap trace unit (for memory leak debugging)'#010+
|
'*g2gh_use heap trace unit (for memory leak ','debugging)'#010+
|
||||||
'*g2gl_use line info unit to show more info for backtrace','s'#010+
|
'*g2gl_use line info unit to show more info for backtraces'#010+
|
||||||
'*g2gc_generate checks for pointers'#010+
|
'*g2gc_generate checks for pointers'#010+
|
||||||
'**1i_information'#010+
|
'**1i_information'#010+
|
||||||
'**2iD_return compiler date'#010+
|
'**2iD_return compiler date'#010+
|
||||||
'**2iV_return compiler version'#010+
|
'**2iV_return compiler version'#010+
|
||||||
'**2iSO_return compiler OS'#010+
|
'**2iSO_return compiler OS'#010+
|
||||||
'**2iSP_return compiler processor'#010+
|
'**2iSP_return compiler processor'#010+
|
||||||
'**2iTO_return target OS'#010+
|
'**2','iTO_return target OS'#010+
|
||||||
'**2iTP_return target processor'#010+
|
'**2iTP_return target processor'#010+
|
||||||
'**1I<x>_adds <x','> to include path'#010+
|
'**1I<x>_adds <x> to include path'#010+
|
||||||
'**1k<x>_Pass <x> to the linker'#010+
|
'**1k<x>_Pass <x> to the linker'#010+
|
||||||
'**1l_write logo'#010+
|
'**1l_write logo'#010+
|
||||||
'**1n_don'#039't read the default config file'#010+
|
'**1n_don'#039't read the default config file'#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+
|
||||||
'**1pg_generate profile code for gprof (defines FPC_PROFILE)'#010+
|
'**1pg_gene','rate profile code for gprof (defines FPC_PROFILE)'#010+
|
||||||
'*L1P_use pipes in','stead of creating temporary assembler files'#010+
|
'*L1P_use pipes instead of creating temporary assembler files'#010+
|
||||||
'**1S<x>_syntax options:'#010+
|
'**1S<x>_syntax options:'#010+
|
||||||
'**2S2_switch some Delphi 2 extensions on'#010+
|
'**2S2_switch some Delphi 2 extensions on'#010+
|
||||||
'**2Sc_supports operators like C (*=,+=,/= and -=)'#010+
|
'**2Sc_supports operators like C (*=,+=,/= and -=)'#010+
|
||||||
'**2Sa_include assertion code.'#010+
|
'**2Sa_include ','assertion code.'#010+
|
||||||
'**2Sd_tries to be Delphi compatible'#010+
|
'**2Sd_tries to be Delphi compatible'#010+
|
||||||
'**2Se<x>_compil','er stops after the <x> errors (default is 1)'#010+
|
'**2Se<x>_compiler stops after the <x> errors (default is 1)'#010+
|
||||||
'**2Sg_allow LABEL and GOTO'#010+
|
'**2Sg_allow LABEL and GOTO'#010+
|
||||||
'**2Sh_Use ansistrings'#010+
|
'**2Sh_Use ansistrings'#010+
|
||||||
'**2Si_support C++ styled INLINE'#010+
|
'**2Si_support C++ styled INLINE'#010+
|
||||||
'**2Sm_support macros like C (global)'#010+
|
'**2Sm_support macros like C (global)'#010+
|
||||||
'**2So_tries to be TP/BP 7.0 compatible'#010+
|
'**2So_trie','s to be TP/BP 7.0 compatible'#010+
|
||||||
'**2Sp_tries to be gpc compatible'#010+
|
'**2Sp_tries to be gpc compatible'#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+
|
||||||
'**1s_don'#039't call assembler and linker (only with -a)'#010+
|
'**1s_don'#039't call assembler and linker (only with -a)'#010+
|
||||||
'**2st_Generate script to link on target'#010+
|
'**2st_Generate script to l','ink on target'#010+
|
||||||
'**2sh_Generate script to link on host'#010+
|
'**2sh_Generate script to link on host'#010+
|
||||||
'**1u<x>_undefin','es the symbol <x>'#010+
|
'**1u<x>_undefines the symbol <x>'#010+
|
||||||
'**1U_unit options:'#010+
|
'**1U_unit options:'#010+
|
||||||
'**2Un_don'#039't check the unit name'#010+
|
'**2Un_don'#039't check the unit name'#010+
|
||||||
'**2Ur_generate release unit files'#010+
|
'**2Ur_generate release unit files'#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 o','f the following letters:'#010+
|
||||||
'**2*_e : Show errors (default) d : S','how debug info'#010+
|
'**2*_e : Show errors (default) d : Show debug info'#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/used files'#010+
|
'**2*_n : Show notes t : Show tried/used files'#010+
|
||||||
'**2*_h : Show hints m : Show defined macros'#010+
|
'**2*_h : Show hints m ',': Show defined macros'#010+
|
||||||
'**2*_i : Show general info p : Show',' compiled procedures'#010+
|
'**2*_i : Show general info p : Show compiled procedures'#010+
|
||||||
'**2*_l : Show linenumbers c : Show conditionals'#010+
|
'**2*_l : Show linenumbers c : Show conditionals'#010+
|
||||||
'**2*_a : Show everything 0 : Show nothing (except errors)'#010+
|
'**2*_a : Show everything 0 : Show nothing (except errors)'#010+
|
||||||
'**2*_b : Show all procedure r : Rhide/GCC compatibility mode'#010+
|
'**2*_b : Show all proce','dure r : Rhide/GCC compatibility mod'+
|
||||||
'**2*_ declaration','s if an error x : Executable info (Win32 only'+
|
'e'#010+
|
||||||
')'#010+
|
'**2*_ declarations if an error x : Executable info (Win32 only)'#010+
|
||||||
'**2*_ occurs'#010+
|
'**2*_ occurs'#010+
|
||||||
'**1X_executable options:'#010+
|
'**1X_executable options:'#010+
|
||||||
'*L2Xc_link with the c library'#010+
|
'*L2Xc_link with the c library'#010+
|
||||||
'**2Xs_strip all symbols from executable'#010+
|
'**2Xs_strip all symbols from executable'#010+
|
||||||
'**2XD_try to link dynamic (defines FPC_LINK_DYNAMIC)'#010+
|
'**2XD_try to',' link dynamic (defines FPC_LINK_DYNAMIC)'#010+
|
||||||
'**2XS_try to link',' static (default) (defines FPC_LINK_STATIC)'#010+
|
'**2XS_try to link static (default) (defines FPC_LINK_STATIC)'#010+
|
||||||
'**2XX_try to link smart (defines FPC_LINK_SMART)'#010+
|
'**2XX_try to link smart (defines FPC_LINK_SMART)'#010+
|
||||||
'**0*_Processor specific options:'#010+
|
'**0*_Processor specific options:'#010+
|
||||||
'3*1A<x>_output format:'#010+
|
'3*1A<x>_output format:'#010+
|
||||||
'3*2Aas_assemble using GNU AS'#010+
|
'3*2Aas_assemb','le using GNU AS'#010+
|
||||||
'3*2Aasaout_assemble using GNU AS for aout (Go32v1)'#010,
|
'3*2Aasaout_assemble using GNU AS for aout (Go32v1)'#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*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 fi','le using Tasm (Borland)'#010+
|
||||||
'3*2Acoff_coff (Go32v2) using internal write','r'#010+
|
'3*2Acoff_coff (Go32v2) using internal writer'#010+
|
||||||
'3*2Apecoff_pecoff (Win32) using internal writer'#010+
|
'3*2Apecoff_pecoff (Win32) using internal writer'#010+
|
||||||
'3*1R<x>_assembler reading style:'#010+
|
'3*1R<x>_assembler reading style:'#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+
|
||||||
'3*2Rdirect_copy assembler text directly to assembler file'#010+
|
'3*2Rdirect_copy ass','embler text directly to assembler file'#010+
|
||||||
'3*1O<x>_optimizations:'#010+
|
'3*1O<x>_optimizations:'#010+
|
||||||
'3*2Og','_generate smaller code'#010+
|
'3*2Og_generate smaller code'#010+
|
||||||
'3*2OG_generate faster code (default)'#010+
|
'3*2OG_generate faster code (default)'#010+
|
||||||
'3*2Or_keep certain variables in registers'#010+
|
'3*2Or_keep certain variables in registers'#010+
|
||||||
'3*2Ou_enable uncertain optimizations (see docs)'#010+
|
'3*2Ou_enable uncertain optimizations (see docs)'#010+
|
||||||
'3*2O1_level 1 optimizations (quick optimizations)'#010+
|
'3*2O1_level 1 optimizat','ions (quick optimizations)'#010+
|
||||||
'3*2O2_level 2 optimizations (-O1 + slowe','r optimizations)'#010+
|
'3*2O2_level 2 optimizations (-O1 + slower optimizations)'#010+
|
||||||
'3*2O3_level 3 optimizations (-O2 repeatedly, max 5 times)'#010+
|
'3*2O3_level 3 optimizations (-O2 repeatedly, max 5 times)'#010+
|
||||||
'3*2Op<x>_target processor:'#010+
|
'3*2Op<x>_target processor:'#010+
|
||||||
'3*3Op1_set target processor to 386/486'#010+
|
'3*3Op1_set target processor to 386/486'#010+
|
||||||
'3*3Op2_set target processor to Pentium/PentiumMMX (tm)'#010+
|
'3*3Op2_set target processor to P','entium/PentiumMMX (tm)'#010+
|
||||||
'3*3Op3_set target processor to PPro/PII/c6x8','6/K6 (tm)'#010+
|
'3*3Op3_set target processor to PPro/PII/c6x86/K6 (tm)'#010+
|
||||||
'3*1T<x>_Target operating system:'#010+
|
'3*1T<x>_Target operating system:'#010+
|
||||||
'3*2TGO32V2_version 2 of DJ Delorie DOS extender'#010+
|
'3*2TGO32V2_version 2 of DJ Delorie DOS extender'#010+
|
||||||
'3*2TWDOSX DOS 32 Bit Extender'#010+
|
'3*2TWDOSX DOS 32 Bit Extender'#010+
|
||||||
'3*2TLINUX_Linux'#010+
|
'3*2TLINUX_Linux'#010+
|
||||||
'3*2Tnetware_Novell Netware Module (experimental)'#010+
|
'3*2Tnetware_Novell Netware Module (e','xperimental)'#010+
|
||||||
'3*2TOS2_OS/2 2.x'#010+
|
'3*2TOS2_OS/2 2.x'#010+
|
||||||
'3*2TSUNOS_SunOS/Solaris'#010+
|
'3*2TSUNOS_SunOS/Solaris'#010+
|
||||||
'3*2TWin32_Win','dows 32 Bit'#010+
|
'3*2TWin32_Windows 32 Bit'#010+
|
||||||
'3*1W<x>_Win32 target options'#010+
|
'3*1W<x>_Win32 target options'#010+
|
||||||
'3*2WB<x>_Set Image base to Hexadecimal <x> value'#010+
|
'3*2WB<x>_Set Image base to Hexadecimal <x> value'#010+
|
||||||
'3*2WC_Specify console type application'#010+
|
'3*2WC_Specify console type application'#010+
|
||||||
'3*2WD_Use DEFFILE to export functions of DLL or EXE'#010+
|
'3*2WD_Use DEFFILE to export functions of DLL',' or EXE'#010+
|
||||||
'3*2WF_Specify full-screen type application (OS/2 only)'#010+
|
'3*2WF_Specify full-screen type application (OS/2 only)'#010+
|
||||||
'3*2W','G_Specify graphic type application'#010+
|
'3*2WG_Specify graphic type application'#010+
|
||||||
'3*2WN_Do not generate relocation code (necessary for debugging)'#010+
|
'3*2WN_Do not generate relocation code (necessary for debugging)'#010+
|
||||||
'3*2WR_Generate relocation code'#010+
|
'3*2WR_Generate relocation code'#010+
|
||||||
'6*1A<x>_output format'#010+
|
'6*1A<x>_output format'#010+
|
||||||
'6*2Aas_Unix o-file using GNU AS'#010+
|
'6*2Aas_Unix o-file us','ing GNU AS'#010+
|
||||||
'6*2Agas_GNU Motorola assembler'#010+
|
'6*2Agas_GNU Motorola assembler'#010+
|
||||||
'6*2Amit_MIT Syntax (old G','AS)'#010+
|
'6*2Amit_MIT Syntax (old GAS)'#010+
|
||||||
'6*2Amot_Standard Motorola assembler'#010+
|
'6*2Amot_Standard Motorola assembler'#010+
|
||||||
'6*1O_optimizations:'#010+
|
'6*1O_optimizations:'#010+
|
||||||
'6*2Oa_turn on the optimizer'#010+
|
'6*2Oa_turn on the optimizer'#010+
|
||||||
'6*2Og_generate smaller code'#010+
|
'6*2Og_generate smaller code'#010+
|
||||||
'6*2OG_generate faster code (default)'#010+
|
'6*2OG_generate faster code (default)'#010+
|
||||||
'6*2Ox_optimize maximum (still BUGGY!!!)'#010+
|
'6*2Ox_optimize maxim','um (still BUGGY!!!)'#010+
|
||||||
'6*2O2_set target processor to a MC68020+'#010+
|
'6*2O2_set target processor to a MC68020+'#010+
|
||||||
'6*1R<x','>_assembler reading style:'#010+
|
'6*1R<x>_assembler reading style:'#010+
|
||||||
'6*2RMOT_read motorola style assembler'#010+
|
'6*2RMOT_read motorola style assembler'#010+
|
||||||
'6*1T<x>_Target operating system:'#010+
|
'6*1T<x>_Target operating system:'#010+
|
||||||
'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*2TMACOS_Macintosh m68k'#010+
|
'6*2TMACOS_Macintosh m68','k'#010+
|
||||||
'6*2TLINUX_Linux-68k'#010+
|
'6*2TLINUX_Linux-68k'#010+
|
||||||
'6*2TPALMOS_PalmOS'#010+
|
'6*2TPALMOS_PalmOS'#010+
|
||||||
'**1*_'#010+
|
'**1*_'#010+
|
||||||
'**1?_shows this help'#010,
|
'**1?_shows this help'#010+
|
||||||
'**1h_shows this help without waiting'#000
|
'**1h_shows this help without waiting'#000
|
||||||
);
|
);
|
||||||
|
@ -1863,9 +1863,9 @@ implementation
|
|||||||
if (right.nodetype=typen) then
|
if (right.nodetype=typen) then
|
||||||
begin
|
begin
|
||||||
if tobjectdef(left.resulttype.def).isiidguidvalid then
|
if tobjectdef(left.resulttype.def).isiidguidvalid then
|
||||||
right:=cguidconstnode.create(tobjectdef(left.resulttype.def).iidguid)
|
right:=cguidconstnode.create(tobjectdef(left.resulttype.def).iidguid)
|
||||||
else
|
else
|
||||||
internalerror(200206282);
|
internalerror(200206282);
|
||||||
resulttypepass(right);
|
resulttypepass(right);
|
||||||
end;
|
end;
|
||||||
end
|
end
|
||||||
@ -1893,7 +1893,10 @@ begin
|
|||||||
end.
|
end.
|
||||||
{
|
{
|
||||||
$Log$
|
$Log$
|
||||||
Revision 1.65 2002-07-29 21:23:42 florian
|
Revision 1.66 2002-08-09 07:33:01 florian
|
||||||
|
* a couple of interface related fixes
|
||||||
|
|
||||||
|
Revision 1.65 2002/07/29 21:23:42 florian
|
||||||
* more fixes for the ppc
|
* more fixes for the ppc
|
||||||
+ wrappers for the tcnvnode.first_* stuff introduced
|
+ wrappers for the tcnvnode.first_* stuff introduced
|
||||||
|
|
||||||
|
@ -28,7 +28,7 @@ unit nobj;
|
|||||||
interface
|
interface
|
||||||
|
|
||||||
uses
|
uses
|
||||||
cutils,cclasses,
|
cutils,cclasses,cpuinfo,
|
||||||
symdef,aasmbase,aasmtai,aasmcpu;
|
symdef,aasmbase,aasmtai,aasmcpu;
|
||||||
|
|
||||||
type
|
type
|
||||||
@ -99,6 +99,11 @@ interface
|
|||||||
procedure gintfdoonintf(intf: tobjectdef; intfindex: longint);
|
procedure gintfdoonintf(intf: tobjectdef; intfindex: longint);
|
||||||
procedure gintfwalkdowninterface(intf: tobjectdef; intfindex: longint);
|
procedure gintfwalkdowninterface(intf: tobjectdef; intfindex: longint);
|
||||||
protected
|
protected
|
||||||
|
{ adjusts the self value with ioffset when casting a interface
|
||||||
|
to a class
|
||||||
|
}
|
||||||
|
procedure adjustselfvalue(procdef: tprocdef;ioffset: aword);virtual;
|
||||||
|
{ generates the wrapper for a call to a method via an interface }
|
||||||
procedure cgintfwrapper(asmlist: TAAsmoutput; procdef: tprocdef; const labelname: string; ioffset: longint);virtual;abstract;
|
procedure cgintfwrapper(asmlist: TAAsmoutput; procdef: tprocdef; const labelname: string; ioffset: longint);virtual;abstract;
|
||||||
public
|
public
|
||||||
constructor create(c:tobjectdef);
|
constructor create(c:tobjectdef);
|
||||||
@ -135,11 +140,11 @@ implementation
|
|||||||
strings,
|
strings,
|
||||||
{$endif}
|
{$endif}
|
||||||
globtype,globals,verbose,
|
globtype,globals,verbose,
|
||||||
symtable,symconst,symtype,symsym,defbase,
|
symtable,symconst,symtype,symsym,defbase,paramgr,
|
||||||
{$ifdef GDB}
|
{$ifdef GDB}
|
||||||
gdb,
|
gdb,
|
||||||
{$endif GDB}
|
{$endif GDB}
|
||||||
cpuinfo
|
cpubase,cgbase,cginfo,cgobj,rgobj
|
||||||
;
|
;
|
||||||
|
|
||||||
|
|
||||||
@ -793,7 +798,7 @@ implementation
|
|||||||
proccount:=implintf.implproccount(intfindex);
|
proccount:=implintf.implproccount(intfindex);
|
||||||
for i:=1 to proccount do
|
for i:=1 to proccount do
|
||||||
begin
|
begin
|
||||||
tmps:=implintf.implprocs(intfindex,i).mangledname+'_$_'+curintf.objname^;
|
tmps:=mangledname_prefix('WRPR',_class.owner)+_class.objname^+'_$_'+curintf.objname^+'_$_'+implintf.implprocs(intfindex,i).mangledname;
|
||||||
{ create wrapper code }
|
{ create wrapper code }
|
||||||
cgintfwrapper(rawcode,implintf.implprocs(intfindex,i),tmps,implintf.ioffsets(intfindex)^);
|
cgintfwrapper(rawcode,implintf.implprocs(intfindex,i),tmps,implintf.ioffsets(intfindex)^);
|
||||||
{ create reference }
|
{ create reference }
|
||||||
@ -1031,7 +1036,7 @@ implementation
|
|||||||
if assigned(implprocdef) then
|
if assigned(implprocdef) then
|
||||||
_class.implementedinterfaces.addimplproc(intfindex,implprocdef)
|
_class.implementedinterfaces.addimplproc(intfindex,implprocdef)
|
||||||
else
|
else
|
||||||
Message1(sym_e_id_not_found,procname);
|
Message1(sym_e_no_matching_implementation_found,proc.fullprocnamewithret);
|
||||||
end;
|
end;
|
||||||
end;
|
end;
|
||||||
end;
|
end;
|
||||||
@ -1263,13 +1268,35 @@ implementation
|
|||||||
dataSegment.concat(Tai_symbol_end.Createname(_class.vmt_mangledname));
|
dataSegment.concat(Tai_symbol_end.Createname(_class.vmt_mangledname));
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
procedure tclassheader.adjustselfvalue(procdef: tprocdef;ioffset: aword);
|
||||||
|
var
|
||||||
|
href : treference;
|
||||||
|
l : tparalocation;
|
||||||
|
begin
|
||||||
|
l:=paramanager.getselflocation(procdef);
|
||||||
|
case l.loc of
|
||||||
|
LOC_REGISTER:
|
||||||
|
cg.a_op_const_reg(exprasmlist,OP_SUB,ioffset,l.register);
|
||||||
|
LOC_REFERENCE:
|
||||||
|
begin
|
||||||
|
reference_reset_base(href,l.reference.index,l.reference.offset);
|
||||||
|
cg.a_op_const_ref(exprasmlist,OP_SUB,OS_ADDR,ioffset,href);
|
||||||
|
end
|
||||||
|
else
|
||||||
|
internalerror(2002080801);
|
||||||
|
end;
|
||||||
|
end;
|
||||||
|
|
||||||
|
|
||||||
initialization
|
initialization
|
||||||
cclassheader:=tclassheader;
|
cclassheader:=tclassheader;
|
||||||
end.
|
end.
|
||||||
{
|
{
|
||||||
$Log$
|
$Log$
|
||||||
Revision 1.22 2002-07-20 11:57:55 florian
|
Revision 1.23 2002-08-09 07:33:01 florian
|
||||||
|
* a couple of interface related fixes
|
||||||
|
|
||||||
|
Revision 1.22 2002/07/20 11:57:55 florian
|
||||||
* types.pas renamed to defbase.pas because D6 contains a types
|
* types.pas renamed to defbase.pas because D6 contains a types
|
||||||
unit so this would conflicts if D6 programms are compiled
|
unit so this would conflicts if D6 programms are compiled
|
||||||
+ Willamette/SSE2 instructions to assembler added
|
+ Willamette/SSE2 instructions to assembler added
|
||||||
|
@ -33,9 +33,9 @@ unit paramgr;
|
|||||||
symtype,symdef;
|
symtype,symdef;
|
||||||
|
|
||||||
type
|
type
|
||||||
{# This class defines some methods to take care of routine
|
{# This class defines some methods to take care of routine
|
||||||
parameters. It should be overriden for each new processor
|
parameters. It should be overriden for each new processor
|
||||||
}
|
}
|
||||||
tparamanager = class
|
tparamanager = class
|
||||||
{# Returns true if the return value can be put in accumulator }
|
{# Returns true if the return value can be put in accumulator }
|
||||||
function ret_in_acc(def : tdef) : boolean;virtual;
|
function ret_in_acc(def : tdef) : boolean;virtual;
|
||||||
@ -47,27 +47,29 @@ unit paramgr;
|
|||||||
|
|
||||||
function push_high_param(def : tdef) : boolean;virtual;
|
function push_high_param(def : tdef) : boolean;virtual;
|
||||||
|
|
||||||
{# Returns true if a parameter is too large to copy and only
|
{# Returns true if a parameter is too large to copy and only
|
||||||
the address is pushed
|
the address is pushed
|
||||||
}
|
}
|
||||||
function push_addr_param(def : tdef) : boolean;virtual;
|
function push_addr_param(def : tdef) : boolean;virtual;
|
||||||
{# Returns a structure giving the information on
|
{# Returns a structure giving the information on
|
||||||
the storage of the parameter (which must be
|
the storage of the parameter (which must be
|
||||||
an integer parameter)
|
an integer parameter)
|
||||||
|
|
||||||
@param(nr Parameter number of routine, starting from 1)
|
@param(nr Parameter number of routine, starting from 1)
|
||||||
}
|
}
|
||||||
function getintparaloc(nr : longint) : tparalocation;virtual;abstract;
|
function getintparaloc(nr : longint) : tparalocation;virtual;abstract;
|
||||||
procedure create_param_loc_info(p : tabstractprocdef);virtual;abstract;
|
procedure create_param_loc_info(p : tabstractprocdef);virtual;abstract;
|
||||||
|
|
||||||
{#
|
{#
|
||||||
Returns the location where the invisible parameter for structured
|
Returns the location where the invisible parameter for structured
|
||||||
function results will be passed.
|
function results will be passed.
|
||||||
}
|
}
|
||||||
function getfuncretloc(p : tabstractprocdef) : tparalocation;virtual;abstract;
|
function getfuncretloc(p : tabstractprocdef) : tparalocation;virtual;abstract;
|
||||||
{ Returns the self pointer for the give procdef
|
{ Returns the self pointer location for the given tabstractprocdef,
|
||||||
function getfuncretloc(p : tabstractprocdef) : tparalocation;virtual;abstract;
|
when the stack frame is already created. This is used by the code
|
||||||
|
generating the wrappers for implemented interfaces.
|
||||||
}
|
}
|
||||||
|
function getselflocation(p : tabstractprocdef) : tparalocation;virtual;abstract;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure setparalocs(p : tprocdef);
|
procedure setparalocs(p : tprocdef);
|
||||||
@ -173,7 +175,10 @@ end.
|
|||||||
|
|
||||||
{
|
{
|
||||||
$Log$
|
$Log$
|
||||||
Revision 1.8 2002-08-06 20:55:21 florian
|
Revision 1.9 2002-08-09 07:33:02 florian
|
||||||
|
* a couple of interface related fixes
|
||||||
|
|
||||||
|
Revision 1.8 2002/08/06 20:55:21 florian
|
||||||
* first part of ppc calling conventions fix
|
* first part of ppc calling conventions fix
|
||||||
|
|
||||||
Revision 1.7 2002/08/05 18:27:48 carl
|
Revision 1.7 2002/08/05 18:27:48 carl
|
||||||
|
@ -764,27 +764,34 @@ implementation
|
|||||||
end;
|
end;
|
||||||
end;
|
end;
|
||||||
|
|
||||||
|
procedure handleimplementedinterface(implintf : tobjectdef);
|
||||||
|
|
||||||
|
begin
|
||||||
|
if not is_interface(implintf) then
|
||||||
|
begin
|
||||||
|
Message1(type_e_interface_type_expected,implintf.typename);
|
||||||
|
exit;
|
||||||
|
end;
|
||||||
|
if aktclass.implementedinterfaces.searchintf(implintf)<>-1 then
|
||||||
|
Message1(sym_e_duplicate_id,implintf.name)
|
||||||
|
else
|
||||||
|
aktclass.implementedinterfaces.addintf(implintf);
|
||||||
|
end;
|
||||||
|
|
||||||
procedure readimplementedinterfaces;
|
procedure readimplementedinterfaces;
|
||||||
var
|
var
|
||||||
implintf: tobjectdef;
|
|
||||||
tt : ttype;
|
tt : ttype;
|
||||||
begin
|
begin
|
||||||
while try_to_consume(_COMMA) do begin
|
while try_to_consume(_COMMA) do
|
||||||
id_type(tt,pattern,false);
|
begin
|
||||||
implintf:=tobjectdef(tt.def);
|
id_type(tt,pattern,false);
|
||||||
if (tt.def.deftype<>objectdef) then begin
|
if (tt.def.deftype<>objectdef) then
|
||||||
Message1(type_e_interface_type_expected,tt.def.typename);
|
begin
|
||||||
Continue; { omit }
|
Message1(type_e_interface_type_expected,tt.def.typename);
|
||||||
|
continue;
|
||||||
|
end;
|
||||||
|
handleimplementedinterface(tobjectdef(tt.def));
|
||||||
end;
|
end;
|
||||||
if not is_interface(implintf) then begin
|
|
||||||
Message1(type_e_interface_type_expected,implintf.typename);
|
|
||||||
Continue; { omit }
|
|
||||||
end;
|
|
||||||
if aktclass.implementedinterfaces.searchintf(tt.def)<>-1 then
|
|
||||||
Message1(sym_e_duplicate_id,tt.def.name)
|
|
||||||
else
|
|
||||||
aktclass.implementedinterfaces.addintf(tt.def);
|
|
||||||
end;
|
|
||||||
end;
|
end;
|
||||||
|
|
||||||
procedure readinterfaceiid;
|
procedure readinterfaceiid;
|
||||||
@ -810,7 +817,10 @@ implementation
|
|||||||
|
|
||||||
|
|
||||||
procedure readparentclasses;
|
procedure readparentclasses;
|
||||||
|
var
|
||||||
|
hp : tobjectdef;
|
||||||
begin
|
begin
|
||||||
|
hp:=nil;
|
||||||
{ reads the parent class }
|
{ reads the parent class }
|
||||||
if token=_LKLAMMER then
|
if token=_LKLAMMER then
|
||||||
begin
|
begin
|
||||||
@ -821,7 +831,7 @@ implementation
|
|||||||
(childof.deftype<>objectdef) then
|
(childof.deftype<>objectdef) then
|
||||||
begin
|
begin
|
||||||
if assigned(childof) then
|
if assigned(childof) then
|
||||||
Message1(type_e_class_type_expected,childof.typename);
|
Message1(type_e_class_type_expected,childof.typename);
|
||||||
childof:=nil;
|
childof:=nil;
|
||||||
aktclass:=tobjectdef.create(classtype,n,nil);
|
aktclass:=tobjectdef.create(classtype,n,nil);
|
||||||
end
|
end
|
||||||
@ -831,9 +841,19 @@ implementation
|
|||||||
isn't allowed }
|
isn't allowed }
|
||||||
case classtype of
|
case classtype of
|
||||||
odt_class:
|
odt_class:
|
||||||
if not(is_class(childof)) and
|
if not(is_class(childof)) then
|
||||||
not(is_interface(childof)) then
|
begin
|
||||||
Message(parser_e_mix_of_classes_and_objects);
|
if is_interface(childof) then
|
||||||
|
begin
|
||||||
|
{ we insert the interface after the child
|
||||||
|
is set, see below
|
||||||
|
}
|
||||||
|
hp:=childof;
|
||||||
|
childof:=class_tobject;
|
||||||
|
end
|
||||||
|
else
|
||||||
|
Message(parser_e_mix_of_classes_and_objects);
|
||||||
|
end;
|
||||||
odt_interfacecorba,
|
odt_interfacecorba,
|
||||||
odt_interfacecom:
|
odt_interfacecom:
|
||||||
if not(is_interface(childof)) then
|
if not(is_interface(childof)) then
|
||||||
@ -861,7 +881,11 @@ implementation
|
|||||||
else
|
else
|
||||||
aktclass:=tobjectdef.create(classtype,n,childof);
|
aktclass:=tobjectdef.create(classtype,n,childof);
|
||||||
if aktclass.objecttype=odt_class then
|
if aktclass.objecttype=odt_class then
|
||||||
readimplementedinterfaces;
|
begin
|
||||||
|
if assigned(hp) then
|
||||||
|
handleimplementedinterface(hp);
|
||||||
|
readimplementedinterfaces;
|
||||||
|
end;
|
||||||
end;
|
end;
|
||||||
consume(_RKLAMMER);
|
consume(_RKLAMMER);
|
||||||
end
|
end
|
||||||
@ -1133,7 +1157,10 @@ implementation
|
|||||||
end.
|
end.
|
||||||
{
|
{
|
||||||
$Log$
|
$Log$
|
||||||
Revision 1.47 2002-07-20 11:57:55 florian
|
Revision 1.48 2002-08-09 07:33:02 florian
|
||||||
|
* a couple of interface related fixes
|
||||||
|
|
||||||
|
Revision 1.47 2002/07/20 11:57:55 florian
|
||||||
* types.pas renamed to defbase.pas because D6 contains a types
|
* types.pas renamed to defbase.pas because D6 contains a types
|
||||||
unit so this would conflicts if D6 programms are compiled
|
unit so this would conflicts if D6 programms are compiled
|
||||||
+ Willamette/SSE2 instructions to assembler added
|
+ Willamette/SSE2 instructions to assembler added
|
||||||
|
@ -41,7 +41,7 @@ type
|
|||||||
{$endif Test_Double_checksum}
|
{$endif Test_Double_checksum}
|
||||||
|
|
||||||
const
|
const
|
||||||
CurrentPPUVersion=27;
|
CurrentPPUVersion=28;
|
||||||
|
|
||||||
{ buffer sizes }
|
{ buffer sizes }
|
||||||
maxentrysize = 1024;
|
maxentrysize = 1024;
|
||||||
@ -981,7 +981,10 @@ end;
|
|||||||
end.
|
end.
|
||||||
{
|
{
|
||||||
$Log$
|
$Log$
|
||||||
Revision 1.20 2002-05-18 13:34:13 peter
|
Revision 1.21 2002-08-09 07:33:02 florian
|
||||||
|
* a couple of interface related fixes
|
||||||
|
|
||||||
|
Revision 1.20 2002/05/18 13:34:13 peter
|
||||||
* readded missing revisions
|
* readded missing revisions
|
||||||
|
|
||||||
Revision 1.19 2002/05/16 19:46:44 carl
|
Revision 1.19 2002/05/16 19:46:44 carl
|
||||||
|
@ -2561,7 +2561,7 @@ implementation
|
|||||||
function tformaldef.gettypename : string;
|
function tformaldef.gettypename : string;
|
||||||
|
|
||||||
begin
|
begin
|
||||||
gettypename:='Var';
|
gettypename:='<Formal type>';
|
||||||
end;
|
end;
|
||||||
|
|
||||||
{***************************************************************************
|
{***************************************************************************
|
||||||
@ -3251,7 +3251,11 @@ implementation
|
|||||||
begin
|
begin
|
||||||
if hp.paratyp in [vs_var,vs_const,vs_out] then
|
if hp.paratyp in [vs_var,vs_const,vs_out] then
|
||||||
s := s + ' ';
|
s := s + ' ';
|
||||||
s:=s+hp.paratype.def.typesym.realname;
|
hs:=hp.paratype.def.typesym.realname;
|
||||||
|
if hs[1]<>'$' then
|
||||||
|
s:=s+hp.paratype.def.typesym.realname
|
||||||
|
else
|
||||||
|
s:=s+hp.paratype.def.gettypename;
|
||||||
end;
|
end;
|
||||||
{ default value }
|
{ default value }
|
||||||
if assigned(hp.defaultvalue) then
|
if assigned(hp.defaultvalue) then
|
||||||
@ -4135,7 +4139,7 @@ implementation
|
|||||||
if objecttype in [odt_interfacecom,odt_interfacecorba] then
|
if objecttype in [odt_interfacecom,odt_interfacecorba] then
|
||||||
begin
|
begin
|
||||||
isiidguidvalid:=boolean(ppufile.getbyte);
|
isiidguidvalid:=boolean(ppufile.getbyte);
|
||||||
ppufile.putguid(iidguid);
|
ppufile.getguid(iidguid);
|
||||||
iidstr:=stringdup(ppufile.getstring);
|
iidstr:=stringdup(ppufile.getstring);
|
||||||
lastvtableindex:=ppufile.getlongint;
|
lastvtableindex:=ppufile.getlongint;
|
||||||
end;
|
end;
|
||||||
@ -4356,7 +4360,7 @@ implementation
|
|||||||
end;*)
|
end;*)
|
||||||
|
|
||||||
procedure Tobjectdef._searchdestructor(sym:Tnamedindexitem;arg:pointer);
|
procedure Tobjectdef._searchdestructor(sym:Tnamedindexitem;arg:pointer);
|
||||||
|
|
||||||
begin
|
begin
|
||||||
{ if we found already a destructor, then we exit }
|
{ if we found already a destructor, then we exit }
|
||||||
if (sd=nil) and (Tsym(sym).typ=procsym) then
|
if (sd=nil) and (Tsym(sym).typ=procsym) then
|
||||||
@ -5486,7 +5490,10 @@ implementation
|
|||||||
end.
|
end.
|
||||||
{
|
{
|
||||||
$Log$
|
$Log$
|
||||||
Revision 1.85 2002-07-23 09:51:24 daniel
|
Revision 1.86 2002-08-09 07:33:03 florian
|
||||||
|
* a couple of interface related fixes
|
||||||
|
|
||||||
|
Revision 1.85 2002/07/23 09:51:24 daniel
|
||||||
* Tried to make Tprocsym.defs protected. I didn't succeed but the cleanups
|
* Tried to make Tprocsym.defs protected. I didn't succeed but the cleanups
|
||||||
are worth comitting.
|
are worth comitting.
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user