[Issue 11381] New: warn/error when static if else ladder has no matching block (or misses "else")
d-bugmail at puremagic.com
d-bugmail at puremagic.com
Tue Oct 29 19:57:18 PDT 2013
http://d.puremagic.com/issues/show_bug.cgi?id=11381
Summary: warn/error when static if else ladder has no matching
block (or misses "else")
Product: D
Version: D2
Platform: All
OS/Version: All
Status: NEW
Severity: enhancement
Priority: P2
Component: DMD
AssignedTo: nobody at puremagic.com
ReportedBy: code at dawg.eu
--- Comment #0 from Martin Nowak <code at dawg.eu> 2013-10-29 19:57:05 PDT ---
static if (T.sizeof == 4) { /*A*/ }
else static if (T.sizeof == 8) { /*B*/ }
else static if (T.sizeof == 12) { /*C*/ }
version (Windows) {}
else version (linux) {}
else version (OSX) {}
static if (something) {}
else version (foo) {}
else static if (somethingelse) {}
----
When such a construct is detected and none of the conditional blocks is matched
the compiler should warn/error about an unhandled case.
We could also try to make the declaration of such a ladder without an
else-clause a warning/error. This would require an explicit "else {}" to
achieve the current behavior and avoids inadvertently missing else clauses
similar to how non-final switch statements require a default label.
--
Configure issuemail: http://d.puremagic.com/issues/userprefs.cgi?tab=email
------- You are receiving this mail because: -------
More information about the Digitalmars-d-bugs
mailing list