<html><head><meta http-equiv="Content-Type" content="text/html charset=us-ascii"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><div>hi all,</div><div><br></div><div>any update on this?</div><div><br></div><div>ta,</div><div>richard.</div><br><div><div>On 08 Nov 2013, at 22:23, Jordan Rose <<a href="mailto:jordan_rose@apple.com">jordan_rose@apple.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div style="font-family: Helvetica; font-size: 14px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;"><div><br class="Apple-interchange-newline">On Nov 6, 2013, at 7:18 , Tarka T <<a href="mailto:tarka.t.otter@gmail.com">tarka.t.otter@gmail.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div dir="ltr">On Tue, Nov 5, 2013 at 6:46 PM, Jordan Rose<span class="Apple-converted-space"> </span><span dir="ltr"><<a href="mailto:jordan_rose@apple.com" target="_blank">jordan_rose@apple.com</a>></span><span class="Apple-converted-space"> </span>wrote:<br><div class="gmail_extra"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-color: rgb(204, 204, 204); border-left-style: solid; padding-left: 1ex;"><div style="word-wrap: break-word;"><br><div><div class="im"><div>On Oct 31, 2013, at 5:43 , Richard <<a href="mailto:tarka.t.otter@gmail.com" target="_blank">tarka.t.otter@gmail.com</a>> wrote:</div><br><blockquote type="cite"><div style="word-wrap: break-word;">On 29 Oct 2013, at 17:11, Jordan Rose <<a href="mailto:jordan_rose@apple.com" target="_blank">jordan_rose@apple.com</a>> wrote:<br><div><br><blockquote type="cite"><div style="font-family: Helvetica; font-size: 14px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px;">The logic all seems correct here, but I think we can still do better on the message. The class and protocol cases seem a little underinformative to me, especially since the analyzer doesn't have a note where the availability shows up. So instead of a version kind, how about just passing the decl that has the availability attribute? That way we can say "method", "function", "class 'Foo'", or "protocol 'Foo'".</div><div style="font-family: Helvetica; font-size: 14px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px;"><br></div><div style="font-family: Helvetica; font-size: 14px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px;">Also, it would be nice to include the platform name with the version. This code is stolen from DeclBase.cpp, but I don't have a better place for it right now.</div><div style="font-family: Helvetica; font-size: 14px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px;"><br></div><div style="font-family: Helvetica; font-size: 14px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px;"><div style="margin: 0px; font-size: 11px; font-family: Menlo;"> <span style="color: rgb(79, 129, 135);">StringRef</span><span> </span>TargetPlatform = Context.<span style="color: rgb(49, 89, 93);">getTargetInfo</span>().<span style="color: rgb(49, 89, 93);">getPlatformName</span>();</div><div style="margin: 0px; font-size: 11px; font-family: Menlo;"> <span> </span><span style="color: rgb(79, 129, 135);">StringRef</span><span> </span>PrettyPlatformName</div><div style="margin: 0px; font-size: 11px; font-family: Menlo;"> =<span> </span><span style="color: rgb(79, 129, 135);">AvailabilityAttr</span>::<span style="color: rgb(49, 89, 93);">getPrettyPlatformName</span>(TargetPlatform);</div><div style="margin: 0px; font-size: 11px; font-family: Menlo;"> <span> </span><span style="color: rgb(187, 44, 162);">if</span><span> </span>(PrettyPlatformName.<span style="color: rgb(49, 89, 93);">empty</span>())</div><div style="margin: 0px; font-size: 11px; font-family: Menlo;"> PrettyPlatformName = TargetPlatform;</div><div><br></div><div>"Calling method introduced in OS X 10.9 (deployment target is 10.8)"</div><div><br></div><div>But other than this polish this is looking very good. Have you tried running it on existing projects?</div><div>Jordan</div></div></blockquote></div><br><div>OK, I have changed the message as suggested, works for you?</div><div><br></div><div>I have been running this on some small projects, but today gave it a test on all the large old projects I have here. Mostly it is working well (and caught many unsafe calls I was not aware of), but there were some issues which I have addressed in the latest patch:</div><div><br></div><div>* id types cause false positives</div><div>When calling methods on id types (in block enumerations and so on) the method decl match is often incorrect, and so the version check information often causes false positives. I fixed this by not checking any ObjCMethodCall without a receiver interface.</div><div></div></div></blockquote><div><br></div></div><div>Ha, good catch.</div><div class="im"><div><br></div><br><blockquote type="cite"><div style="word-wrap: break-word;"><div>* Array and Dictionary subscripting</div><div>When using subscripting in a project with a deployment target less than iOS6 (or 10.8?), every subscript will cause a version warning. However, as stated here:</div><div><br></div><div><a href="https://developer.apple.com/library/ios/releasenotes/ObjectiveC/ObjCAvailabilityIndex/index.html" target="_blank">https://developer.apple.com/library/ios/releasenotes/ObjectiveC/ObjCAvailabilityIndex/index.html</a></div><div><br></div><div>subscripting is handled back to iOS5 and 10.6. I am not sure of the best way to handle this, the current workaround was just to match the selectors by name and not version check when we have a subscript selector. Ideally the checker would make sure that the deployment target was high enough for the runtime to support subscripting, is there a way to get this information from some API?</div><div></div></div></blockquote><div><br></div></div><div>ObjCMethodCall has an accessor that lets you know if it's using subscripting syntax. I think we can ignore it in that case.</div><div class="im"><div><br></div><br><blockquote type="cite"><div style="word-wrap: break-word;"><div>* Methods that call [super sameMethod]</div><div>I had a few false positives where implementing eg</div><div><br></div><div><div style="margin: 0px; font-family: Monaco;">- (<span style="color: rgb(187, 44, 162);">void</span>)encodeRestorableStateWithCoder:(<span style="color: rgb(112, 61, 170);">NSCoder</span><span class="Apple-converted-space"> </span>*)coder</div><div style="margin: 0px; font-family: Monaco;">{</div><div style="margin: 0px; font-family: Monaco; color: rgb(61, 29, 129);"><span> [</span><span style="color: rgb(187, 44, 162);">super</span><span> </span>encodeRestorableStateWithCoder<span>:coder];</span></div><div style="margin: 0px; font-family: Monaco; min-height: 19px;">}</div></div><div><br></div><div>Currently I have left these as false positives, but perhaps there should be special casing to handle this situation too. What do you think about this, is it safe to ignore methods called on super that have been implemented on self, regardless of deployment target? </div><div></div></div></blockquote><div><br></div></div><div>The most pedantic thing to do here would be to require putting an availability attribute on your own method, but I don't think that will fly. Let's start conservative and say it's always okay to call super if the caller has the same selector as the callee. (In most other cases you'd just use self.)</div><div><br></div><div><br></div><div>Spot comments:</div><div><br></div><div><div>+ const Decl *VD = VersionDecl == NULL ? D : VersionDecl;</div><div><br></div><div>Might as well just set VersionDecl to D initially. It's not used for anything else.</div><div><br></div><div>+ os << "'" << cast<NamedDecl>(D)->getName() << "'";</div><div><br></div></div><blockquote type="cite"><div style="word-wrap: break-word;"><div></div></div></blockquote></div>You should just be able to use "os << *D" here, which will work even if we start printing method names (which aren't simple identifiers). You can drop the cast by making the parameter always be NamedDecl.<div><br></div><div><div>+ default:</div><div>+ break;</div></div><div><br></div><div>Please make this llvm_unreachable, since we don't expect any other kinds to come in here and won't handle them properly if they do.</div><div><br></div><div>Everything else looks good. Thanks for testing this on existing projects.</div><span class="HOEnZb"><font color="#888888">Jordan</font></span></div></blockquote></div><br></div><div class="gmail_extra">OK, I think the current patch covers everything then. Let me know if you see any more issues.</div><div class="gmail_extra"><br></div><div class="gmail_extra">Regards,</div><div class="gmail_extra">Richard</div></div></blockquote><br></div><div style="font-family: Helvetica; font-size: 14px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;">This looks good to me. I'd like to give Ted a chance to look at it too before committing, in case he has any comments. Unfortunately, we were tied up with the Developer Meeting on Wed and Thu, and he's on vacation today, so that won't be until next week. </div><div style="font-family: Helvetica; font-size: 14px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;"><br></div><div style="font-family: Helvetica; font-size: 14px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;">Jordan</div></blockquote></div><br></body></html>