<div dir="ltr"><br><br><div class="gmail_quote"><div dir="ltr">On Fri, Jul 24, 2015 at 10:42 AM Greg Clayton <<a href="mailto:clayborg@gmail.com">clayborg@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><br>
> On Jul 24, 2015, at 10:19 AM, Zachary Turner <<a href="mailto:zturner@google.com" target="_blank">zturner@google.com</a>> wrote:<br>
><br>
> zturner added a comment.<br>
><br>
> Hi Greg,<br>
><br>
> I wonder if this has something to do with the fact that the SWIG generation shell script is one of the build phases of LLDB.Framework as you mentioned once before here: <a href="http://lists.cs.uiuc.edu/pipermail/lldb-dev/2015-February/006685.html" rel="noreferrer" target="_blank">http://lists.cs.uiuc.edu/pipermail/lldb-dev/2015-February/006685.html</a>. Is it possible to change this so that the SWIG wrappers are built along with the regular source? It seems to me like LLDBWrapPython.cpp should be compiled into Plugins/ScriptInterpreter/Python<br>
<br>
The SWIG stuff needs to be built in your ScriptInterpreterPython static library, not with LLDB.framework. The bindings just use the public API so these swig bindings should be moved to where you are compiling the ScriptInterpreterPython.<br>
<br>
><br>
> Or, alternatively, manually fiddle with the linker line as a last resort?<br>
<br>
Hopefully we don't have to do this.<br>
<br>
> This might be a better approach for now, because moving the location of LLDBWrapPython.cpp might require changes to the shells cript and python script. Which we can do, but it seems better as a followup CL just so that we can do things in small pieces in order to keep moving forward.<br>
<br>
No, this needs to be done with this CL since you are extracting all python stuff into a plug-in.<br>
><br>
> I'm still a little unclear why the problem happens though. If LLDBWrapPython.cpp is being linked into liblldb, and ScriptInterpreterPython is being built as a static library, then where are the linker errors coming from? They're declared extern in the Python plugin, which shouldn't care that they're not visible at link time, because liblldb contains all the definitions. What part am I missing?<br>
<br>
Not sure. I haven't had time to get tot this yet, but the SWIG stuff should be being built into the static library for ScriptInterpreterPython.<br></blockquote><div> </div><div>I can make this work for the CMake build, but I think I will need help getting this working with the Xcode build since it requires changing build phases and is not just adding / moving around source files.</div><div><br></div><div>Is there anyone there that has some cycles to help out with this? I've had this CL in the pipeline for close to 3 weeks (not including the time I was away on vacation), so I would like to see it closed out.</div></div></div>