/* * Copyright (c) 2012 The Broad Institute * * Permission is hereby granted, free of charge, to any person * obtaining a copy of this software and associated documentation * files (the "Software"), to deal in the Software without * restriction, including without limitation the rights to use, * copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following * conditions: * * The above copyright notice and this permission notice shall be * included in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR * THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ package htsjdk.variant.vcf; import htsjdk.samtools.SAMSequenceRecord; import htsjdk.tribble.TribbleException; import java.util.LinkedHashMap; import java.util.Map; /** * A special class representing a contig VCF header line. Knows the true contig order and sorts on that * * @author mdepristo */ public class VCFContigHeaderLine extends VCFSimpleHeaderLine { final Integer contigIndex; /** * create a VCF contig header line * * @param line the header line * @param version the vcf header version * @param key the key for this header line */ public VCFContigHeaderLine(final String line, final VCFHeaderVersion version, final String key, final int contigIndex) { super(line, version, key, null); if (contigIndex < 0) throw new TribbleException("The contig index is less than zero."); this.contigIndex = contigIndex; } public VCFContigHeaderLine(final Map<String, String> mapping, final int contigIndex) { super(VCFHeader.CONTIG_KEY, mapping); if (contigIndex < 0) throw new TribbleException("The contig index is less than zero."); this.contigIndex = contigIndex; } VCFContigHeaderLine(final SAMSequenceRecord sequenceRecord, final String assembly) { // Using LinkedHashMap to preserve order of keys in contig line (ID, length, assembly) super(VCFHeader.CONTIG_KEY, new LinkedHashMap<String, String>() {{ // Now inside an init block in an anon HashMap subclass this.put("ID", sequenceRecord.getSequenceName()); this.put("length", Integer.toString(sequenceRecord.getSequenceLength())); if ( assembly != null ) this.put("assembly", assembly); }}); this.contigIndex = sequenceRecord.getSequenceIndex(); } public Integer getContigIndex() { return contigIndex; } public SAMSequenceRecord getSAMSequenceRecord() { final String lengthString = this.getGenericFieldValue("length"); if (lengthString == null) throw new TribbleException("Contig " + this.getID() + " does not have a length field."); final SAMSequenceRecord record = new SAMSequenceRecord(this.getID(), Integer.valueOf(lengthString)); record.setAssembly(this.getGenericFieldValue("assembly")); record.setSequenceIndex(this.contigIndex); return record; } /** * IT IS CRITICAL THAT THIS BE OVERRIDDEN SO WE SORT THE CONTIGS IN THE CORRECT ORDER */ @Override public int compareTo(final Object other) { if ( other instanceof VCFContigHeaderLine ) return contigIndex.compareTo(((VCFContigHeaderLine) other).contigIndex); else { return super.compareTo(other); } } }