[fpc-devel] generics defy scoping rules -- Intended?

Hairy Pixels genericptr at gmail.com
Tue Nov 25 16:14:47 CET 2025


 On Nov 25, 2025 at 9:55:46 PM, Martin Frb via fpc-devel <
fpc-devel at lists.freepascal.org> wrote:

> Thanks, which just for confirmation brings up a follow up question. (I
> haven't used generic function much yet, so maybe I miss something)
>
>           function  Foo   (aParam: Integer): integer;
>   generic function  Foo<T>(aParam: t)      : integer;
>
>
> Those are 2 different function too? (not an overload? because "T" could be
> integer in same cases)
>
> Do you then always have to call the generic using
>   specialize Foo<integer>(1)
> ?
>
> I seem to remember a discussion about adding automatic specialization?
> But then
>   foo('abc') // would be clear, to specialize with string
> but
>   foo(1)  // could be either
> _______________________________________________
>


yes those are two different functions. The generic function is just a
template which includes the parsed tokens and is named with $X where X is
the number of generic parameters. Only at the time of specialization is the
code generated, until the it's just an array of tokens.

there is a {$modeswitch implicitfunctionspecialization} mode switch ( my
work so I apologize for the bugs 😂) which infers the parameter type so
that foo('abc') becomes foo<String>('String').
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.freepascal.org/pipermail/fpc-devel/attachments/20251125/fcf7e912/attachment.htm>


More information about the fpc-devel mailing list