| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209 | 
							- /*=========================================================================
 
-   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 "cmQTWrapUICommand.h"
 
- // cmQTWrapUICommand
 
- bool cmQTWrapUICommand::InitialPass(std::vector<std::string> const& argsIn)
 
- {
 
-   if(argsIn.size() < 4 )
 
-     {
 
-     this->SetError("called with incorrect number of arguments");
 
-     return false;
 
-     }
 
-   std::vector<std::string> args;
 
-   m_Makefile->ExpandSourceListArguments(argsIn, args, 3);
 
-   // 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];
 
-   std::string sourceListValue;
 
-   std::string headerListValue;
 
-   const char *def = m_Makefile->GetDefinition(m_SourceList.c_str());  
 
-   if (def)
 
-     {
 
-     sourceListValue = def;
 
-     }
 
-  
 
-   // get the list of classes for this library
 
-   for(std::vector<std::string>::iterator j = (args.begin() + 3);
 
-       j != args.end(); ++j)
 
-     {   
 
-     cmSourceFile *curr = m_Makefile->GetSource(j->c_str());
 
-     
 
-     // if we should wrap the class
 
-     if (!curr || !curr->GetPropertyAsBool("WRAP_EXCLUDE"))
 
-       {
 
-       cmSourceFile header_file;
 
-       cmSourceFile source_file;
 
-       cmSourceFile moc_file;
 
-       std::string srcName = cmSystemTools::GetFilenameWithoutExtension(*j);
 
-       header_file.SetName(srcName.c_str(), 
 
-                           m_Makefile->GetCurrentOutputDirectory(),
 
-                           "h",false);
 
-       source_file.SetName(srcName.c_str(), 
 
-                           m_Makefile->GetCurrentOutputDirectory(),
 
-                           "cxx",false);
 
-       std::string moc_source_name("moc_");
 
-       moc_source_name = moc_source_name + srcName;
 
-       moc_file.SetName(moc_source_name.c_str(), 
 
-                        m_Makefile->GetCurrentOutputDirectory(),
 
-                        "cxx",false);
 
-       std::string origname;
 
-       if ( (*j)[0] == '/' || (*j)[1] == ':' )
 
-         {
 
-         origname = *j;
 
-         }
 
-       else
 
-         {
 
-         if ( curr && curr->GetPropertyAsBool("GENERATED") )
 
-           {
 
-           origname = std::string( m_Makefile->GetCurrentOutputDirectory() ) + "/" + *j;
 
-           }
 
-         else
 
-           {
 
-           origname = cdir + "/" + *j;
 
-           }
 
-         }
 
-       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_Makefile->AddSource(source_file);
 
-       m_Makefile->AddSource(moc_file);
 
-       
 
-       // create the list of headers 
 
-       if (headerListValue.size() > 0)
 
-         {
 
-         headerListValue += ";";
 
-         }
 
-       headerListValue += header_file.GetFullPath();
 
-       
 
-       // create the list of sources
 
-       if (sourceListValue.size() > 0)
 
-         {
 
-         sourceListValue += ";";
 
-         }
 
-       sourceListValue += source_file.GetFullPath();
 
-       sourceListValue += ";";
 
-       sourceListValue += moc_file.GetFullPath();
 
-       }
 
-     }
 
-   
 
-   m_Makefile->AddDefinition(m_SourceList.c_str(), sourceListValue.c_str());  
 
-   m_Makefile->AddDefinition(m_HeaderList.c_str(), headerListValue.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<std::string> depends;
 
-   const char* uic_exe = m_Makefile->GetRequiredDefinition("QT_UIC_EXECUTABLE");
 
-   const char* moc_exe = m_Makefile->GetRequiredDefinition("QT_MOC_EXECUTABLE");
 
-   // wrap all the .h files
 
-   depends.push_back(uic_exe);
 
-   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();
 
-     cmCustomCommandLine hCommand;
 
-     hCommand.push_back(uic_exe);
 
-     hCommand.push_back("-o");
 
-     hCommand.push_back(hres);
 
-     hCommand.push_back(m_WrapUserInterface[classNum]);
 
-     cmCustomCommandLines hCommandLines;
 
-     hCommandLines.push_back(hCommand);
 
-     cmCustomCommandLine cxxCommand;
 
-     cxxCommand.push_back(uic_exe);
 
-     cxxCommand.push_back("-impl");
 
-     cxxCommand.push_back(hres);
 
-     cxxCommand.push_back("-o");
 
-     cxxCommand.push_back(cxxres);
 
-     cxxCommand.push_back(m_WrapUserInterface[classNum]);
 
-     cmCustomCommandLines cxxCommandLines;
 
-     cxxCommandLines.push_back(cxxCommand);
 
-     cmCustomCommandLine mocCommand;
 
-     mocCommand.push_back(moc_exe);
 
-     mocCommand.push_back("-o");
 
-     mocCommand.push_back(mocres);
 
-     mocCommand.push_back(hres);
 
-     cmCustomCommandLines mocCommandLines;
 
-     mocCommandLines.push_back(mocCommand);
 
-     depends.clear();
 
-     depends.push_back(m_WrapUserInterface[classNum]);
 
-     const char* no_main_dependency = 0;
 
-     const char* no_comment = 0;
 
-     const char* no_working_dir = 0;
 
-     m_Makefile->AddCustomCommandToOutput(hres.c_str(),
 
-                                          depends,
 
-                                          no_main_dependency,
 
-                                          hCommandLines,
 
-                                          no_comment,
 
-                                          no_working_dir);
 
-     depends.push_back(hres);
 
-     m_Makefile->AddCustomCommandToOutput(cxxres.c_str(),
 
-                                          depends,
 
-                                          no_main_dependency,
 
-                                          cxxCommandLines,
 
-                                          no_comment,
 
-                                          no_working_dir);
 
-     depends.clear();
 
-     depends.push_back(hres);
 
-     m_Makefile->AddCustomCommandToOutput(mocres.c_str(),
 
-                                          depends,
 
-                                          no_main_dependency,
 
-                                          mocCommandLines,
 
-                                          no_comment,
 
-                                          no_working_dir);
 
-     }
 
- }
 
 
  |