in reply to Choosing the sort routine on the fly

I think you are being bitten by the optimisation that translates {$a cmp $b} and {$b cmp $a} into direct sorts that do not use a callback. Effectively the block supplied, if one of a few pre-defined forms is used to compile in a different codepath at compile time.

About the best I've achieved in the past is to have both codepaths in the code and select between them yourself.

$flag = 1; print $flag ? sort 'a'..'z' : sort {$b cmp $a } 'a'..'z';; a b c d e f g h i j k l m n o p q r s t u v w x y z $flag = 0; print $flag ? sort 'a'..'z' : sort {$b cmp $a } 'a'..'z';; z y x w v u t s r q p o n m l k j i h g f e d c b a

It means some repetition but avoids a callback and so speeds up the sorting. I've wished several times that there were sortAplhaAscending, sortAlphaDescending, sortNumericAscending & sortNumericDescending keywords in the language. The codepaths already exist in the runtime, but you have to use somewhat obscure syntax to get at them.


Examine what is said, not who speaks -- Silence betokens consent -- Love the truth but pardon error.
Lingua non convalesco, consenesco et abolesco. -- Rule 1 has a caveat! -- Who broke the cabal?
"Science is about questioning the status quo. Questioning authority".
In the absence of evidence, opinion is indistinguishable from prejudice.

Replies are listed 'Best First'.
Re^2: Choosing the sort routine on the fly
by grinder (Bishop) on Sep 08, 2006 at 10:54 UTC
    ...being bitten by the optimisation...

    Not in my particular case. The real-life code is more complicated, as I'm sorting arrays of arrays on an arbitrary column, and the comparators are more that just straight string or numeric compares. Hence I have a number of routines that know how to sort the contents of a column, and I associate each column with a sorter.

    • another intruder with the mooring in the heart of the Perl