f



Prevent Variants unit from being implicitly included?

I have this simple code.

  program test;
  type abc = variant;
  begin
  end.

If I compile it, the compiler includes the Variants unit, even though the
variant type is declared in the System unit.

The above code doesn't even refer the variant type as a variable, so there
no need for variant variable initialization. There should be no variant
related code to be included in the program at all.

So how to prevent the Variant unit to be included into the program by the
compiler? Is there a compiler directive for this? Or a command line
parameter for DCC32?
0
JJ
11/6/2016 8:51:47 PM
comp.lang.pascal.delphi.misc 5769 articles. 1 followers. miniFAQ (1) is leader. Post Follow

2 Replies
96 Views

Similar Articles

[PageSpeed] 30

JJ wrote:

> I have this simple code.
> 
>   program test;
>   type abc = variant;
>   begin
>   end.
> 
> If I compile it, the compiler includes the Variants unit, even though
> the variant type is declared in the System unit.

The compiler does nothing of this sort, it is the IDE when you save the
program file (which it does automatically when you ask it to compile
the code).

> 
> The above code doesn't even refer the variant type as a variable, so
> there no need for variant variable initialization. There should be no
> variant related code to be included in the program at all.


So what? In any real code that actually *uses* your abc type you will
need variant support routines. Your example is completely artifical.

You could try to use OleVariant instead of Variant, if you already have
Windows in the Uses clause anyway.

-- 
Peter Below
TeamB
0
Peter
11/7/2016 5:45:20 PM
On Mon, 7 Nov 2016 17:45:20 +0000 (UTC), Peter Below wrote:
> JJ wrote:
> 
>> I have this simple code.
>> 
>>   program test;
>>   type abc = variant;
>>   begin
>>   end.
>> 
>> If I compile it, the compiler includes the Variants unit, even though
>> the variant type is declared in the System unit.
> 
> The compiler does nothing of this sort, it is the IDE when you save the
> program file (which it does automatically when you ask it to compile
> the code).

Yes it does. I actially tested this using DCC32 command line compiler.

>> The above code doesn't even refer the variant type as a variable, so
>> there no need for variant variable initialization. There should be no
>> variant related code to be included in the program at all.
> 
> So what? In any real code that actually *uses* your abc type you will
> need variant support routines. Your example is completely artifical.
> 
> You could try to use OleVariant instead of Variant, if you already have
> Windows in the Uses clause anyway.

I need to implement my own custom variant routines without including the
Variants unit - for smaller executable file. Variant values won't be
accessed as is. They will be type casted to TVarData and will always be
accessed as TVarData from within the custom variant routines. Only those
routines' function declarations need to have "variant" for a type. e.g.

  procedure XVariantSet(var v: variant; b: boolean); overload;
  begin
    TVarData(v).VType:= varBoolean;
    TVarData(v).VBoolean:= b;
  end;

  procedure XVariantSet(var v: variant; i: integer); overload;
  begin
    TVarData(v).VType:= varInteger;
    TVarData(v).VInteger:= i;
  end;
0
JJ
11/8/2016 10:18:25 AM
Reply: