NAME
ArrayDataRole::BinarySearch::LinesInHandle - Role to be mixed in by ArrayData::* class that puts the elements as lines in a filehandle
VERSION
This document describes version 0.001 of ArrayDataRole::BinarySearch::LinesInHandle (from Perl distribution ArrayDataRole-BinarySearch-LinesInHandle), released on 2021-05-07.
SYNOPSIS
For example, to use with classes that use ArrayDataRole::Spec::Basic and support apply_roles()
:
my $obj = ArrayData::Word::ID::KBBI->new;
$obj->has_item('kuda'); # uses linear search by iterating
$obj = ArrayData::Word::ID::KBBI->new->apply_roles('BinarySearch::LinesInHandle');
$obj->has_item('kuda'); # now uses binary search
DESCRIPTION
REQUIRED METHODS
fh
Must return the filehandle.
OPTIONALLY DEPENDED METHODS
fh_min_offset
Must return the minimum position (in bytes) to search the filehandle from.
If this method is not supported by object, 0 will be assumed.
fh_max_offset
Must return the maximum position (in bytes) to search the filehandle to. Can also return undef
, in which case the filehandle will be stat()
-ed to find out the size of the file.
If this method is not supported by object, the filehandle will also be stat()
-ed.
cmp_items
Usage:
my $res = $obj->cmp_items($item1, $item2); # 0|-1|1
Must return 0, -1, or 1 like Perl's cmp
or <=>
operator. Note that Role::TinyCommons::Collection::CompareItems also uses this method.
PROVIDED METHODS
has_item
Usage:
my $has_item = $obj->has_item($item); # bool
Return true if $item
is found in the filehandle (searched using binary search), false otherwise.
Note that the Role::TinyCommons::Collection::FindItem role also uses this method.
HOMEPAGE
Please visit the project's homepage at https://metacpan.org/release/ArrayDataRole-BinarySearch-LinesInHandle.
SOURCE
Source repository is at https://github.com/perlancar/perl-ArrayDataRole-BinarySearch-LinesInHandle.
BUGS
Please report any bugs or feature requests on the bugtracker website https://github.com/perlancar/perl-ArrayDataRole-BinarySearch-LinesInHandle/issues
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.
SEE ALSO
AUTHOR
perlancar <perlancar@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2021 by 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.