]> granicus.if.org Git - clang/commitdiff
It's an error to call offsetof on a non-POD type.
authorAnders Carlsson <andersca@mac.com>
Fri, 1 May 2009 23:20:30 +0000 (23:20 +0000)
committerAnders Carlsson <andersca@mac.com>
Fri, 1 May 2009 23:20:30 +0000 (23:20 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@70595 91177308-0d34-0410-b5e6-96231b3b80d8

include/clang/Basic/DiagnosticSemaKinds.td
lib/Sema/SemaExpr.cpp
test/SemaCXX/offsetof.cpp [new file with mode: 0644]

index 0cbbfc750bf9aa09a98602a7ae50c0ddfdc1de9b..c9bdf13b308d26a95a7bc3bd593701dc8d82af0d 100644 (file)
@@ -936,6 +936,8 @@ def err_offsetof_record_type : Error<
 def err_offsetof_array_type : Error<"offsetof requires array type, %0 invalid">;
 def ext_offsetof_extended_field_designator : Extension<
   "using extended field designator is an extension">;
+def err_offsetof_non_pod_type : Error<"offset of on non-POD type %0">;
+
 def warn_floatingpoint_eq : Warning<
   "comparing floating point with == or != is unsafe">,
   InGroup<DiagGroup<"float-equal">>, DefaultIgnore;
index bf9947a5e241fc8bd91fa04f9516335d420f1295..3442cc1db9f8ccb1a0e8f5a629c2554f623e27a8 100644 (file)
@@ -4761,6 +4761,13 @@ Sema::OwningExprResult Sema::ActOnBuiltinOffsetOf(Scope *S,
 
       // Get the decl corresponding to this.
       RecordDecl *RD = RC->getDecl();
+      if (CXXRecordDecl *CRD = dyn_cast<CXXRecordDecl>(RD)) {
+        if (!CRD->isPOD())
+          return ExprError(Diag(BuiltinLoc, diag::err_offsetof_non_pod_type)
+                   << SourceRange(CompPtr[0].LocStart, OC.LocEnd)
+                   << Res->getType());
+      }
+      
       FieldDecl *MemberDecl
         = dyn_cast_or_null<FieldDecl>(LookupQualifiedName(RD, OC.U.IdentInfo,
                                                           LookupMemberName)
diff --git a/test/SemaCXX/offsetof.cpp b/test/SemaCXX/offsetof.cpp
new file mode 100644 (file)
index 0000000..726dc7e
--- /dev/null
@@ -0,0 +1,15 @@
+// RUN: clang-cc -fsyntax-only -verify %s
+
+struct NonPOD {
+  virtual void f();
+  int m;
+};
+
+struct P {
+  NonPOD fieldThatPointsToANonPODType;
+};
+
+void f() {
+  int i = __builtin_offsetof(P, fieldThatPointsToANonPODType.m); // expected-error{{offset of on non-POD type 'struct P'}}
+}
+