W dniu 2021-06-14 o 22:25, Michael Van Canneyt via fpc-pascal pisze:
On Mon, 14 Jun 2021, gabor via fpc-pascal wrote:

W dniu 2021-06-14 o 21:27, Michael Van Canneyt via fpc-pascal pisze:


On Mon, 14 Jun 2021, gabor via fpc-pascal wrote:

Why does TMemoryStream only implement one version of SetSize method?


https://svn.freepascal.org/cgi-bin/viewvc.cgi/trunk/rtl/objpas/classes/classesh.inc?revision=49038&view=markup#l1225


The TStream class has two versions of SetSize method (virtual, overload) - one with a parameter of LongInt type and the other with the Int64 type. Since function is virtual, child classes can override it and can be called from code, but then a version of the SetSize function not implemented for a given platform in the TMemoryStream class can be called.

The base method checks which one is overridden. So it does not matter which one you override in the child.
The "other" one will always fall back to the method in TStream.


Unfortunately, on the 64bit platform it does not fully work. See the project below.

Sorry, I was mixing up seek and setsize.

Indeed. You should not be calling the integer SetSize() directly.

People creating descendent classes are expected to know what to do, i.e. to use the 64-bit version.


You are absolutely right. But why do we have different function for different platforms? Wouldn't it be better to implement either one function with an Int64 parameter for both platforms, or even both variants of this function? The Size property is of type int64 on both platforms so why should SetSize (that is public in TMemoryStream) be platform dependent?

Michał.
_______________________________________________
fpc-pascal maillist  -  fpc-pascal@lists.freepascal.org
https://lists.freepascal.org/cgi-bin/mailman/listinfo/fpc-pascal

Reply via email to