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.