aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJonathan Wakely <jwakely.gcc@gmail.com>2011-05-23 08:15:16 +0000
committerJonathan Wakely <redi@gcc.gnu.org>2011-05-23 09:15:16 +0100
commitc11e39b0bdfc580582012fe56f0cce1b84f064f4 (patch)
tree3b87380a633beb61c227f25ea2c76e0edc6884d4
parentbc69f7ffb57a35be61feb20e4a7b4300c8d1de24 (diff)
downloadgcc-c11e39b0bdfc580582012fe56f0cce1b84f064f4.zip
gcc-c11e39b0bdfc580582012fe56f0cce1b84f064f4.tar.gz
gcc-c11e39b0bdfc580582012fe56f0cce1b84f064f4.tar.bz2
re PR c++/18016 (Warn about member variables initialized with itself)
2011-05-23 Jonathan Wakely <jwakely.gcc@gmail.com> PR c++/18016 * init.c (perform_member_init): Check for self-initialization. From-SVN: r174058
-rw-r--r--gcc/cp/ChangeLog5
-rw-r--r--gcc/cp/init.c11
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/warn/pr18016.C11
4 files changed, 32 insertions, 0 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index e6399d3..20c9808 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,8 @@
+2011-05-23 Jonathan Wakely <jwakely.gcc@gmail.com>
+
+ PR c++/18016
+ * init.c (perform_member_init): Check for self-initialization.
+
2011-05-22 Jason Merrill <jason@redhat.com>
PR c++/48647
diff --git a/gcc/cp/init.c b/gcc/cp/init.c
index 7d7adbe..5f30275 100644
--- a/gcc/cp/init.c
+++ b/gcc/cp/init.c
@@ -501,6 +501,17 @@ perform_member_init (tree member, tree init)
if (decl == error_mark_node)
return;
+ if (warn_init_self && init && TREE_CODE (init) == TREE_LIST
+ && TREE_CHAIN (init) == NULL_TREE)
+ {
+ tree val = TREE_VALUE (init);
+ if (TREE_CODE (val) == COMPONENT_REF && TREE_OPERAND (val, 1) == member
+ && TREE_OPERAND (val, 0) == current_class_ref)
+ warning_at (DECL_SOURCE_LOCATION (current_function_decl),
+ OPT_Wuninitialized, "%qD is initialized with itself",
+ member);
+ }
+
if (init == void_type_node)
{
/* mem() means value-initialization. */
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index b1446bb..b87cb2a 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2011-05-23 Jonathan Wakely <jwakely.gcc@gmail.com>
+
+ PR c++/18016
+ * g++.dg/warn/pr18016.C: New.
+
2011-05-23 Tom de Vries <tom@codesourcery.com>
PR target/45098
diff --git a/gcc/testsuite/g++.dg/warn/pr18016.C b/gcc/testsuite/g++.dg/warn/pr18016.C
new file mode 100644
index 0000000..9cf1ea3
--- /dev/null
+++ b/gcc/testsuite/g++.dg/warn/pr18016.C
@@ -0,0 +1,11 @@
+/* { dg-do compile } */
+/* { dg-options "-Wuninitialized -Winit-self" } */
+
+class X {
+ int i;
+ X() : i(i) { } // { dg-warning "initialized with itself" }
+ X(int i) : i(i) { }
+ X(const X& x) : i(x.i) { }
+};
+
+// { dg-prune-output "In constructor" }