/*
* Hibernate, Relational Persistence for Idiomatic Java
*
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
* See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
*/
package org.hibernate.exception.spi;
import java.sql.SQLException;
Knows how to extract a violated constraint name from an error message based on the
fact that the constraint name is templated within the message.
Author: Steve Ebersole, Brett Meyer
/**
* Knows how to extract a violated constraint name from an error message based on the
* fact that the constraint name is templated within the message.
*
* @author Steve Ebersole
* @author Brett Meyer
*/
public abstract class TemplatedViolatedConstraintNameExtracter implements ViolatedConstraintNameExtracter {
@Override
public String extractConstraintName(SQLException sqle) {
try {
String constraintName = null;
// handle nested exceptions
do {
constraintName = doExtractConstraintName(sqle);
if (sqle.getNextException() == null
|| sqle.getNextException() == sqle) {
break;
}
else {
sqle = sqle.getNextException();
}
} while (constraintName == null);
return constraintName;
}
catch (NumberFormatException nfe) {
return null;
}
}
protected abstract String doExtractConstraintName(SQLException sqle) throws NumberFormatException;
Extracts the constraint name based on a template (i.e., templateStartconstraintNametemplateEnd).
Params: - templateStart – The pattern denoting the start of the constraint name within the message.
- templateEnd – The pattern denoting the end of the constraint name within the message.
- message – The templated error message containing the constraint name.
Returns: The found constraint name, or null.
/**
* Extracts the constraint name based on a template (i.e., <i>templateStart</i><b>constraintName</b><i>templateEnd</i>).
*
* @param templateStart The pattern denoting the start of the constraint name within the message.
* @param templateEnd The pattern denoting the end of the constraint name within the message.
* @param message The templated error message containing the constraint name.
* @return The found constraint name, or null.
*/
protected String extractUsingTemplate(String templateStart, String templateEnd, String message) {
int templateStartPosition = message.indexOf( templateStart );
if ( templateStartPosition < 0 ) {
return null;
}
int start = templateStartPosition + templateStart.length();
int end = message.indexOf( templateEnd, start );
if ( end < 0 ) {
end = message.length();
}
return message.substring( start, end );
}
}