<br><br><div><span class="gmail_quote">2006/5/2, Marc Santhoff <<a href="mailto:M.Santhoff@t-online.de">M.Santhoff@t-online.de</a>>:</span><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
Hi,<br><br>i wonder why the declaration of the comparing function of list objects<br>is the way it is:<br><br>TListSortCompare = function (Item1, Item2: Pointer): Integer;<br><br>Since I am writing a class that sorts a list it owns depending on
<br>another property naming the property of the list items for sorting, I<br>would like to have it made a "procedure of object":<br><br>TListSortCompare = function (Item1, Item2: Pointer): Integer of object;<br>
<br>I'm dealing with lists of files and directories that should get sorted<br>by name, date, ...<br>If the comparing function is a plain non object function I have to make<br>some sort of unit global variable or the like for telling it, what
<br>property is the sort criteria. I don't like this design, although in<br>this case there is only one soritng process at a time.<br><br>Is this a concession imposed by Delphi compatibility?</blockquote><div><br>It is in fact Delphi that did  it that way
<br></div><br><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">(If you can suggest a better strategy for using this stuff, please do.)</blockquote>
<div><br>In fact you could have different function for every kind of sort and switch them on the fly when the properties determining the kind of sort that should be made changes. In my experience there is no much code duplication involved in this technique and you could make for example one compare function for every field, after that you make a _complex_ ones calling the simple ones.
<br></div></div><br clear="all">Either way it is not very OO based approach but of course you could make a descendand class of tfplist and add you own sorting code.<br>-- <br>Geno Roupsky