31.03.2014 17:32, Martin Frb пишет:
Just asking this again, as I did not get any answer yet?

Is that the indented behaviour, and if so what is the reasoning for it?


This behavior is hardly intended.
To get clues about what's going on, you can compile the compiler with 
OPT=-dEXTDEBUG,
then use it with -vd to compile your tests.

So, in case of subrange of integer/byte, the overloaded procedures are matched 
as follows:

  Bar(TFoo);
   invalid
  Bar(LongInt);
   ex: 0 eq: 1 l1: 0 l2: 0 l3: 0 l4: 0 l5: 0 l6: 0 oper: 0 ord:  
4.29496729300000047684E+0009
    - LongInt : equal
  Bar(Variant);
   ex: 0 eq: 0 l1: 0 l2: 0 l3: 0 l4: 0 l5: 0 l6: 0 oper: 1 ord:  
0.00000000000000000000E+0000
    - Variant : convert_operator

And in case of subrange of enum, it becomes as follows:

  Bar(TFoo);
   ex: 0 eq: 0 l1: 1 l2: 0 l3: 0 l4: 0 l5: 0 l6: 0 oper: 0 ord:  
0.00000000000000000000E+0000
    - TFoo : convert_l1
  Bar(LongInt);
   invalid
  Bar(Variant);
   ex: 0 eq: 0 l1: 1 l2: 0 l3: 0 l4: 0 l5: 0 l6: 0 oper: 0 ord:  
0.00000000000000000000E+0000
    - Variant : convert_l1

Here Variant gets the same degree of compatibility with TFoo1 as TFoo, that's probably a bug in compiler (Variant should probably have same compatibility as in first case, i.e. convert_operator, if not incompatible at all). Also, the subrange may receive the same treatment as in the first case, i.e. considered equal to its base type but with some "ordinal distance".

Regards,
Sergei

-------- Original Message --------
Subject:        overload question (variant vs enum subrange)
Date:   Sun, 26 Jan 2014 19:48:42 +0000
From:   Martin Frb <laza...@mfriebe.de>
To:     FPC-Pascal users discussions <fpc-pas...@lists.freepascal.org>



TFoo1  is a sub range of  FFoo

And it seems to match both TFoo and variant.
project1.lpr(24,3) Error: Can't determine which overloaded function to
call
project1.lpr(15,11) Hint: Found declaration: Bar(TFoo);
project1.lpr(11,11) Hint: Found declaration: Bar(Variant);

No other type seems to be bothered by variant.
Also variant is the only type, that I found that conflicts with TFoo1

Why?

I know I can declare
   procedure Bar(a: TFoo1); overload;
and it will solve it (even if I leave all the others, because it is an
exact match).

But why does a subrange of integer/byte work? Subrange of integer does
not give the error, even so it could match both.



program Project1;
{$mode objfpc}
{// $mode delpti}
type
   TFoo = (a1,a2,a3,a4,a5);
   TFoo1 = a2..a4;
   TFoo2 = 1..3;
   TFoo3 = byte(1)..(3);


procedure Bar(a: Variant); overload;
begin   end;
procedure Bar(a: Integer); overload;
begin   end;
procedure Bar(a: TFoo); overload;
begin   end;

var
   f1: TFoo;
   f2: TFoo1;
   f3: TFoo2;
   f4: TFoo3;
begin
   Bar(f2);
end.





_______________________________________________
fpc-devel maillist  -  fpc-devel@lists.freepascal.org
http://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-devel



_______________________________________________
fpc-devel maillist  -  fpc-devel@lists.freepascal.org
http://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-devel

Reply via email to