| Summary: | [encapsulate field] Encapsulating a constant used in switch yields compilation error | ||
|---|---|---|---|
| Product: | [Eclipse Project] JDT | Reporter: | Milos Gligoric <milos.gligoric> |
| Component: | UI | Assignee: | JDT-UI-Inbox <jdt-ui-inbox> |
| Status: | CLOSED WONTFIX | QA Contact: | |
| Severity: | normal | ||
| Priority: | P3 | CC: | manju656 |
| Version: | 4.2.1 | ||
| Target Milestone: | --- | ||
| Hardware: | PC | ||
| OS: | Linux | ||
| Whiteboard: | stalebug | ||
Issue is reproducible using I20121210-0800. The code refactoring results in compiler error. This bug hasn't had any activity in quite some time. Maybe the problem got resolved, was a duplicate of something else, or became less pressing for some reason - or maybe it's still relevant but just hasn't been looked at yet. If you have further information on the current state of the bug, please add it. The information can be, for example, that the problem still occurs, that you still want the feature, that more information is needed, or that the bug is (for whatever reason) no longer relevant. -- The automated Eclipse Genie. |
Steps to reproduce: 1. Invoke "Encapsulate Field" refactoring on "m" in code below. 2. There is a compilation error in the resulting code ("case expressions must be constant expressions"). public class EncapsulateFieldBug { // Invoke "Encapsulate Field" on "m" final int m = 10; void f() { switch (3) { case m: } } } (Thanks to Yilong Li for helping with the bug report.)