<div dir="ltr">Hi Georg (and others interested in Clang+JIT),<div><br></div><div>We just implemented this (Clang+JIT) in our open-source project CasADi (<a href="http://casadi.org">http://casadi.org</a>). Feel free to have a look and/or reuse components.</div><div><br></div><div>We used a plugin-design for using Clang, which is a bit different from the examples we could find for using LLVM/Clang. We added a generic "Compiler" class and made Clang/JIT a plugin for this Compiler class. Here is the implementation of the plugin: <a href="https://github.com/casadi/casadi/blob/develop/casadi/interfaces/clang/clang_compiler.cpp">https://github.com/casadi/casadi/blob/develop/casadi/interfaces/clang/clang_compiler.cpp</a>. We also made a second plugin (only for Linux/Mac) which simply calls the system compiler using shell commands. Mainly for benchmarking and when Clang/JIT isn't available: <a href="https://github.com/casadi/casadi/blob/develop/casadi/solvers/shell_compiler.cpp">https://github.com/casadi/casadi/blob/develop/casadi/solvers/shell_compiler.cpp</a>.<br></div><div><br></div><div>The trickiest was to set up the build system (we use CMake) and in particular redistribute the C and C++ standard libraries needed to compile any useful C/C++ code. And do it in a way that makes the compiled code portable and not relying on e.g. setting environmental variables.</div><div><br></div><div>This all works now, also on Windows, although it is not yet completely mature (especially when trying to JIT compile C++ code). The solution used in the LLVM examples was to use the arguments passed to "main", e.g. to locate the "resource", but this didn't work for us since or tool is itself a library and we don't have a "main". So the design we chose instead was to place the compilation resources (including C/C++ standard library headers) in a relative location to the plugin (which is a shared library) since the path of the plugin can be retrieved at runtime by "dladdr" in Linux/Mac and GetModuleHandleEx+GetModuleFileName on Windows.</div><div><br></div><div>Best regards,</div><div>Joel</div><div><br></div><div class="gmail_extra"><br><div class="gmail_quote">2015-10-03 20:37 GMT+02:00 David Blaikie via cfe-users <span dir="ltr"><<a href="mailto:cfe-users@lists.llvm.org" target="_blank">cfe-users@lists.llvm.org</a>></span>:<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"><div><div class="h5">On Sat, Oct 3, 2015 at 12:30 AM, Georg Bartels via cfe-users <span dir="ltr"><<a href="mailto:cfe-users@lists.llvm.org" target="_blank">cfe-users@lists.llvm.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Dear Clang Users,<br>
<br>
I have a particular programming problem, and several discussion forums suggested Clang as a possible solution. Being totally new to Clang and its community, is this the right place to ask questions about how to use Clang for a particular programming task? If not, where should I turn to?<br>
<br>
In case this is the right forum for such questions, I continue describing my problem. Basically, I want to compile a class which inherits from a virtual interface class at runtime of my program. The program should then create an instance of this new class and use it through its interface.<br>
<br>
Let me quickly sketch an example. The static version of my program would look like this:<br>
<br>
class Base<br>
{<br>
  public:<br>
    virtual int calc() const;<br>
};<br>
<br>
class Derived: public Base<br>
{<br>
  public:<br>
    virtual int calc() const<br>
    {<br>
      return 42;<br>
    }<br>
};<br>
<br>
int main()<br>
{<br>
    std::cout << Derived().calc() << std::endl;<br>
    return 0;<br>
}<br>
<br>
<br>
The dynamic version (with two fuzzy lines of code) shall look like this:<br>
<br>
class Base<br>
{<br>
  public:<br>
    virtual void calc() const;<br>
};<br>
<br>
int main()<br>
{<br>
  std::string code = read_derived_code();<br>
<br>
  // two fuzzy lines for which I am looking for a solution<br>
  SomeCompiledObjectClass o = compile(code);<br>
  Base* d = SomeFactoryClass(o).createInstance();<br>
<br>
  std::cout << d->calc() << std::endl;<br>
  return 0;<br>
}<br>
<br>
Is Clang the right tool for solving my two fuzzy lines of code? If yes, which class should have a look at? If not, do you maybe know about another library/compile which can achieve this task?<br></blockquote><div><br></div></div></div><div>This migth be the sort of thing that would escalate to cfe-dev and/or llvm-dev.<br><br>What you're looking to do is JIT (Just In Time) compile some code. That involves using clang to turn the source code into LLVM IR and then LLVM to make machine code from that, put it in memory, make it executable, and call some part of it.<br><br>Your two fuzzy lines of code would look slightly different (chances are what you'd do is generate source code that included a private function that return an instance, then you would JIT compile that function, indirectly code generating anything in the class that was needed, etc).<br><br>I'm not sure where the best examples of the Clang half of this problem are. But for the second have, LLVM has the Kaleidoscope tutorials (especially the recently added ORC examples) that show how to use LLVM as a JIT compiler. You shuold be able to wrap up all these APIs into a fairly simple API for your one specific use case.<br><br>I think /maybe/ out there is an existing C++ rapid development environment using Clang (essentially a C++ interpreter/interactive command prompt like Python) that you might be able to grab the basics of "feed code to compiler, get IR" from.<br><br>- David</div><span class=""><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
Thanks a lot for your help!<br>
<br>
Cheers,<br>
Georg.<br>
<br>
_______________________________________________<br>
cfe-users mailing list<br>
<a href="mailto:cfe-users@lists.llvm.org" target="_blank">cfe-users@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-users" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-users</a><br>
</blockquote></span></div><br></div></div>
<br>_______________________________________________<br>
cfe-users mailing list<br>
<a href="mailto:cfe-users@lists.llvm.org">cfe-users@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-users" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-users</a><br>
<br></blockquote></div><br><br clear="all"><div><br></div>-- <br><div class="gmail_signature"><div dir="ltr"><div><div dir="ltr"><div><div dir="ltr"><div>-- <br>Joel Andersson, PhD<br>Ptge. Busquets 11-13, atico 3<br>E-08940 Cornella de Llobregat (Barcelona), Spain<br>Home: +34-93-6034011<br>Mobile: <span style="font-size:12.8000001907349px">+34-63-4408800 (in</span><span style="font-size:12.8000001907349px"> Sweden also </span><span style="font-size:12.8000001907349px">+46-707-360512)</span></div></div></div></div></div></div></div>
</div></div>