Package htsjdk.samtools
Class BAMFileSpan
- java.lang.Object
-
- htsjdk.samtools.BAMFileSpan
-
- All Implemented Interfaces:
SAMFileSpan,Serializable,Cloneable
public class BAMFileSpan extends Object implements SAMFileSpan, Serializable
An ordered list of chunks, capable of representing a set of discontiguous regions in the BAM file. FileSpans are mutable within the package, but perceived as immutable outside the package. Some operations on FileSpans assume that the spans are sorted. In these cases, sort order will be validated.- See Also:
- Serialized Form
-
-
Constructor Summary
Constructors Constructor Description BAMFileSpan()Create a new empty list of chunks.BAMFileSpan(Chunk chunk)Convenience constructor to construct a BAM file span from a single chunk.BAMFileSpan(List<Chunk> chunks)Create a new chunk list from the given list of chunks.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description protected voidadd(BAMFileSpan span)Merge one span into anotherprotected voidadd(Chunk chunk)Adds a new chunk to this list.BAMFileSpanclone()Deep clone the given chunk list.List<Chunk>getChunks()Gets the constituent chunks stored in this span.SAMFileSpangetContentsFollowing()Gets a file span over the data immediately following this span.longgetFirstOffset()Find the first offset in the chunk listprotected ChunkgetSingleChunk()Checks that there is only a single chunk for this span and returns it.booleanisEmpty()Does this chunk list map to any position within the BAM file?static BAMFileSpanmerge(BAMFileSpan[] spans)SAMFileSpanremoveContentsAfter(SAMFileSpan fileSpan)Creates a new file span by removing all chunks after the given file span ends.SAMFileSpanremoveContentsBefore(SAMFileSpan fileSpan)Creates a new file span by removing all chunks before the given file span starts.protected static SAMFileSpantoChunkList(long[] coordinateArray)The list of chunks is often represented as an array of longs where every even-numbered index is a start coordinate and every odd-numbered index is a stop coordinate.long[]toCoordinateArray()Convert the chunk list to an array of offsets, paired in [start,end) format.StringtoString()Creates a string representation of this chunk list.
-
-
-
Constructor Detail
-
BAMFileSpan
public BAMFileSpan()
Create a new empty list of chunks.
-
BAMFileSpan
public BAMFileSpan(Chunk chunk)
Convenience constructor to construct a BAM file span from a single chunk.- Parameters:
chunk- Chunk to use as the sole region in this span.
-
-
Method Detail
-
isEmpty
public boolean isEmpty()
Does this chunk list map to any position within the BAM file?- Specified by:
isEmptyin interfaceSAMFileSpan- Returns:
- True iff the ChunkList points to any data within the BAM.
-
clone
public BAMFileSpan clone()
Deep clone the given chunk list.
-
removeContentsBefore
public SAMFileSpan removeContentsBefore(SAMFileSpan fileSpan)
Creates a new file span by removing all chunks before the given file span starts. If a chunk in the chunk list starts before and ends after the given chunk, the first portion of the chunk will be deleted.- Specified by:
removeContentsBeforein interfaceSAMFileSpan- Parameters:
fileSpan- The filespan before which to eliminate.- Returns:
- A new BAMFileSpan which contains the portion of the chunk list after the given chunk.
-
removeContentsAfter
public SAMFileSpan removeContentsAfter(SAMFileSpan fileSpan)
Creates a new file span by removing all chunks after the given file span ends. If a chunk in the chunk list starts before and ends after the given chunk, the second portion of the chunk will be deleted.- Parameters:
fileSpan- The filespan after which to eliminate.- Returns:
- A new BAMFileSpan which contains the portion of the chunk list before the given chunk.
-
getContentsFollowing
public SAMFileSpan getContentsFollowing()
Gets a file span over the data immediately following this span.- Specified by:
getContentsFollowingin interfaceSAMFileSpan- Returns:
- The a pointer to data immediately following this span.
-
add
protected void add(BAMFileSpan span)
Merge one span into another- Parameters:
span- - span with chunks to add to this one
-
add
protected void add(Chunk chunk)
Adds a new chunk to this list. Visible only within the BAm.- Parameters:
chunk- Chunk to add.
-
toCoordinateArray
public long[] toCoordinateArray()
Convert the chunk list to an array of offsets, paired in [start,end) format.- Returns:
- Array of offsets.
-
getFirstOffset
public long getFirstOffset()
Find the first offset in the chunk list- Returns:
- The first offset in the span
-
getChunks
public List<Chunk> getChunks()
Gets the constituent chunks stored in this span.- Returns:
- An unmodifiable list of chunks.
-
getSingleChunk
protected Chunk getSingleChunk()
Checks that there is only a single chunk for this span and returns it.- Returns:
- The single chunk stored in this span
-
toChunkList
protected static SAMFileSpan toChunkList(long[] coordinateArray)
The list of chunks is often represented as an array of longs where every even-numbered index is a start coordinate and every odd-numbered index is a stop coordinate. Convert from that format back to a list of chunks.- Parameters:
coordinateArray- List of chunks to convert.- Returns:
- A list of chunks.
-
toString
public String toString()
Creates a string representation of this chunk list.
-
merge
public static BAMFileSpan merge(BAMFileSpan[] spans)
- Returns:
- A single BAMFileSpan that is an intelligent merge of the input spans, i.e. contiguous, overlapping and contained chunks are intelligently merged, and the chunks are sorted.
-
-