$27 GRAYBYTE WORDPRESS FILE MANAGER $90

SERVER : in-mum-web1330.main-hosting.eu #1 SMP Mon Feb 10 22:45:17 UTC 2025
SERVER IP : 88.222.243.47 | ADMIN IP 216.73.216.215
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/usr/share/perl5/

HOME
Current File : /usr/share/perl5//sort.pm
package sort;

our $VERSION = '2.02';

# The hints for pp_sort are now stored in $^H{sort}; older versions
# of perl used the global variable $sort::hints. -- rjh 2005-12-19

$sort::quicksort_bit   = 0x00000001;
$sort::mergesort_bit   = 0x00000002;
$sort::sort_bits       = 0x000000FF; # allow 256 different ones
$sort::stable_bit      = 0x00000100;

use strict;

sub import {
    shift;
    if (@_ == 0) {
	require Carp;
	Carp::croak("sort pragma requires arguments");
    }
    local $_;
    $^H{sort} //= 0;
    while ($_ = shift(@_)) {
	if (/^_q(?:uick)?sort$/) {
	    $^H{sort} &= ~$sort::sort_bits;
	    $^H{sort} |=  $sort::quicksort_bit;
	} elsif ($_ eq '_mergesort') {
	    $^H{sort} &= ~$sort::sort_bits;
	    $^H{sort} |=  $sort::mergesort_bit;
	} elsif ($_ eq 'stable') {
	    $^H{sort} |=  $sort::stable_bit;
	} elsif ($_ eq 'defaults') {
	    $^H{sort} =   0;
	} else {
	    require Carp;
	    Carp::croak("sort: unknown subpragma '$_'");
	}
    }
}

sub unimport {
    shift;
    if (@_ == 0) {
	require Carp;
	Carp::croak("sort pragma requires arguments");
    }
    local $_;
    no warnings 'uninitialized';	# bitops would warn
    while ($_ = shift(@_)) {
	if (/^_q(?:uick)?sort$/) {
	    $^H{sort} &= ~$sort::sort_bits;
	} elsif ($_ eq '_mergesort') {
	    $^H{sort} &= ~$sort::sort_bits;
	} elsif ($_ eq 'stable') {
	    $^H{sort} &= ~$sort::stable_bit;
	} else {
	    require Carp;
	    Carp::croak("sort: unknown subpragma '$_'");
	}
    }
}

sub current {
    my @sort;
    if ($^H{sort}) {
	push @sort, 'quicksort' if $^H{sort} & $sort::quicksort_bit;
	push @sort, 'mergesort' if $^H{sort} & $sort::mergesort_bit;
	push @sort, 'stable'    if $^H{sort} & $sort::stable_bit;
    }
    push @sort, 'mergesort' unless @sort;
    join(' ', @sort);
}

1;
__END__

=head1 NAME

sort - perl pragma to control sort() behaviour

=head1 SYNOPSIS

    use sort 'stable';		# guarantee stability
    use sort '_quicksort';	# use a quicksort algorithm
    use sort '_mergesort';	# use a mergesort algorithm
    use sort 'defaults';	# revert to default behavior
    no  sort 'stable';		# stability not important

    use sort '_qsort';		# alias for quicksort

    my $current;
    BEGIN {
	$current = sort::current();	# identify prevailing algorithm
    }

=head1 DESCRIPTION

With the C<sort> pragma you can control the behaviour of the builtin
C<sort()> function.

In Perl versions 5.6 and earlier the quicksort algorithm was used to
implement C<sort()>, but in Perl 5.8 a mergesort algorithm was also made
available, mainly to guarantee worst case O(N log N) behaviour:
the worst case of quicksort is O(N**2).  In Perl 5.8 and later,
quicksort defends against quadratic behaviour by shuffling large
arrays before sorting.

A stable sort means that for records that compare equal, the original
input ordering is preserved.  Mergesort is stable, quicksort is not.
Stability will matter only if elements that compare equal can be
distinguished in some other way.  That means that simple numerical
and lexical sorts do not profit from stability, since equal elements
are indistinguishable.  However, with a comparison such as

   { substr($a, 0, 3) cmp substr($b, 0, 3) }

stability might matter because elements that compare equal on the
first 3 characters may be distinguished based on subsequent characters.
In Perl 5.8 and later, quicksort can be stabilized, but doing so will
add overhead, so it should only be done if it matters.

The best algorithm depends on many things.  On average, mergesort
does fewer comparisons than quicksort, so it may be better when
complicated comparison routines are used.  Mergesort also takes
advantage of pre-existing order, so it would be favored for using
C<sort()> to merge several sorted arrays.  On the other hand, quicksort
is often faster for small arrays, and on arrays of a few distinct
values, repeated many times.  You can force the
choice of algorithm with this pragma, but this feels heavy-handed,
so the subpragmas beginning with a C<_> may not persist beyond Perl 5.8.
The default algorithm is mergesort, which will be stable even if
you do not explicitly demand it.
But the stability of the default sort is a side-effect that could
change in later versions.  If stability is important, be sure to
say so with a

  use sort 'stable';

The C<no sort> pragma doesn't
I<forbid> what follows, it just leaves the choice open.  Thus, after

  no sort qw(_mergesort stable);

a mergesort, which happens to be stable, will be employed anyway.
Note that

  no sort "_quicksort";
  no sort "_mergesort";

have exactly the same effect, leaving the choice of sort algorithm open.

=head1 CAVEATS

As of Perl 5.10, this pragma is lexically scoped and takes effect
at compile time. In earlier versions its effect was global and took
effect at run-time; the documentation suggested using C<eval()> to
change the behaviour:

  { eval 'use sort qw(defaults _quicksort)'; # force quicksort
    eval 'no sort "stable"';      # stability not wanted
    print sort::current . "\n";
    @a = sort @b;
    eval 'use sort "defaults"';   # clean up, for others
  }
  { eval 'use sort qw(defaults stable)';     # force stability
    print sort::current . "\n";
    @c = sort @d;
    eval 'use sort "defaults"';   # clean up, for others
  }

Such code no longer has the desired effect, for two reasons.
Firstly, the use of C<eval()> means that the sorting algorithm
is not changed until runtime, by which time it's too late to
have any effect. Secondly, C<sort::current> is also called at
run-time, when in fact the compile-time value of C<sort::current>
is the one that matters.

So now this code would be written:

  { use sort qw(defaults _quicksort); # force quicksort
    no sort "stable";      # stability not wanted
    my $current;
    BEGIN { $current = sort::current; }
    print "$current\n";
    @a = sort @b;
    # Pragmas go out of scope at the end of the block
  }
  { use sort qw(defaults stable);     # force stability
    my $current;
    BEGIN { $current = sort::current; }
    print "$current\n";
    @c = sort @d;
  }

=cut


Current_dir [ NOT WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
15 Mar 2026 11.23 AM
root / root
0755
B
--
25 Jan 2024 4.24 PM
root / root
0755
Class
--
25 Jan 2024 4.24 PM
root / root
0755
Config
--
25 Jan 2024 4.24 PM
root / root
0755
DBM_Filter
--
25 Jan 2024 4.24 PM
root / root
0755
ExtUtils
--
25 Jan 2024 4.24 PM
root / root
0755
File
--
25 Jan 2024 4.24 PM
root / root
0755
Getopt
--
25 Jan 2024 4.24 PM
root / root
0755
I18N
--
25 Jan 2024 4.24 PM
root / root
0755
IPC
--
25 Jan 2024 4.24 PM
root / root
0755
Math
--
25 Jan 2024 5.01 PM
root / root
0755
Net
--
25 Jan 2024 4.24 PM
root / root
0755
Pod
--
25 Jan 2024 4.24 PM
root / root
0755
Search
--
25 Jan 2024 4.24 PM
root / root
0755
Term
--
25 Jan 2024 4.24 PM
root / root
0755
Text
--
25 Jan 2024 4.24 PM
root / root
0755
Thread
--
25 Jan 2024 4.24 PM
root / root
0755
Tie
--
25 Jan 2024 4.24 PM
root / root
0755
Time
--
25 Jan 2024 4.24 PM
root / root
0755
URI
--
25 Jan 2024 2.16 PM
root / root
0755
Unicode
--
25 Jan 2024 4.24 PM
root / root
0755
User
--
25 Jan 2024 4.24 PM
root / root
0755
encoding
--
25 Jan 2024 4.24 PM
root / root
0755
overload
--
25 Jan 2024 4.24 PM
root / root
0755
pod
--
25 Jan 2024 4.24 PM
root / root
0755
unicore
--
25 Jan 2024 4.24 PM
root / root
0755
vendor_perl
--
28 Feb 2025 12.46 AM
root / root
0755
warnings
--
25 Jan 2024 4.24 PM
root / root
0755
AnyDBM_File.pm
2.557 KB
18 May 2023 9.34 PM
root / root
0644
AutoLoader.pm
15.427 KB
18 May 2023 9.34 PM
root / root
0644
AutoSplit.pm
19.177 KB
18 May 2023 9.34 PM
root / root
0644
Benchmark.pm
30.298 KB
18 May 2023 9.34 PM
root / root
0644
CORE.pod
3.113 KB
18 May 2023 9.34 PM
root / root
0644
DB.pm
18.479 KB
18 May 2023 9.34 PM
root / root
0644
DBM_Filter.pm
14.048 KB
18 May 2023 9.34 PM
root / root
0644
DirHandle.pm
1.52 KB
18 May 2023 9.34 PM
root / root
0644
Dumpvalue.pm
17.145 KB
18 May 2023 9.34 PM
root / root
0644
English.pm
4.649 KB
18 May 2023 9.34 PM
root / root
0644
FileCache.pm
5.441 KB
18 May 2023 9.34 PM
root / root
0644
FileHandle.pm
6.625 KB
18 May 2023 9.34 PM
root / root
0644
FindBin.pm
4.454 KB
18 May 2023 9.34 PM
root / root
0644
Internals.pod
2.516 KB
18 May 2023 9.34 PM
root / root
0644
NEXT.pm
18.404 KB
18 May 2023 9.34 PM
root / root
0644
PerlIO.pm
10.214 KB
18 May 2023 9.34 PM
root / root
0644
Safe.pm
24.494 KB
18 May 2023 9.34 PM
root / root
0644
SelectSaver.pm
1.051 KB
18 May 2023 9.34 PM
root / root
0644
Symbol.pm
4.687 KB
18 May 2023 9.34 PM
root / root
0644
Thread.pm
8.093 KB
18 May 2023 9.34 PM
root / root
0644
UNIVERSAL.pm
6.439 KB
18 May 2023 9.34 PM
root / root
0644
URI.pm
33.975 KB
9 Jan 2018 6.42 AM
root / root
0644
XSLoader.pm
11.003 KB
18 May 2023 9.34 PM
root / root
0644
_charnames.pm
32.389 KB
18 May 2023 9.34 PM
root / root
0644
autouse.pm
4.139 KB
18 May 2023 9.34 PM
root / root
0644
base.pm
10.723 KB
18 May 2023 9.34 PM
root / root
0644
blib.pm
2.037 KB
18 May 2023 9.34 PM
root / root
0644
bytes.pm
3.666 KB
18 May 2023 9.34 PM
root / root
0644
bytes_heavy.pl
0.74 KB
18 May 2023 9.34 PM
root / root
0644
charnames.pm
20.378 KB
18 May 2023 9.34 PM
root / root
0644
deprecate.pm
3.007 KB
18 May 2023 9.34 PM
root / root
0644
diagnostics.pm
18.592 KB
18 May 2023 9.34 PM
root / root
0644
dumpvar.pl
15.19 KB
18 May 2023 9.34 PM
root / root
0644
feature.pm
16.685 KB
18 May 2023 9.34 PM
root / root
0644
fields.pm
9.267 KB
18 May 2023 9.34 PM
root / root
0644
filetest.pm
3.909 KB
18 May 2023 9.34 PM
root / root
0644
if.pm
3.262 KB
18 May 2023 9.34 PM
root / root
0644
integer.pm
3.178 KB
18 May 2023 9.34 PM
root / root
0644
less.pm
3.129 KB
18 May 2023 9.34 PM
root / root
0644
locale.pm
4.741 KB
18 May 2023 9.34 PM
root / root
0644
meta_notation.pm
2.067 KB
18 May 2023 9.34 PM
root / root
0644
overload.pm
52.064 KB
18 May 2023 9.34 PM
root / root
0644
overloading.pm
1.766 KB
18 May 2023 9.34 PM
root / root
0644
perl5db.pl
309.004 KB
18 May 2023 9.34 PM
root / root
0644
sigtrap.pm
7.428 KB
18 May 2023 9.34 PM
root / root
0644
sort.pm
5.938 KB
18 May 2023 9.34 PM
root / root
0644
strict.pm
4.627 KB
18 May 2023 9.34 PM
root / root
0644
subs.pm
0.828 KB
18 May 2023 9.34 PM
root / root
0644
utf8.pm
8.902 KB
18 May 2023 9.34 PM
root / root
0644
utf8_heavy.pl
30.874 KB
18 May 2023 9.34 PM
root / root
0644
vars.pm
2.357 KB
18 May 2023 9.34 PM
root / root
0644
vmsish.pm
4.212 KB
18 May 2023 9.34 PM
root / root
0644
warnings.pm
43.707 KB
18 May 2023 9.34 PM
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2026 CONTACT ME
Static GIF