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

org.snpeff.snpEffect.Hgvs Maven / Gradle / Ivy

The newest version!
package org.snpeff.snpEffect;

import org.snpeff.interval.Genome;
import org.snpeff.interval.Marker;
import org.snpeff.interval.Transcript;
import org.snpeff.interval.Variant;

/**
 * HGSV notation
 *
 * References: http://www.hgvs.org/
 *
 * @author pcingola
 */
public class Hgvs {

	// Don't show sequences that are too long
	public static final int MAX_SEQUENCE_LEN_HGVS = 100;

	protected VariantEffect variantEffect;
	protected Variant variant;
	protected Marker marker;
	protected Transcript tr;
	protected Genome genome;

	protected boolean duplication;
	protected boolean strandPlus, strandMinus;
	protected boolean hgvsTrId;

	public static String parseTranscript(String hgvs) {
		int idxTr = hgvs.indexOf(':');
		if (idxTr < 0) return null;
		return hgvs.substring(0, idxTr);
	}

	public static String removeTranscript(String hgvs) {
		int idxTr = hgvs.indexOf(':');
		if (idxTr < 0) return hgvs;
		return hgvs.substring(idxTr + 1);
	}

	public Hgvs(VariantEffect variantEffect) {
		this.variantEffect = variantEffect;
		variant = variantEffect.getVariant();
		marker = variantEffect.getMarker();
		tr = variantEffect.getTranscript();
		genome = marker != null ? marker.getGenome() : null;
		hgvsTrId = Config.get().isHgvsTrId();
		initStrand();
	}

	protected void initStrand() {
		// Strand information
		if (tr != null) strandMinus = tr.isStrandMinus();
		else if (marker != null) strandMinus = marker.isStrandMinus();

		strandPlus = !strandMinus;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy