$66 GRAYBYTE WORDPRESS FILE MANAGER $16

SERVER : vnpttt-amd7f72-h1.vietnix.vn #1 SMP Fri May 24 12:42:50 UTC 2024
SERVER IP : 103.200.23.149 | ADMIN IP 216.73.216.22
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
..
--
16 Mar 2026 5.03 PM
root / root
0755
Attribute
--
14 Aug 2025 9.24 PM
root / root
0755
B
--
14 Aug 2025 9.24 PM
root / root
0755
CPAN
--
30 Aug 2024 10.28 PM
root / root
0755
Class
--
14 Aug 2025 9.24 PM
root / root
0755
Compress
--
31 Aug 2024 4.31 AM
root / root
0755
Config
--
14 Aug 2025 9.24 PM
root / root
0755
DBM_Filter
--
14 Aug 2025 9.24 PM
root / root
0755
Devel
--
14 Aug 2025 9.24 PM
root / root
0755
ExtUtils
--
14 Aug 2025 9.24 PM
root / root
0755
File
--
14 Aug 2025 9.24 PM
root / root
0755
Getopt
--
14 Aug 2025 9.24 PM
root / root
0755
I18N
--
14 Aug 2025 9.24 PM
root / root
0755
IO
--
14 Aug 2025 9.24 PM
root / root
0755
IPC
--
14 Aug 2025 9.24 PM
root / root
0755
Locale
--
28 Jul 2025 3.08 PM
root / root
0755
Math
--
14 Aug 2025 9.24 PM
root / root
0755
Memoize
--
14 Aug 2025 9.24 PM
root / root
0755
Module
--
14 Aug 2025 9.24 PM
root / root
0755
Net
--
14 Aug 2025 9.24 PM
root / root
0755
Pod
--
14 Aug 2025 9.24 PM
root / root
0755
Search
--
14 Aug 2025 9.24 PM
root / root
0755
Term
--
14 Aug 2025 9.24 PM
root / root
0755
Text
--
14 Aug 2025 9.24 PM
root / root
0755
Thread
--
14 Aug 2025 9.24 PM
root / root
0755
Tie
--
14 Aug 2025 9.24 PM
root / root
0755
Time
--
14 Aug 2025 9.24 PM
root / root
0755
URI
--
31 Aug 2024 4.31 AM
root / root
0755
Unicode
--
14 Aug 2025 9.24 PM
root / root
0755
User
--
14 Aug 2025 9.24 PM
root / root
0755
encoding
--
14 Aug 2025 9.24 PM
root / root
0755
overload
--
14 Aug 2025 9.24 PM
root / root
0755
pod
--
14 Aug 2025 9.24 PM
root / root
0755
unicore
--
14 Aug 2025 9.24 PM
root / root
0755
vendor_perl
--
14 Aug 2025 9.25 PM
root / root
0755
warnings
--
14 Aug 2025 9.24 PM
root / root
0755
AnyDBM_File.pm
2.557 KB
28 Jul 2025 3.07 PM
root / root
0644
AutoLoader.pm
15.427 KB
28 Jul 2025 3.07 PM
root / root
0644
AutoSplit.pm
19.177 KB
28 Jul 2025 3.07 PM
root / root
0644
Benchmark.pm
30.298 KB
28 Jul 2025 3.07 PM
root / root
0644
CORE.pod
3.113 KB
28 Jul 2025 3.07 PM
root / root
0644
DB.pm
18.479 KB
28 Jul 2025 3.07 PM
root / root
0644
DBM_Filter.pm
14.048 KB
28 Jul 2025 3.07 PM
root / root
0644
DirHandle.pm
1.52 KB
28 Jul 2025 3.07 PM
root / root
0644
Dumpvalue.pm
17.145 KB
28 Jul 2025 3.07 PM
root / root
0644
English.pm
4.649 KB
28 Jul 2025 3.07 PM
root / root
0644
FileCache.pm
5.441 KB
28 Jul 2025 3.07 PM
root / root
0644
FileHandle.pm
6.625 KB
28 Jul 2025 3.07 PM
root / root
0644
FindBin.pm
4.454 KB
28 Jul 2025 3.07 PM
root / root
0644
Internals.pod
2.516 KB
28 Jul 2025 3.07 PM
root / root
0644
Memoize.pm
35.344 KB
28 Jul 2025 3.08 PM
root / root
0644
NEXT.pm
18.404 KB
28 Jul 2025 3.07 PM
root / root
0644
PerlIO.pm
10.214 KB
28 Jul 2025 3.07 PM
root / root
0644
Safe.pm
24.494 KB
28 Jul 2025 3.07 PM
root / root
0644
SelectSaver.pm
1.051 KB
28 Jul 2025 3.07 PM
root / root
0644
SelfLoader.pm
17.277 KB
28 Jul 2025 3.08 PM
root / root
0644
Symbol.pm
4.687 KB
28 Jul 2025 3.07 PM
root / root
0644
Test.pm
29.353 KB
28 Jul 2025 3.08 PM
root / root
0644
Thread.pm
8.093 KB
28 Jul 2025 3.07 PM
root / root
0644
UNIVERSAL.pm
6.439 KB
28 Jul 2025 3.07 PM
root / root
0644
URI.pm
33.975 KB
9 Jan 2018 1.42 PM
root / root
0644
XSLoader.pm
11.003 KB
28 Jul 2025 3.07 PM
root / root
0644
_charnames.pm
32.389 KB
28 Jul 2025 3.07 PM
root / root
0644
autouse.pm
4.139 KB
28 Jul 2025 3.07 PM
root / root
0644
base.pm
10.723 KB
28 Jul 2025 3.07 PM
root / root
0644
blib.pm
2.037 KB
28 Jul 2025 3.07 PM
root / root
0644
bytes.pm
3.666 KB
28 Jul 2025 3.07 PM
root / root
0644
bytes_heavy.pl
0.74 KB
28 Jul 2025 3.07 PM
root / root
0644
charnames.pm
20.378 KB
28 Jul 2025 3.07 PM
root / root
0644
deprecate.pm
3.007 KB
28 Jul 2025 3.07 PM
root / root
0644
diagnostics.pm
18.592 KB
28 Jul 2025 3.07 PM
root / root
0644
dumpvar.pl
15.19 KB
28 Jul 2025 3.07 PM
root / root
0644
feature.pm
16.685 KB
28 Jul 2025 3.07 PM
root / root
0644
fields.pm
9.267 KB
28 Jul 2025 3.07 PM
root / root
0644
filetest.pm
3.909 KB
28 Jul 2025 3.07 PM
root / root
0644
if.pm
3.262 KB
28 Jul 2025 3.07 PM
root / root
0644
integer.pm
3.178 KB
28 Jul 2025 3.07 PM
root / root
0644
less.pm
3.129 KB
28 Jul 2025 3.07 PM
root / root
0644
locale.pm
4.741 KB
28 Jul 2025 3.07 PM
root / root
0644
meta_notation.pm
2.067 KB
28 Jul 2025 3.07 PM
root / root
0644
open.pm
7.833 KB
28 Jul 2025 3.08 PM
root / root
0644
overload.pm
52.064 KB
28 Jul 2025 3.07 PM
root / root
0644
overloading.pm
1.766 KB
28 Jul 2025 3.07 PM
root / root
0644
perl5db.pl
309.004 KB
28 Jul 2025 3.07 PM
root / root
0644
sigtrap.pm
7.428 KB
28 Jul 2025 3.07 PM
root / root
0644
sort.pm
5.938 KB
28 Jul 2025 3.07 PM
root / root
0644
strict.pm
4.627 KB
28 Jul 2025 3.07 PM
root / root
0644
subs.pm
0.828 KB
28 Jul 2025 3.07 PM
root / root
0644
utf8.pm
8.902 KB
28 Jul 2025 3.07 PM
root / root
0644
utf8_heavy.pl
30.874 KB
28 Jul 2025 3.07 PM
root / root
0644
vars.pm
2.357 KB
28 Jul 2025 3.07 PM
root / root
0644
vmsish.pm
4.212 KB
28 Jul 2025 3.07 PM
root / root
0644
warnings.pm
43.707 KB
28 Jul 2025 3.07 PM
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2026 CONTACT ME
Static GIF