Subversion Repositories WebE

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
33 PointedEar 1
/*
2
 * Hibernate, Relational Persistence for Idiomatic Java
3
 *
4
 * Copyright (c) 2008, Red Hat Middleware LLC or third-party contributors as
5
 * indicated by the @author tags or express copyright attribution
6
 * statements applied by the authors.  All third-party contributions are
7
 * distributed under license by Red Hat Middleware LLC.
8
 *
9
 * This copyrighted material is made available to anyone wishing to use, modify,
10
 * copy, or redistribute it subject to the terms and conditions of the GNU
11
 * Lesser General Public License, as published by the Free Software Foundation.
12
 *
13
 * This program is distributed in the hope that it will be useful,
14
 * but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
15
 * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License
16
 * for more details.
17
 *
18
 * You should have received a copy of the GNU Lesser General Public License
19
 * along with this distribution; if not, write to:
20
 * Free Software Foundation, Inc.
21
 * 51 Franklin Street, Fifth Floor
22
 * Boston, MA  02110-1301  USA
23
 *
24
 */
25
package org.hibernate;
26
 
27
import org.hibernate.util.StringHelper;
28
 
29
/**
30
 * Thrown when the (illegal) value of a property can not be persisted.
31
 * There are two main causes:
32
 * <ul>
33
 * <li>a property declared <tt>not-null="true"</tt> is null
34
 * <li>an association references an unsaved transient instance
35
 * </ul>
36
 * @author Gavin King
37
 */
38
public class PropertyValueException extends HibernateException {
39
 
40
        private final String entityName;
41
        private final String propertyName;
42
 
43
        public PropertyValueException(String s, String entityName, String propertyName) {
44
                super(s);
45
                this.entityName = entityName;
46
                this.propertyName = propertyName;
47
        }
48
 
49
        public String getEntityName() {
50
                return entityName;
51
        }
52
 
53
        public String getPropertyName() {
54
                return propertyName;
55
        }
56
 
57
        public String getMessage() {
58
                return super.getMessage() + ": " +
59
                        StringHelper.qualify(entityName, propertyName);
60
        }
61
 
62
        /**
63
         * Return a well formed property path.
64
         * Basicaly, it will return parent.child
65
         *
66
         * @param parent parent in path
67
         * @param child child in path
68
         * @return parent-child path
69
         */
70
        public static String buildPropertyPath(String parent, String child) {
71
                return new StringBuffer(parent).append('.').append(child).toString();
72
        }
73
}
74
 
75
 
76
 
77
 
78
 
79