Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

CodeBlocks generator is deprecated #520

Open
christian-rauch opened this issue Nov 28, 2024 · 4 comments
Open

CodeBlocks generator is deprecated #520

christian-rauch opened this issue Nov 28, 2024 · 4 comments

Comments

@christian-rauch
Copy link
Member

The build step shows the warning:

CMake Deprecation Warning:
  Support for "Extra Generators" like

    CodeBlocks

  is deprecated and will be removed from a future version of CMake.  IDEs may
  use the cmake-file-api(7) to view CMake-generated project build trees.

And the CMake documentation for CodeBlocks mentions that this will be removed in future:

Deprecated since version 3.27: Support for Extra Generators is deprecated and will be removed from a future version of CMake. IDEs may use the cmake-file-api(7) to view CMake-generated project build trees.

The build tools set the CodeBlocks - Unix Makefiles generator explicitly in many places via --cmake-args -G \"CodeBlocks - Unix Makefiles\" and there is a dedicated function ROSUtils::parseCodeBlocksFile to parse them.

@Levi-Armstrong What is the reason for using one of the CodeBlocks generators? What information is extracted from the cbp? Is this only to create the content for ROSUtils::PackageBuildInfoMap? What is the reason that we cannot use the default generator here?

@Levi-Armstrong
Copy link
Member

This is what the old cmake plugin used for building the code model so did the same for the roster plugin, but not sure how that is currently being done in the plugin now.

@christian-rauch
Copy link
Member Author

christian-rauch commented Jan 4, 2025

I am trying to understand what ROSUtils::parseCodeBlocksFile does, as it seems that this is the only part that makes use of the generated .cbp files. As far as I can tell, it parses the .cbp files per package / CMake project and adds targets to ROSUtils::PackageBuildInfo / PackageTargetInfoList:

buildInfo.targets.append(targetInfo);

This in the end, seems to be used only in the ROSProject::buildCppCodeModel:

for (const ROSUtils::PackageTargetInfoPtr& targetInfo : buildInfo.targets)
{
ProjectExplorer::RawProjectPart rpp;
const QString defineArg
= Utils::transform(targetInfo->defines, [](const QString &s) -> QString {
QString result = QString::fromLatin1("#define ") + s;
int assignIndex = result.indexOf('=');
if (assignIndex != -1)
result[assignIndex] = ' ';
return result;
}).join('\n');
rpp.setProjectFileLocation(projectFilePath);
rpp.setBuildSystemTarget(buildInfo.parent.name + '|' + targetInfo->name + '|' + projectFilePath.toString());
rpp.setDisplayName(buildInfo.parent.name + '|' + targetInfo->name);
rpp.setQtVersion(activeQtVersion);
rpp.setMacros(ProjectExplorer::Macro::toMacros(defineArg.toUtf8()));
QSet<QString> toolChainIncludes;
const HeaderPaths header_paths = \
cxxToolChain->createBuiltInHeaderPathsRunner(env)\
(targetInfo->flags, sysRoot, QString());
for (const HeaderPath &hp : header_paths) {
toolChainIncludes.insert(hp.path);
}
for (const QString &i : targetInfo->includes) {
if (!toolChainIncludes.contains(i) && !package_includes.contains(i)) {
packageHeaderPaths.append(ProjectExplorer::HeaderPath(i, ProjectExplorer::HeaderPathType::System));
package_includes.append(i);
}
}
rpp.setFlagsForCxx({cxxToolChain, targetInfo->flags, sysRoot});
rpp.setFiles(targetInfo->source_files);
rpp.setHeaderPaths(packageHeaderPaths);
rpps.append(rpp);
}

to populate ProjectExplorer::RawProjectPart.

I initially assumed that this is for showing the source and header files in the "Projects View" of the workspace. But those are already shown before compiling and removing -G \"CodeBlocks - Unix Makefiles\" and ROSUtils::parseCodeBlocksFile also compile the workspace successfully.

@Levi-Armstrong For which feature in Qt Creator are these targets from the .cbp files used? Or in other words, if we would remove the generation and parsing of the .cbp files, what would break?

@Levi-Armstrong
Copy link
Member

This builds the code model which is used for code completion, refactoring, code following, etc.

@Levi-Armstrong
Copy link
Member

Levi-Armstrong commented Jan 4, 2025

This is how the old cmake project code worked so you might be able to leverage what they do now.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants