/******************************************************************************* * Copyright (c) 2012, 2015 Oracle and/or its affiliates. All rights reserved. * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 * which accompanies this distribution. * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html * and the Eclipse Distribution License is available at * http://www.eclipse.org/org/documents/edl-v10.php. * * Contributors: * Blaise Doughan - 2.5 - initial implementation ******************************************************************************/ package org.eclipse.persistence.internal.oxm.mappings; import java.util.List; import java.util.Map; import org.eclipse.persistence.core.descriptors.CoreDescriptor; import org.eclipse.persistence.core.mappings.CoreAttributeAccessor; import org.eclipse.persistence.core.mappings.converters.CoreConverter; import org.eclipse.persistence.core.sessions.CoreSession; import org.eclipse.persistence.internal.core.helper.CoreField; import org.eclipse.persistence.internal.core.queries.CoreContainerPolicy; import org.eclipse.persistence.internal.core.sessions.CoreAbstractSession; import org.eclipse.persistence.internal.oxm.Marshaller; import org.eclipse.persistence.internal.oxm.Unmarshaller; import org.eclipse.persistence.internal.oxm.XMLChoiceFieldToClassAssociation; import org.eclipse.persistence.internal.oxm.record.XMLRecord; public interface ChoiceCollectionMapping< ABSTRACT_SESSION extends CoreAbstractSession, ATTRIBUTE_ACCESSOR extends CoreAttributeAccessor, CONTAINER_POLICY extends CoreContainerPolicy, CONVERTER extends CoreConverter, DESCRIPTOR extends CoreDescriptor, FIELD extends CoreField, MARSHALLER extends Marshaller, SESSION extends CoreSession, UNMARSHALLER extends Unmarshaller, XML_FIELD extends Field, XML_MAPPING extends Mapping, XML_RECORD extends XMLRecord > extends Mapping<ABSTRACT_SESSION, ATTRIBUTE_ACCESSOR, CONTAINER_POLICY, DESCRIPTOR, FIELD, XML_RECORD>, XMLContainerMapping, XMLConverterMapping<MARSHALLER, SESSION, UNMARSHALLER> { public void addChoiceElement(List<XML_FIELD> srcFields, String elementTypeName, List<XML_FIELD> tgtFields); public void addChoiceElement(String xpath, String elementTypeName); public void addChoiceElement(String srcXpath, String elementTypeName, String tgtXpath); public void addChoiceElement(XML_FIELD field, String elementTypeName); public void addConverter(XML_FIELD field, CONVERTER converter); public Map<XML_FIELD, XML_MAPPING> getChoiceElementMappings(); public Map<Class, XML_MAPPING> getChoiceElementMappingsByClass(); public List<XMLChoiceFieldToClassAssociation> getChoiceFieldToClassAssociations(); public Map<String, XML_FIELD> getClassNameToFieldMappings(); public Map<Class, XML_FIELD> getClassToFieldMappings(); public Map<Class, List<XML_FIELD>> getClassToSourceFieldsMappings(); public CONVERTER getConverter(); public CONVERTER getConverter(XML_FIELD field); public Map<XML_FIELD, Class> getFieldToClassMappings(); public XML_MAPPING getMixedContentMapping(); public boolean isMixedContent(); /** * Set the converter on the mapping. * A converter can be used to convert between the object's value and database value of the attribute. */ public void setConverter(CONVERTER converter); public void setIsWriteOnly(boolean b); /** * Allows the user to indicate that this mapping should also allow for mixed content in addition to * any of the elements in the choice. * @since EclipseLink 2.3.1 */ public void setMixedContent(boolean mixed); /** * Allows the user to indicate that this mapping should also allow for mixed content in addition to * any of the elements in the choice. The grouping element parameter is used in the case that there is * a common grouping element to all the other elements in this choice. If so, that grouping element can * be specified here to allow the mixed content to be written/detected inside the wrapper element. * @since EclipseLink 2.3.1 */ public void setMixedContent(String groupingElement); public void useCollectionClassName(String concreteContainerClassName); public boolean isAny(); public AnyCollectionMapping getAnyMapping(); }