File path: /hibernate-distribution-3.3.2.GA/project/core/src/main/java/org/hibernate/impl/SessionFactoryImpl.java | File path: /hibernate-distribution-3.3.2.GA/project/core/src/main/java/org/hibernate/impl/SessionFactoryImpl.java | |||
Method name: void evictEntity(String, Serializable)
|
Method name: void evictCollection(String, Serializable)
|
|||
Number of AST nodes: 6 | Number of AST nodes: 6 | |||
1 | EntityPersister p = getEntityPersister( entityName );↵ | 1 | CollectionPersister p = getCollectionPersister( roleName );↵ | |
2 | if ( p.hasCache() ) {↵ | 2 | if ( p.hasCache() ) {↵ | |
3 | if ( log.isDebugEnabled() ) {↵ | 3 | if ( log.isDebugEnabled() ) {↵ | |
4 | log.debug( "evicting second-level cache: " + MessageHelper.infoString(p, id, this) );↵ | 4 | log.debug( "evicting second-level cache: " + MessageHelper.collectionInfoString(p, id, this) );↵ | |
5 | }↵ | 5 | }↵ | |
6 | CacheKey cacheKey = new CacheKey( id, p.getIdentifierType(), p.getRootEntityName(), EntityMode.POJO, this );↵ | 6 | CacheKey cacheKey = new CacheKey( id, p.getKeyType(), p.getRole(), EntityMode.POJO, this );↵ | |
7 | p.getCacheAccessStrategy().evict( cacheKey );↵ | 7 | p.getCacheAccessStrategy().evict( cacheKey );↵ | |
8 | } | 8 |
| |
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 | 14 |
Number of mapped statements | 5 |
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) | 9.7 |
Clone type | Type 2 |
ID | Statement | ID | Statement | ||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1 | CollectionPersister p = getCollectionPersister(roleName); | |||||||||||||||||||||||
1 | EntityPersister p = getEntityPersister(entityName); | | |||||||||||||||||||||||
2 | if (p.hasCache()) |
| 2 | if (p.hasCache()) | |||||||||||||||||||||
3 | if (log.isDebugEnabled()) | 3 | if (log.isDebugEnabled()) | ||||||||||||||||||||||
4 | log.debug("evicting second-level cache: " + MessageHelper.infoString(p, id, this)); |
| 4 | log.debug("evicting second-level cache: " + MessageHelper.collectionInfoString(p, id, this)); | |||||||||||||||||||||
5 | CacheKey cacheKey = new CacheKey(id, p.getIdentifierType(), p.getRootEntityName(), EntityMode.POJO, this); |
| 5 | CacheKey cacheKey = new CacheKey(id, p.getKeyType(), p.getRole(), EntityMode.POJO, this); | |||||||||||||||||||||
6 | p.getCacheAccessStrategy().evict(cacheKey); |
| 6 | p.getCacheAccessStrategy().evict(cacheKey); |
Row | Violation |
---|---|
1 | Type org.hibernate.persister.entity.EntityPersister of variable p does not match with type org.hibernate.persister.collection.CollectionPersister of variable p |
2 | Type org.hibernate.persister.entity.EntityPersister of variable p does not match with type org.hibernate.persister.collection.CollectionPersister of variable p |
3 | Type org.hibernate.persister.entity.EntityPersister of variable p does not match with type org.hibernate.persister.collection.CollectionPersister of variable p |
4 | Type org.hibernate.persister.entity.EntityPersister of variable p does not match with type org.hibernate.persister.collection.CollectionPersister of variable p |
5 | Type org.hibernate.cache.access.EntityRegionAccessStrategy of variable p.getCacheAccessStrategy() does not match with type org.hibernate.cache.access.CollectionRegionAccessStrategy of variable p.getCacheAccessStrategy() |
6 | Type org.hibernate.persister.entity.EntityPersister of variable p does not match with type org.hibernate.persister.collection.CollectionPersister of variable p |