Subversion Repositories WebE

Rev

View as "text/plain" | Blame | Last modification | View Log | RSS feed

1
/*
 * Hibernate, Relational Persistence for Idiomatic Java
 *
 * Copyright (c) 2008, Red Hat Middleware LLC or third-party contributors as
 * indicated by the @author tags or express copyright attribution
 * statements applied by the authors.  All third-party contributions are
 * distributed under license by Red Hat Middleware LLC.
 *
 * This copyrighted material is made available to anyone wishing to use, modify,
 * copy, or redistribute it subject to the terms and conditions of the GNU
 * Lesser General Public License, as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
 * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License
 * for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this distribution; if not, write to:
 * Free Software Foundation, Inc.
 * 51 Franklin Street, Fifth Floor
 * Boston, MA  02110-1301  USA
 *
 */

package org.hibernate;

import org.hibernate.util.StringHelper;

/**
 * Thrown when the (illegal) value of a property can not be persisted.
 * There are two main causes:
 * <ul>
 * <li>a property declared <tt>not-null="true"</tt> is null
 * <li>an association references an unsaved transient instance
 * </ul>
 * @author Gavin King
 */

public class PropertyValueException extends HibernateException {

        private final String entityName;
        private final String propertyName;

        public PropertyValueException(String s, String entityName, String propertyName) {
                super(s);
                this.entityName = entityName;
                this.propertyName = propertyName;
        }

        public String getEntityName() {
                return entityName;
        }

        public String getPropertyName() {
                return propertyName;
        }

        public String getMessage() {
                return super.getMessage() + ": " +
                        StringHelper.qualify(entityName, propertyName);
        }

        /**
         * Return a well formed property path.
         * Basicaly, it will return parent.child
         *
         * @param parent parent in path
         * @param child child in path
         * @return parent-child path
         */

        public static String buildPropertyPath(String parent, String child) {
                return new StringBuffer(parent).append('.').append(child).toString();
        }
}