File path: /jruby-1.4.0/src/org/jruby/util/Convert.java | File path: /jruby-1.4.0/src/org/jruby/util/Convert.java | |||
Method name: double byteArrayToDouble(byte[], int, int, boolean)
|
Method name: double byteArrayToDouble(byte[], int, int, boolean)
|
|||
Number of AST nodes: 24 | Number of AST nodes: 16 | |||
1 | for ( ; i < buflen ; ) {↵ | |||
2 | switch(ival = bytes[i++]) {↵ | 1 | switch(ival = bytes[i++]) {↵ | |
3 | case '0': case '1': case '2': case '3': case '4':↵ | 2 | case '0': case '1': case '2': case '3': case '4':↵ | |
4 | case '5': case '6': case '7': case '8': case '9':↵ | 3 | case '5': case '6': case '7': case '8': case '9':↵ | |
5 | chars[offset++] = (char)ival;↵ | 4 | ↵ | |
6 | lastValidOffset = offset;↵ | |||
7 | break; // switch↵ | |||
8 | case 'e':↵ | |||
9 | case 'E':↵ | |||
10 | state = SEXP;↵ | |||
11 | break states;↵ | |||
12 | case '_':↵ | 5 | expSpec = (int)ival-(int)'0';↵ | |
13 | break; // switch↵ | 6 | break; //switch↵ | |
14 | default:↵ | 7 | default:↵ | |
15 | state = SCOMPLETE;↵ | 8 | state = SERR_NOT_STRICT;↵ | |
16 | break states;↵ | 9 | break states;↵ | |
17 | } // switch↵ | 10 |
| |
18 | } | |||
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 the same method |
Number of node comparisons | 154 |
Number of mapped statements | 16 |
Number of unmapped statements in the first code fragment | 7 |
Number of unmapped statements in the second code fragment | 0 |
Time elapsed for statement mapping (ms) | 15.7 |
Clone type | Type 3 |
ID | Statement | ID | Statement | |||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
539 | switch (ival = bytes[i++]) | 407 | switch (ival = bytes[i++]) | |||||||||||||||
540 | case '0': | 408 | case '0': | |||||||||||||||
541 | case '1': | 409 | case '1': | |||||||||||||||
542 | case '2': | 410 | case '2': | |||||||||||||||
543 | case '3': | 411 | case '3': | |||||||||||||||
544 | case '4': | 412 | case '4': | |||||||||||||||
545 | case '5': | 413 | case '5': | |||||||||||||||
546 | case '6': | 414 | case '6': | |||||||||||||||
547 | case '7': | 415 | case '7': | |||||||||||||||
548 | case '8': | 416 | case '8': | |||||||||||||||
549 | case '9': | 417 | case '9': | |||||||||||||||
550 | chars[offset++] = (char)ival; |
| | |||||||||||||||
551 | lastValidOffset = offset; |
| 418 | expSpec = (int)ival - (int)'0'; | ||||||||||||||
552 | break; | 419 | break; | |||||||||||||||
553 | case 'e': | | ||||||||||||||||
554 | case 'E': | | ||||||||||||||||
555 | state = SEXP; |
| 421 | state = SERR_NOT_STRICT; | ||||||||||||||
556 | break states; |
| | |||||||||||||||
557 | case '_': | | ||||||||||||||||
558 | break; |
| | |||||||||||||||
559 | default: | 420 | default: | |||||||||||||||
560 | state = SCOMPLETE; |
| | |||||||||||||||
561 | break states; | 422 | break states; |
Row | Violation |
---|---|
1 | Unmatched statement chars[offset++]=(char)ival; cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
2 | Expression (int)ival - (int)'0' cannot be parameterized, because it has dependencies to/from statements that will be extracted |
3 | Unmatched break states; |
4 | Unmatched break; |
5 | Unmatched statement state=SCOMPLETE; cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
6 | Clone fragment #1 returns variables i, ival, lastValidOffset , while Clone fragment #2 returns variables i, expSpec |