<HTML><BODY style="word-wrap: break-word; -khtml-nbsp-mode: space; -khtml-line-break: after-white-space; "><DIV><BLOCKQUOTE type="cite"><DIV><BLOCKQUOTE type="cite">3. There are inconsistencies in the ObjC class interfaces. For example, it is ObjcInterfaceDecl::getNumInstanceVariables but it is ObjcImplementationDecl::getImplDeclNumIvars. This is strangeness. Please pick a set of shorthand (e.g. Inst for instance, Proto for protocol, Meth for method, Vars for variables etc) and use it consistently. Many method names are really long. getNumInstanceVariables should get getNumInstVars() or getNumIVars().<BR><BR></BLOCKQUOTE><DIV><BR class="webkit-block-placeholder"></DIV>I agree with removing the inconsistency. There are two consistency issues here: (1) the ObjC AST API's should be self consistent. (2) the ObjC AST API's should be consistent with the C AST API's.</DIV></BLOCKQUOTE><DIV><BR class="khtml-block-placeholder"></DIV>Ok.</DIV><DIV><BR><BLOCKQUOTE type="cite"><DIV>That said, I think shortening the names (and coming up with a bunch of abbreviations) is questionable. For example, the type checker uses "getCanonicalType" all over the place. Here is an excerpt...</DIV><DIV><BR class="webkit-block-placeholder"></DIV><DIV><DIV style="margin-top: 0px; margin-right: 0px; margin-bottom: 0px; margin-left: 0px; font: normal normal normal 10px/normal Monaco; "> <SPAN style="color: #3f6e74">QualType</SPAN> <SPAN style="color: #3f6e74">lhs</SPAN> = lhsExpr->getType().getCanonicalType().getUnqualifiedType();</DIV><DIV style="margin-top: 0px; margin-right: 0px; margin-bottom: 0px; margin-left: 0px; font: normal normal normal 10px/normal Monaco; "> <SPAN style="color: #3f6e74">QualType</SPAN> rhs = rhsExpr->getType().getCanonicalType().getUnqualifiedType();</DIV><DIV><FONT class="Apple-style-span" face="Monaco" size="2"><SPAN class="Apple-style-span" style="font-size: 10px;"><BR class="webkit-block-placeholder"></SPAN></FONT></DIV><DIV>From my perspective, the Type accessors have long names. We could consider converting them to...</DIV><DIV><BR class="webkit-block-placeholder"></DIV><DIV><DIV style="margin-top: 0px; margin-right: 0px; margin-bottom: 0px; margin-left: 0px; font: normal normal normal 10px/normal Monaco; "> <SPAN style="color: rgb(63, 110, 116); ">QualType</SPAN> <SPAN style="color: rgb(63, 110, 116); ">lhs</SPAN> = lhsExpr->getType().getCanonType().getUnqualType();</DIV><DIV style="margin-top: 0px; margin-right: 0px; margin-bottom: 0px; margin-left: 0px; font: normal normal normal 10px/normal Monaco; "> <SPAN style="color: rgb(63, 110, 116); ">QualType</SPAN> rhs = rhsExpr->getType().getCanonType().getUnqualType();</DIV><DIV><FONT class="Apple-style-span" face="Monaco" size="2"><SPAN class="Apple-style-span" style="font-size: 10px;"><BR class="webkit-block-placeholder"></SPAN></FONT></DIV></DIV> </DIV><DIV><DIV>From my perspective, this would be the wrong decision (since the original names are "good").</DIV></DIV></BLOCKQUOTE><DIV><BR class="khtml-block-placeholder"></DIV>Ok.</DIV><DIV><BR><BLOCKQUOTE type="cite"><DIV><DIV>I general, I don't believe shortening names just for the sake of shortening is the right decision. The names can certainly be improved. I just don't see a general/good solution to your complaint that "Many method names are really long". </DIV></DIV></BLOCKQUOTE><DIV><BR class="khtml-block-placeholder"></DIV><DIV>I'm much more concerned with consistency than terseness, I'm happy to go with consistent but long names :)</DIV><BR><BLOCKQUOTE type="cite"><DIV><BLOCKQUOTE type="cite">4. There are 4 or 5 implementations of lookupInstanceMethod, and they all do different things. :( Please pick a name that is more specific to the various classes that explains how it searches. For example, ObjcImplementationDecl::lookupInstanceMethod could be ObjcImplementationDecl::findDefinedInstMethod(), which makes it more clear that it only returns things *defined in the @implementation*.<BR><BR></BLOCKQUOTE><DIV><BR class="webkit-block-placeholder"></DIV>I disagree with your assertion that "they all do different things. :(". From my perspective, using polymorphism here makes sense.</DIV></BLOCKQUOTE><DIV><BR class="khtml-block-placeholder"></DIV><DIV>Some do a "shallow" lookup, others walk the inheritance chain. It should be clear from their name what they do.</DIV><BR><BLOCKQUOTE type="cite"><DIV><BLOCKQUOTE type="cite">5. Related, I think you should split ObjcProtocolDecl::lookupInstanceMethod up into two things: one that searches locally, and one that walks the "referenced protocols", calling the local search on each one. Likewise for any similar ones.<BR><BR></BLOCKQUOTE><DIV><BR class="webkit-block-placeholder"></DIV>I think having different ways to search is fine. Off hand, I don't know if I prefer a "knob" (on an existing API) or a new API. To some extent is depends on how we resolve the naming/polymorphism issues above.</DIV></BLOCKQUOTE><DIV><BR class="khtml-block-placeholder"></DIV>Please split it into two functions, where one calls the other. instead of "lookupInstanceMethod" how about getinstanceMethodBySelector() or something? Wow that name is long ;-)</DIV><DIV><BR><BLOCKQUOTE type="cite"><DIV><BLOCKQUOTE type="cite">6. One specific question is that ObjcInterfaceDecl::lookupInstanceMethod scans methods immediately referenced in protocols, but it doesn't scan protocol's parent protocols. Is this correct? Either way, please change it to call the methods added in step #5.<BR><BR></BLOCKQUOTE>I agree with you...I don't believe this is correct. ObjcInterfaceDecl should likely query the protocol directly (rather than iterate over the protocols instance methods directly).</DIV></BLOCKQUOTE><DIV><BR class="khtml-block-placeholder"></DIV>Ok.</DIV><BR><DIV>Thanks Steve,</DIV><DIV><BR class="khtml-block-placeholder"></DIV><DIV>-Chris</DIV></BODY></HTML>