<html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"></head><body dir="auto"><div><br><br>Sent from my iPhone</div><div><br>On May 16, 2015, at 8:15 AM, Manuel Klimek <<a href="mailto:klimek@google.com">klimek@google.com</a>> wrote:<br><br></div><blockquote type="cite"><div><div dir="ltr"><div class="gmail_quote">On Thu, May 14, 2015 at 3:46 PM Ben Laurie <<a href="mailto:benl@google.com">benl@google.com</a>> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On 14 May 2015 at 14:43, Manuel Klimek <span dir="ltr"><<a href="mailto:klimek@google.com" target="_blank">klimek@google.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><p dir="ltr">Ah, wrong parent map :) the ast context has a function to retrieve parents that supports crossing into decls. I can look up the details when I'm back at a real computer ...</p></blockquote><div><br></div></div></div></div><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div>Ah! Thanks.</div></div></div></div></blockquote><div><br></div><div>You can get the ASTContext from the CheckerContext, and then call getParents() on it.</div><div><br></div></div></div></div></blockquote>CheckerContext is the way to go.<br><blockquote type="cite"><div><div dir="ltr"><div class="gmail_quote"><div>Also cc'ing Anna and Jordan, who might have better ideas how to capture context info from a static analyzer check.</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<p dir="ltr">BTW do you need the symbolic execution engine for what you want to check? If the ast is enough consider using a clang-tidy check, those are a bit simpler to write with the ast matchers.</p></blockquote><div><br></div></div></div></div><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div>I do need symbolic execution.</div></div></div></div><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><div>
<br><div class="gmail_quote">On Thu, May 14, 2015, 1:20 PM Ben Laurie <<a href="mailto:benl@google.com" target="_blank">benl@google.com</a>> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Manuel asked me for more info.<div><br></div><div>Given a checker like this:</div><div><br></div><div><div>class MyChecker : </div><div> public Checker< check::PreStmt<ReturnStmt> > {</div></div><div>public:</div><div><div> void checkPreStmt(const ReturnStmt *RS, CheckerContext &C) const;</div></div><div>};</div><div><br></div><div><div>void MyChecker::checkPreStmt(const ReturnStmt *RS,</div><div><span style="white-space:pre-wrap"> </span> CheckerContext &C) const {</div><div> RS->dump();</div><div><br></div><div> const Stmt *s = RS;</div><div><br></div><div> ParentMap &PM = C.getLocationContext()->getParentMap();</div><div><br></div><div> while ((s = PM.getParent(s)) != NULL) {</div><div> std::cerr << "------\n";</div><div> s->dump();</div><div> }</div><div>}</div></div><div><br></div><div>And this as input:</div><div><br></div><div><div>int f(void)</div><div> {</div><div> return 1;</div><div> }</div></div><div><br></div><div><br></div><div>This is the output:</div><div><br></div><div><div>ReturnStmt 0x807cbdda8</div><div>`-IntegerLiteral 0x807cbdd88 'int' 1</div><div>------</div><div>CompoundStmt 0x807cbddc0</div><div>`-ReturnStmt 0x807cbdda8</div><div> `-IntegerLiteral 0x807cbdd88 'int' 1</div></div><div><br></div><div>As you can see, it terminates at the function body, not the declaration.</div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On 14 May 2015 at 07:03, Ben Laurie <span dir="ltr"><<a href="mailto:benl@google.com" target="_blank">benl@google.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote"><span>On 11 May 2015 at 11:20, Manuel Klimek <span dir="ltr"><<a href="mailto:klimek@google.com" target="_blank">klimek@google.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_quote"><span>On Sun, May 10, 2015 at 11:54 PM Nikola Smiljanic <<a href="mailto:popizdeh@gmail.com" target="_blank">popizdeh@gmail.com</a>> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">I think you'll need to use ParentMap from ASTContext.</div></blockquote><div><br></div></span><div>Note that the parent-map is lazy-built (that is, the first time you get a parent, you build the parent-map for the whole TU), and thus has a pretty high cost. Usually we first try to get away with not using it.</div><div><br></div><div>Can you give a bit more context on what you're trying to do?</div></div></div></blockquote><div><br></div></span><div>Sorry for delay ... I am trying to label functions to have certain checks done on their return values if an attribute is set on the function.</div><div><br></div><div>ParentMap appears not to work for this case (it stops finding parents once you have the function body).</div><div><br></div><div>Currently, the only way I could make this work was to construct a map of function bodies that have the attribute set in an AST observer, and then using ParentMap to get back to the body, which is looked up in the map.</div><div><br></div><div>Doesn't seem optimal!</div><span><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_quote"><span><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="gmail_extra"><br><div class="gmail_quote">On Mon, May 11, 2015 at 4:18 AM, Ben Laurie <span dir="ltr"><<a href="mailto:benl@google.com" target="_blank">benl@google.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">If I have a checker for check::PreStmt<ReturnStmt>, how do I get from<br>
the ReturnStmt to the function it is part of (I want to check<br>
attributes on that function)?<br>
_______________________________________________<br>
cfe-dev mailing list<br>
<a href="mailto:cfe-dev@cs.uiuc.edu" target="_blank">cfe-dev@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev</a><br>
</blockquote></div><br></div>
_______________________________________________<br>
cfe-dev mailing list<br>
<a href="mailto:cfe-dev@cs.uiuc.edu" target="_blank">cfe-dev@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev</a><br>
</blockquote></span></div></div>
</blockquote></span></div><br></div></div>
</blockquote></div><br></div>
</blockquote></div>
</div></div></blockquote></div></div></div></blockquote></div></div>
</div></blockquote></body></html>