<html><head></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><br><div><div>On Aug 21, 2012, at 9:04 AM, Jordan Rose wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div><br>On Aug 20, 2012, at 18:47 , Jordan Rose <<a href="mailto:jordan_rose@apple.com">jordan_rose@apple.com</a>> wrote:<br><br><blockquote type="cite">Yeah, I don't like this approach as much as I thought I would. My original reason for making a new summary out of an old one was to re-use the existing summary evaluation code. This eliminates that, and processSummaryOfInlined is crippled since it only handles StopTrackingHard and NoRetHard. And there's a lot of duplication elsewhere.<br></blockquote><blockquote type="cite"><br></blockquote><blockquote type="cite">I'd rather see this:<br></blockquote><blockquote type="cite"><br></blockquote><blockquote type="cite"> RetainSummaryManager &Summaries = getSummaryManager(C);<br></blockquote><blockquote type="cite"> const RetainSummary *Summ = Summaries.getSummary(Call, C.getState());<br></blockquote><blockquote type="cite"><br></blockquote><blockquote type="cite"> if (C.wasInlined && !Summ->appliesToInlined())<br></blockquote><blockquote type="cite">   return;<br></blockquote><blockquote type="cite"><br></blockquote><blockquote type="cite"> checkSummary(*Summ, Call, C);<br></blockquote><br>Thinking about this again, this is about whether we're saying "this summary should be applied even when inlining", or "these /effects/ should be applied even when inlining". Even in the latter case I'd consider adding flags to the ArgEffects rather than adding new ArgEffect kinds, but that's an interesting distinction/decision. Obviously the latter is more flexible, but which do you think we /should/ be doing?</div></blockquote><div><blockquote type="cite"></blockquote></div><div><br></div><div>There are several reasons why I am not reusing the checkSummary code when processing summaries for inlined function.</div><div> - As you mentioned above, parts/individual effects in a summary are marked as "applied when inlining" not the whole summary. It makes sense to keep it this way. We make decisions on what effect each argument/return value should have separately.</div><div> - I do not perform checking for errors in processSummaryOfInlined, which is a big part of checkSummary. Even in DecRefAndStopTracking, I think it's OK to not check for use-after-free since we did inline the function and know better if it used the object or not. We should have generated the warning while analyzing the function in the former case.</div><div> - Passing an extra flag to checkSummary to act differently in the inlined case is much more messy - the only thing the functions share is the argument visitation logic. I'd rather have the argument iterator and get receiver code duplicated rather than one huge function with a lot of conditions. If you are very concerned about it, we could reduce parameter visitation to a single loop by adding another iteration APIs to EvalCall and RetainSummary, which processes both the arguments and receiver. That would make both functions (checkSummary and processSummaryOfInlined<span class="Apple-style-span" style="font-size: 11px;">)</span> much smaller. (Not sure that it's worth it though.)</div><div><br></div><div><blockquote type="cite"></blockquote></div><blockquote type="cite"><div><br></div></blockquote></div><div><blockquote type="cite"><div>Jordan</div></blockquote></div><br></body></html>