<div dir="ltr"><div>Liam reminded me,</div><div><br></div><div>3. the upper bound for class literals, which maybe went without saying, but there it is. Also harmless if I am correct that doing anything with the result of `newInstance` etc. always results in one kind of warning or another.</div><div><br></div><div>Sorry, this is pointless to the real question you're asking, I just hate saying something wrong without correcting it. :-)</div><div><br></div></div><br><div class="gmail_quote"><div dir="ltr">On Wed, Dec 5, 2018 at 11:26 AM Kevin Bourrillion <<a href="mailto:kevinb@google.com" target="_blank">kevinb@google.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div dir="ltr"><div class="gmail_quote"><div dir="ltr">On Wed, Dec 5, 2018 at 8:19 AM Maurizio Cimadamore <<a href="mailto:maurizio.cimadamore@oracle.com" target="_blank">maurizio.cimadamore@oracle.com</a>> wrote:<br></div><div dir="ltr"><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">* Our proposed treatment for generic enums raises an additional, more <br>
philosophical, question: what are raw types *for* and how happy are we <br>
in seeing more of them (in the form of raw enum types)?<br></blockquote><div><br></div><div>I have looked high and low for valid use cases for raw types (apart from interacting with legacy code), and only ever found... two.</div><div><br></div><div>1. As the stepping stone to make a forbidden cast:</div><div><br></div></div></div><blockquote style="margin:0 0 0 40px;border:none;padding:0px"><div><div class="gmail_quote"><div><div>@SuppressWarnings("unchecked") // safe because runtime type is functionally covariant<br></div></div></div></div><div><div class="gmail_quote"><div><div>Iterator<Object> objects = (Iterator) strings;</div></div></div></div></blockquote><div dir="ltr"><div class="gmail_quote"><div><br></div><div>A common use case for this is to interact with APIs that forgot their wlidcards, but there are plenty of other cases that can't be "fixed".</div><div><br></div><div>2. As the argument to instanceof. Everyone does it, of course, because writing out `instanceof Map<?, ?>` serves no purpose.</div><div><br></div><div>Thankfully, they're both harmless... and I believe (?) they were even made exempt from "rawtypes" warnings. (If not, I'd opine that they should be.)</div><div><br></div><div><br></div></div>-- <br><div dir="ltr" class="m_-5395093240811864363m_7475577344141634623gmail_signature"><div dir="ltr"><div><div dir="ltr"><div><div dir="ltr"><div style="line-height:1.5em;padding-top:10px;margin-top:10px;color:rgb(85,85,85);font-family:sans-serif"><span style="border-width:2px 0px 0px;border-style:solid;border-color:rgb(213,15,37);padding-top:2px;margin-top:2px">Kevin Bourrillion |</span><span style="border-width:2px 0px 0px;border-style:solid;border-color:rgb(51,105,232);padding-top:2px;margin-top:2px"> Java Librarian |</span><span style="border-width:2px 0px 0px;border-style:solid;border-color:rgb(0,153,57);padding-top:2px;margin-top:2px"> Google, Inc. |</span><span style="border-width:2px 0px 0px;border-style:solid;border-color:rgb(238,178,17);padding-top:2px;margin-top:2px"> <a href="mailto:kevinb@google.com" target="_blank">kevinb@google.com</a></span></div></div></div></div></div></div></div></div></div>
</blockquote></div><br clear="all"><div><br></div>-- <br><div dir="ltr" class="m_-5395093240811864363gmail_signature" data-smartmail="gmail_signature"><div dir="ltr"><div><div dir="ltr"><div><div dir="ltr"><div style="line-height:1.5em;padding-top:10px;margin-top:10px;color:rgb(85,85,85);font-family:sans-serif"><span style="border-width:2px 0px 0px;border-style:solid;border-color:rgb(213,15,37);padding-top:2px;margin-top:2px">Kevin Bourrillion |</span><span style="border-width:2px 0px 0px;border-style:solid;border-color:rgb(51,105,232);padding-top:2px;margin-top:2px"> Java Librarian |</span><span style="border-width:2px 0px 0px;border-style:solid;border-color:rgb(0,153,57);padding-top:2px;margin-top:2px"> Google, Inc. |</span><span style="border-width:2px 0px 0px;border-style:solid;border-color:rgb(238,178,17);padding-top:2px;margin-top:2px"> <a href="mailto:kevinb@google.com" target="_blank">kevinb@google.com</a></span></div></div></div></div></div></div></div>