/*========================================================================= Program: CMake - Cross-Platform Makefile Generator Module: $RCSfile$ Language: C++ Date: $Date$ Version: $Revision$ Copyright (c) 2002 Kitware, Inc., Insight Consortium. All rights reserved. See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details. This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the above copyright notices for more information. =========================================================================*/ #include "cmExportLibraryDependencies.h" #include "cmGlobalGenerator.h" #include "cmLocalGenerator.h" #include "cmGeneratedFileStream.h" #include "cmake.h" #include // auto_ptr // cmExecutableCommand bool cmExportLibraryDependenciesCommand::InitialPass(std::vector const& args) { // First argument is the name of the test // Second argument is the name of the executable to run (a target or external // program) // Remaining arguments are the arguments to pass to the executable if(args.size() < 1 ) { this->SetError("called with incorrect number of arguments"); return false; } // store the arguments for the final pass // also expand any CMake variables m_Args = args; return true; } void cmExportLibraryDependenciesCommand::FinalPass() { // don't do anything if local mode if(m_Makefile->GetLocal()) { return; } // Create a full path filename for output std::string fname = m_Args[0]; bool append = false; if(m_Args.size() > 1) { if(m_Args[1] == "APPEND") { append = true; } } // Use copy-if-different if not appending. std::ostream* foutPtr; std::auto_ptr foutNew; if(append) { foutPtr = new std::ofstream(fname.c_str(), std::ios::app); } else { std::auto_ptr ap( new cmGeneratedFileStream(fname.c_str(), true, true)); foutNew = ap; foutPtr = foutNew.get(); } std::ostream& fout = *foutPtr; if (!fout) { cmSystemTools::Error("Error Writing ", fname.c_str()); cmSystemTools::ReportLastSystemError(""); return; } cmake* cm = m_Makefile->GetCMakeInstance(); cmGlobalGenerator* global = cm->GetGlobalGenerator(); std::vector locals; global->GetLocalGenerators(locals); std::string libDepName; for(std::vector::iterator i = locals.begin(); i != locals.end(); ++i) { cmLocalGenerator* gen = *i; cmTargets &tgts = gen->GetMakefile()->GetTargets(); std::vector depends; const char *defType; for(cmTargets::const_iterator l = tgts.begin(); l != tgts.end(); ++l) { if ((l->second.GetType() != cmTarget::INSTALL_FILES) && (l->second.GetType() != cmTarget::INSTALL_PROGRAMS)) { libDepName = l->first; libDepName += "_LIB_DEPENDS"; const char* def = m_Makefile->GetDefinition(libDepName.c_str()); if(def) { fout << "SET(" << libDepName << " \"" << def << "\")\n"; // now for each dependency, check for link type cmSystemTools::ExpandListArgument(def, depends); for(std::vector::const_iterator d = depends.begin(); d != depends.end(); ++d) { libDepName = *d; libDepName += "_LINK_TYPE"; defType = m_Makefile->GetDefinition(libDepName.c_str()); libDepName = cmSystemTools::EscapeSpaces(libDepName.c_str()); if(defType) { fout << "SET(" << libDepName << " \"" << defType << "\")\n"; } } } } } } return; }