/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying file Copyright.txt or https://cmake.org/licensing for details. */ #include "cmQTWrapUICommand.h" #include #include "cmCustomCommandLines.h" #include "cmExecutionStatus.h" #include "cmMakefile.h" #include "cmRange.h" #include "cmSourceFile.h" #include "cmStringAlgorithms.h" #include "cmSystemTools.h" bool cmQTWrapUICommand(std::vector const& args, cmExecutionStatus& status) { if (args.size() < 4) { status.SetError("called with incorrect number of arguments"); return false; } cmMakefile& mf = status.GetMakefile(); // Get the uic and moc executables to run in the custom commands. std::string const& uic_exe = mf.GetRequiredDefinition("QT_UIC_EXECUTABLE"); std::string const& moc_exe = mf.GetRequiredDefinition("QT_MOC_EXECUTABLE"); // Get the variable holding the list of sources. std::string const& headerList = args[1]; std::string const& sourceList = args[2]; std::string headerListValue = mf.GetSafeDefinition(headerList); std::string sourceListValue = mf.GetSafeDefinition(sourceList); // Create rules for all sources listed. for (std::string const& arg : cmMakeRange(args).advance(3)) { cmSourceFile* curr = mf.GetSource(arg); // if we should wrap the class if (!(curr && curr->GetPropertyAsBool("WRAP_EXCLUDE"))) { // Compute the name of the files to generate. std::string srcName = cmSystemTools::GetFilenameWithoutLastExtension(arg); std::string hName = cmStrCat(mf.GetCurrentBinaryDirectory(), '/', srcName, ".h"); std::string cxxName = cmStrCat(mf.GetCurrentBinaryDirectory(), '/', srcName, ".cxx"); std::string mocName = cmStrCat(mf.GetCurrentBinaryDirectory(), "/moc_", srcName, ".cxx"); // Compute the name of the ui file from which to generate others. std::string uiName; if (cmSystemTools::FileIsFullPath(arg)) { uiName = arg; } else { if (curr && curr->GetIsGenerated()) { uiName = mf.GetCurrentBinaryDirectory(); } else { uiName = mf.GetCurrentSourceDirectory(); } uiName += "/"; uiName += arg; } // create the list of headers if (!headerListValue.empty()) { headerListValue += ";"; } headerListValue += hName; // create the list of sources if (!sourceListValue.empty()) { sourceListValue += ";"; } sourceListValue += cxxName; sourceListValue += ";"; sourceListValue += mocName; // set up .ui to .h and .cxx command cmCustomCommandLine hCommand; hCommand.push_back(uic_exe); hCommand.push_back("-o"); hCommand.push_back(hName); hCommand.push_back(uiName); cmCustomCommandLines hCommandLines; hCommandLines.push_back(std::move(hCommand)); cmCustomCommandLine cxxCommand; cxxCommand.push_back(uic_exe); cxxCommand.push_back("-impl"); cxxCommand.push_back(hName); cxxCommand.push_back("-o"); cxxCommand.push_back(cxxName); cxxCommand.push_back(uiName); cmCustomCommandLines cxxCommandLines; cxxCommandLines.push_back(std::move(cxxCommand)); cmCustomCommandLine mocCommand; mocCommand.push_back(moc_exe); mocCommand.push_back("-o"); mocCommand.push_back(mocName); mocCommand.push_back(hName); cmCustomCommandLines mocCommandLines; mocCommandLines.push_back(std::move(mocCommand)); std::vector depends; depends.push_back(uiName); std::string no_main_dependency; const char* no_comment = nullptr; const char* no_working_dir = nullptr; mf.AddCustomCommandToOutput(hName, depends, no_main_dependency, hCommandLines, no_comment, no_working_dir); depends.push_back(hName); mf.AddCustomCommandToOutput(cxxName, depends, no_main_dependency, cxxCommandLines, no_comment, no_working_dir); depends.clear(); depends.push_back(hName); mf.AddCustomCommandToOutput(mocName, depends, no_main_dependency, mocCommandLines, no_comment, no_working_dir); } } // Store the final list of source files and headers. mf.AddDefinition(sourceList, sourceListValue); mf.AddDefinition(headerList, headerListValue); return true; }