001 // SECTION-START[License Header]
002 // <editor-fold defaultstate="collapsed" desc=" Generated License ">
003 /*
004 * Copyright (c) 2010 The JOMC Project
005 * Copyright (c) 2005 Christian Schulte <schulte2005@users.sourceforge.net>
006 * All rights reserved.
007 *
008 * Redistribution and use in source and binary forms, with or without
009 * modification, are permitted provided that the following conditions
010 * are met:
011 *
012 * o Redistributions of source code must retain the above copyright
013 * notice, this list of conditions and the following disclaimer.
014 *
015 * o Redistributions in binary form must reproduce the above copyright
016 * notice, this list of conditions and the following disclaimer in
017 * the documentation and/or other materials provided with the
018 * distribution.
019 *
020 * THIS SOFTWARE IS PROVIDED BY THE JOMC PROJECT AND CONTRIBUTORS "AS IS"
021 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
022 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
023 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE JOMC PROJECT OR
024 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
025 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
026 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
027 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
028 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
029 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
030 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
031 *
032 * $Id: SequenceExistsException.java 2244 2010-06-29 07:58:09Z schulte2005 $
033 *
034 */
035 // </editor-fold>
036 // SECTION-END
037 package org.jomc.sequences;
038
039 // SECTION-START[Documentation]
040 // <editor-fold defaultstate="collapsed" desc=" Generated Documentation ">
041 /**
042 * Gets thrown when a sequence is about to be added to a directory although a sequence with the same name already exists.
043 * <p><b>Dependencies</b><ul>
044 * <li>"{@link #getLocale Locale}"<blockquote>
045 * Dependency on {@code 'java.util.Locale'} {@code (java.util.Locale)} at specification level 1.1 bound to an instance.</blockquote></li>
046 * </ul></p>
047 * <p><b>Messages</b><ul>
048 * <li>"{@link #getSequenceExistsMessage sequenceExistsMessage}"<table>
049 * <tr><td valign="top">English:</td><td valign="top"><pre>A sequence with the name ''{0}'' already exists.</pre></td></tr>
050 * <tr><td valign="top">Deutsch:</td><td valign="top"><pre>Eine Sequenz mit Namen ''{0}'' existiert bereits.</pre></td></tr>
051 * </table>
052 * </ul></p>
053 *
054 * @author <a href="mailto:schulte2005@users.sourceforge.net">Christian Schulte</a> 1.0
055 * @version $Id: SequenceExistsException.java 2244 2010-06-29 07:58:09Z schulte2005 $
056 */
057 // </editor-fold>
058 // SECTION-END
059 // SECTION-START[Annotations]
060 // <editor-fold defaultstate="collapsed" desc=" Generated Annotations ">
061 @javax.annotation.Generated( value = "org.jomc.tools.SourceFileProcessor 1.0", comments = "See http://jomc.sourceforge.net/jomc/1.0/jomc-tools" )
062 // </editor-fold>
063 // SECTION-END
064 public class SequenceExistsException extends SequencesException
065 {
066 // SECTION-START[SequenceExistsException]
067
068 /** Serial version UID for backwards compatibility with 1.0.x classes. */
069 private static final long serialVersionUID = -2793698651762153200L;
070
071 /**
072 * The sequence already known.
073 * @serial
074 */
075 private final Sequence sequence;
076
077 /**
078 * Creates a new {@code SequenceExistsException} taking the already existing sequence.
079 *
080 * @param sequence The sequence already known.
081 */
082 public SequenceExistsException( final Sequence sequence )
083 {
084 super();
085 this.sequence = sequence;
086 }
087
088 /**
089 * Gets the sequence already known.
090 *
091 * @return The sequence already known.
092 */
093 public Sequence getSequence()
094 {
095 return this.sequence;
096 }
097
098 /**
099 * Gets the message of the exception.
100 *
101 * @return The message of the exception.
102 */
103 @Override
104 public String getMessage()
105 {
106 return this.getSequenceExistsMessage(
107 this.getLocale(), this.getSequence() != null ? this.getSequence().getName() : null );
108
109 }
110
111 // SECTION-END
112 // SECTION-START[Dependencies]
113 // <editor-fold defaultstate="collapsed" desc=" Generated Dependencies ">
114
115 /**
116 * Gets the {@code Locale} dependency.
117 * <p>This method returns the {@code 'default'} object of the {@code 'java.util.Locale'} {@code (java.util.Locale)} specification at specification level 1.1.</p>
118 * <p>That specification does not apply to any scope. A new object is returned whenever requested and bound to this instance.</p>
119 * @return The {@code Locale} dependency.
120 * @throws org.jomc.ObjectManagementException if getting the dependency instance fails.
121 */
122 @javax.annotation.Generated( value = "org.jomc.tools.SourceFileProcessor 1.0", comments = "See http://jomc.sourceforge.net/jomc/1.0/jomc-tools" )
123 private java.util.Locale getLocale()
124 {
125 final java.util.Locale _d = (java.util.Locale) org.jomc.ObjectManagerFactory.getObjectManager( this.getClass().getClassLoader() ).getDependency( this, "Locale" );
126 assert _d != null : "'Locale' dependency not found.";
127 return _d;
128 }
129 // </editor-fold>
130 // SECTION-END
131 // SECTION-START[Properties]
132 // SECTION-END
133 // SECTION-START[Messages]
134 // <editor-fold defaultstate="collapsed" desc=" Generated Messages ">
135
136 /**
137 * Gets the text of the {@code sequenceExistsMessage} message.
138 * <p><b>Templates</b><br/><table>
139 * <tr><td valign="top">English:</td><td valign="top"><pre>A sequence with the name ''{0}'' already exists.</pre></td></tr>
140 * <tr><td valign="top">Deutsch:</td><td valign="top"><pre>Eine Sequenz mit Namen ''{0}'' existiert bereits.</pre></td></tr>
141 * </table></p>
142 * @param locale The locale of the message to return.
143 * @param sequenceName Format argument.
144 * @return Message stating that a sequence already exists in the directory.
145 *
146 * @throws org.jomc.ObjectManagementException if getting the message instance fails.
147 */
148 @javax.annotation.Generated( value = "org.jomc.tools.SourceFileProcessor 1.0", comments = "See http://jomc.sourceforge.net/jomc/1.0/jomc-tools" )
149 private String getSequenceExistsMessage( final java.util.Locale locale, final java.lang.String sequenceName )
150 {
151 final String _m = org.jomc.ObjectManagerFactory.getObjectManager( this.getClass().getClassLoader() ).getMessage( this, "sequenceExistsMessage", locale, sequenceName );
152 assert _m != null : "'sequenceExistsMessage' message not found.";
153 return _m;
154 }
155 // </editor-fold>
156 // SECTION-END
157 }