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 }