/* * ome.xml.model.Group * *----------------------------------------------------------------------------- * * Copyright (C) @year@ Open Microscopy Environment * Massachusetts Institute of Technology, * National Institutes of Health, * University of Dundee, * University of Wisconsin-Madison * * * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * *----------------------------------------------------------------------------- */ /*----------------------------------------------------------------------------- * * THIS IS AUTOMATICALLY GENERATED CODE. DO NOT MODIFY. * Created by melissa via xsd-fu on 2011-11-09 10:55:09-0500 * *----------------------------------------------------------------------------- */ package ome.xml.model; import java.util.ArrayList; import java.util.List; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.Node; import org.w3c.dom.NodeList; import ome.xml.model.enums.*; import ome.xml.model.primitives.*; public class Group extends AbstractOMEModelObject { // Base: -- Name: Group -- Type: Group -- javaBase: AbstractOMEModelObject -- javaType: Object // -- Constants -- public static final String NAMESPACE = "http://www.openmicroscopy.org/Schemas/OME/2011-06"; /** Logger for this class. */ private static final Logger LOGGER = LoggerFactory.getLogger(Group.class); // -- Instance variables -- // Property private String name; // Property private String id; // Property private String description; // Property private Experimenter leader; // Property private Experimenter contact; // Back reference Image_BackReference private List<Image> image_BackReferenceList = new ArrayList<Image>(); // Back reference Project_BackReference private List<Project> project_BackReferenceList = new ArrayList<Project>(); // Back reference Dataset_BackReference private List<Dataset> dataset_BackReferenceList = new ArrayList<Dataset>(); // Back reference Experimenter_BackReference private List<Experimenter> experimenter_BackReferenceList = new ArrayList<Experimenter>(); // -- Constructors -- /** Default constructor. */ public Group() { super(); } /** * Constructs Group recursively from an XML DOM tree. * @param element Root of the XML DOM tree to construct a model object * graph from. * @param model Handler for the OME model which keeps track of instances * and references seen during object population. * @throws EnumerationException If there is an error instantiating an * enumeration during model object creation. */ public Group(Element element, OMEModel model) throws EnumerationException { update(element, model); } // -- Custom content from Group specific template -- // -- OMEModelObject API methods -- /** * Updates Group recursively from an XML DOM tree. <b>NOTE:</b> No * properties are removed, only added or updated. * @param element Root of the XML DOM tree to construct a model object * graph from. * @param model Handler for the OME model which keeps track of instances * and references seen during object population. * @throws EnumerationException If there is an error instantiating an * enumeration during model object creation. */ public void update(Element element, OMEModel model) throws EnumerationException { super.update(element, model); String tagName = element.getTagName(); if (!"Group".equals(tagName)) { LOGGER.debug("Expecting node name of Group got {}", tagName); } if (element.hasAttribute("Name")) { // Attribute property Name setName(String.valueOf( element.getAttribute("Name"))); } if (!element.hasAttribute("ID") && getID() == null) { // TODO: Should be its own exception throw new RuntimeException(String.format( "Group missing required ID property.")); } if (element.hasAttribute("ID")) { // ID property setID(String.valueOf( element.getAttribute("ID"))); // Adding this model object to the model handler model.addModelObject(getID(), this); } List<Element> Description_nodeList = getChildrenByTagName(element, "Description"); if (Description_nodeList.size() > 1) { // TODO: Should be its own Exception throw new RuntimeException(String.format( "Description node list size %d != 1", Description_nodeList.size())); } else if (Description_nodeList.size() != 0) { // Element property Description which is not complex (has no // sub-elements) setDescription( String.valueOf(Description_nodeList.get(0).getTextContent())); } // Element reference Leader List<Element> Leader_nodeList = getChildrenByTagName(element, "Leader"); for (Element Leader_element : Leader_nodeList) { Leader leader_reference = new Leader(); leader_reference.setID(Leader_element.getAttribute("ID")); model.addReference(this, leader_reference); } // Element reference Contact List<Element> Contact_nodeList = getChildrenByTagName(element, "Contact"); for (Element Contact_element : Contact_nodeList) { Contact contact_reference = new Contact(); contact_reference.setID(Contact_element.getAttribute("ID")); model.addReference(this, contact_reference); } // *** IGNORING *** Skipped back reference Image_BackReference // *** IGNORING *** Skipped back reference Project_BackReference // *** IGNORING *** Skipped back reference Dataset_BackReference // *** IGNORING *** Skipped back reference Experimenter_BackReference } // -- Group API methods -- public boolean link(Reference reference, OMEModelObject o) { boolean wasHandledBySuperClass = super.link(reference, o); if (wasHandledBySuperClass) { return true; } if (reference instanceof Leader) { Experimenter o_casted = (Experimenter) o; o_casted.linkGroup(this); leader = o_casted; return true; } if (reference instanceof Contact) { Experimenter o_casted = (Experimenter) o; o_casted.linkGroup(this); contact = o_casted; return true; } LOGGER.debug("Unable to handle reference of type: {}", reference.getClass()); return false; } // Property public String getName() { return name; } public void setName(String name) { this.name = name; } // Property public String getID() { return id; } public void setID(String id) { this.id = id; } // Property public String getDescription() { return description; } public void setDescription(String description) { this.description = description; } // Reference public Experimenter getLinkedLeader() { return leader; } public void linkLeader(Experimenter o) { leader = o; } public void unlinkLeader(Experimenter o) { if (leader == o) { leader = null; } } // Reference public Experimenter getLinkedContact() { return contact; } public void linkContact(Experimenter o) { contact = o; } public void unlinkContact(Experimenter o) { if (contact == o) { contact = null; } } // Reference which occurs more than once public int sizeOfLinkedImageList() { return image_BackReferenceList.size(); } public List<Image> copyLinkedImageList() { return new ArrayList<Image>(image_BackReferenceList); } public Image getLinkedImage(int index) { return image_BackReferenceList.get(index); } public Image setLinkedImage(int index, Image o) { return image_BackReferenceList.set(index, o); } public boolean linkImage(Image o) { return image_BackReferenceList.add(o); } public boolean unlinkImage(Image o) { return image_BackReferenceList.remove(o); } // Reference which occurs more than once public int sizeOfLinkedProjectList() { return project_BackReferenceList.size(); } public List<Project> copyLinkedProjectList() { return new ArrayList<Project>(project_BackReferenceList); } public Project getLinkedProject(int index) { return project_BackReferenceList.get(index); } public Project setLinkedProject(int index, Project o) { return project_BackReferenceList.set(index, o); } public boolean linkProject(Project o) { return project_BackReferenceList.add(o); } public boolean unlinkProject(Project o) { return project_BackReferenceList.remove(o); } // Reference which occurs more than once public int sizeOfLinkedDatasetList() { return dataset_BackReferenceList.size(); } public List<Dataset> copyLinkedDatasetList() { return new ArrayList<Dataset>(dataset_BackReferenceList); } public Dataset getLinkedDataset(int index) { return dataset_BackReferenceList.get(index); } public Dataset setLinkedDataset(int index, Dataset o) { return dataset_BackReferenceList.set(index, o); } public boolean linkDataset(Dataset o) { return dataset_BackReferenceList.add(o); } public boolean unlinkDataset(Dataset o) { return dataset_BackReferenceList.remove(o); } // Reference which occurs more than once public int sizeOfLinkedExperimenterList() { return experimenter_BackReferenceList.size(); } public List<Experimenter> copyLinkedExperimenterList() { return new ArrayList<Experimenter>(experimenter_BackReferenceList); } public Experimenter getLinkedExperimenter(int index) { return experimenter_BackReferenceList.get(index); } public Experimenter setLinkedExperimenter(int index, Experimenter o) { return experimenter_BackReferenceList.set(index, o); } public boolean linkExperimenter(Experimenter o) { return experimenter_BackReferenceList.add(o); } public boolean unlinkExperimenter(Experimenter o) { return experimenter_BackReferenceList.remove(o); } public Element asXMLElement(Document document) { return asXMLElement(document, null); } protected Element asXMLElement(Document document, Element Group_element) { // Creating XML block for Group if (Group_element == null) { Group_element = document.createElementNS(NAMESPACE, "Group"); } if (name != null) { // Attribute property Name Group_element.setAttribute("Name", name.toString()); } if (id != null) { // Attribute property ID Group_element.setAttribute("ID", id.toString()); } if (description != null) { // Element property Description which is not complex (has no // sub-elements) Element description_element = document.createElementNS(NAMESPACE, "Description"); description_element.setTextContent(description.toString()); Group_element.appendChild(description_element); } if (leader != null) { // Reference property Leader Leader o = new Leader(); o.setID(leader.getID()); Group_element.appendChild(o.asXMLElement(document)); } if (contact != null) { // Reference property Contact Contact o = new Contact(); o.setID(contact.getID()); Group_element.appendChild(o.asXMLElement(document)); } if (image_BackReferenceList != null) { // *** IGNORING *** Skipped back reference Image_BackReference } if (project_BackReferenceList != null) { // *** IGNORING *** Skipped back reference Project_BackReference } if (dataset_BackReferenceList != null) { // *** IGNORING *** Skipped back reference Dataset_BackReference } if (experimenter_BackReferenceList != null) { // *** IGNORING *** Skipped back reference Experimenter_BackReference } return super.asXMLElement(document, Group_element); } }