Source code: org/objectstyle/cayenne/project/validator/ValidationInfo.java
1 /* ====================================================================
2 *
3 * The ObjectStyle Group Software License, Version 1.0
4 *
5 * Copyright (c) 2002-2003 The ObjectStyle Group
6 * and individual authors of the software. 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 * 1. Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 *
15 * 2. 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 * 3. The end-user documentation included with the redistribution, if
21 * any, must include the following acknowlegement:
22 * "This product includes software developed by the
23 * ObjectStyle Group (http://objectstyle.org/)."
24 * Alternately, this acknowlegement may appear in the software itself,
25 * if and wherever such third-party acknowlegements normally appear.
26 *
27 * 4. The names "ObjectStyle Group" and "Cayenne"
28 * must not be used to endorse or promote products derived
29 * from this software without prior written permission. For written
30 * permission, please contact andrus@objectstyle.org.
31 *
32 * 5. Products derived from this software may not be called "ObjectStyle"
33 * nor may "ObjectStyle" appear in their names without prior written
34 * permission of the ObjectStyle Group.
35 *
36 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
37 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
38 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
39 * DISCLAIMED. IN NO EVENT SHALL THE OBJECTSTYLE GROUP OR
40 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
41 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
42 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
43 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
44 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
45 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
46 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
47 * SUCH DAMAGE.
48 * ====================================================================
49 *
50 * This software consists of voluntary contributions made by many
51 * individuals on behalf of the ObjectStyle Group. For more
52 * information on the ObjectStyle Group, please see
53 * <http://objectstyle.org/>.
54 *
55 */
56 package org.objectstyle.cayenne.project.validator;
57
58 import org.objectstyle.cayenne.project.ProjectPath;
59
60 /**
61 * ValidationInfo encapsulates information about a single node validation
62 * on the project tree.
63 *
64 * @author Andrei Adamchik
65 */
66 public class ValidationInfo {
67 public static final int VALID = 0;
68 public static final int WARNING = 1;
69 public static final int ERROR = 2;
70
71 protected ProjectPath path;
72 protected String message;
73 protected int severity;
74
75 /**
76 * Constructor for ValidationInfo.
77 */
78 public ValidationInfo(int severity, String message, ProjectPath path) {
79 this.severity = severity;
80 this.message = message;
81 this.path = path;
82 }
83
84 public Object getValidatedObject() {
85 return path.getObject();
86 }
87
88 public Object getValidatedObjectParent() {
89 return path.getObjectParent();
90 }
91
92 public String toString() {
93 return getMessage();
94 }
95
96 /**
97 * Returns the message.
98 * @return String
99 */
100 public String getMessage() {
101 return message;
102 }
103
104 /**
105 * Returns the severity.
106 * @return int
107 */
108 public int getSeverity() {
109 return severity;
110 }
111
112 /**
113 * Returns the ProjectPath object identifing a location
114 * described by this ValidationInfo.
115 */
116 public ProjectPath getPath() {
117 return path;
118 }
119 }