try {
result = getRowFromResultSet(
resultSet,
session,
queryParameters,
getLockModes( queryParameters.getLockModes() ),
null,
hydratedObjects,
new EntityKey[entitySpan],
returnProxies
);
}
catch ( SQLException sqle ) {
throw JDBCExceptionHelper.convert(
factory.getSQLExceptionConverter(),
sqle,
"could not read next row of results",
getSQLString()
);
}
try {
doQueryAndInitializeNonLazyCollections(
session,
new QueryParameters( new Type[]{type}, ids, ids ),
true
);
}
catch ( SQLException sqle ) {
throw JDBCExceptionHelper.convert(
factory.getSQLExceptionConverter(),
sqle,
"could not initialize a collection: " +
MessageHelper.collectionInfoString( getCollectionPersisters()[0], id, getFactory() ),
getSQLString()
);
}
Clone fragments detected by clone detection tool
File path: /hibernate-distribution-3.3.2.GA/project/core/src/main/java/org/hibernate/loader/Loader.java
|
|
File path: /hibernate-distribution-3.3.2.GA/project/core/src/main/java/org/hibernate/loader/Loader.java
|
Method name: Object loadSingleRow(ResultSet, SessionImplementor, QueryParameters, boolean)
|
|
Method name: void loadCollection(SessionImplementor, Serializable, Type)
|
Number of AST nodes: 2
|
|
Number of AST nodes: 2
|
|
1 | try {↵ | | 1 | try {↵
|
2 | result = getRowFromResultSet(↵ | | 2 | ↵
|
3 | resultSet,↵ | | |
|
4 | session,↵ | | |
|
5 | queryParameters,↵ | | |
|
6 | getLockModes( queryParameters.getLockModes() ),↵ | | |
|
7 | null,↵ | | |
|
8 | hydratedObjects,↵ | | |
|
9 | new EntityKey[entitySpan],↵ | | |
|
10 | returnProxies↵ | | 3 | doQueryAndInitializeNonLazyCollections( ↵
|
| | | 4 | session,↵
|
| | | 5 | new QueryParameters( new Type[]{type}, ids, ids ),↵
|
| | | 6 | true ↵
|
11 | );↵ | | 7 | );↵
|
12 | }↵ | | 8 | }↵
|
13 | catch ( SQLException sqle ) {↵ | | 9 | catch ( SQLException sqle ) {↵
|
14 | throw JDBCExceptionHelper.convert(↵ | | 10 | throw JDBCExceptionHelper.convert(↵
|
15 | factory.getSQLExceptionConverter(),↵ | | 11 | factory.getSQLExceptionConverter(),↵
|
16 | sqle,↵ | | 12 | sqle,↵
|
17 | "could not read next row of results",↵ | | 13 | "could not ↵
|
18 | ↵ | | 14 | initialize a collection: " + ↵
|
| | | 15 | MessageHelper.collectionInfoString( getCollectionPersisters()[0], id, getFactory() ),↵
|
19 | getSQLString()↵ | | 16 | getSQLString()↵
|
20 | );↵ | | 17 | );↵
|
21 | } | | 18 | }
|
See real code fragment |
|
See real code fragment |
Summary
Number of common nesting structure subtrees | 1 |
Number of refactorable cases | 0 |
Number of non-refactorable cases | 1 |
Time elapsed for finding largest common nesting structure subtrees (ms) | 0.4 |
Clones location | Clones are declared in the same class |
Number of node comparisons | 4 |
-
{Non-refactorable}
Mapping Summary
Number of mapped statements | 1 |
Number of unmapped statements in the first code fragment | 1 |
Number of unmapped statements in the second code fragment | 1 |
Time elapsed for statement mapping (ms) | 5.8 |
Clone type | Type 2 |
Mapped Statements
ID |
Statement |
|
ID |
Statement |
4 | try | | 4 | try |
| | | 5 | doQueryAndInitializeNonLazyCollections(session, new QueryParameters(new Type[] {type}, ids, ids), true); |
5 | result = getRowFromResultSet(resultSet, session, queryParameters, getLockModes(queryParameters.getLockModes()), null, hydratedObjects, new EntityKey[entitySpan], returnProxies); | | | |
Precondition Violations (2)
Row |
Violation |
1 | Unmatched statement doQueryAndInitializeNonLazyCollections(session,new QueryParameters(new Type[]{type},ids,ids),true); cannot be moved before or after the extracted code, because it throws exception(s) that should be caught by a try block that will be extracted |
2 | Unmatched statement result=getRowFromResultSet(resultSet,session,queryParameters,getLockModes(queryParameters.getLockModes()),null,hydratedObjects,new EntityKey[entitySpan],returnProxies); cannot be moved before or after the extracted code, because it throws exception(s) that should be caught by a try block that will be extracted |