[fpc-pascal] private integer is an illegal counter variable
Juha Manninen
juha.manninen at phnet.fi
Fri Nov 27 23:43:39 CET 2009
On perjantai, 27. marraskuuta 2009 23:52:30 Frank Peelo wrote:
> > The reason is that a for-loop tries to make a number of reasonable
> > guarantees that the counter variable cannot be modified during the loop.
> > E.g., direct assignments to a counter variable are forbidden inside the
> > loop (except in TP-mode). If you use a private field, then any method of
> > that class called in the body of the loop can easily (accidentally)
> > change the value of the counter variable, completely messing up the loop.
>
> In any case, why would one want a loop counter to have any more than the
> minimum possible scope? Why would one want it to be a class data member
> at all? Surely it would be far better/neater/more elegant, if it is used
> by methods, to pass it as a parameter?
Right, it is better define it locally. I did this experiment by accident when
copying code around.
This is actually a good deviation from Delphi's rules. No problem here.
There are some other deviations which look weird for me, like treating
"string" as a dynamic ansistring sometimes but as an old shortstring
sometimes. That is in the default {$mode objfpc}.
Fortunately there is {$mode delphi} which behaves more logically.
I understand it is important to support also the old shortstring but it should
be defined explicitly and "string" should always mean just one thing.
Well, I guess this has been discussed before...
I can always use mode delphi.
Juha Manninen
More information about the fpc-pascal
mailing list