<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class="">Did a little post-patch (and post-fix) research. Looks like this is a difference between Py2 and Py3. It is well explained here:<div class=""><br class=""></div><div class=""><a href="http://bugs.python.org/issue5242" class="">http://bugs.python.org/issue5242</a></div><div class=""><br class=""></div><div class="">Apparently eval only grabs locals and globals, and in Py3 list comprehensions have their own function scopes, which isn’t how they worked in py2.</div><div class=""><br class=""></div><div class="">In general we should probably look for ways to remove eval calls from the test suite. They are widely discouraged in python code.</div><div class=""><br class=""></div><div class="">-Chris</div><div class=""><br class=""><div><blockquote type="cite" class=""><div class="">On Nov 8, 2016, at 10:05 AM, Chris Bieneman via lldb-commits <<a href="mailto:lldb-commits@lists.llvm.org" class="">lldb-commits@lists.llvm.org</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><meta http-equiv="Content-Type" content="text/html charset=us-ascii" class=""><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class="">I pushed an attempted fix in r286254.<div class=""><br class=""></div><div class="">I wonder if this is a difference between python 2.7 and 3. The comprehension should capture everything, as should the eval call. I wonder if one of those captures less in python 3 compared to python 2.7.</div><div class=""><br class=""></div><div class="">Hopefully my patch will resolve the issue for you.</div><div class=""><br class=""></div><div class="">-Chris</div><div class=""><br class=""><div class=""><blockquote type="cite" class=""><div class="">On Nov 8, 2016, at 7:37 AM, Zachary Turner <<a href="mailto:zturner@google.com" class="">zturner@google.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class=""><br class=""><br class=""><div class="gmail_quote"><div dir="ltr" class="">On Sun, Oct 30, 2016 at 9:57 PM Chris Bieneman via lldb-commits <<a href="mailto:lldb-commits@lists.llvm.org" class="">lldb-commits@lists.llvm.org</a>> wrote:<br class=""></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><br class="gmail_msg">
Modified: lldb/trunk/packages/Python/lldbsuite/test/lldbtest.py<br class="gmail_msg">
URL: <a href="http://llvm.org/viewvc/llvm-project/lldb/trunk/packages/Python/lldbsuite/test/lldbtest.py?rev=285542&r1=285541&r2=285542&view=diff" rel="noreferrer" class="gmail_msg" target="_blank">http://llvm.org/viewvc/llvm-project/lldb/trunk/packages/Python/lldbsuite/test/lldbtest.py?rev=285542&r1=285541&r2=285542&view=diff</a><br class="gmail_msg">
==============================================================================<br class="gmail_msg">
--- lldb/trunk/packages/Python/lldbsuite/test/lldbtest.py (original)<br class="gmail_msg">
+++ lldb/trunk/packages/Python/lldbsuite/test/lldbtest.py Sun Oct 30 23:48:19 2016<br class="gmail_msg">
@@ -1848,6 +1848,33 @@ class TestBase(Base):<br class="gmail_msg">
folder = os.path.dirname(folder)<br class="gmail_msg">
continue<br class="gmail_msg">
<br class="gmail_msg">
+ def generateSource(self, source):<br class="gmail_msg">
+ template = source + '.template'<br class="gmail_msg">
+ temp = os.path.join(os.getcwd(), template)<br class="gmail_msg">
+ with open(temp, 'r') as f:<br class="gmail_msg">
+ content = f.read()<br class="gmail_msg">
+<br class="gmail_msg">
+ public_api_dir = os.path.join(<br class="gmail_msg">
+ os.environ["LLDB_SRC"], "include", "lldb", "API")<br class="gmail_msg">
+<br class="gmail_msg">
+ # Look under the include/lldb/API directory and add #include statements<br class="gmail_msg">
+ # for all the SB API headers.<br class="gmail_msg">
+ public_headers = os.listdir(public_api_dir)<br class="gmail_msg">
+ # For different platforms, the include statement can vary.<br class="gmail_msg">
+ if self.hasDarwinFramework():<br class="gmail_msg">
+ include_stmt = "'#include <%s>' % os.path.join('LLDB', header)"<br class="gmail_msg">
+ else:<br class="gmail_msg">
+ include_stmt = "'#include <%s>' % os.path.join(public_api_dir, header)"<br class="gmail_msg">
+ list = [eval(include_stmt) for header in public_headers if (<br class="gmail_msg">
+ header.startswith("SB") and header.endswith(".h"))]<br class="gmail_msg">
+ includes = '\n'.join(list)<br class="gmail_msg">
+ new_content = content.replace('%include_SB_APIs%', includes)<br class="gmail_msg">
+ src = os.path.join(os.getcwd(), source)<br class="gmail_msg">
+ with open(src, 'w') as f:<br class="gmail_msg">
+ f.write(new_content)<br class="gmail_msg">
+<br class="gmail_msg">
+ self.addTearDownHook(lambda: os.remove(src))<br class="gmail_msg">
+<br class="gmail_msg"></blockquote><div class=""><br class=""></div><div class="">The non hasDarwinFramework codepath is broken here, and I don't believe it to be a Windows specific issue. I'm getting the following error in multiple tests.</div><div class=""><br class=""></div><div class="">Traceback (most recent call last):</div><div class=""> File "C:\src\llvm\tools\lldb\packages\Python\lldbsuite\test\functionalities\plugins\commands\TestPluginCommands.py", line 23, in setUp</div><div class=""> self.generateSource('plugin.cpp')</div><div class=""> File "C:\src\llvm\tools\lldb\packages\Python\lldbsuite\test\lldbtest.py", line 1868, in generateSource</div><div class=""> list = [eval(include_stmt) for header in public_headers if (</div><div class=""> File "C:\src\llvm\tools\lldb\packages\Python\lldbsuite\test\lldbtest.py", line 1869, in <listcomp></div><div class=""> header.startswith("SB") and header.endswith(".h"))]</div><div class=""> File "<string>", line 1, in <module></div><div class=""><b class="">NameError: name 'public_api_dir' is not defined</b></div><div class="">Config=i686-C:\src\llvmbuild\ninja_release\bin\clang.exe </div><div class=""><br class=""></div><div class="">I'm hypothesizing that the problem is that from inside of a list comprehension, your set of locals is not the same as outside of the list comprehension, and so the eval statement does not see the variable `public_api_dir`. Is there any way you could provide a fix for this?</div></div></div>
</div></blockquote></div><br class=""></div></div>_______________________________________________<br class="">lldb-commits mailing list<br class=""><a href="mailto:lldb-commits@lists.llvm.org" class="">lldb-commits@lists.llvm.org</a><br class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits<br class=""></div></blockquote></div><br class=""></div></body></html>