File path: /hibernate-distribution-3.3.2.GA/project/core/src/main/java/org/hibernate/persister/entity/AbstractEntityPersister.java | File path: /hibernate-distribution-3.3.2.GA/project/core/src/main/java/org/hibernate/tuple/entity/AbstractEntityTuplizer.java | |||
Method name: String generateInsertString(boolean, boolean[], int)
|
Method name: void setPropertyValues(Object, Object[])
|
|||
Number of AST nodes: 3 | Number of AST nodes: 3 | |||
1 | for ( int i = 0; i < entityMetamodel.getPropertySpan(); i++ ) {↵ | 1 | for ( int j = 0; j < entityMetamodel.getPropertySpan(); j++ ) { ↵ | |
2 | if ( includeProperty[i] && isPropertyOfTable( i, j ) ) {↵ | 2 | if ( setAll || values[j] != LazyPropertyInitializer.UNFETCHED_PROPERTY ) { ↵ | |
3 | // this property belongs on the table and is to be inserted↵ | 3 | ↵ | |
4 | insert.addColumns( getPropertyColumnNames(i), propertyColumnInsertable[i] );↵ | 4 | setters[j].set( entity, values[j], getFactory() ); ↵ | |
5 | }↵ | 5 | } ↵ | |
6 | } | 6 |
| |
See real code fragment | See real code fragment |
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.5 |
Clones location | Clones are in different classes |
Number of node comparisons | 5 |
Number of mapped statements | 2 |
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) | 103.3 |
Clone type | Type 2 |
ID | Statement | ID | Statement | ||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
2 | for (int i = 0; i < entityMetamodel.getPropertySpan(); i++) |
| 2 | for (int j = 0; j < entityMetamodel.getPropertySpan(); j++) | |||||||||||||||||||||
3 | if (includeProperty[i] && isPropertyOfTable(i, j)) |
| 3 | if (setAll || values[j] != LazyPropertyInitializer.UNFETCHED_PROPERTY) | |||||||||||||||||||||
|
| 4 | setters[j].set(entity, values[j], getFactory()); | ||||||||||||||||||||||
4 | insert.addColumns(getPropertyColumnNames(i), propertyColumnInsertable[i]); |
| |
Row | Violation |
---|---|
1 | Expression includeProperty[i] cannot be parameterized, because it has dependencies to/from statements that will be extracted |
2 | Expression isPropertyOfTable(i,j) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
3 | Expression values[j] != LazyPropertyInitializer.UNFETCHED_PROPERTY cannot be parameterized, because it has dependencies to/from statements that will be extracted |
4 | Expression includeProperty[i] && isPropertyOfTable(i,j) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
5 | Expression setAll || values[j] != LazyPropertyInitializer.UNFETCHED_PROPERTY cannot be parameterized, because it has dependencies to/from statements that will be extracted |
6 | Unmatched statement setters[j].set(entity,values[j],getFactory()); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
7 | Unmatched statement setters[j].set(entity,values[j],getFactory()); 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 |
8 | Unmatched statement insert.addColumns(getPropertyColumnNames(i),propertyColumnInsertable[i]); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
9 | The refactoring of the clones is infeasible, because classes org.hibernate.persister.entity.AbstractEntityPersister and org.hibernate.tuple.entity.AbstractEntityTuplizer do not have a common superclass |