<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>yeah, thats fixed it, ta.</div><br><div><div>On 14 Dec 2012, at 20:12, Anna Zaks <<a href="mailto:ganna@apple.com">ganna@apple.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><meta http-equiv="Content-Type" content="text/html charset=us-ascii"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; ">Looks like you've hit a bug in the analyzer ExprEngine! <div><br></div><div>Should be fixed by r170232. Let me know if that's not the case.<div><br></div><div>Cheers,</div><div>Anna.<br><div><div>On Dec 14, 2012, at 8:47 AM, Richard <<a href="mailto:tarka.t.otter@googlemail.com">tarka.t.otter@googlemail.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><meta http-equiv="Content-Type" content="text/html charset=us-ascii"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div>hey anna</div><div><br></div><div>i am sure that both the callbacks are called, i am stepping through them in lldb, and i have checked the graph to get the order, but i cannot work out why state cannot be propagated from checkBranchCondition callbacks. for the trivial test code below:</div><div><br></div><div><div style="margin: 0px; font-size: 14px; font-family: Monaco; "><span style="color: #bb2ca2">int</span> main(<span style="color: #bb2ca2">int</span> argc, <span style="color: #bb2ca2">char</span> *argv[])</div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">{</div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">    UILabel *l = [[UILabel alloc] init];    </div><div style="margin: 0px; font-size: 14px; font-family: Monaco; min-height: 19px; ">    <br class="webkit-block-placeholder"></div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">    <span style="color: #bb2ca2">if</span> ([l respondsToSelector:<span style="color: #bb2ca2">@selector</span>(adjustsLetterSpacingToFitWidth)]) {</div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">        l.adjustsLetterSpacingToFitWidth = <span style="color: #bb2ca2">YES</span>;</div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">    } <span style="color: #bb2ca2">else</span> {</div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">        l.adjustsLetterSpacingToFitWidth = <span style="color: #bb2ca2">NO</span>;</div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">    }</div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">    [l release];</div><div style="margin: 0px; font-size: 14px; font-family: Monaco; min-height: 19px; ">    <br class="webkit-block-placeholder"></div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">    <span style="color: rgb(187, 44, 162); ">return<span style=""> </span><span style="color: #272ad8">0</span><span style="">;</span></span></div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">}</div></div><div><br></div><div>if i add state before the IfStmt, say in a checkPostCall callback, i can read this state from any point further down the graph. if i add state in the checkBranchCondition callback however, it is visible for the duration of the callback, but is then being removed somewhere, and the only state visible after the branch is state set outside the IfStmt. i tried adding a breakpoint in the StateTrait::Remove method, but it did not seem to get called.</div><div><br></div><div>any suggestions?</div><br><div><div>On 13 Dec 2012, at 23:36, Anna Zaks <<a href="mailto:ganna@apple.com">ganna@apple.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><meta http-equiv="Content-Type" content="text/html charset=us-ascii"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; ">Your understanding is correct, the map should be propagated.<div>Are you sure that checkBranchCondition and checkPreCall are both called? Furthermore, are you sure one is called after the other along the same path? (You might find the ExplodedGraph viewing (p ViewGraph(0)) helpful for debugging this: <a href="http://clang-analyzer.llvm.org/checker_dev_manual.html#commands">http://clang-analyzer.llvm.org/checker_dev_manual.html#commands</a>.)</div><div><br></div><div>Also, if checking for the availability is done through a simple API call returning a bool (ex: 'is_available'), the following approach might work. Register for checkPostCall on that API and store the returned symbol. Later, when the deprecated API is used, check if the symbol (return value from the is_available call) evaluates to true. (This would be similar to how we check if fopen succeeded in the talk.)</div><div><br></div><div>Cheers,</div><div>Anna.</div><div><div><div>On Dec 13, 2012, at 8:11 AM, Richard <<a href="mailto:tarka.t.otter@googlemail.com">tarka.t.otter@googlemail.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><meta http-equiv="Content-Type" content="text/html charset=us-ascii"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; ">hi<div><br></div><div>another fairly basic question that i am having trouble with: i am trying to set some state in an analyzer checker in checkBranchCondition and then retrieve it in checkPreCall. the state is being set ok, but for some reason is never readable in successive checkPreCall callbacks, the state map always returns NULL. i thought that the ProgramState data map was supposed to propagate down the graph, is this not how it works? i can see the node that is added to the graph, so why can i not get the state that is set?</div><div><br></div><div>here is the code i am using, i followed some of the other checkers pretty closely, am i doing something stupid here?</div><div><br></div><div><div style="margin: 0px; font-size: 14px; font-family: Monaco; "><span style="color: #bb2ca2">void</span> UnavailableMethodChecker::checkBranchCondition(<span style="color: #bb2ca2">const</span> Stmt *Condition, CheckerContext &Ctx) <span style="color: #bb2ca2">const</span></div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">{</div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">    VersionTuple V = getAvailabilityForStmt(Condition, Ctx);</div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">    ProgramStateRef State = Ctx.getState();</div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">    SymbolRef Sym = State->getSVal(Condition, Ctx.getLocationContext()).getAsSymbol();</div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">    State = State->set<AvailabilityMap>(Sym, AvailabilityState(V));</div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">    Ctx.addTransition(State);</div><div style="margin: 0px; font-size: 14px; font-family: Monaco; ">}</div></div><div style="margin: 0px; font-size: 14px; font-family: Monaco; "><br></div><div style="margin: 0px; font-size: 14px; font-family: Monaco; "><div style="margin: 0px; "><span style="color: #bb2ca2">void</span> UnavailableMethodChecker::checkPreCall(<span style="color: #bb2ca2">const</span> CallEvent &Call, CheckerContext &Ctx) <span style="color: #bb2ca2">const</span></div><div style="margin: 0px; ">{</div><div style="margin: 0px; ">    ...</div><div style="margin: 0px; "><br></div><div style="margin: 0px; ">    ProgramStateRef State = Ctx.getState();</div><div style="margin: 0px; ">    AvailabilityMapTy M = State->get<AvailabilityMap>();</div><div style="margin: 0px; ">    // M is always NULL here</div><div style="margin: 0px; "><br></div><div style="margin: 0px; ">    <span style="color: #bb2ca2">for</span> (AvailabilityMapTy::iterator I = M.begin(), E = M.end(); I != E; ++I) {</div><div style="margin: 0px; ">        AvailabilityState A = I->second;</div><div style="margin: 0px; ">        <span style="color: #bb2ca2">if</span> (A.Version >= CallVersion) {</div><div style="margin: 0px; ">            <span style="color: #bb2ca2">return</span>;</div><div style="margin: 0px; ">        }</div><div style="margin: 0px; ">    }</div><div style="margin: 0px; "><br></div><div style="margin: 0px; ">    ...</div><div style="margin: 0px; ">}</div></div><div style="margin: 0px; font-size: 14px; font-family: Monaco; "><br></div><div style="margin: 0px; font-size: 14px; font-family: Monaco; "><div style="font-family: Helvetica; font-size: medium; ">thanks for the help.</div></div></div>_______________________________________________<br>cfe-dev mailing list<br><a href="mailto:cfe-dev@cs.uiuc.edu">cfe-dev@cs.uiuc.edu</a><br><a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev</a><br></blockquote></div><br></div></div></blockquote></div><br></div></blockquote></div><br></div></div></div></blockquote></div><br></body></html>