mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-04-17 12:59:24 +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)
|
||||
function getintparaloc(nr : longint) : tparalocation;override;
|
||||
procedure create_param_loc_info(p : tabstractprocdef);override;
|
||||
function getselflocation(p : tabstractprocdef) : tparalocation;override;
|
||||
end;
|
||||
|
||||
implementation
|
||||
@ -60,13 +61,22 @@ unit cpupara;
|
||||
}
|
||||
end;
|
||||
|
||||
function ti386paramanager.getselflocation(p : tabstractprocdef) : tparalocation;
|
||||
begin
|
||||
getselflocation.loc:=LOC_REFERENCE;
|
||||
getselflocation.reference.index:=R_ESP;
|
||||
getselflocation.reference.offset:=4;
|
||||
end;
|
||||
|
||||
begin
|
||||
paramanager:=ti386paramanager.create;
|
||||
end.
|
||||
{
|
||||
$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
|
||||
|
||||
Revision 1.1 2002/07/07 09:52:33 florian
|
||||
|
@ -107,15 +107,6 @@ procedure ti386classheader.cgintfwrapper(asmlist: TAAsmoutput; procdef: tprocdef
|
||||
Internalerror(200006139);
|
||||
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);
|
||||
var
|
||||
href : treference;
|
||||
@ -183,7 +174,7 @@ begin
|
||||
exprasmList.concat(Tai_symbol.Createname(labelname,0));
|
||||
|
||||
{ set param1 interface to self }
|
||||
adjustselfvalue(ioffset);
|
||||
adjustselfvalue(procdef,ioffset);
|
||||
|
||||
{ case 1 or 2 }
|
||||
if (po_clearstack in procdef.procoptions) then
|
||||
@ -197,7 +188,7 @@ begin
|
||||
else { case 1 }
|
||||
cg.a_call_name(exprasmlist,procdef.mangledname);
|
||||
{ restore param1 value self to interface }
|
||||
adjustselfvalue(-ioffset);
|
||||
adjustselfvalue(procdef,-ioffset);
|
||||
end
|
||||
{ case 3 }
|
||||
else if [po_virtualmethod,po_saveregisters]*procdef.procoptions=[po_virtualmethod,po_saveregisters] then
|
||||
@ -237,7 +228,10 @@ initialization
|
||||
end.
|
||||
{
|
||||
$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
|
||||
|
||||
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.
|
||||
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.
|
||||
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}
|
||||
#
|
||||
# Codegenerator
|
||||
|
@ -344,6 +344,7 @@ const
|
||||
sym_e_id_no_member=05038;
|
||||
sym_b_param_list=05039;
|
||||
sym_e_segment_too_large=05040;
|
||||
sym_e_no_matching_implementation_found=05041;
|
||||
cg_e_break_not_allowed=06000;
|
||||
cg_e_continue_not_allowed=06001;
|
||||
cg_e_too_complex_expr=06002;
|
||||
@ -608,9 +609,9 @@ const
|
||||
option_info=11024;
|
||||
option_help_pages=11025;
|
||||
|
||||
MsgTxtSize = 34117;
|
||||
MsgTxtSize = 34184;
|
||||
|
||||
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
|
||||
);
|
||||
|
@ -386,454 +386,456 @@ const msgtxt : array[0..000142,1..240] of char=(
|
||||
'05038_E_identifier idents no member "$1"'#000+
|
||||
'05039_B_Found declaration: $1'#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+
|
||||
'06001_E_CONTINUE not allowed'#000+
|
||||
'06002_E_Expression too complicated - FPU stack overflow'#000+
|
||||
'06003_E_Illegal expression'#000+
|
||||
'06004_E_Invalid integer expression'#000+
|
||||
'06004_E_Invalid integer ex','pression'#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+
|
||||
'06008_E_Can'#039't determine which overloaded function to call'#000+
|
||||
'06009_E_Parameter list size exceeds 65535 bytes'#000+
|
||||
'06010_E_Illegal type conversion'#000+
|
||||
'06011_D_Conversion between ordinals and pointers is not po','rtable acr'+
|
||||
'oss platforms'#000+
|
||||
'06010_E_Illegal type co','nversion'#000+
|
||||
'06011_D_Conversion between ordinals and pointers is not portable acros'+
|
||||
's platforms'#000+
|
||||
'06012_E_File types must be var parameters'#000+
|
||||
'06013_E_The use of a far pointer isn'#039't allowed there'#000+
|
||||
'06014_E_illegal call by reference parameters'#000+
|
||||
'06015_E_EXPORT declared functions can'#039't be called'#000+
|
||||
'06016_W_Possible illegal c','all of constructor or destructor (doesn'#039+
|
||||
't match to this context)'#000+
|
||||
'06015_E_E','XPORT declared functions can'#039't be called'#000+
|
||||
'06016_W_Possible illegal call of constructor or destructor (doesn'#039't'+
|
||||
' match to this context)'#000+
|
||||
'06017_N_Inefficient code'#000+
|
||||
'06018_W_unreachable code'#000+
|
||||
'06019_E_procedure call with stackframe ESP/SP'#000+
|
||||
'06020_E_Abstract methods can'#039't be called directly'#000+
|
||||
'06021_F_Internal Error in get','floatreg(), allocation failure'#000+
|
||||
'06020_E_Abst','ract methods can'#039't be called directly'#000+
|
||||
'06021_F_Internal Error in getfloatreg(), allocation failure'#000+
|
||||
'06022_F_Unknown float type'#000+
|
||||
'06023_F_SecondVecn() base defined twice'#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+
|
||||
'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+
|
||||
'06029_D_Stack frame is omitted'#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+
|
||||
'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'+
|
||||
'sed, use (set)length instead'#000+
|
||||
'06036_E_Include and exclude not implemented in this case'#000+
|
||||
'06037_E_Constructors or destruct','ors can not be called inside a '#039'w'+
|
||||
'ith'#039' clause'#000+
|
||||
'06036_E_Include and ex','clude not implemented in this case'#000+
|
||||
'06037_E_Constructors or destructors can not be called inside a '#039'wi'+
|
||||
'th'#039' clause'#000+
|
||||
'06038_E_Cannot call message handler method directly'#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+
|
||||
'07000_D_Starting $1 styled a','ssembler parsing'#000+
|
||||
'06040_E_Control flow statem','ents aren'#039't allowed in a finally bloc'+
|
||||
'k'#000+
|
||||
'07000_D_Starting $1 styled assembler parsing'#000+
|
||||
'07001_D_Finished $1 styled assembler parsing'#000+
|
||||
'07002_E_Non-label pattern contains @'#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+
|
||||
'07006_E_TYPE used without',' identifier'#000+
|
||||
'07006_E_TYPE used without identifier'#000+
|
||||
'07007_E_Cannot use local variable or parameters here'#000+
|
||||
'07008_E_need to use OFFSET here'#000+
|
||||
'07009_E_need to use $ here'#000+
|
||||
'07010_E_Cannot use multiple relocatable symbols'#000+
|
||||
'07011_E_Relocatable symbol can only be added'#000+
|
||||
'07012_E_Invalid constan','t expression'#000+
|
||||
'0','7011_E_Relocatable symbol can only be added'#000+
|
||||
'07012_E_Invalid constant expression'#000+
|
||||
'07013_E_Relocatable symbol is not allowed'#000+
|
||||
'07014_E_Invalid reference syntax'#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+
|
||||
'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+
|
||||
'07020_E_Multiple index register usage'#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+
|
||||
'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+
|
||||
'07026_E_Illegal expression'#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+
|
||||
'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+
|
||||
'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+
|
||||
'07035_E_Error c','onverting decimal $1'#000+
|
||||
'07035_E_Error converting decimal $1'#000+
|
||||
'07036_E_Error converting octal $1'#000+
|
||||
'07037_E_Error converting binary $1'#000+
|
||||
'07038_E_Error converting hexadecimal $1'#000+
|
||||
'07039_H_$1 translated to $2'#000+
|
||||
'07040_W_$1 is associated to an overloaded function'#000+
|
||||
'07041_E_Cannot use SELF outside',' a method'#000+
|
||||
'07040_W_$1 is a','ssociated to an overloaded function'#000+
|
||||
'07041_E_Cannot use SELF outside a method'#000+
|
||||
'07042_E_Cannot use OLDEBP outside a nested procedure'#000+
|
||||
'07043_W_Procedures can'#039't return any value in asm code'#000+
|
||||
'07044_E_SEG not supported'#000+
|
||||
'07045_E_Size suffix and destination or source size do not match'#000+
|
||||
'07046_W_Size suffix and destinati','on 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 destination or source size do not match'#000+
|
||||
'07047_E_Assembler syntax error'#000+
|
||||
'07048_E_Invalid combination of opcode and operands'#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+
|
||||
'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+
|
||||
'07054_E_Invalid or missing opcode'#000+
|
||||
'07055_E_Invalid combination of prefix and opcode: $1'#000+
|
||||
'07056_E_Invalid combination of override and opcode: $1'#000+
|
||||
'07057_E_Too many oper','ands on line'#000+
|
||||
'07056_E_I','nvalid combination of override and opcode: $1'#000+
|
||||
'07057_E_Too many operands on line'#000+
|
||||
'07058_W_NEAR ignored'#000+
|
||||
'07059_W_FAR ignored'#000+
|
||||
'07060_E_Duplicate local symbol $1'#000+
|
||||
'07061_E_Undefined local symbol $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+
|
||||
'07065_E','_NOR not supported'#000+
|
||||
'07065_E_NOR not supported'#000+
|
||||
'07066_W_Modulo not supported'#000+
|
||||
'07067_E_Invalid floating point constant $1'#000+
|
||||
'07068_E_Invalid floating point expression'#000+
|
||||
'07069_E_Wrong symbol type'#000+
|
||||
'07070_E_Cannot index a local var or parameter with a register'#000+
|
||||
'07071_E_Invalid seg','ment override expression'#000+
|
||||
'07070_E_Cannot',' index a local var or parameter with a register'#000+
|
||||
'07071_E_Invalid segment override expression'#000+
|
||||
'07072_W_Identifier $1 supposed external'#000+
|
||||
'07073_E_Strings not allowed as constants'#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+
|
||||
'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+
|
||||
'07079_W_32bit constant created for address'#000+
|
||||
'07080_N_.align is target specific, use .balign or .p2align'#000+
|
||||
'07081_E_Can'#039't access fields directly for par','ameters'#000+
|
||||
'07080_N_.align is target specific, u','se .balign or .p2align'#000+
|
||||
'07081_E_Can'#039't access fields directly for parameters'#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'+
|
||||
'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+
|
||||
'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+
|
||||
'07088_W_"$1 %st(n)" translated into "$1 %st(n),%st"'#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+
|
||||
'07092_E_Inva','lid XDEF syntax'#000+
|
||||
'07092_E_Invalid XDEF syntax'#000+
|
||||
'07093_W_ALIGN not supported'#000+
|
||||
'07094_E_Inc and Dec cannot be together'#000+
|
||||
'07095_E_Invalid reglist for movem'#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+
|
||||
'08001_F_Selected assembler ','output not supported'#000+
|
||||
'08001_F_Selected assembler output not supported'#000+
|
||||
'08002_F_Comp not supported'#000+
|
||||
'08003_F_Direct not support for binary writers'#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+
|
||||
'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+
|
||||
'08009_E_Asm: Invalid effective address'#000+
|
||||
'08010_E_Asm: Immediate or reference expected'#000+
|
||||
'08011_E_Asm: $1 value exceeds bounds $2'#000+
|
||||
'08012_E_Asm: Short jump is out',' of range $1'#000+
|
||||
'080','11_E_Asm: $1 value exceeds bounds $2'#000+
|
||||
'08012_E_Asm: Short jump is out of range $1'#000+
|
||||
'08013_E_Asm: Undefined label $1'#000+
|
||||
'08014_E_Asm: Comp 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+
|
||||
'09001_I_Ass','embling (pipe) $1'#000+
|
||||
'09001_I_Assembling (pipe) $1'#000+
|
||||
'09002_E_Can'#039't create assember file: $1'#000+
|
||||
'09003_E_Can'#039't create object 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+
|
||||
'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'+
|
||||
'ssembling'#000+
|
||||
'09009_I_Assembling $1'#000+
|
||||
'09010_I_Assembling smartlink $1'#000+
|
||||
'09011_W_Object $1 not found, Linking may fail !'#000+
|
||||
'09012_W_Library $1 not found, Link','ing may fail !'#000+
|
||||
'09011_W_Object ','$1 not found, Linking may fail !'#000+
|
||||
'09012_W_Library $1 not found, Linking may fail !'#000+
|
||||
'09013_E_Error while linking'#000+
|
||||
'09014_E_Can'#039't call the linker, switching to external linking'#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+
|
||||
'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+
|
||||
'09020_I_Closing script $1'#000+
|
||||
'09021_E_resource compiler not found, switching to external mode'#000+
|
||||
'09022_I_Compiling resource $1'#000+
|
||||
'09023_T_unit $1 can'#039't be static linked, switching to ','smart linki'+
|
||||
'ng'#000+
|
||||
'09022_I_Compilin','g resource $1'#000+
|
||||
'09023_T_unit $1 can'#039't be static linked, switching to smart linking'+
|
||||
#000+
|
||||
'09024_T_unit $1 can'#039't be smart linked, switching to static linking'+
|
||||
#000+
|
||||
'09025_T_unit $1 can'#039't be shared linked, switching to static linkin'+
|
||||
'g'#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+
|
||||
'09026_E_unit $1 can'#039't be',' smart or static linked'#000+
|
||||
'09027_E_unit $1 can'#039't be shared or static linked'#000+
|
||||
'09028_F_Can'#039't post process executable $1'#000+
|
||||
'09029_F_Can'#039't open executable $1'#000+
|
||||
'09030_X_Size of Code: $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+
|
||||
'09','034_X_Stack space commited: $1 bytes'#000+
|
||||
'09034_X_Stack space commited: $1 bytes'#000+
|
||||
'10000_T_Unitsearch: $1'#000+
|
||||
'10001_T_PPU Loading $1'#000+
|
||||
'10002_U_PPU Name: $1'#000+
|
||||
'10003_U_PPU Flags: $1'#000+
|
||||
'10004_U_PPU Crc: $1'#000+
|
||||
'10005_U_PPU Time: $1'#000+
|
||||
'10006_U_PPU File too short'#000+
|
||||
'10007_U_PPU Invalid Header (no PPU at the begi','n)'#000+
|
||||
'10006_','U_PPU File too short'#000+
|
||||
'10007_U_PPU Invalid Header (no PPU at the begin)'#000+
|
||||
'10008_U_PPU Invalid Version $1'#000+
|
||||
'10009_U_PPU is compiled for an other processor'#000+
|
||||
'10010_U_PPU is compiled for an other target'#000+
|
||||
'10011_U_PPU Source: $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+
|
||||
'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+
|
||||
'10017_F_PPU Dbx count problem'#000+
|
||||
'10018_E_Illegal unit name: $1'#000+
|
||||
'10019_F_Too much units'#000+
|
||||
'10020_F_Circular unit reference between $1 and $2'#000+
|
||||
'10021_F_Can'#039't compile unit $1, no sources availabl','e'#000+
|
||||
'10020_F_Circular unit reference b','etween $1 and $2'#000+
|
||||
'10021_F_Can'#039't compile unit $1, no sources available'#000+
|
||||
'10022_F_Can'#039't find unit $1'#000+
|
||||
'10023_W_Unit $1 was not found but $2 exists'#000+
|
||||
'10024_F_Unit $1 searched but $2 found'#000+
|
||||
'10025_W_Compiling the system unit requires the -Us switch'#000+
|
||||
'10026_F_There were $1 errors compiling module, stopping'#000+
|
||||
'10027_U_Load fr','om $1 ($2) unit $3'#000+
|
||||
'1002','6_F_There were $1 errors compiling module, stopping'#000+
|
||||
'10027_U_Load from $1 ($2) unit $3'#000+
|
||||
'10028_U_Recompiling $1, checksum changed for $2'#000+
|
||||
'10029_U_Recompiling $1, source found only'#000+
|
||||
'10030_U_Recompiling unit, static 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+
|
||||
'10031','_U_Recompiling unit, shared lib is 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+
|
||||
'10034_U_Parsing interface 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+
|
||||
'10038_H_C','onditional $1 was not set at startup in last compilation of'+
|
||||
' $2'#000+
|
||||
'10038_H_Conditional $1 was not 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+
|
||||
'10041_H_File $1 is newer than Release PPU fi','le $2'#000+
|
||||
'10040_W_Can'#039't recompile unit $1, but found',' modifed include files'+
|
||||
#000+
|
||||
'10041_H_File $1 is newer than Release PPU file $2'#000+
|
||||
'11000_$1 [options] <inputfile> [options]'#000+
|
||||
'11001_W_Only one source file supported'#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+
|
||||
'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+
|
||||
'11007_H_-? writes help pages'#000+
|
||||
'11008_F_Too many config files nested'#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+
|
||||
'11012_W_Shar','ed libs not supported on DOS platform, reverting to stat'+
|
||||
'ic'#000+
|
||||
'11012_W_Shared libs not supported on DOS platform, reverting to static'+
|
||||
#000+
|
||||
'11013_F_too many IF(N)DEFs'#000+
|
||||
'11014_F_too many ENDIFs'#000+
|
||||
'11015_F_open conditional at the end of the file'#000+
|
||||
'11016_W_Debug information generation is not supported by this executab'+
|
||||
'le'#000+
|
||||
'11017_H_T','ry recompiling with -dGDB'#000+
|
||||
'11016_W_Debug i','nformation generation is not supported by this execut'+
|
||||
'able'#000+
|
||||
'11017_H_Try recompiling with -dGDB'#000+
|
||||
'11018_E_You are using the obsolete switch $1'#000+
|
||||
'11019_E_You are using the obsolete switch $1, please use $2'#000+
|
||||
'11020_N_Switching assembler to default source writing assembler'#000+
|
||||
'11021_W_Assembler output selected "$1" is not',' compatible with "$2"'#000+
|
||||
'11020_N_Switching assembler to default sou','rce writing assembler'#000+
|
||||
'11021_W_Assembler output selected "$1" is not compatible with "$2"'#000+
|
||||
'11022_W_"$1" assembler use forced'#000+
|
||||
'11026_T_Reading options from file $1'#000+
|
||||
'11027_T_Reading options from environment $1'#000+
|
||||
'11028_D_Handling option "$1"'#000+
|
||||
'11029__*** press enter ***'#000+
|
||||
'11029__','*** press enter ***'#000+
|
||||
'11030_E_Unknown code page'#000+
|
||||
'11023_Free Pascal Com','piler version $FPCVER [$FPCDATE] for $FPCTARGET'+
|
||||
#010+
|
||||
'11023_Free Pascal Compiler version $FPCVER [$FPCDATE] for $FPCTARGET'#010+
|
||||
'Copyright (c) 1993-2002 by Florian Klaempfl'#000+
|
||||
'11024_Free Pascal Compiler version $FPCVER'#010+
|
||||
#010+
|
||||
'Compiler Date : $FPCDATE'#010+
|
||||
'Compiler Target: $FPCTARGET'#010+
|
||||
'Compiler Ta','rget: $FPCTARGET'#010+
|
||||
#010+
|
||||
'Supported targets:'#010+
|
||||
' $OSTARGETS'#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+
|
||||
#010+
|
||||
'Report bugs,suggestions etc to:'#010+
|
||||
' bugrep@freepascal.org'#000+
|
||||
'11025_**0*_put + after a boolean switch option to enable it, - to disa'+
|
||||
'ble it'#010+
|
||||
'**1a_the comp','iler doesn'#039't delete the generated assembler file'#010+
|
||||
'11025_**0*_put + after ','a boolean switch option to enable it, - to di'+
|
||||
'sable it'#010+
|
||||
'**1a_the compiler doesn'#039't delete the generated assembler file'#010+
|
||||
'**2al_list sourcecode lines in assembler file'#010+
|
||||
'**2ar_list register allocation/release info in assembler file'#010+
|
||||
'**2at_list temp allocation/release info in assembler file'#010+
|
||||
'**1b_generate browser inf','o'#010+
|
||||
'**2at_list temp ','allocation/release info in assembler file'#010+
|
||||
'**1b_generate browser info'#010+
|
||||
'**2bl_generate local symbol info'#010+
|
||||
'**1B_build all modules'#010+
|
||||
'**1C<x>_code generation options:'#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+
|
||||
'**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_verify object method call validity'#010+
|
||||
'**2Cs<n>_set stack size to <n>'#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+
|
||||
'*O1D_generate a DE','F file'#010+
|
||||
'*O1D_generate a DEF file'#010+
|
||||
'*O2Dd<x>_set description to <x>'#010+
|
||||
'*O2Dw_PM application'#010+
|
||||
'**1e<x>_set path to executable'#010+
|
||||
'**1E_same as -Cn'#010+
|
||||
'**1F<x>_set file names and paths:'#010+
|
||||
'**2FD<x>_sets the directory where to search for compiler utilities'#010+
|
||||
'**2Fe<x>_redirect error output ','to <x>'#010+
|
||||
'**2FD<x>_sets the directory whe','re to search for compiler utilities'#010+
|
||||
'**2Fe<x>_redirect error output to <x>'#010+
|
||||
'**2FE<x>_set exe/unit output path to <x>'#010+
|
||||
'**2Fi<x>_adds <x> to include path'#010+
|
||||
'**2Fl<x>_adds <x> to library path'#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+
|
||||
'**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+
|
||||
'*g1g_generate debugger information:'#010+
|
||||
'*g2gg_use gsym'#010+
|
||||
'*g2gd_use dbx'#010+
|
||||
'*g2gh_use heap trace unit (for memory leak debugging)'#010+
|
||||
'*g2gl_use line info unit to show more info for backtrace','s'#010+
|
||||
'*g2gh_use heap trace unit (for memory leak ','debugging)'#010+
|
||||
'*g2gl_use line info unit to show more info for backtraces'#010+
|
||||
'*g2gc_generate checks for pointers'#010+
|
||||
'**1i_information'#010+
|
||||
'**2iD_return compiler date'#010+
|
||||
'**2iV_return compiler version'#010+
|
||||
'**2iSO_return compiler OS'#010+
|
||||
'**2iSP_return compiler processor'#010+
|
||||
'**2iTO_return target OS'#010+
|
||||
'**2','iTO_return target OS'#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+
|
||||
'**1l_write logo'#010+
|
||||
'**1n_don'#039't read the default config file'#010+
|
||||
'**1o<x>_change the name of the executable produced to <x>'#010+
|
||||
'**1pg_generate profile code for gprof (defines FPC_PROFILE)'#010+
|
||||
'*L1P_use pipes in','stead of creating temporary assembler files'#010+
|
||||
'**1pg_gene','rate profile code for gprof (defines FPC_PROFILE)'#010+
|
||||
'*L1P_use pipes instead of creating temporary assembler files'#010+
|
||||
'**1S<x>_syntax options:'#010+
|
||||
'**2S2_switch some Delphi 2 extensions on'#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+
|
||||
'**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+
|
||||
'**2Sh_Use ansistrings'#010+
|
||||
'**2Si_support C++ styled INLINE'#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+
|
||||
'**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+
|
||||
'**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+
|
||||
'**1u<x>_undefin','es the symbol <x>'#010+
|
||||
'**1u<x>_undefines the symbol <x>'#010+
|
||||
'**1U_unit options:'#010+
|
||||
'**2Un_don'#039't check the unit name'#010+
|
||||
'**2Ur_generate release unit files'#010+
|
||||
'**2Us_compile a system unit'#010+
|
||||
'**1v<x>_Be verbose. <x> is a combination of the following letters:'#010+
|
||||
'**2*_e : Show errors (default) d : S','how debug info'#010+
|
||||
'**1v<x>_Be verbose. <x> is a combination o','f the following letters:'#010+
|
||||
'**2*_e : Show errors (default) d : Show debug info'#010+
|
||||
'**2*_w : Show warnings u : Show unit info'#010+
|
||||
'**2*_n : Show notes t : Show tried/used files'#010+
|
||||
'**2*_h : Show hints m : Show defined macros'#010+
|
||||
'**2*_i : Show general info p : Show',' compiled procedures'#010+
|
||||
'**2*_h : Show hints m ',': Show defined macros'#010+
|
||||
'**2*_i : Show general info p : Show compiled procedures'#010+
|
||||
'**2*_l : Show linenumbers c : Show conditionals'#010+
|
||||
'**2*_a : Show everything 0 : Show nothing (except errors)'#010+
|
||||
'**2*_b : Show all procedure r : Rhide/GCC compatibility mode'#010+
|
||||
'**2*_ declaration','s if an error x : Executable info (Win32 only'+
|
||||
')'#010+
|
||||
'**2*_b : Show all proce','dure r : Rhide/GCC compatibility mod'+
|
||||
'e'#010+
|
||||
'**2*_ declarations if an error x : Executable info (Win32 only)'#010+
|
||||
'**2*_ occurs'#010+
|
||||
'**1X_executable options:'#010+
|
||||
'*L2Xc_link with the c library'#010+
|
||||
'**2Xs_strip all symbols from executable'#010+
|
||||
'**2XD_try to link dynamic (defines FPC_LINK_DYNAMIC)'#010+
|
||||
'**2XS_try to link',' static (default) (defines FPC_LINK_STATIC)'#010+
|
||||
'**2XD_try to',' link dynamic (defines FPC_LINK_DYNAMIC)'#010+
|
||||
'**2XS_try to link static (default) (defines FPC_LINK_STATIC)'#010+
|
||||
'**2XX_try to link smart (defines FPC_LINK_SMART)'#010+
|
||||
'**0*_Processor specific options:'#010+
|
||||
'3*1A<x>_output format:'#010+
|
||||
'3*2Aas_assemble using GNU AS'#010+
|
||||
'3*2Aasaout_assemble using GNU AS for aout (Go32v1)'#010,
|
||||
'3*2Aas_assemb','le using GNU AS'#010+
|
||||
'3*2Aasaout_assemble using GNU AS for aout (Go32v1)'#010+
|
||||
'3*2Anasmcoff_coff (Go32v2) file using Nasm'#010+
|
||||
'3*2Anasmelf_elf32 (Linux) file using Nasm'#010+
|
||||
'3*2Anasmobj_obj file using Nasm'#010+
|
||||
'3*2Amasm_obj file using Masm (Microsoft)'#010+
|
||||
'3*2Atasm_obj file using Tasm (Borland)'#010+
|
||||
'3*2Acoff_coff (Go32v2) using internal write','r'#010+
|
||||
'3*2Atasm_obj fi','le using Tasm (Borland)'#010+
|
||||
'3*2Acoff_coff (Go32v2) using internal writer'#010+
|
||||
'3*2Apecoff_pecoff (Win32) using internal writer'#010+
|
||||
'3*1R<x>_assembler reading style:'#010+
|
||||
'3*2Ratt_read AT&T 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*2Og','_generate smaller code'#010+
|
||||
'3*2Og_generate smaller code'#010+
|
||||
'3*2OG_generate faster code (default)'#010+
|
||||
'3*2Or_keep certain variables in registers'#010+
|
||||
'3*2Ou_enable uncertain optimizations (see docs)'#010+
|
||||
'3*2O1_level 1 optimizations (quick optimizations)'#010+
|
||||
'3*2O2_level 2 optimizations (-O1 + slowe','r optimizations)'#010+
|
||||
'3*2O1_level 1 optimizat','ions (quick optimizations)'#010+
|
||||
'3*2O2_level 2 optimizations (-O1 + slower optimizations)'#010+
|
||||
'3*2O3_level 3 optimizations (-O2 repeatedly, max 5 times)'#010+
|
||||
'3*2Op<x>_target processor:'#010+
|
||||
'3*3Op1_set target processor to 386/486'#010+
|
||||
'3*3Op2_set target processor to Pentium/PentiumMMX (tm)'#010+
|
||||
'3*3Op3_set target processor to PPro/PII/c6x8','6/K6 (tm)'#010+
|
||||
'3*3Op2_set target processor to P','entium/PentiumMMX (tm)'#010+
|
||||
'3*3Op3_set target processor to PPro/PII/c6x86/K6 (tm)'#010+
|
||||
'3*1T<x>_Target operating system:'#010+
|
||||
'3*2TGO32V2_version 2 of DJ Delorie DOS extender'#010+
|
||||
'3*2TWDOSX DOS 32 Bit Extender'#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*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*2WB<x>_Set Image base to Hexadecimal <x> value'#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*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*2WR_Generate relocation code'#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*2Amit_MIT Syntax (old G','AS)'#010+
|
||||
'6*2Amit_MIT Syntax (old GAS)'#010+
|
||||
'6*2Amot_Standard Motorola assembler'#010+
|
||||
'6*1O_optimizations:'#010+
|
||||
'6*2Oa_turn on the optimizer'#010+
|
||||
'6*2Og_generate smaller code'#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*1R<x','>_assembler reading style:'#010+
|
||||
'6*1R<x>_assembler reading style:'#010+
|
||||
'6*2RMOT_read motorola style assembler'#010+
|
||||
'6*1T<x>_Target operating system:'#010+
|
||||
'6*2TAMIGA_Commodore Amiga'#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*2TPALMOS_PalmOS'#010+
|
||||
'**1*_'#010+
|
||||
'**1?_shows this help'#010,
|
||||
'**1?_shows this help'#010+
|
||||
'**1h_shows this help without waiting'#000
|
||||
);
|
||||
|
@ -1863,9 +1863,9 @@ implementation
|
||||
if (right.nodetype=typen) then
|
||||
begin
|
||||
if tobjectdef(left.resulttype.def).isiidguidvalid then
|
||||
right:=cguidconstnode.create(tobjectdef(left.resulttype.def).iidguid)
|
||||
right:=cguidconstnode.create(tobjectdef(left.resulttype.def).iidguid)
|
||||
else
|
||||
internalerror(200206282);
|
||||
internalerror(200206282);
|
||||
resulttypepass(right);
|
||||
end;
|
||||
end
|
||||
@ -1893,7 +1893,10 @@ begin
|
||||
end.
|
||||
{
|
||||
$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
|
||||
+ wrappers for the tcnvnode.first_* stuff introduced
|
||||
|
||||
|
@ -28,7 +28,7 @@ unit nobj;
|
||||
interface
|
||||
|
||||
uses
|
||||
cutils,cclasses,
|
||||
cutils,cclasses,cpuinfo,
|
||||
symdef,aasmbase,aasmtai,aasmcpu;
|
||||
|
||||
type
|
||||
@ -99,6 +99,11 @@ interface
|
||||
procedure gintfdoonintf(intf: tobjectdef; intfindex: longint);
|
||||
procedure gintfwalkdowninterface(intf: tobjectdef; intfindex: longint);
|
||||
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;
|
||||
public
|
||||
constructor create(c:tobjectdef);
|
||||
@ -135,11 +140,11 @@ implementation
|
||||
strings,
|
||||
{$endif}
|
||||
globtype,globals,verbose,
|
||||
symtable,symconst,symtype,symsym,defbase,
|
||||
symtable,symconst,symtype,symsym,defbase,paramgr,
|
||||
{$ifdef GDB}
|
||||
gdb,
|
||||
{$endif GDB}
|
||||
cpuinfo
|
||||
cpubase,cgbase,cginfo,cgobj,rgobj
|
||||
;
|
||||
|
||||
|
||||
@ -793,7 +798,7 @@ implementation
|
||||
proccount:=implintf.implproccount(intfindex);
|
||||
for i:=1 to proccount do
|
||||
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 }
|
||||
cgintfwrapper(rawcode,implintf.implprocs(intfindex,i),tmps,implintf.ioffsets(intfindex)^);
|
||||
{ create reference }
|
||||
@ -1031,7 +1036,7 @@ implementation
|
||||
if assigned(implprocdef) then
|
||||
_class.implementedinterfaces.addimplproc(intfindex,implprocdef)
|
||||
else
|
||||
Message1(sym_e_id_not_found,procname);
|
||||
Message1(sym_e_no_matching_implementation_found,proc.fullprocnamewithret);
|
||||
end;
|
||||
end;
|
||||
end;
|
||||
@ -1263,13 +1268,35 @@ implementation
|
||||
dataSegment.concat(Tai_symbol_end.Createname(_class.vmt_mangledname));
|
||||
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
|
||||
cclassheader:=tclassheader;
|
||||
end.
|
||||
{
|
||||
$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
|
||||
unit so this would conflicts if D6 programms are compiled
|
||||
+ Willamette/SSE2 instructions to assembler added
|
||||
|
@ -33,9 +33,9 @@ unit paramgr;
|
||||
symtype,symdef;
|
||||
|
||||
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
|
||||
}
|
||||
}
|
||||
tparamanager = class
|
||||
{# Returns true if the return value can be put in accumulator }
|
||||
function ret_in_acc(def : tdef) : boolean;virtual;
|
||||
@ -47,27 +47,29 @@ unit paramgr;
|
||||
|
||||
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
|
||||
}
|
||||
function push_addr_param(def : tdef) : boolean;virtual;
|
||||
{# Returns a structure giving the information on
|
||||
the storage of the parameter (which must be
|
||||
an integer parameter)
|
||||
|
||||
|
||||
@param(nr Parameter number of routine, starting from 1)
|
||||
}
|
||||
}
|
||||
function getintparaloc(nr : longint) : tparalocation;virtual;abstract;
|
||||
procedure create_param_loc_info(p : tabstractprocdef);virtual;abstract;
|
||||
|
||||
{#
|
||||
{#
|
||||
Returns the location where the invisible parameter for structured
|
||||
function results will be passed.
|
||||
}
|
||||
function getfuncretloc(p : tabstractprocdef) : tparalocation;virtual;abstract;
|
||||
{ Returns the self pointer for the give procdef
|
||||
function getfuncretloc(p : tabstractprocdef) : tparalocation;virtual;abstract;
|
||||
{ Returns the self pointer location for the given tabstractprocdef,
|
||||
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;
|
||||
|
||||
procedure setparalocs(p : tprocdef);
|
||||
@ -173,7 +175,10 @@ end.
|
||||
|
||||
{
|
||||
$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
|
||||
|
||||
Revision 1.7 2002/08/05 18:27:48 carl
|
||||
|
@ -764,27 +764,34 @@ implementation
|
||||
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;
|
||||
var
|
||||
implintf: tobjectdef;
|
||||
tt : ttype;
|
||||
begin
|
||||
while try_to_consume(_COMMA) do begin
|
||||
id_type(tt,pattern,false);
|
||||
implintf:=tobjectdef(tt.def);
|
||||
if (tt.def.deftype<>objectdef) then begin
|
||||
Message1(type_e_interface_type_expected,tt.def.typename);
|
||||
Continue; { omit }
|
||||
while try_to_consume(_COMMA) do
|
||||
begin
|
||||
id_type(tt,pattern,false);
|
||||
if (tt.def.deftype<>objectdef) then
|
||||
begin
|
||||
Message1(type_e_interface_type_expected,tt.def.typename);
|
||||
continue;
|
||||
end;
|
||||
handleimplementedinterface(tobjectdef(tt.def));
|
||||
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;
|
||||
|
||||
procedure readinterfaceiid;
|
||||
@ -810,7 +817,10 @@ implementation
|
||||
|
||||
|
||||
procedure readparentclasses;
|
||||
var
|
||||
hp : tobjectdef;
|
||||
begin
|
||||
hp:=nil;
|
||||
{ reads the parent class }
|
||||
if token=_LKLAMMER then
|
||||
begin
|
||||
@ -821,7 +831,7 @@ implementation
|
||||
(childof.deftype<>objectdef) then
|
||||
begin
|
||||
if assigned(childof) then
|
||||
Message1(type_e_class_type_expected,childof.typename);
|
||||
Message1(type_e_class_type_expected,childof.typename);
|
||||
childof:=nil;
|
||||
aktclass:=tobjectdef.create(classtype,n,nil);
|
||||
end
|
||||
@ -831,9 +841,19 @@ implementation
|
||||
isn't allowed }
|
||||
case classtype of
|
||||
odt_class:
|
||||
if not(is_class(childof)) and
|
||||
not(is_interface(childof)) then
|
||||
Message(parser_e_mix_of_classes_and_objects);
|
||||
if not(is_class(childof)) then
|
||||
begin
|
||||
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_interfacecom:
|
||||
if not(is_interface(childof)) then
|
||||
@ -861,7 +881,11 @@ implementation
|
||||
else
|
||||
aktclass:=tobjectdef.create(classtype,n,childof);
|
||||
if aktclass.objecttype=odt_class then
|
||||
readimplementedinterfaces;
|
||||
begin
|
||||
if assigned(hp) then
|
||||
handleimplementedinterface(hp);
|
||||
readimplementedinterfaces;
|
||||
end;
|
||||
end;
|
||||
consume(_RKLAMMER);
|
||||
end
|
||||
@ -1133,7 +1157,10 @@ implementation
|
||||
end.
|
||||
{
|
||||
$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
|
||||
unit so this would conflicts if D6 programms are compiled
|
||||
+ Willamette/SSE2 instructions to assembler added
|
||||
|
@ -41,7 +41,7 @@ type
|
||||
{$endif Test_Double_checksum}
|
||||
|
||||
const
|
||||
CurrentPPUVersion=27;
|
||||
CurrentPPUVersion=28;
|
||||
|
||||
{ buffer sizes }
|
||||
maxentrysize = 1024;
|
||||
@ -981,7 +981,10 @@ end;
|
||||
end.
|
||||
{
|
||||
$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
|
||||
|
||||
Revision 1.19 2002/05/16 19:46:44 carl
|
||||
|
@ -2561,7 +2561,7 @@ implementation
|
||||
function tformaldef.gettypename : string;
|
||||
|
||||
begin
|
||||
gettypename:='Var';
|
||||
gettypename:='<Formal type>';
|
||||
end;
|
||||
|
||||
{***************************************************************************
|
||||
@ -3251,7 +3251,11 @@ implementation
|
||||
begin
|
||||
if hp.paratyp in [vs_var,vs_const,vs_out] then
|
||||
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;
|
||||
{ default value }
|
||||
if assigned(hp.defaultvalue) then
|
||||
@ -4135,7 +4139,7 @@ implementation
|
||||
if objecttype in [odt_interfacecom,odt_interfacecorba] then
|
||||
begin
|
||||
isiidguidvalid:=boolean(ppufile.getbyte);
|
||||
ppufile.putguid(iidguid);
|
||||
ppufile.getguid(iidguid);
|
||||
iidstr:=stringdup(ppufile.getstring);
|
||||
lastvtableindex:=ppufile.getlongint;
|
||||
end;
|
||||
@ -4356,7 +4360,7 @@ implementation
|
||||
end;*)
|
||||
|
||||
procedure Tobjectdef._searchdestructor(sym:Tnamedindexitem;arg:pointer);
|
||||
|
||||
|
||||
begin
|
||||
{ if we found already a destructor, then we exit }
|
||||
if (sd=nil) and (Tsym(sym).typ=procsym) then
|
||||
@ -5486,7 +5490,10 @@ implementation
|
||||
end.
|
||||
{
|
||||
$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
|
||||
are worth comitting.
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user