org.dishevelled.bio.feature.gff3.Gff3Reader Maven / Gradle / Ivy
/*
dsh-bio-feature Sequence features.
Copyright (c) 2013-2022 held jointly by the individual authors.
This library is free software; you can redistribute it and/or modify it
under the terms of the GNU Lesser General Public License as published
by the Free Software Foundation; either version 3 of the License, or (at
your option) any later version.
This library is distributed in the hope that it will be useful, but WITHOUT
ANY WARRANTY; with out even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
License for more details.
You should have received a copy of the GNU Lesser General Public License
along with this library; if not, write to the Free Software Foundation,
Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
> http://www.fsf.org/licensing/licenses/lgpl.html
> http://www.opensource.org/licenses/lgpl-license.php
*/
package org.dishevelled.bio.feature.gff3;
import static com.google.common.base.Preconditions.checkNotNull;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import com.google.common.io.CharStreams;
import com.google.common.io.LineProcessor;
/**
* GFF3 format reader.
*
* @author Michael Heuer
*/
public final class Gff3Reader {
/**
* Private no-arg constructor.
*/
private Gff3Reader() {
// empty
}
/**
* Read zero or more GFF3 records from the specified readable.
*
* @param readable to read from, must not be null
* @return zero or more GFF3 records read from the specified readable
* @throws IOException if an I/O error occurs
*/
public static Iterable read(final Readable readable) throws IOException {
checkNotNull(readable);
Collect collect = new Collect();
stream(readable, collect);
return collect.records();
}
/**
* Stream zero or more GFF3 records from the specified readable.
*
* @param readable readable to stream from, must not be null
* @param listener event based listener callback, must not be null
* @throws IOException if an I/O error occurs
*/
public static void stream(final Readable readable, final Gff3Listener listener) throws IOException {
checkNotNull(readable);
checkNotNull(listener);
Gff3LineProcessor lineProcessor = new Gff3LineProcessor(listener);
CharStreams.readLines(readable, lineProcessor);
}
/**
* GFF3 line processor.
*/
private static final class Gff3LineProcessor implements LineProcessor