use of org.sbolstandard.core2.MapsTo in project libSBOLj by SynBioDex.
the class SBOLReader method parseMapsTo.
/**
* @param mapsTo
* @param inModule
* @return
* @throws SBOLValidationException if either of the following conditions is satisfied:
* <ul>
* <li>any of the following SBOL validation rules was violated:
* 10203, 10204, 10206, 10208, 10212, 10213, 10606, 10802, 10805, 10810, 11706; or
*</li>
* <li>an SBOL validation rule violation occurred in the following constructor or methods:
* <ul>
* <li>{@link MapsTo#MapsTo(URI, RefinementType, URI, URI)},</li>
* <li>{@link MapsTo#setDisplayId(String)},</li>
* <li>{@link MapsTo#setVersion(String)},</li>
* <li>{@link MapsTo#setWasDerivedFrom(URI)}, or</li>
* <li>{@link Identified#setAnnotations(List)}.</li>
* </ul>
* </li>
* </ul>
*/
private static MapsTo parseMapsTo(NestedDocument<QName> mapsTo, boolean inModule) throws SBOLValidationException {
// URIcompliance.extractDisplayId(mapsTo.getIdentity());
String displayId = null;
String name = null;
String description = null;
// URI.create(URIcompliance.extractPersistentId(mapsTo.getIdentity()));
URI persistentIdentity = null;
String version = null;
URI remote = null;
RefinementType refinement = null;
URI local = null;
Set<URI> wasDerivedFroms = new HashSet<>();
Set<URI> wasGeneratedBys = new HashSet<>();
List<Annotation> annotations = new ArrayList<>();
for (NamedProperty<QName> namedProperty : mapsTo.getProperties()) {
if (namedProperty.getName().equals(Sbol2Terms.Identified.persistentIdentity)) {
if (!(namedProperty.getValue() instanceof Literal) || persistentIdentity != null || (!(((Literal<QName>) namedProperty.getValue()).getValue() instanceof URI))) {
throw new SBOLValidationException("sbol-10203", mapsTo.getIdentity());
}
persistentIdentity = URI.create(((Literal<QName>) namedProperty.getValue()).getValue().toString());
} else if (namedProperty.getName().equals(Sbol2Terms.Identified.displayId)) {
if (!(namedProperty.getValue() instanceof Literal) || displayId != null || (!(((Literal<QName>) namedProperty.getValue()).getValue() instanceof String))) {
throw new SBOLValidationException("sbol-10204", mapsTo.getIdentity());
}
displayId = ((Literal<QName>) namedProperty.getValue()).getValue().toString();
} else if (namedProperty.getName().equals(Sbol2Terms.Identified.title)) {
if (!(namedProperty.getValue() instanceof Literal) || name != null || (!(((Literal<QName>) namedProperty.getValue()).getValue() instanceof String))) {
throw new SBOLValidationException("sbol-10212", mapsTo.getIdentity());
}
name = ((Literal<QName>) namedProperty.getValue()).getValue().toString();
} else if (namedProperty.getName().equals(Sbol2Terms.Identified.description)) {
if (!(namedProperty.getValue() instanceof Literal) || description != null || (!(((Literal<QName>) namedProperty.getValue()).getValue() instanceof String))) {
throw new SBOLValidationException("sbol-10213", mapsTo.getIdentity());
}
description = ((Literal<QName>) namedProperty.getValue()).getValue().toString();
} else if (namedProperty.getName().equals(Sbol2Terms.Identified.version)) {
if (!(namedProperty.getValue() instanceof Literal) || version != null || (!(((Literal<QName>) namedProperty.getValue()).getValue() instanceof String))) {
throw new SBOLValidationException("sbol-10206", mapsTo.getIdentity());
}
version = ((Literal<QName>) namedProperty.getValue()).getValue().toString();
} else if (namedProperty.getName().equals(Sbol2Terms.MapsTo.refinement)) {
if (!(namedProperty.getValue() instanceof Literal) || refinement != null || (!(((Literal<QName>) namedProperty.getValue()).getValue() instanceof URI))) {
throw new SBOLValidationException("sbol-10810", mapsTo.getIdentity());
}
String refinementStr = ((Literal<QName>) namedProperty.getValue()).getValue().toString();
if (!refinementStr.startsWith("http://sbols.org/v2#")) {
System.err.println("Warning: namespace for refinement types should be http://sbols.org/v2#");
refinementStr = "http://sbols.org/v2#" + refinementStr;
}
try {
refinement = RefinementType.convertToRefinementType(URI.create(refinementStr));
} catch (SBOLValidationException e) {
throw new SBOLValidationException("sbol-10810", mapsTo.getIdentity());
}
} else if (namedProperty.getName().equals(Sbol2Terms.MapsTo.hasRemote)) {
if (!(namedProperty.getValue() instanceof Literal) || remote != null || (!(((Literal<QName>) namedProperty.getValue()).getValue() instanceof URI))) {
throw new SBOLValidationException("sbol-10805", mapsTo.getIdentity());
}
remote = URI.create(((Literal<QName>) namedProperty.getValue()).getValue().toString());
} else if (namedProperty.getName().equals(Sbol2Terms.MapsTo.hasLocal)) {
if (!(namedProperty.getValue() instanceof Literal) || local != null || (!(((Literal<QName>) namedProperty.getValue()).getValue() instanceof URI))) {
throw new SBOLValidationException("sbol-10802", mapsTo.getIdentity());
}
local = URI.create(((Literal<QName>) namedProperty.getValue()).getValue().toString());
} else if (namedProperty.getName().equals(Sbol2Terms.Identified.wasDerivedFrom)) {
if (!(namedProperty.getValue() instanceof Literal) || (!(((Literal<QName>) namedProperty.getValue()).getValue() instanceof URI))) {
throw new SBOLValidationException("sbol-10208", mapsTo.getIdentity());
}
wasDerivedFroms.add(URI.create(((Literal<QName>) namedProperty.getValue()).getValue().toString()));
} else if (namedProperty.getName().equals(Sbol2Terms.Identified.wasGeneratedBy)) {
if (!(namedProperty.getValue() instanceof Literal) || (!(((Literal<QName>) namedProperty.getValue()).getValue() instanceof URI))) {
throw new SBOLValidationException("sbol-10221", mapsTo.getIdentity());
}
wasGeneratedBys.add(URI.create(((Literal<QName>) namedProperty.getValue()).getValue().toString()));
} else {
annotations.add(new Annotation(namedProperty));
}
}
MapsTo map = new MapsTo(mapsTo.getIdentity(), refinement, local, remote);
if (displayId != null)
map.setDisplayId(displayId);
if (name != null)
map.setName(name);
if (description != null)
map.setDescription(description);
if (persistentIdentity != null)
map.setPersistentIdentity(persistentIdentity);
if (version != null)
map.setVersion(version);
map.setWasDerivedFroms(wasDerivedFroms);
map.setWasGeneratedBys(wasGeneratedBys);
if (!annotations.isEmpty())
map.setAnnotations(annotations);
return map;
}
use of org.sbolstandard.core2.MapsTo in project libSBOLj by SynBioDex.
the class SBOLDocument method updateReferences.
// TODO: need to update persistentIdentities too
private void updateReferences(URI originalIdentity, URI newIdentity) throws SBOLValidationException {
for (TopLevel topLevel : getTopLevels()) {
for (URI wasDerivedFrom : topLevel.getWasDerivedFroms()) {
if (wasDerivedFrom.equals(originalIdentity)) {
topLevel.removeWasDerivedFrom(originalIdentity);
topLevel.addWasDerivedFrom(newIdentity);
}
}
for (URI wasGeneratedBy : topLevel.getWasGeneratedBys()) {
if (wasGeneratedBy.equals(originalIdentity)) {
topLevel.removeWasGeneratedBy(originalIdentity);
topLevel.addWasGeneratedBy(newIdentity);
}
}
for (URI attachmentURI : topLevel.getAttachmentURIs()) {
if (attachmentURI.equals(originalIdentity)) {
topLevel.removeAttachment(originalIdentity);
topLevel.addAttachment(newIdentity);
}
}
}
for (Collection collection : getCollections()) {
for (URI memberURI : collection.getMemberURIs()) {
if (memberURI.equals(originalIdentity)) {
collection.removeMember(originalIdentity);
collection.addMember(newIdentity);
}
}
updateReferences(collection, originalIdentity, newIdentity);
}
for (ComponentDefinition componentDefinition : getComponentDefinitions()) {
updateReferences(componentDefinition, originalIdentity, newIdentity);
for (Component component : componentDefinition.getComponents()) {
if (component.getDefinitionURI().equals(originalIdentity)) {
component.setDefinition(newIdentity);
for (MapsTo mapsTo : component.getMapsTos()) {
ComponentDefinition cd = getComponentDefinition(newIdentity);
if (cd != null) {
String displayId = URIcompliance.extractDisplayId(mapsTo.getRemoteURI());
URI newURI = URIcompliance.createCompliantURI(cd.getPersistentIdentity().toString(), displayId, cd.getVersion());
mapsTo.setRemote(newURI);
}
}
}
updateReferences(component, originalIdentity, newIdentity);
for (MapsTo mapsTo : component.getMapsTos()) {
updateReferences(mapsTo, originalIdentity, newIdentity);
}
}
for (SequenceAnnotation sa : componentDefinition.getSequenceAnnotations()) {
for (Location loc : sa.getLocations()) {
updateReferences(loc, originalIdentity, newIdentity);
}
updateReferences(sa, originalIdentity, newIdentity);
}
for (SequenceConstraint sc : componentDefinition.getSequenceConstraints()) {
updateReferences(sc, originalIdentity, newIdentity);
}
for (URI sequenceURI : componentDefinition.getSequenceURIs()) {
if (sequenceURI.equals(originalIdentity)) {
componentDefinition.removeSequence(originalIdentity);
componentDefinition.addSequence(newIdentity);
}
}
}
for (ModuleDefinition moduleDefinition : getModuleDefinitions()) {
updateReferences(moduleDefinition, originalIdentity, newIdentity);
for (FunctionalComponent functionalComponent : moduleDefinition.getFunctionalComponents()) {
if (functionalComponent.getDefinitionURI().equals(originalIdentity)) {
functionalComponent.setDefinition(newIdentity);
for (MapsTo mapsTo : functionalComponent.getMapsTos()) {
ComponentDefinition cd = getComponentDefinition(newIdentity);
if (cd != null) {
String displayId = URIcompliance.extractDisplayId(mapsTo.getRemoteURI());
URI newURI = URIcompliance.createCompliantURI(cd.getPersistentIdentity().toString(), displayId, cd.getVersion());
mapsTo.setRemote(newURI);
}
}
}
updateReferences(functionalComponent, originalIdentity, newIdentity);
for (MapsTo mapsTo : functionalComponent.getMapsTos()) {
updateReferences(mapsTo, originalIdentity, newIdentity);
}
}
for (Module module : moduleDefinition.getModules()) {
if (module.getDefinitionURI().equals(originalIdentity)) {
module.setDefinition(newIdentity);
for (MapsTo mapsTo : module.getMapsTos()) {
ModuleDefinition md = getModuleDefinition(newIdentity);
if (md != null) {
String displayId = URIcompliance.extractDisplayId(mapsTo.getRemoteURI());
URI newURI = URIcompliance.createCompliantURI(md.getPersistentIdentity().toString(), displayId, md.getVersion());
mapsTo.setRemote(newURI);
}
}
}
updateReferences(module, originalIdentity, newIdentity);
for (MapsTo mapsTo : module.getMapsTos()) {
updateReferences(mapsTo, originalIdentity, newIdentity);
}
}
for (Interaction interaction : moduleDefinition.getInteractions()) {
updateReferences(interaction, originalIdentity, newIdentity);
for (Participation participation : interaction.getParticipations()) {
updateReferences(participation, originalIdentity, newIdentity);
}
}
for (URI modelURI : moduleDefinition.getModelURIs()) {
if (modelURI.equals(originalIdentity)) {
moduleDefinition.removeModel(originalIdentity);
moduleDefinition.addModel(newIdentity);
}
}
}
for (Model model : getModels()) {
updateReferences(model, originalIdentity, newIdentity);
}
for (Attachment attachment : getAttachments()) {
updateReferences(attachment, originalIdentity, newIdentity);
}
for (Implementation implementation : getImplementations()) {
if (implementation.isSetBuilt() && implementation.getBuiltURI().equals(originalIdentity)) {
implementation.setBuilt(newIdentity);
}
updateReferences(implementation, originalIdentity, newIdentity);
}
for (Sequence sequence : getSequences()) {
updateReferences(sequence, originalIdentity, newIdentity);
}
for (GenericTopLevel genericTopLevel : getGenericTopLevels()) {
updateReferences(genericTopLevel, originalIdentity, newIdentity);
}
for (CombinatorialDerivation combinatorialDerivation : getCombinatorialDerivations()) {
updateReferences(combinatorialDerivation, originalIdentity, newIdentity);
if (combinatorialDerivation.getTemplateURI().equals(originalIdentity)) {
combinatorialDerivation.setTemplate(newIdentity);
ComponentDefinition cd = getComponentDefinition(newIdentity);
if (cd != null) {
for (VariableComponent variableComponent : combinatorialDerivation.getVariableComponents()) {
String displayId = URIcompliance.extractDisplayId(variableComponent.getVariableURI());
URI newURI = URIcompliance.createCompliantURI(cd.getPersistentIdentity().toString(), displayId, cd.getVersion());
variableComponent.setVariable(newURI);
}
}
}
for (VariableComponent variableComponent : combinatorialDerivation.getVariableComponents()) {
updateReferences(variableComponent, originalIdentity, newIdentity);
}
}
for (Activity activity : getActivities()) {
updateReferences(activity, originalIdentity, newIdentity);
for (Association association : activity.getAssociations()) {
if (association.getAgentURI().equals(originalIdentity)) {
association.setAgent(newIdentity);
}
if (association.isSetPlan() && association.getPlanURI().equals(originalIdentity)) {
association.setPlan(newIdentity);
}
updateReferences(association, originalIdentity, newIdentity);
}
for (Usage usage : activity.getUsages()) {
if (usage.getEntityURI().equals(originalIdentity)) {
usage.setEntity(newIdentity);
}
updateReferences(usage, originalIdentity, newIdentity);
}
}
for (Agent agent : getAgents()) {
updateReferences(agent, originalIdentity, newIdentity);
}
for (Plan plan : getPlans()) {
updateReferences(plan, originalIdentity, newIdentity);
}
}
use of org.sbolstandard.core2.MapsTo in project libSBOLj by SynBioDex.
the class Module method createMapsTo.
/**
* Creates a child mapsTo for this module with the given arguments, and then adds it to its list of mapsTos.
* <p>
* This method creates compliant local and remote URIs first.
* The compliant local URI is created with this module's persistent identity URI, followed by
* the given local module's display ID, followed by this module's version.
* The compliant remote URI is created following the same pattern.
* It then calls {@link #createMapsTo(String, RefinementType, URI, URI)} with the given mapsTo's display ID, its refinement type,
* and the created compliant local and remote functional components' URIs.
* <p>
* This method calls {@link ModuleDefinition#createFunctionalComponent(String, AccessType, String, String, DirectionType)}
* to automatically create a local functional component with the given display ID of referenced local component definition,
* {@link AccessType#PUBLIC}, an empty version string, and {@link DirectionType#INOUT}, if all of the following conditions are satisfied:
* <ul>
* <li>the associated SBOLDocument instance for this module is not {@code null};</li>
* <li>if default functional components should be automatically created when not present in the associated SBOLDocument instance,
* i.e., {@link SBOLDocument#isCreateDefaults} returns {@code true};</li>
* <li>if this module's parent ModuleDefinition instance exists; and</li>
* <li>if this module's parent ModuleDefinition instance does not already have a functional component
* with the created compliant local URI.</li>
* </ul>
* This automatically created created functional component has the same display ID as its referenced component definition.
*
* @param displayId the display ID of the mapsTo to be created
* @param refinement the relationship between the local and remote components
* @param localId the display ID of the local functional component
* @param remoteId the display ID of the remote functional component
* @return the created mapsTo
* @throws SBOLValidationException if any of the following condition is satisfied:
* <ul>
* <li>if either of the following SBOL validation rules was violated: 10204, 10206;</li>
* <li>an SBOL validation exception occurred in {@link ModuleDefinition#createFunctionalComponent(String, AccessType, String, String, DirectionType)}; or</li>
* <li>an SBOL validation exception occurred in {@link #createMapsTo(String, RefinementType, URI, URI)}.</li>
* </ul>
*/
public MapsTo createMapsTo(String displayId, RefinementType refinement, String localId, String remoteId) throws SBOLValidationException {
URI localURI = URIcompliance.createCompliantURI(moduleDefinition.getPersistentIdentity().toString(), localId, moduleDefinition.getVersion());
if (this.getSBOLDocument() != null && this.getSBOLDocument().isCreateDefaults() && moduleDefinition != null && moduleDefinition.getFunctionalComponent(localURI) == null) {
moduleDefinition.createFunctionalComponent(localId, AccessType.PUBLIC, localId, "", DirectionType.INOUT);
}
URI remoteURI = URIcompliance.createCompliantURI(getDefinition().getPersistentIdentity().toString(), remoteId, getDefinition().getVersion());
return createMapsTo(displayId, refinement, localURI, remoteURI);
}
use of org.sbolstandard.core2.MapsTo in project libSBOLj by SynBioDex.
the class FunctionalComponent method createMapsTo.
/**
* Creates a child MapsTo instance for this module with the given arguments, and then adds to this module's list of mapsTos.
* <p>
* This method creates compliant local and remote URIs first.
* The compliant local URI is created with this module's persistent identity URI, followed by
* the given local component's display ID, followed by this module's version.
* The compliant remote URI is created following the same pattern.
* It then calls {@link #createMapsTo(String, RefinementType, URI, URI)} to create
* a MapsTo instance.
* <p>
* This method automatically creates a local functional component if all of the following conditions are satisfied:
* <ul>
* <li>the associated SBOLDocument instance for this module is not {@code null};</li>
* <li>if default functional components should be automatically created when not present for the associated SBOLDocument instance,
* i.e., {@link SBOLDocument#isCreateDefaults} returns {@code true};</li>
* <li>if this module's parent module definition exists; and</li>
* <li>if this module's parent module definition does not already have a functional component
* with the created compliant local functional component URI.</li>
* </ul>
* @param displayId the display ID of the mapsTo to be created
* @param refinement the relationship between the local and remote functional components
* @param localId the display ID of the local functional component
* @param remoteId the display ID of the remote functional component
* @return the created mapsTo
* @throws SBOLValidationException if any of the following conditions is satisfied:
* <ul>
* <li>if either of the following SBOL validation rules was violated: 10204, 10206;</li>
* <li>an SBOL validation rule violation occurred in {@link ModuleDefinition#createFunctionalComponent(String, AccessType, String, String, DirectionType)}; or</li>
* <li>an SBOL validation rule violation occurred in {@link #createMapsTo(String, RefinementType, URI, URI)}.</li>
* </ul>
*/
public MapsTo createMapsTo(String displayId, RefinementType refinement, String localId, String remoteId) throws SBOLValidationException {
URI localURI = URIcompliance.createCompliantURI(moduleDefinition.getPersistentIdentity().toString(), localId, moduleDefinition.getVersion());
if (this.getSBOLDocument() != null && this.getSBOLDocument().isCreateDefaults() && moduleDefinition != null && moduleDefinition.getFunctionalComponent(localURI) == null) {
moduleDefinition.createFunctionalComponent(localId, AccessType.PUBLIC, localId, "", DirectionType.INOUT);
}
URI remoteURI = URIcompliance.createCompliantURI(getDefinition().getPersistentIdentity().toString(), remoteId, getDefinition().getVersion());
return createMapsTo(displayId, refinement, localURI, remoteURI);
}
use of org.sbolstandard.core2.MapsTo in project libSBOLj by SynBioDex.
the class MapsToExample method main.
public static void main(String[] args) throws URISyntaxException, SBOLValidationException {
SBOLDocument doc = new SBOLDocument();
doc.setDefaultURIprefix("http://sbols.org/MapsToExample/");
doc.setComplete(true);
doc.setCreateDefaults(true);
String version = "";
ModuleDefinition md1 = doc.createModuleDefinition("md1", version);
ComponentDefinition fc1_def = doc.createComponentDefinition("fc1_def", version, ComponentDefinition.DNA);
ComponentDefinition fc2_def = doc.createComponentDefinition("fc2_def", version, ComponentDefinition.DNA);
FunctionalComponent fc1 = md1.createFunctionalComponent("fc1", AccessType.PUBLIC, "fc1_def", version, DirectionType.NONE);
FunctionalComponent fc2 = md1.createFunctionalComponent("fc2", AccessType.PUBLIC, "fc2_def", version, DirectionType.NONE);
ComponentDefinition cd = doc.createComponentDefinition("cd", version, ComponentDefinition.DNA);
fc1_def.createComponent("component", AccessType.PUBLIC, "cd");
fc1.createMapsTo("mapsTo", RefinementType.USELOCAL, "fc2", "component");
SBOLValidate.validateSBOL(doc, true, true, true);
if (SBOLValidate.getNumErrors() > 0) {
for (String error : SBOLValidate.getErrors()) {
System.out.println(error);
}
return;
}
}
Aggregations