Skip to content

Conversation

@davidstone
Copy link
Contributor

No description provided.

@llvmbot llvmbot added clang Clang issues not falling into any other category clang:frontend Language frontend issues, e.g. anything involving "Sema" labels Nov 24, 2025
@llvmbot
Copy link
Member

llvmbot commented Nov 24, 2025

@llvm/pr-subscribers-clang

Author: David Stone (davidstone)

Changes

Full diff: https://github.com/llvm/llvm-project/pull/169385.diff

1 Files Affected:

  • (modified) clang/lib/Sema/SemaDeclCXX.cpp (+11-11)
diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp index 8030aac3d8771..3bc748969065a 100644 --- a/clang/lib/Sema/SemaDeclCXX.cpp +++ b/clang/lib/Sema/SemaDeclCXX.cpp @@ -3782,21 +3782,21 @@ namespace { if (CheckReferenceOnly && !ReferenceField) return true; - llvm::SmallVector<unsigned, 4> UsedFieldIndex; // Discard the first field since it is the field decl that is being // initialized. - for (const FieldDecl *FD : llvm::drop_begin(llvm::reverse(Fields))) - UsedFieldIndex.push_back(FD->getFieldIndex()); - - for (auto UsedIter = UsedFieldIndex.begin(), - UsedEnd = UsedFieldIndex.end(), - OrigIter = InitFieldIndex.begin(), - OrigEnd = InitFieldIndex.end(); - UsedIter != UsedEnd && OrigIter != OrigEnd; ++UsedIter, ++OrigIter) { - if (*UsedIter < *OrigIter) + auto UsedFields = llvm::drop_begin(llvm::reverse(Fields)); + auto UsedIter = UsedFields.begin(); + const auto UsedEnd = UsedFields.end(); + + for (const unsigned Orig : InitFieldIndex) { + if (UsedIter == UsedEnd) + break; + const unsigned UsedIndex = (*UsedIter)->getFieldIndex(); + if (UsedIndex < Orig) return true; - if (*UsedIter > *OrigIter) + if (UsedIndex > Orig) break; + ++UsedIter; } return false; 
@davidstone davidstone merged commit f545c2c into main Nov 25, 2025
13 checks passed
@davidstone davidstone deleted the users/davidstone/dont-copy-into-vector-just-to-iterate-in-IsInitListMemberExprInitialized branch November 25, 2025 18:15
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

clang:frontend Language frontend issues, e.g. anything involving "Sema" clang Clang issues not falling into any other category

4 participants