do { if (module.hasClassVariable(name)) { return module.storeClassVariable(name, value); } } while ((module = module.getSuperClass()) != null);
for (SymbolEntry e = table[index = hash & (table.length - 1)]; e != null; e = e.next) { if (hash == e.hash && name.equals(e.name)) { return e.symbol; } }
Clone fragments detected by clone detection tool
File path: /jruby-1.4.0/src/org/jruby/RubyModule.java File path: /jruby-1.4.0/src/org/jruby/RubySymbol.java
Method name: IRubyObject setClassVar(String, IRubyObject) Method name: RubySymbol createSymbol(String, ByteList, int, SymbolEntry[])
Number of AST nodes: 3 Number of AST nodes: 3
1
do {
1
for (SymbolEntry e = table[index = hash & (table.length - 1)]; e != null; e = e.next) {
2
            if (module.hasClassVariable(name)) {
2
                    if (hash == e.hash && name.equals(e.name)) {
3
                return module.storeClassVariable(name, value);
3
                
4
            }
5
        } while ((module = module.getSuperClass()) != null);
4
        return e.symbol;
5
                    }
6
                }
Summary
Number of common nesting structure subtrees0
Number of refactorable cases0
Number of non-refactorable cases0
Time elapsed for finding largest common nesting structure subtrees (ms)0.1
Clones locationClones are in different classes
Number of node comparisons1