File path: /hibernate-distribution-3.3.2.GA/project/core/src/main/java/org/hibernate/collection/AbstractPersistentCollection.java | File path: /hibernate-distribution-3.3.2.GA/project/core/src/main/java/org/hibernate/collection/AbstractPersistentCollection.java | |||
Method name: Boolean readElementExistence(Object)
|
Method name: Object readElementByIndex(Object)
|
|||
Number of AST nodes: 7 | Number of AST nodes: 7 | |||
1 | throwLazyInitializationExceptionIfNotConnected();↵ | 1 | throwLazyInitializationExceptionIfNotConnected();↵ | |
2 | CollectionEntry entry = session.getPersistenceContext().getCollectionEntry(this);↵ | 2 | CollectionEntry entry = session.getPersistenceContext().getCollectionEntry(this);↵ | |
3 | CollectionPersister persister = entry.getLoadedPersister();↵ | 3 | CollectionPersister persister = entry.getLoadedPersister();↵ | |
4 | if ( persister.isExtraLazy() ) {↵ | 4 | if ( persister.isExtraLazy() ) {↵ | |
5 | if ( hasQueuedOperations() ) {↵ | 5 | if ( hasQueuedOperations() ) {↵ | |
6 | session.flush();↵ | 6 | session.flush();↵ | |
7 | }↵ | 7 | }↵ | |
8 | return new Boolean( persister.elementExists( entry.getLoadedKey(), element, session ) );↵ | 8 | return persister.getElementByIndex( entry.getLoadedKey(), index, session, owner );↵ | |
9 | } | 9 |
| |
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.2 |
Clones location | Clones are declared in the same class |
Number of node comparisons | 18 |
Number of mapped statements | 6 |
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) | 1.9 |
Clone type | Type 2 |
ID | Statement | ID | Statement | |||||
---|---|---|---|---|---|---|---|---|
2 | throwLazyInitializationExceptionIfNotConnected(); | 2 | throwLazyInitializationExceptionIfNotConnected(); | |||||
3 | CollectionEntry entry = session.getPersistenceContext().getCollectionEntry(this); | 3 | CollectionEntry entry = session.getPersistenceContext().getCollectionEntry(this); | |||||
4 | CollectionPersister persister = entry.getLoadedPersister(); | 4 | CollectionPersister persister = entry.getLoadedPersister(); | |||||
5 | if (persister.isExtraLazy()) | 5 | if (persister.isExtraLazy()) | |||||
6 | if (hasQueuedOperations()) | 6 | if (hasQueuedOperations()) | |||||
7 | session.flush(); | 7 | session.flush(); | |||||
|
| 8 | return persister.getElementByIndex(entry.getLoadedKey(), index, session, owner); | |||||
8 | return new Boolean(persister.elementExists(entry.getLoadedKey(), element, session)); |
| |
Row | Violation |
---|---|
1 | Unmatched statement return persister.getElementByIndex(entry.getLoadedKey(),index,session,owner); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
2 | Unmatched return persister.getElementByIndex(entry.getLoadedKey(),index,session,owner); |
3 | Unmatched statement return new Boolean(persister.elementExists(entry.getLoadedKey(),element,session)); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
4 | Unmatched return new Boolean(persister.elementExists(entry.getLoadedKey(),element,session)); |
5 | Clone fragment #1 returns variables entry, persister , while Clone fragment #2 returns variables entry, persister |