org.pharmgkb.parser.vcf.model.VcfSample Maven / Gradle / Ivy
package org.pharmgkb.parser.vcf.model;
import com.google.common.base.Preconditions;
import org.pharmgkb.parser.vcf.VcfUtils;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import java.util.*;
/**
* This class contains sample data for a VCF position line.
*
* @author Mark Woon
*/
public class VcfSample {
private LinkedHashMap m_properties = new LinkedHashMap<>();
public VcfSample(@Nullable List keys, @Nullable List values) {
if (keys == null) {
if (values == null || values.size() == 0) {
return;
}
throw new IllegalArgumentException("keys is null but values is not");
} else if (values == null) {
throw new IllegalArgumentException("values is null but keys is not");
}
Preconditions.checkArgument(keys.size() == values.size(), "Number of keys does not match number of values");
for (int x = 0; x < keys.size(); x++) {
m_properties.put(keys.get(x), values.get(x));
}
init();
}
public VcfSample(@Nonnull LinkedHashMap properties) {
m_properties = properties;
init();
}
private void init() {
for (Map.Entry entry : m_properties.entrySet()) {
if (entry.getKey().contains("\n") || entry.getValue().contains("\n")) {
throw new IllegalArgumentException("FORMAT [[[" + entry.getKey() + "=" + entry.getValue() + "]]] contains a newline");
}
}
}
public @Nullable String getProperty(@Nonnull String key) {
return m_properties.get(key);
}
/**
* Returns the value for the reserved property as the type specified by both {@link ReservedFormatProperty#getType()}
* and {@link ReservedFormatProperty#isList()}.
* @param The type specified by {@code ReservedInfoProperty.getType()} if {@code ReservedFormatProperty.isList()}
* is false;
* otherwise {@code List} where V is the type specified by {@code ReservedFormatProperty.getType()}.
*/
@SuppressWarnings("InfiniteRecursion")
public @Nullable T getProperty(@Nonnull ReservedFormatProperty key) {
return VcfUtils.convertProperty(key, getProperty(key.getId()));
}
public boolean containsProperty(@Nonnull String key) {
return m_properties.containsKey(key);
}
public boolean containsProperty(@Nonnull ReservedFormatProperty key) {
return m_properties.containsKey(key.getId());
}
public void putProperty(@Nonnull String key, @Nullable String value) {
m_properties.put(key, value);
}
public void putProperty(@Nonnull ReservedFormatProperty key, @Nullable String value) {
m_properties.put(key.getId(), value);
}
public void removeProperty(@Nonnull String key) {
m_properties.remove(key);
}
public void removeProperty(@Nonnull ReservedFormatProperty key) {
m_properties.remove(key.getId());
}
public void clearProperties() {
m_properties.clear();
}
/**
* @return A set of the property keys, which has guaranteed order
*/
@Nonnull
public Set getPropertyKeys() {
// LinkedHashMap.keySet() returns a LinkedKeySet, which has guaranteed order
return m_properties.keySet();
}
@Nonnull
public Set> propertyEntrySet() {
return m_properties.entrySet();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy