[clang] [CIR] Upstream support for accessing structure members (PR #136383)
Erich Keane via cfe-commits
cfe-commits at lists.llvm.org
Mon Apr 21 12:19:48 PDT 2025
================
@@ -309,6 +309,37 @@ RecordType::computeStructAlignment(const mlir::DataLayout &dataLayout) const {
return recordAlignment;
}
+uint64_t RecordType::getElementOffset(const ::mlir::DataLayout &dataLayout,
+ unsigned idx) const {
+ assert(idx < getMembers().size() && "access not valid");
+
+ // All union elements are at offset zero.
+ if (isUnion() || idx == 0)
+ return 0;
+
+ assert(isComplete() && "Cannot get layout of incomplete records");
+ assert(idx < getNumElements());
+ llvm::ArrayRef<mlir::Type> members = getMembers();
+
+ unsigned offset = 0;
+
+ for (unsigned i = 0, e = idx; i != e; ++i) {
----------------
erichkeane wrote:
Typically clang prefers range-for for readability and avoiding the 'error-prone-ness' of an index. Readability is because it assures that we are only visiting anything 'once', and the index is unchanged between iterations. Typically when I see one of these types of loops, it means "funny-business is happening in the body, so look closely".
https://github.com/llvm/llvm-project/pull/136383
More information about the cfe-commits
mailing list