data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
com.fulcrumgenomics.coord.LocatableOrdering.scala Maven / Gradle / Ivy
The newest version!
package com.fulcrumgenomics.coord
import com.fulcrumgenomics.fasta.SequenceDictionary
import htsjdk.samtools.util.Locatable
/** Methods for building orderings of [[Locatable]] instances. */
object LocatableOrdering {
/** Build a coordinate-based ordering of [[Locatable]] instances. */
def apply(dict: SequenceDictionary): Ordering[Locatable] = (x: Locatable, y: Locatable) => {
var compare = (dict.get(x.getContig), dict.get(y.getContig)) match {
case (Some(meta1), Some(meta2)) => meta1.index.compare(meta2.index)
case (None, _) => throw new NoSuchElementException(s"Sequence dictionary does not contain contig: ${x.getContig}")
case (_, None) => throw new NoSuchElementException(s"Sequence dictionary does not contain contig: ${y.getContig}")
}
if (compare == 0) compare = x.getStart.compare(y.getStart)
if (compare == 0) compare = x.getEnd.compare(y.getEnd)
compare
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy