On Nov 15, 2010, at 9:50 AM, Bill Hoffman wrote:

On 11/14/2010 5:00 AM, Eric Noulard wrote:

There has been some discussion on the list about improvement
of the dependency scanner, this kind of idea may be examined there.
May be it's worth filing a feature request on this subject.


I have not followed this too closely. However, I thought might add a few things. To date CMake does NOT run the dependency program at CMake time, but rather at build time. In addition for the VS IDE it is NEVER run, as VS does its own dependency scanning. So, it would be a big change for CMake to do this at CMake time. My fear would be that it would be VERY slow. If this is to handle 5000 header files, I am guessing the VS IDE would choke on loading them anyway. For most C++ projects I working on there is a one to one mapping between C++ classes in .cxx and class definitions in .h files. So, you usually add the .h when you add the .cxx, your you could even have a macro that adds both automatically. However, a scanner that auto-adds the .h files seems a bit heavy handed, and would have serious performance issues.


-Bill

I have been casually following this thread and I understand the OPs hesitation when trying to add thousands of files into a CMake build system but what I think one needs to think about is that you are only going to add the files ONCE for the project. After that the CMake files are correctly created and any other additions are in the form of only a few files at a time during the course of normal development. What I end up doing in the cases where this happened to me was to create my CMake files and figure out what needs to added to a CMake file and the syntax that it needs to be added in. Then a one off shell script (or pick your favorite language) is created to look at the project, get a list of files needed, then "generate" a CMake file that can be incorporated into your project. After that is done the shell script is no longer needed because you have your CMake files and you will not need your dependency analysis tool because CMake and/or Visual Studio will have what it needs.

You can place the CMake code in files called "Sources.cmake" in each source directory then have your higher level CMake files simply "include" Sources.cmake for each project. Yes there is development time for this but the shell script does not have to be pretty or efficient. It is only going to be run once to generate the cmake files.
___________________________________________________________
Mike Jackson                      www.bluequartz.net
Principal Software Engineer       mike.jack...@bluequartz.net
BlueQuartz Software               Dayton, Ohio



_______________________________________________
Powered by www.kitware.com

Visit other Kitware open-source projects at 
http://www.kitware.com/opensource/opensource.html

Please keep messages on-topic and check the CMake FAQ at: 
http://www.cmake.org/Wiki/CMake_FAQ

Follow this link to subscribe/unsubscribe:
http://www.cmake.org/mailman/listinfo/cmake

Reply via email to