synchronized (arr_true) {
arr_true.append(larg);
}
if (threadService.getCritical()) {
// If the target thread is sleeping or stopped, wake it
synchronized (this) {
notify();
}
// interrupt the target thread in case it's blocking or waiting
// WARNING: We no longer interrupt the target thread, since this usually means
// interrupting IO and with NIO that means the channel is no longer usable.
// We either need a new way to handle waking a target thread that's waiting
// on IO, or we need to accept that we can't wake such threads and must wait
// for them to complete their operation.
//threadImpl.interrupt();
}
Clone fragments detected by clone detection tool
File path: /jruby-1.4.0/src/org/jruby/RubyEnumerable.java
|
|
File path: /jruby-1.4.0/src/org/jruby/RubyThread.java
|
Method name: IRubyObject call(ThreadContext, IRubyObject[], Block)
|
|
Method name: IRubyObject join(IRubyObject[])
|
Number of AST nodes: 2
|
|
Number of AST nodes: 3
|
|
1 | synchronized (arr_true) {↵ | | |
|
2 | arr_true.append(larg);↵ | | |
|
3 | ↵ | | 1 | if (threadService.getCritical()) {↵
|
| | | 2 | // If the target thread is sleeping or stopped, wake it↵
|
| | | 3 | synchronized (this) {↵
|
| | | 4 | notify();↵
|
| | | 5 | }↵
|
| | | 6 | ↵
|
| | | 7 | // interrupt the target thread in case it's blocking or waiting↵
|
| | | 8 | // WARNING: We no longer interrupt the target thread, since this usually means↵
|
| | | 9 | // interrupting IO and with NIO that means the channel is no longer usable.↵
|
| | | 10 | // We either need a new way to handle waking a target thread that's waiting↵
|
| | | 11 | // on IO, or we need to accept that we can't wake such threads and must wait↵
|
| | | 12 | // for them to complete their operation.↵
|
| | | 13 | //threadImpl.interrupt();↵
|
4 | } | | 14 | }
|
See real code fragment |
|
See real code fragment |
Summary
Number of common nesting structure subtrees | 1 |
Number of refactorable cases | 1 |
Number of non-refactorable cases | 0 |
Time elapsed for finding largest common nesting structure subtrees (ms) | 10.8 |
Clones location | Clones are in different classes |
Number of node comparisons | 5 |
-
{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) | 0.5 |
Clone type | Type 2 |
Mapped Statements
ID |
Statement |
|
ID |
Statement |
3 | synchronized (arr_true) | | 14 | synchronized (this) |
4 | | | | |
| | | 15 | |
Precondition Violations (0)
Row |
Violation |