All Downloads are FREE. Search and download functionalities are using the official Maven repository.

htsjdk.tribble.FeatureReader Maven / Gradle / Ivy

There is a newer version: 4.1.3
Show newest version
/*
 * Copyright (c) 2007-2010 by The Broad Institute, Inc. and the Massachusetts Institute of Technology.
 * All Rights Reserved.
 *
 * This software is licensed under the terms of the GNU Lesser General Public License (LGPL), Version 2.1 which
 * is available at http://www.opensource.org/licenses/lgpl-2.1.php.
 *
 * THE SOFTWARE IS PROVIDED "AS IS." THE BROAD AND MIT MAKE NO REPRESENTATIONS OR WARRANTIES OF
 * ANY KIND CONCERNING THE SOFTWARE, EXPRESS OR IMPLIED, INCLUDING, WITHOUT LIMITATION, WARRANTIES
 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, NONINFRINGEMENT, OR THE ABSENCE OF LATENT
 * OR OTHER DEFECTS, WHETHER OR NOT DISCOVERABLE.  IN NO EVENT SHALL THE BROAD OR MIT, OR THEIR
 * RESPECTIVE TRUSTEES, DIRECTORS, OFFICERS, EMPLOYEES, AND AFFILIATES BE LIABLE FOR ANY DAMAGES OF
 * ANY KIND, INCLUDING, WITHOUT LIMITATION, INCIDENTAL OR CONSEQUENTIAL DAMAGES, ECONOMIC
 * DAMAGES OR INJURY TO PROPERTY AND LOST PROFITS, REGARDLESS OF WHETHER THE BROAD OR MIT SHALL
 * BE ADVISED, SHALL HAVE OTHER REASON TO KNOW, OR IN FACT SHALL KNOW OF THE POSSIBILITY OF THE
 * FOREGOING.
 */

package htsjdk.tribble;

import htsjdk.samtools.util.Locatable;

import java.io.Closeable;
import java.io.IOException;
import java.util.List;

/**
 * the basic interface that feature sources need to match
 *
 * @param  a feature type
 */
public interface FeatureReader extends Closeable {

    /**
     * Query the reader for a particular interval corresponding to a contig and a 1-based closed
     *
     * @param chr   the contig to be queried
     * @param start the start of the interval (1-based) to be queried
     * @param end   the last base in the interval to be queried
     * @return an iterator containing the features that at in the interval.
     * @throws IOException If there's a problem reading or if the reader is not queryable, e.g. if it doesn't have an index.
     */
    CloseableTribbleIterator query(final String chr, final int start, final int end) throws IOException;

    /**
     * Query the reader for a particular interval corresponding to a contig and a 1-based closed
     *
     * @param locus The locus to be queried
     * @return an iterator containing the features that at in the interval.
     * @throws IOException If there's a problem reading or if the reader is not queryable, e.g. if it doesn't have an index.
     */
    default CloseableTribbleIterator query(Locatable locus) throws IOException {
        return query(locus.getContig(), locus.getStart(), locus.getEnd());
    }

    /**
     * Provides access to all the features in the reader
     *
     * @return an iterator to all the features in the reader
     * @throws IOException If there's a problem reading.
     */
    CloseableTribbleIterator iterator() throws IOException;

    /**
     * Closes the reader
     *
     * @throws IOException
     */
    @Override
    void close() throws IOException;

    /**
     * Provides the list of sequenceNames if known. Otherwise will return an empty list.
     *
     * @return the list of sequenceNames if known. Otherwise will return an empty list.
     */
    List getSequenceNames();

    /**
     * Provide access to the header of the reader
     *
     * @return the header of the reader. May be null.
     */
    Object getHeader();

    /**
     * @return true if the reader has an index, which means that it can be queried.
     * Must be implemented to return true if the implementation supports {@link #query(Locatable)}
     */
    default boolean isQueryable() {
        return false;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy