<html><head><meta http-equiv="Content-Type" content="text/html charset=iso-8859-1"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div>As a counter example (which perhaps could be improved on), we are currently putting our generated cmake files in the build tree. The reason for this to allow git post-checkout and post-rewrite hooks to updating the build files if needed. We have python script that rewrites the files if they would be different, but otherwise doesn't touch them. It is run by cmake as well as by git. </div><div><br></div><br><div><div>On Jun 13, 2013, at 5:41 AM, William McKenzie <<a href="mailto:wsmckenz@cartewright.com">wsmckenz@cartewright.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div dir="ltr">It's nice when everyone agrees.<div><br></div><div style="">thanks</div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Wed, Jun 12, 2013 at 2:49 PM, Matthew Woehlke <span dir="ltr"><<a href="mailto:matthew.woehlke@kitware.com" target="_blank">matthew.woehlke@kitware.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">On 2013-06-12 15:30, William McKenzie wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Just wondering what the common convention is here. If I have some generated<br>
c/c++ source files, say from gSoap or Lex/Yacc (and my build rules take<br>
care of the generation), is the convention to generate these into the build<br>
folder, or the original source folder? I understand I could use either, and<br>
in some ways it makes more sense for them to go into the build folder. But<br>
it also feels a little weird that all of my c files are not in the same<br>
place if I do that.<br>
</blockquote>
<br>
Build directory. Configuring and building should never, ever alter the source directory in any way. (It should be possible, even, to configure and build successfully if the source directory is mounted read-only.)<br>
<br>
Basically, generated artifacts of any kind should be kept separate from non-generated, for several reasons:<br>
<br>
- Makes version control much easier.<br>
<br>
- Can get back to 'pristine' state simply by removing the build directory.<br>
<br>
- Can have multiple builds with different configurations (or even compilers) sharing a single source directory.<br>
<br>
- Can ensure integrity of the source tree by making it immutable (see above ;-)... not that I tend to do this, but it's still good to have the ability if needed).<br>
<br>
-- <br>
Matthew<br>
<br>
--<br>
<br>
Powered by <a href="http://www.kitware.com/" target="_blank">www.kitware.com</a><br>
<br>
Visit other Kitware open-source projects at <a href="http://www.kitware.com/opensource/opensource.html" target="_blank">http://www.kitware.com/<u></u>opensource/opensource.html</a><br>
<br>
Please keep messages on-topic and check the CMake FAQ at: <a href="http://www.cmake.org/Wiki/CMake_FAQ" target="_blank">http://www.cmake.org/Wiki/<u></u>CMake_FAQ</a><br>
<br>
Follow this link to subscribe/unsubscribe:<br>
<a href="http://www.cmake.org/mailman/listinfo/cmake" target="_blank">http://www.cmake.org/mailman/<u></u>listinfo/cmake</a><br>
</blockquote></div><br></div>
--<br><br>Powered by <a href="http://www.kitware.com">www.kitware.com</a><br><br>Visit other Kitware open-source projects at <a href="http://www.kitware.com/opensource/opensource.html">http://www.kitware.com/opensource/opensource.html</a><br><br>Please keep messages on-topic and check the CMake FAQ at: <a href="http://www.cmake.org/Wiki/CMake_FAQ">http://www.cmake.org/Wiki/CMake_FAQ</a><br><br>Follow this link to subscribe/unsubscribe:<br><a href="http://www.cmake.org/mailman/listinfo/cmake">http://www.cmake.org/mailman/listinfo/cmake</a></blockquote></div><br></body></html>