<br><br><div class="gmail_quote">On Tue, Jun 5, 2012 at 8:34 AM, Sean Silva <span dir="ltr"><<a href="mailto:silvas@purdue.edu" target="_blank">silvas@purdue.edu</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
The two attached patches change the TableGen backend API (of LLVM and clang respectively). They are git diff'd against current ToT. They must both be applied "atomically" because the Clang changes depend on LLVM header changes (is there a way to avoid this problem without leaving in the old code in with a "don't touch, will be removed soon" comment?).<div>
<br></div><div><br></div><div>### Description of the changes</div><div><br></div><div>These patches change the TableGen backend API as described in <<a href="http://lists.cs.uiuc.edu/pipermail/llvmdev/2012-May/049530.html" target="_blank">http://lists.cs.uiuc.edu/pipermail/llvmdev/2012-May/049530.html</a>> (I'm working on documentation component, but I'm planning on having that be a separate patch, submitted after the one that actually changes the API is committed). The new backend API is just:</div>
<div><br></div><div>EmitFoo(RecordKeeper &, raw_ostream & /*, anything else you need */);</div><div><br></div><div>which is simpler and more flexible than the current one. Another benefit is that backends can be in their own .cpp file, without needing a pointless stub header; additionally, everything inside the .cpp file can be put in an anonymous namespace except EmitFoo.</div>
<div><br></div><div><div>Although the patches are >2K lines each, it is mostly mechanical refactoring churn. Generally, the following changes were made:</div><div>* remove header files whose only use was to declare classes inheriting from TableGenBackend. if the class was literally just a stub around the FooEmitter::run method, I just made the `run` method become an `EmitFoo` function and deleted the stub class. if there was a more substantial class that holds state for the emission process, I brought the declaration down into the .cpp file and then made EmitFoo just be a stub calling FooEmitter(Records).run(OS).</div>
</div><div>* centralize the declaration of all of the TableGen backends into {llvm,clang}/utils/TableGen/TableGenBackends.h</div><div>* clean out include/llvm/TableGen/TableGenBackend.h. remove class TableGenBackend, with accompanying changes to TableGenBackend.cpp. EmitSourceFileHeader was preserved, but made a freestanding function with name changed to start with a lowercase letter.</div>
<div>* made appropriate changes to {llvm,clang} TableGen.cpp files to use the new API.</div><div>* within the backends, I wrapped stuff in an anonymous namespace as I saw opportunities to do so that the new API afforded and I was "in the area".</div>
<div><br></div><div><div>I built the "check" and "clang-test" targets with these changes applied and they both pass (are there other test targets i should run?).</div><div><br></div></div><div><br></div>
<div>### Specific feedback requests</div><div><br></div><div>I'm in the air about where to declare the backends namespacewise. In the LLVM TableGen (which I converted first), I decided to put all the backends inside a namespace "tblgen_backends" inside namespace llvm, which turns out to be a pain in the ass, since you have to write</div>
<div><br></div><div>namespace llvm {</div><div>namespace tblgen_backends{</div><div>EmitFoo(RecordKeeper &RK, raw_ostream &OS) {</div><div> /* emit stuff */</div><div>}</div><div>} // End llvm namespace</div><div>
} // End tblgen_backends namespace</div><div><br></div><div>inside the backend's .cpp file. In the clang TableGen, I decided to go leaner and just have the backends in namespace "tblgen_backends". I'm considering also just having the backends be in the global namespace, since it doesn't really matter that much and is more convenient to write.</div>
<div><br></div><div>Another area that I have questions is whether the filenames should be changed, since they are all called FooEmitter.cpp, but sometimes a class FooEmitter doesn't exist anymore. My general feeling is that it doesn't really matter, so best to just leave them. This is easily changed in a future patch if it is deemed desirable.</div>
<div><br></div><div>These patches are hopefully pretty much ready to go into trunk besides the issues I just mentioned. Some general nitpicking would also be appreciated.</div><span class="HOEnZb"><font color="#888888"><div>
<br></div><div>--Sean Silva</div>
</font></span><br>_______________________________________________<br>
cfe-commits mailing list<br>
<a href="mailto:cfe-commits@cs.uiuc.edu">cfe-commits@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits</a><br>
<br></blockquote></div><br>Regarding the namespace issue perhaps that a middle ground approach would work ?<br><br>I believe that:<br><br> namespace llvm { namespace tblgen {<br><br> }} // namespace tblgen, llvm<br>
<br>is not much more typing than just "namespace llvm" and still nicely isolate the functions so they don't accidentally conflict with other stuff.<br><br>On the other hand.. since they are likely to live in entirely separate binaries anyway, perhaps just "namespace llvm" would be fine (it's either that or "using namespace::llvm;" as it will use lots of llvm classes and functions anyway; so I'd just rather nest into the namespace).<br>
<br>-- Matthieu<br>