mirror of
https://github.com/telegramdesktop/tdesktop
synced 2025-01-25 08:44:38 +00:00
Avoid generating multiple time the forward declarations in the headers generated by codegen_style.
This commit is contained in:
parent
a403ad7d37
commit
a868c7bc8b
@ -20,6 +20,7 @@ Copyright (c) 2014-2017 John Preston, https://desktop.telegram.org
|
|||||||
*/
|
*/
|
||||||
#include "codegen/style/generator.h"
|
#include "codegen/style/generator.h"
|
||||||
|
|
||||||
|
#include <set>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
#include <functional>
|
#include <functional>
|
||||||
#include <QtCore/QDir>
|
#include <QtCore/QDir>
|
||||||
@ -609,10 +610,14 @@ bool Generator::writeStructsForwardDeclarations() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
header_->newline();
|
header_->newline();
|
||||||
bool result = module_.enumVariables([this](const Variable &value) -> bool {
|
std::set<QString> alreadyDeclaredTypes;
|
||||||
|
bool result = module_.enumVariables([this, &alreadyDeclaredTypes](const Variable &value) -> bool {
|
||||||
if (value.value.type().tag == structure::TypeTag::Struct) {
|
if (value.value.type().tag == structure::TypeTag::Struct) {
|
||||||
if (!module_.findStructInModule(value.value.type().name, module_)) {
|
if (!module_.findStructInModule(value.value.type().name, module_)) {
|
||||||
|
if (alreadyDeclaredTypes.find(value.value.type().name.back()) == alreadyDeclaredTypes.end()) {
|
||||||
header_->stream() << "struct " << value.value.type().name.back() << ";\n";
|
header_->stream() << "struct " << value.value.type().name.back() << ";\n";
|
||||||
|
alreadyDeclaredTypes.emplace(value.value.type().name.back());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
Loading…
Reference in New Issue
Block a user