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/graph/src/main/java/name/angoca/zemucan/core/graph/model/NotExistingChildNodeException.java $:
28 */
29 package name.angoca.zemucan.core.graph.model;
30
31 import name.angoca.zemucan.tools.messages.Messages;
32
33 import org.slf4j.Logger;
34 import org.slf4j.LoggerFactory;
35
36 /**
37 * The node has a child that does not exist.
38 * <p>
39 * <b>Control Version</b>
40 * <p>
41 * <ul>
42 * <li>1.0.0 Class creation.</li>
43 * <li>1.0.1 Error code.</li>
44 * <li>1.0.2 Logger and final.</li>
45 * <li>1.0.3 Assert.</li>
46 * <li>1.0.4 New id.</li>
47 * <li>1.1.0 GrammarReader separated from Graph.</li>
48 * <li>1.2.0 get id.</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.2.0 2009-11-08
54 */
55 public final class NotExistingChildNodeException extends AbstractGraphException {
56
57 /**
58 * Logger.
59 */
60 private static final Logger LOGGER = LoggerFactory
61 .getLogger(NotExistingChildNodeException.class);
62
63 /**
64 * ID of the exception.
65 */
66 private static final long serialVersionUID = -3547193297634519255L;
67
68 /**
69 * Not existing node.
70 */
71 private final String childNodeId;
72 /**
73 * Wrongly defined node.
74 */
75 private final String parentNodeId;
76
77 /**
78 * Creates the exception with the node id where there is child that does not
79 * exists.
80 *
81 * @param excepParentNodeId
82 * Wrongly defined node id.
83 * @param excepChildNodeId
84 * Not existing node id.
85 */
86 public NotExistingChildNodeException(final String/* ! */excepParentNodeId,
87 final String/* ! */excepChildNodeId) {
88 assert excepParentNodeId != null;
89 assert excepChildNodeId != null;
90
91 this.parentNodeId = excepParentNodeId;
92 this.childNodeId = excepChildNodeId;
93 NotExistingChildNodeException.LOGGER
94 .debug(NotExistingChildNodeException.class.getName()
95 + " created."); //$NON-NLS-1$
96 }
97
98 /**
99 * Retrieves the name of the inexistent node.
100 *
101 * @return child node id.
102 */
103 public String/* ! */getChildNodeId() {
104 return this.childNodeId;
105 }
106
107 /*
108 * (non-Javadoc)
109 * @see java.lang.Throwable#getMessage()
110 */
111 @Override
112 public String/* ! */getMessage() {
113 return Messages.getString("NotExistingChildNodeException." //$NON-NLS-1$
114 + "GRPH13-InvalidNode") + this.parentNodeId //$NON-NLS-1$
115 + Messages.getString("NotExistingChildNodeException."//$NON-NLS-1$
116 + "GRPH13-InexistingChildNode") + this.childNodeId; //$NON-NLS-1$
117 }
118
119 /**
120 * Retrieves the id of the node that makes reference to an inexistent node.
121 *
122 * @return parent node id.
123 */
124 public String/* ! */getParentNodeId() {
125 return this.parentNodeId;
126 }
127 }