View Javadoc

1   /*
2    * Zemucan: A Syntax Assistant for DB2
3    * Copyright (C) 2009, 2010 Andres Gomez Casanova
4    *
5    * This file is part of Zemucan.
6    *
7    * Zemucan is free software: you can redistribute it and/or modify
8    * it under the terms of the GNU Lesser General Public License as published by
9    * the Free Software Foundation; either version 3 of the License, or
10   * (at your option) any later version.
11   *
12   * Zemucan is distributed in the hope that it will be useful,
13   * but WITHOUT ANY WARRANTY; without even the implied warranty of
14   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15   * GNU Lesser General Public License for more details.
16   *
17   * You should have received a copy of the GNU Lesser General Public License
18   * along with this library; if not, see <http://www.gnu.org/licenses/>.
19   *
20   * Contact:
21   * a n g o c a  at  y a h o o  dot  c o m
22   * Cra. 45 No 61 - 31, Bogota, Colombia.
23   *
24   * Author:   $LastChangedBy: angoca $:
25   * Date:     $LastChangedDate: 2011-03-06 09:19:05 -0500 (dom, 06 mar 2011) $:
26   * Revision: $LastChangedRevision: 1910 $:
27   * URL:      $HeadURL: https://zemucan.svn.sourceforge.net/svnroot/zemucan/branches/zemucan_v1/source-code/grammarReaderImplXML/src/main/java/name/angoca/zemucan/grammarReader/impl/xml/NoIdDefinedInNodeException.java $:
28   */
29  package name.angoca.zemucan.grammarReader.impl.xml;
30  
31  import name.angoca.zemucan.grammarReader.api.AbstractInvalidGrammarException;
32  import name.angoca.zemucan.tools.messages.xml.Messages;
33  
34  import org.slf4j.Logger;
35  import org.slf4j.LoggerFactory;
36  
37  /**
38   * The node in the grammar file does not have an id.
39   * <p>
40   * <b>Control Version</b>
41   * <p>
42   * <ul>
43   * <li>1.0.0 Class creation.</li>
44   * <li>1.0.1 Error code.</li>
45   * <li>1.0.2 Logger and final.</li>
46   * <li>1.0.3 Assert.</li>
47   * <li>1.0.4 New id.</li>
48   * <li>1.1.0 getId.</li>
49   * </ul>
50   *
51   * @author Andres Gomez Casanova <a
52   *         href="mailto:a n g o c a at y a h o o dot c o m">(AngocA)</a>
53   * @version 1.1.0 2009-11-08
54   */
55  public final class NoIdDefinedInNodeException extends
56          AbstractInvalidGrammarException {
57  
58      /**
59       * Logger.
60       */
61      private static final Logger LOGGER = LoggerFactory
62              .getLogger(NoIdDefinedInNodeException.class);
63  
64      /**
65       * ID of the exception.
66       */
67      private static final long serialVersionUID = 3757272748718647362L;
68  
69      /**
70       * Name of the node that does not have id.
71       */
72      private final String name;
73  
74      /**
75       * Creates the exception with the name of the node that does not have id.
76       *
77       * @param excepName
78       *            Node's name.
79       */
80      public NoIdDefinedInNodeException(final String/* ! */excepName) {
81          super();
82          assert excepName != null;
83  
84          this.name = excepName;
85          NoIdDefinedInNodeException.LOGGER
86                  .debug(NoIdDefinedInNodeException.class.getName() + " created."); //$NON-NLS-1$
87      }
88  
89      /*
90       * (non-Javadoc)
91       * @see java.lang.Throwable#getMessage()
92       */
93      @Override
94      public String/* ! */getMessage() {
95          return Messages.getString("NoIdDefinedInNodeException." //$NON-NLS-1$
96                  + "GRXM2-NodeName") + this.name; //$NON-NLS-1$
97      }
98  
99      /**
100      * Retrieves the name of the node that does not have id.
101      *
102      * @return name's node.
103      */
104     public String/* ! */getName() {
105         return this.name;
106     }
107 }