Comparer-file_num_links
view release on metacpan or search on metacpan
lib/Comparer/file_num_links.pm view on Meta::CPAN
package Comparer::file_num_links;
use 5.010001;
use strict 'subs', 'vars';
use warnings;
our $AUTHORITY = 'cpan:PERLANCAR'; # AUTHORITY
our $DATE = '2024-11-10'; # DATE
our $DIST = 'Comparer-file_num_links'; # DIST
our $VERSION = '0.002'; # VERSION
sub meta {
return +{
v => 1,
args => {
follow_symlink => {schema=>'bool*', default=>1},
reverse => {schema => 'bool*'},
},
};
}
sub gen_comparer {
my %args = @_;
my $follow_symlink = $args{follow_symlink} // 1;
my $reverse = $args{reverse};
sub {
my @st1 = $follow_symlink ? stat($_[0]) : lstat($_[0]);
my @st2 = $follow_symlink ? stat($_[1]) : lstat($_[1]);
(
$st1[3] <=> $st2[3]
) * ($reverse ? -1 : 1)
};
}
1;
# ABSTRACT: Compare file's number of (hard) links
__END__
=pod
=encoding UTF-8
=head1 NAME
Comparer::file_num_links - Compare file's number of (hard) links
=head1 VERSION
This document describes version 0.002 of Comparer::file_num_links (from Perl distribution Comparer-file_num_links), released on 2024-11-10.
=head1 SYNOPSIS
use Comparer::file_num_links;
my $cmp = Comparer::file_num_links::gen_comparer();
my @sorted = sort { $cmp->($a,$b) } "foo", "bar", "baz";
=head1 DESCRIPTION
This comparer assumes the entries are filenames and will compare their
number of (hard) links.
=for Pod::Coverage ^(meta|gen_comparer)$
=head1 COMPARER ARGUMENTS
=head2 follow_symlink
Bool, default true. If set to false, will use C<lstat()> function instead of the
default C<stat()>.
=head2 reverse
Bool.
=head1 HOMEPAGE
Please visit the project's homepage at L<https://metacpan.org/release/Comparer-file_num_links>.
=head1 SOURCE
Source repository is at L<https://github.com/perlancar/perl-Comparer-file_num_links>.
=head1 SEE ALSO
L<Sorter::file_by_num_links>
L<SortKey::Num::file_num_links>
=head1 AUTHOR
perlancar <perlancar@cpan.org>
=head1 CONTRIBUTING
To contribute, you can send patches by email/via RT, or send pull requests on
GitHub.
Most of the time, you don't need to build the distribution yourself. You can
simply modify the code, then test via:
% prove -l
If you want to build the distribution (e.g. to try to install it locally on your
system), you can install L<Dist::Zilla>,
L<Dist::Zilla::PluginBundle::Author::PERLANCAR>,
L<Pod::Weaver::PluginBundle::Author::PERLANCAR>, and sometimes one or two other
Dist::Zilla- and/or Pod::Weaver plugins. Any additional steps required beyond
that are considered a bug and can be reported to me.
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2024 by perlancar <perlancar@cpan.org>.
This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.
=head1 BUGS
Please report any bugs or feature requests on the bugtracker website L<https://rt.cpan.org/Public/Dist/Display.html?Name=Comparer-file_num_links>
When submitting a bug or request, please include a test-file or a
patch to an existing test-file that illustrates the bug or desired
feature.
=cut
( run in 2.357 seconds using v1.01-cache-2.11-cpan-8f98c5d2c55 )