/* 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 #include "cmCustomCommand.h" #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 cmCustomCommandLines hCommandLines = cmMakeSingleCommandLine({ uic_exe, "-o", hName, uiName }); cmCustomCommandLines cxxCommandLines = cmMakeSingleCommandLine( { uic_exe, "-impl", hName, "-o", cxxName, uiName }); cmCustomCommandLines mocCommandLines = cmMakeSingleCommandLine({ moc_exe, "-o", mocName, hName }); std::vector depends; depends.push_back(uiName); auto cc = cm::make_unique(); cc->SetOutputs(hName); cc->SetDepends(depends); cc->SetCommandLines(hCommandLines); mf.AddCustomCommandToOutput(std::move(cc)); depends.push_back(hName); cc = cm::make_unique(); cc->SetOutputs(cxxName); cc->SetDepends(depends); cc->SetCommandLines(cxxCommandLines); mf.AddCustomCommandToOutput(std::move(cc)); depends.clear(); depends.push_back(hName); cc = cm::make_unique(); cc->SetOutputs(mocName); cc->SetDepends(depends); cc->SetCommandLines(mocCommandLines); mf.AddCustomCommandToOutput(std::move(cc)); } } // Store the final list of source files and headers. mf.AddDefinition(sourceList, sourceListValue); mf.AddDefinition(headerList, headerListValue); return true; }