1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
|
=head1 LICENSE
Copyright [2015-2018] EMBL-European Bioinformatics Institute
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
=cut
=head1 NAME
Bio::DB::HTS::Kseq - Bindings to Kseq
=head1 DESCRIPTION
Bindings to the Kseq library for iterating through a locally held FASTA/FASTQ file very quickly. Supports compressed and uncompressed files alongside filehandles.
=head1 SYNOPSIS
my $kseq = Bio::DB::HTS::Kseq->new('path/to/file');
my $iter = $kseq->iterator();
while(my $r = $iter->next_seq()) {
say $r->name;
say $r->desc;
say $r->seq;
say $r->qual;
}
# Allowing the object to go out of scope will close down all file handles
=head2 METHODS
=over 8
=item C<new>
my $kseq = Bio::DB::HTS::Kseq->new('path/to/file');
Returns an instance of this object from a file path.
=item C<newfh>
open my $fh, '<', 'path' or die "Cannot open path: $!";
binmode $fh;
my $kseq = Bio::DB::HTS::Kseq->newfh($fh);
Returns an instance of this object from an opened file handle. This supports any known Perl glob/filehandle type
=item C<iterator>
my $iter = $kseq->iterator();
Returns the kseq iterator object
=back
=cut
package Bio::DB::HTS::Kseq;
use Bio::DB::HTS; #load the XS
use Bio::DB::HTS::Kseq::Record;
$Bio::DB::HTS::Kseq::VERSION = '3.01';
use strict;
use warnings;
1;
|