Skip to content

Commit

Permalink
re PR c++/46401 (very slow compile time with -Wsequence-point)
Browse files Browse the repository at this point in the history
	PR c++/46401
	* c-common.c (warning_candidate_p): Don't track non-const calls
	or STRING_CSTs.

	* g++.dg/warn/Wsequence-point-3.C: New test.

From-SVN: r166823
  • Loading branch information
jakubjelinek committed Nov 16, 2010
1 parent 18c33e0 commit 0707866
Show file tree
Hide file tree
Showing 4 changed files with 50 additions and 3 deletions.
6 changes: 6 additions & 0 deletions gcc/c-family/ChangeLog
Original file line number Diff line number Diff line change
@@ -1,3 +1,9 @@
2010-11-16 Jakub Jelinek <[email protected]>

PR c++/46401
* c-common.c (warning_candidate_p): Don't track non-const calls
or STRING_CSTs.

2010-11-15 Ian Lance Taylor <[email protected]>

* c-lex.c (init_c_lex): Set macro debug callbacks if
Expand Down
22 changes: 19 additions & 3 deletions gcc/c-family/c-common.c
Original file line number Diff line number Diff line change
Expand Up @@ -2324,10 +2324,26 @@ warn_for_collisions (struct tlist *list)
static int
warning_candidate_p (tree x)
{
/* !VOID_TYPE_P (TREE_TYPE (x)) is workaround for cp/tree.c
if (DECL_P (x) && DECL_ARTIFICIAL (x))
return 0;

/* VOID_TYPE_P (TREE_TYPE (x)) is workaround for cp/tree.c
(lvalue_p) crash on TRY/CATCH. */
return !(DECL_P (x) && DECL_ARTIFICIAL (x))
&& TREE_TYPE (x) && !VOID_TYPE_P (TREE_TYPE (x)) && lvalue_p (x);
if (TREE_TYPE (x) == NULL_TREE || VOID_TYPE_P (TREE_TYPE (x)))
return 0;

if (!lvalue_p (x))
return 0;

/* No point to track non-const calls, they will never satisfy
operand_equal_p. */
if (TREE_CODE (x) == CALL_EXPR && (call_expr_flags (x) & ECF_CONST) == 0)
return 0;

if (TREE_CODE (x) == STRING_CST)
return 0;

return 1;
}

/* Return nonzero if X and Y appear to be the same candidate (or NULL) */
Expand Down
5 changes: 5 additions & 0 deletions gcc/testsuite/ChangeLog
Original file line number Diff line number Diff line change
@@ -1,3 +1,8 @@
2010-11-16 Jakub Jelinek <[email protected]>

PR c++/46401
* g++.dg/warn/Wsequence-point-3.C: New test.

2010-11-16 Kai Tietz <[email protected]>

PR preprocessor/17349
Expand Down
20 changes: 20 additions & 0 deletions gcc/testsuite/g++.dg/warn/Wsequence-point-3.C
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
// PR c++/46401
// { dg-do compile }
// { dg-options "-Wsequence-point" }

struct S
{
S ();
S &operator<< (const char *);
S (const S &);
};

#define N1(n) << #n
#define N2(n) N1(n)
#define N3(n) N2(n##0) N2(n##1) N2(n##2) N2(n##3) N2(n##4) \
N2(n##5) N2(n##6) N2(n##7) N2(n##8) N2(n##9)
#define N4(n) N3(n##0) N3(n##1) N3(n##2) N3(n##3) N3(n##4) \
N3(n##5) N3(n##6) N3(n##7) N3(n##8) N3(n##9)
#define N5(n) N4(n##0) N4(n##1) N4(n##2) N4(n##3) N4(n##4) \
N4(n##5) N4(n##6) N4(n##7) N4(n##8) N4(n##9)
S s = S () N5(a) N5(b);

0 comments on commit 0707866

Please sign in to comment.