mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-09-06 16:50:25 +02:00
* several variant init./final. stuff fixed
This commit is contained in:
parent
fe4cb5e126
commit
99ebd46010
@ -139,7 +139,7 @@ begin
|
||||
recordrtti(data,typeinfo,@int_initialize);
|
||||
{$ifdef HASVARIANT}
|
||||
tkVariant:
|
||||
variant_init(Variant(PVarData(Data)^));
|
||||
variant_init(PVarData(Data)^);
|
||||
{$endif HASVARIANT}
|
||||
end;
|
||||
end;
|
||||
@ -150,7 +150,7 @@ begin
|
||||
case PByte(TypeInfo)^ of
|
||||
tkAstring :
|
||||
begin
|
||||
fpc_AnsiStr_Decr_Ref(PPointer(Data)^);
|
||||
fpc_AnsiStr_Decr_Ref(PPointer(Data)^);
|
||||
PPointer(Data)^:=nil;
|
||||
end;
|
||||
{$ifdef HASWIDESTRING}
|
||||
@ -176,7 +176,7 @@ begin
|
||||
fpc_dynarray_decr_ref(PPointer(Data)^,TypeInfo);
|
||||
{$ifdef HASVARIANT}
|
||||
tkVariant:
|
||||
variant_clear(Variant(PVarData(Data)^))
|
||||
variant_clear(PVarData(Data)^);
|
||||
{$endif HASVARIANT}
|
||||
end;
|
||||
end;
|
||||
@ -204,7 +204,7 @@ begin
|
||||
{$endif HASINTF}
|
||||
{$ifdef HASVARIANT}
|
||||
tkVariant:
|
||||
variant_addref(PVariant(Data)^);
|
||||
variant_addref(pvardata(Data)^);
|
||||
{$endif HASVARIANT}
|
||||
end;
|
||||
end;
|
||||
@ -237,7 +237,7 @@ begin
|
||||
{$endif HASINTF}
|
||||
{$ifdef HASVARIANT}
|
||||
tkVariant:
|
||||
variant_clear(PVariant(Data)^);
|
||||
variant_clear(pvardata(data)^);
|
||||
{$endif HASVARIANT}
|
||||
end;
|
||||
end;
|
||||
@ -251,11 +251,12 @@ procedure fpc_finalize_array(data,typeinfo : pointer;count,size : longint); [Pub
|
||||
int_finalize(data+size*i,typeinfo);
|
||||
end;
|
||||
|
||||
|
||||
|
||||
{
|
||||
$Log$
|
||||
Revision 1.20 2005-01-08 20:43:44 florian
|
||||
Revision 1.21 2005-01-15 18:47:26 florian
|
||||
* several variant init./final. stuff fixed
|
||||
|
||||
Revision 1.20 2005/01/08 20:43:44 florian
|
||||
+ init/cleaning code for variants added
|
||||
|
||||
Revision 1.19 2004/11/02 15:52:04 florian
|
||||
|
@ -41,7 +41,7 @@ begin
|
||||
end;
|
||||
|
||||
|
||||
procedure variant_init(var v : variant);[Public,Alias:'FPC_VARIANT_INIT'];
|
||||
procedure variant_init(var v : tvardata);[Public,Alias:'FPC_VARIANT_INIT'];
|
||||
begin
|
||||
{ calling the variant manager here is a problem because the static/global variants
|
||||
are initialized while the variant manager isn't assigned }
|
||||
@ -49,15 +49,17 @@ procedure variant_init(var v : variant);[Public,Alias:'FPC_VARIANT_INIT'];
|
||||
end;
|
||||
|
||||
|
||||
procedure variant_clear(var v : variant);[Public,Alias:'FPC_VARIANT_CLEAR'];
|
||||
procedure variant_clear(var v : tvardata);[Public,Alias:'FPC_VARIANT_CLEAR'];
|
||||
begin
|
||||
variantmanager.varclear(v);
|
||||
if assigned(VarClearProc) then
|
||||
VarClearProc(v)
|
||||
end;
|
||||
|
||||
|
||||
procedure variant_addref(var v : variant);[Public,Alias:'FPC_VARIANT_ADDREF'];
|
||||
procedure variant_addref(var v : tvardata);[Public,Alias:'FPC_VARIANT_ADDREF'];
|
||||
begin
|
||||
variantmanager.varaddref(v);
|
||||
if assigned(VarAddRefProc) then
|
||||
VarAddRefProc(v);
|
||||
end;
|
||||
|
||||
|
||||
@ -113,7 +115,6 @@ function fpc_interface_to_variant(const i : iinterface) : variant;compilerproc;
|
||||
operator :=(const source : byte) dest : variant;
|
||||
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
Variantmanager.varfromInt(Dest,Source,1);
|
||||
end;
|
||||
|
||||
@ -121,7 +122,6 @@ end;
|
||||
operator :=(const source : shortint) dest : variant;
|
||||
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
Variantmanager.varfromInt(Dest,Source,-1);
|
||||
end;
|
||||
|
||||
@ -129,56 +129,43 @@ end;
|
||||
operator :=(const source : word) dest : variant;
|
||||
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
Variantmanager.varfromInt(Dest,Source,2);
|
||||
end;
|
||||
|
||||
|
||||
operator :=(const source : smallint) dest : variant;
|
||||
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
Variantmanager.varfromInt(Dest,Source,-2);
|
||||
end;
|
||||
|
||||
|
||||
operator :=(const source : dword) dest : variant;
|
||||
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
Variantmanager.varfromInt(Dest,Source,4);
|
||||
end;
|
||||
|
||||
|
||||
operator :=(const source : longint) dest : variant;
|
||||
|
||||
begin
|
||||
// Variant_Init(Dest);
|
||||
Variantmanager.varfromInt(Dest,Source,-4);
|
||||
end;
|
||||
|
||||
|
||||
operator :=(const source : qword) dest : variant;
|
||||
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
Variantmanager.varfromWord64(Dest,Source);
|
||||
end;
|
||||
|
||||
|
||||
operator :=(const source : int64) dest : variant;
|
||||
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
Variantmanager.varfromInt64(Dest,Source);
|
||||
end;
|
||||
|
||||
{ Boolean }
|
||||
|
||||
operator :=(const source : boolean) dest : variant;
|
||||
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
Variantmanager.varfromBool(Dest,Source);
|
||||
end;
|
||||
|
||||
@ -186,7 +173,6 @@ end;
|
||||
operator :=(const source : wordbool) dest : variant;
|
||||
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
Variantmanager.varfromBool(Dest,Boolean(Source));
|
||||
end;
|
||||
|
||||
@ -194,7 +180,6 @@ end;
|
||||
operator :=(const source : longbool) dest : variant;
|
||||
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
Variantmanager.varfromBool(Dest,Boolean(Source));
|
||||
end;
|
||||
|
||||
@ -204,7 +189,6 @@ end;
|
||||
operator :=(const source : char) dest : variant;
|
||||
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
VariantManager.VarFromPStr(Dest,Source);
|
||||
end;
|
||||
|
||||
@ -212,7 +196,6 @@ end;
|
||||
operator :=(const source : widechar) dest : variant;
|
||||
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
VariantManager.VarFromWStr(Dest,Source);
|
||||
end;
|
||||
|
||||
@ -221,7 +204,6 @@ end;
|
||||
operator :=(const source : shortstring) dest : variant;
|
||||
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
VariantManager.VarFromPStr(Dest,Source);
|
||||
end;
|
||||
|
||||
@ -229,7 +211,6 @@ end;
|
||||
operator :=(const source : ansistring) dest : variant;
|
||||
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
VariantManager.VarFromLStr(Dest,Source);
|
||||
end;
|
||||
|
||||
@ -237,7 +218,6 @@ end;
|
||||
operator :=(const source : widestring) dest : variant;
|
||||
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
VariantManager.VarFromWStr(Dest,Source);
|
||||
end;
|
||||
|
||||
@ -246,7 +226,6 @@ end;
|
||||
{$ifdef SUPPORT_SINGLE}
|
||||
operator :=(const source : single) dest : variant;
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
VariantManager.VarFromReal(Dest,Source);
|
||||
end;
|
||||
{$endif SUPPORT_SINGLE}
|
||||
@ -255,7 +234,6 @@ end;
|
||||
{$ifdef SUPPORT_DOUBLE}
|
||||
operator :=(const source : double) dest : variant;
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
VariantManager.VarFromReal(Dest,Source);
|
||||
end;
|
||||
{$endif SUPPORT_DOUBLE}
|
||||
@ -264,7 +242,6 @@ end;
|
||||
{$ifdef SUPPORT_EXTENDED}
|
||||
operator :=(const source : extended) dest : variant;
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
VariantManager.VarFromReal(Dest,Source);
|
||||
end;
|
||||
{$endif SUPPORT_EXTENDED}
|
||||
@ -273,7 +250,6 @@ end;
|
||||
{$ifdef SUPPORT_COMP}
|
||||
Operator :=(const source : comp) dest : variant;
|
||||
begin
|
||||
Variant_Init(Dest);
|
||||
VariantManager.VarFromReal(Dest,Source);
|
||||
end;
|
||||
{$endif SUPPORT_COMP}
|
||||
@ -622,7 +598,10 @@ procedure initvariantmanager;
|
||||
|
||||
{
|
||||
$Log$
|
||||
Revision 1.21 2005-01-08 20:43:44 florian
|
||||
Revision 1.22 2005-01-15 18:47:26 florian
|
||||
* several variant init./final. stuff fixed
|
||||
|
||||
Revision 1.21 2005/01/08 20:43:44 florian
|
||||
+ init/cleaning code for variants added
|
||||
|
||||
Revision 1.20 2005/01/07 21:15:46 florian
|
||||
|
@ -186,6 +186,13 @@ procedure GetVariantManager(var VarMgr: TVariantManager);
|
||||
procedure SetVariantManager(const VarMgr: TVariantManager);
|
||||
function IsVariantManagerSet: Boolean;
|
||||
|
||||
const
|
||||
VarClearProc : procedure(var v : TVarData) = nil;
|
||||
VarAddRefProc : procedure(var v : TVarData) = nil;
|
||||
VarCopyProc : procedure(var d : TVarData;const s : TVarData) = nil;
|
||||
VarToLStrProc : procedure(var d : AnsiString;const s : TVarData) = nil;
|
||||
VarToWStrProc : procedure(var d : WideString;const s : TVarData) = nil;
|
||||
|
||||
var
|
||||
VarDispProc : pointer;
|
||||
DispCallByIDProc : pointer;
|
||||
@ -311,7 +318,10 @@ operator <=(const op1,op2 : variant) dest : boolean;
|
||||
|
||||
{
|
||||
$Log$
|
||||
Revision 1.16 2003-12-22 23:07:52 peter
|
||||
Revision 1.17 2005-01-15 18:47:26 florian
|
||||
* several variant init./final. stuff fixed
|
||||
|
||||
Revision 1.16 2003/12/22 23:07:52 peter
|
||||
* fixed type of verror
|
||||
|
||||
Revision 1.15 2003/12/10 01:36:39 florian
|
||||
|
@ -69,7 +69,8 @@ begin
|
||||
case VType of
|
||||
varEmpty, varNull, varSmallint, varInteger, varSingle, varDouble,
|
||||
varCurrency, varDate, varError, varBoolean, varByte,VarShortInt,
|
||||
varInt64, VarLongWord,VarQWord:;
|
||||
varInt64, VarLongWord,VarQWord:
|
||||
;
|
||||
varOleStr:
|
||||
WideString(Pointer(VOleStr)):='';
|
||||
varDispatch,
|
||||
@ -709,7 +710,10 @@ end;
|
||||
{$endif HASVARIANT}
|
||||
{
|
||||
$Log$
|
||||
Revision 1.12 2005-01-08 16:19:42 florian
|
||||
Revision 1.13 2005-01-15 18:47:26 florian
|
||||
* several variant init./final. stuff fixed
|
||||
|
||||
Revision 1.12 2005/01/08 16:19:42 florian
|
||||
* made some variants stuff more readable
|
||||
|
||||
Revision 1.11 2004/04/28 20:48:20 peter
|
||||
|
Loading…
Reference in New Issue
Block a user