/*========================================================================= Program: Insight Segmentation & Registration Toolkit Module: $RCSfile$ Language: C++ Date: $Date$ Version: $Revision$ Copyright (c) 2002 Insight Consortium. All rights reserved. See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm 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 "cmQTWrapUICommand.h" // cmQTWrapUICommand bool cmQTWrapUICommand::InitialPass(std::vector const& args) { if(args.size() < 4 ) { this->SetError("called with incorrect number of arguments"); return false; } // Now check and see if the value has been stored in the cache // already, if so use that value and don't look for the program const char* QT_WRAP_UI_value = m_Makefile->GetDefinition("QT_WRAP_UI"); if (QT_WRAP_UI_value==0) { this->SetError("called with QT_WRAP_UI undefined"); return false; } if(cmSystemTools::IsOff(QT_WRAP_UI_value)) { this->SetError("called with QT_WRAP_UI off : "); return false; } // what is the current source dir std::string cdir = m_Makefile->GetCurrentDirectory(); // keep the library name m_LibraryName = args[0]; m_HeaderList = args[1]; m_SourceList = args[2]; // get the list of classes for this library cmMakefile::SourceMap &Classes = m_Makefile->GetSources(); for(std::vector::const_iterator j = (args.begin() + 3); j != args.end(); ++j) { cmMakefile::SourceMap::iterator l = Classes.find(*j); if (l == Classes.end()) { this->SetError("bad source list passed to QTWrapUICommand"); return false; } for(std::vector::iterator i = l->second.begin(); i != l->second.end(); i++) { cmSourceFile &curr = *i; // if we should wrap the class if (!curr.GetWrapExclude()) { cmSourceFile header_file; cmSourceFile source_file; cmSourceFile moc_file; header_file.SetName(curr.GetSourceName().c_str(), m_Makefile->GetCurrentOutputDirectory(), "h",false); source_file.SetName(curr.GetSourceName().c_str(), m_Makefile->GetCurrentOutputDirectory(), "cxx",false); std::string moc_source_name("moc_"); moc_source_name = moc_source_name + curr.GetSourceName().c_str(); moc_file.SetName(moc_source_name.c_str(), m_Makefile->GetCurrentOutputDirectory(), "cxx",false); std::string origname = cdir + "/" + curr.GetSourceName() + "." + curr.GetSourceExtension(); std::string hname = header_file.GetFullPath(); m_WrapUserInterface.push_back(origname); // add starting depends moc_file.GetDepends().push_back(hname); source_file.GetDepends().push_back(hname); source_file.GetDepends().push_back(origname); header_file.GetDepends().push_back(origname); m_WrapHeadersClasses.push_back(header_file); m_WrapSourcesClasses.push_back(source_file); m_WrapMocClasses.push_back(moc_file); m_Makefile->AddSource(header_file, m_HeaderList.c_str()); m_Makefile->AddSource(source_file, m_SourceList.c_str()); m_Makefile->AddSource(moc_file, m_SourceList.c_str()); } } } return true; } void cmQTWrapUICommand::FinalPass() { // first we add the rules for all the .ui to .h and .cxx files size_t lastHeadersClass = m_WrapHeadersClasses.size(); std::vector depends; std::string uic_exe = "${QT_UIC_EXE}"; std::string moc_exe = "${QT_MOC_EXE}"; // wrap all the .h files depends.push_back(uic_exe); const char * GENERATED_QT_FILES_value= m_Makefile->GetDefinition("GENERATED_QT_FILES"); std::string ui_list(""); if (GENERATED_QT_FILES_value!=0) { ui_list=ui_list+GENERATED_QT_FILES_value; } for(size_t classNum = 0; classNum < lastHeadersClass; classNum++) { // set up .ui to .h and .cxx command std::string hres = m_Makefile->GetCurrentOutputDirectory(); hres += "/"; hres += m_WrapHeadersClasses[classNum].GetSourceName() + "." + m_WrapHeadersClasses[classNum].GetSourceExtension(); std::string cxxres = m_Makefile->GetCurrentOutputDirectory(); cxxres += "/"; cxxres += m_WrapSourcesClasses[classNum].GetSourceName() + "." + m_WrapSourcesClasses[classNum].GetSourceExtension(); std::string mocres = m_Makefile->GetCurrentOutputDirectory(); mocres += "/"; mocres += m_WrapMocClasses[classNum].GetSourceName() + "." + m_WrapMocClasses[classNum].GetSourceExtension(); ui_list = ui_list + " " + hres + " " + cxxres + " " + mocres; std::vector hargs; hargs.push_back("-o"); hargs.push_back(hres); hargs.push_back(m_WrapUserInterface[classNum]); std::vector cxxargs; cxxargs.push_back("-impl"); cxxargs.push_back(hres); cxxargs.push_back("-o"); cxxargs.push_back(cxxres); cxxargs.push_back(m_WrapUserInterface[classNum]); std::vector mocargs; mocargs.push_back("-o"); mocargs.push_back(mocres); mocargs.push_back(hres); m_Makefile->AddCustomCommand(m_WrapUserInterface[classNum].c_str(), uic_exe.c_str(), hargs, depends, hres.c_str(), m_LibraryName.c_str()); depends.push_back(hres); m_Makefile->AddCustomCommand(m_WrapUserInterface[classNum].c_str(), uic_exe.c_str(), cxxargs, depends, cxxres.c_str(), m_LibraryName.c_str()); depends.clear(); depends.push_back(moc_exe); m_Makefile->AddCustomCommand(hres.c_str(), moc_exe.c_str(), mocargs, depends, mocres.c_str(), m_LibraryName.c_str()); } m_Makefile->AddDefinition("GENERATED_QT_FILES",ui_list.c_str()); }