From 21d634c525709fdeeb60d8542cdb323fa950fa58 Mon Sep 17 00:00:00 2001 From: Brad King Date: Tue, 17 Jul 2001 15:41:49 -0400 Subject: [PATCH] ENH: Added generation of dependencies on the CMake-generated input to gcc-xml so that re-generation of wrappers will occur if a header changes. --- Source/cmCableWrapTclCommand.cxx | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) diff --git a/Source/cmCableWrapTclCommand.cxx b/Source/cmCableWrapTclCommand.cxx index cf6533166..f9e7f055b 100644 --- a/Source/cmCableWrapTclCommand.cxx +++ b/Source/cmCableWrapTclCommand.cxx @@ -42,7 +42,7 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. #include "cmCacheManager.h" #include "cmTarget.h" #include "cmGeneratedFileStream.h" - +#include "cmMakeDepend.h" cmCableWrapTclCommand::cmCableWrapTclCommand(): m_CableClassSet(NULL) @@ -256,6 +256,26 @@ void cmCableWrapTclCommand::GenerateCableClassFiles(const char* name, std::string command = this->GetGccXmlFromCache(); std::vector depends; depends.push_back(command); + + // Get the dependencies of the file. + cmMakeDepend md; + md.SetMakefile(m_Makefile); + const cmDependInformation* dependInfo = + md.FindDependencies(classCxxName.c_str()); + if(dependInfo) + { + for(cmDependInformation::DependencySet::const_iterator d = + dependInfo->m_DependencySet.begin(); + d != dependInfo->m_DependencySet.end(); ++d) + { + // Make sure the full path is given. If not, the dependency was + // not found. + if((*d)->m_FullPath != "") + { + depends.push_back((*d)->m_FullPath); + } + } + } std::string commandArgs = this->GetGccXmlFlagsFromCache(); commandArgs += " ";