Blame SOURCES/gcc48-pr77375.patch

8178f7
2017-05-30  Jakub Jelinek  <jakub@redhat.com>
8178f7
 
8178f7
 	Backported from mainline
8178f7
	2016-09-16  Jakub Jelinek  <jakub@redhat.com>
8178f7
8178f7
	PR c++/77375
8178f7
	* class.c (check_bases): Set CLASSTYPE_HAS_MUTABLE if any
8178f7
	TYPE_HAS_MUTABLE_P for any bases.
8178f7
8178f7
	* g++.dg/cpp0x/mutable1.C: New test.
8178f7
8178f7
--- gcc/cp/class.c	2017-10-17 17:27:32.287980595 +0200
8178f7
+++ gcc/cp/class.c	2017-10-17 17:29:11.104213281 +0200
8178f7
@@ -1479,6 +1479,8 @@ check_bases (tree t,
8178f7
 	|= CLASSTYPE_CONTAINS_EMPTY_CLASS_P (basetype);
8178f7
       TYPE_HAS_COMPLEX_DFLT (t) |= (!TYPE_HAS_DEFAULT_CONSTRUCTOR (basetype)
8178f7
 				    || TYPE_HAS_COMPLEX_DFLT (basetype));
8178f7
+      if (TYPE_HAS_MUTABLE_P (basetype))
8178f7
+	CLASSTYPE_HAS_MUTABLE (t) = 1;
8178f7
 
8178f7
       /*  A standard-layout class is a class that:
8178f7
 	  ...
8178f7
--- /dev/null
8178f7
+++ gcc/testsuite/g++.dg/cpp0x/mutable1.C
8178f7
@@ -0,0 +1,12 @@
8178f7
+// PR c++/77375
8178f7
+// { dg-do run { target c++11 } }
8178f7
+
8178f7
+struct Base { mutable int i; };
8178f7
+struct Derived : Base {};
8178f7
+const Derived foo{};
8178f7
+
8178f7
+int
8178f7
+main ()
8178f7
+{
8178f7
+  foo.i = 42;
8178f7
+}