cmGlobalGenerator: Initialize generator targets on construction (#15729)
The Ninja generator and Visual Studio generators are special-cased for the
QtAutogen feature. In order to reduce the number of custom targets, the Visual
Studio generators prefer to create custom commands instead, and in order to
create appropriate Ninja files, generated rcc files are listed as byproducts.
This requires the use of the GetConfigCommonSourceFiles API of the
cmGeneratorTarget for those generators when initializing the autogen target.
The initializer method is called from Compute() after the cmGeneratorTarget
objects are created, however the initialization of the object directory occurs
later in the InitGeneratorTargets method. That means that the resulting object
locations are computed incorrectly and cached before the object directory is
determined, so the generated buildsystem can not find the object files.
The initialization of the object directory was split from the creation of
cmGeneratorTarget instances in commit 0e0258c8
(cmGlobalGenerator: Split
creation of generator object from initialization., 2015-07-25). The motivation
for the split was to do only what is essential to do early in cases where
cmGeneratorTargets need to be created at configure-time. That is required for
the purpose of implementing policies CMP0024 and CMP0026, and for
try_compile(LINK_LIBRARIES). However, the split was not really necessary.
Compute the object directory in the cmGeneratorTarget constructor instead.
The QtAutogen unit test already tests the use of TARGET_OBJECTS with AUTOMOC,
and that test already passes on Ninja. The reason it already passes is that
the QtAutogen target also uses the AUTORCC feature, and specifies several qrc
files in its SOURCES. Later in the Compute algorithm (after the
InitGeneratorTargets call), the rcc files are determined and target->AddSource
is called. The AddSource call clears the previously mentioned cache of source
files, causing it to be regenerated when next queried, this time taking account
of the object directory.
Extend the test suite with a new target which does not make use of AUTORCC with
qrc files so that the test added alone would break without the fix in this
commit.
This commit is contained in:
parent
1fe390201d
commit
9bc6eb8e1f
|
@ -275,6 +275,8 @@ cmGeneratorTarget::cmGeneratorTarget(cmTarget* t, cmLocalGenerator* lg)
|
||||||
this->LocalGenerator = lg;
|
this->LocalGenerator = lg;
|
||||||
this->GlobalGenerator = this->LocalGenerator->GetGlobalGenerator();
|
this->GlobalGenerator = this->LocalGenerator->GetGlobalGenerator();
|
||||||
|
|
||||||
|
this->GlobalGenerator->ComputeTargetObjectDirectory(this);
|
||||||
|
|
||||||
CreatePropertyGeneratorExpressions(
|
CreatePropertyGeneratorExpressions(
|
||||||
t->GetIncludeDirectoriesEntries(),
|
t->GetIncludeDirectoriesEntries(),
|
||||||
t->GetIncludeDirectoriesBacktraces(),
|
t->GetIncludeDirectoriesBacktraces(),
|
||||||
|
|
|
@ -1263,8 +1263,6 @@ bool cmGlobalGenerator::Compute()
|
||||||
this->LocalGenerators[i]->AddHelperCommands();
|
this->LocalGenerators[i]->AddHelperCommands();
|
||||||
}
|
}
|
||||||
|
|
||||||
this->InitGeneratorTargets();
|
|
||||||
|
|
||||||
#ifdef CMAKE_BUILD_WITH_CMAKE
|
#ifdef CMAKE_BUILD_WITH_CMAKE
|
||||||
for (std::vector<cmTarget const*>::iterator it = autogenTargets.begin();
|
for (std::vector<cmTarget const*>::iterator it = autogenTargets.begin();
|
||||||
it != autogenTargets.end(); ++it)
|
it != autogenTargets.end(); ++it)
|
||||||
|
@ -1557,19 +1555,6 @@ void cmGlobalGenerator::CreateGeneratorTargets(TargetTypes targetTypes,
|
||||||
mf->SetGeneratorTargets(generatorTargets);
|
mf->SetGeneratorTargets(generatorTargets);
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
|
||||||
void cmGlobalGenerator::InitGeneratorTargets()
|
|
||||||
{
|
|
||||||
for(cmGeneratorTargetsType::iterator ti =
|
|
||||||
this->GeneratorTargets.begin(); ti != this->GeneratorTargets.end(); ++ti)
|
|
||||||
{
|
|
||||||
if (!ti->second->Target->IsImported())
|
|
||||||
{
|
|
||||||
this->ComputeTargetObjectDirectory(ti->second);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
void cmGlobalGenerator::CreateGeneratorTargets(TargetTypes targetTypes)
|
void cmGlobalGenerator::CreateGeneratorTargets(TargetTypes targetTypes)
|
||||||
{
|
{
|
||||||
|
|
|
@ -480,7 +480,6 @@ private:
|
||||||
cmGeneratorTargetsType GeneratorTargets;
|
cmGeneratorTargetsType GeneratorTargets;
|
||||||
friend class cmake;
|
friend class cmake;
|
||||||
void CreateGeneratorTargets(TargetTypes targetTypes, cmLocalGenerator* lg);
|
void CreateGeneratorTargets(TargetTypes targetTypes, cmLocalGenerator* lg);
|
||||||
void InitGeneratorTargets();
|
|
||||||
void CreateGeneratorTargets(TargetTypes targetTypes);
|
void CreateGeneratorTargets(TargetTypes targetTypes);
|
||||||
|
|
||||||
void ClearGeneratorMembers();
|
void ClearGeneratorMembers();
|
||||||
|
|
|
@ -101,7 +101,14 @@ add_executable(QtAutogen main.cpp calwidget.cpp second_widget.cpp foo.cpp blub.c
|
||||||
)
|
)
|
||||||
set_property(TARGET QtAutogen APPEND PROPERTY AUTOGEN_TARGET_DEPENDS generate_moc_input "${CMAKE_CURRENT_BINARY_DIR}/myotherinterface.h")
|
set_property(TARGET QtAutogen APPEND PROPERTY AUTOGEN_TARGET_DEPENDS generate_moc_input "${CMAKE_CURRENT_BINARY_DIR}/myotherinterface.h")
|
||||||
|
|
||||||
set_target_properties(QtAutogen codeeditorLib privateSlot PROPERTIES AUTOMOC TRUE)
|
add_executable(targetObjectsTest targetObjectsTest.cpp $<TARGET_OBJECTS:privateSlot>)
|
||||||
|
target_link_libraries(targetObjectsTest ${QT_LIBRARIES})
|
||||||
|
|
||||||
|
set_target_properties(
|
||||||
|
QtAutogen codeeditorLib privateSlot targetObjectsTest
|
||||||
|
PROPERTIES
|
||||||
|
AUTOMOC TRUE
|
||||||
|
)
|
||||||
|
|
||||||
include(GenerateExportHeader)
|
include(GenerateExportHeader)
|
||||||
# The order is relevant here. B depends on A, and B headers depend on A
|
# The order is relevant here. B depends on A, and B headers depend on A
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
Loading…
Reference in New Issue