1 // SECTION-START[License Header] 2 // <editor-fold defaultstate="collapsed" desc=" Generated License "> 3 /* 4 * Copyright (c) 2010 The JOMC Project 5 * Copyright (c) 2005 Christian Schulte <schulte2005@users.sourceforge.net> 6 * All rights reserved. 7 * 8 * Redistribution and use in source and binary forms, with or without 9 * modification, are permitted provided that the following conditions 10 * are met: 11 * 12 * o Redistributions of source code must retain the above copyright 13 * notice, this list of conditions and the following disclaimer. 14 * 15 * o Redistributions in binary form must reproduce the above copyright 16 * notice, this list of conditions and the following disclaimer in 17 * the documentation and/or other materials provided with the 18 * distribution. 19 * 20 * THIS SOFTWARE IS PROVIDED BY THE JOMC PROJECT AND CONTRIBUTORS "AS IS" 21 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 22 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 23 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE JOMC PROJECT OR 24 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 25 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 26 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 27 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 28 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 29 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 30 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 31 * 32 * $Id: SequenceMapper.java 2247 2010-06-29 08:01:42Z schulte2005 $ 33 * 34 */ 35 // </editor-fold> 36 // SECTION-END 37 package org.jomc.sequences.ri; 38 39 import org.jomc.sequences.Sequence; 40 import org.jomc.sequences.SequencesSystemException; 41 import org.jomc.sequences.model.SequenceType; 42 43 // SECTION-START[Documentation] 44 // <editor-fold defaultstate="collapsed" desc=" Generated Documentation "> 45 /** 46 * Maps model classes. 47 * 48 * <p> 49 * This specification declares a multiplicity of {@code Many}. 50 * An application assembler may provide multiple implementations of this specification (including none). 51 * </p> 52 * 53 * <p> 54 * Use of class {@link org.jomc.ObjectManager ObjectManager} is supported for accessing implementations. 55 * <pre> 56 * SequenceMapper[] objects = ObjectManagerFactory.getObjectManager( getClass().getClassLoader() ).getObject( SequenceMapper[].class ); 57 * SequenceMapper object = ObjectManagerFactory.getObjectManager( getClass().getClassLoader() ).getObject( SequenceMapper.class, "<i>implementation name</i>" ); 58 * </pre> 59 * </p> 60 * 61 * <p> 62 * This specification does not apply to any scope. A new object is returned whenever requested. 63 * </p> 64 * 65 * @author <a href="mailto:schulte2005@users.sourceforge.net">Christian Schulte</a> 1.0 66 * @version $Id: SequenceMapper.java 2247 2010-06-29 08:01:42Z schulte2005 $ 67 */ 68 // </editor-fold> 69 // SECTION-END 70 // SECTION-START[Annotations] 71 // <editor-fold defaultstate="collapsed" desc=" Generated Annotations "> 72 @javax.annotation.Generated( value = "org.jomc.tools.SourceFileProcessor 1.0", comments = "See http://jomc.sourceforge.net/jomc/1.0/jomc-tools" ) 73 // </editor-fold> 74 // SECTION-END 75 public interface SequenceMapper 76 { 77 // SECTION-START[SequenceMapper] 78 79 /** 80 * Maps a {@code SequenceType} instance to a {@code Sequence} instance. 81 * 82 * @param sequenceType The instance to map. 83 * @param sequence The target instance to map {@code sequenceType} to. 84 * 85 * @return {@code sequenceType} mapped to {@code sequence}. 86 * 87 * @throws SequencesSystemException if mapping fails unexpectedly. 88 */ 89 Sequence map( SequenceType sequenceType, Sequence sequence ) throws SequencesSystemException; 90 91 /** 92 * Maps a {@code Sequence} instance to a {@code SequenceType} instance. 93 * 94 * @param sequence The instance to map. 95 * @param sequenceType The target instance to map {@code sequence} to. 96 * 97 * @return {@code sequence} mapped to {@code sequenceType}. 98 * 99 * @throws SequencesSystemException if mapping fails unexpectedly. 100 */ 101 SequenceType map( Sequence sequence, SequenceType sequenceType ) throws SequencesSystemException; 102 103 // SECTION-END 104 }