From: Jason Merrill Date: Sun, 14 Feb 2010 15:17:30 +0000 (-0500) Subject: re PR c++/41997 ([C++0x] constant initializer_list not optimised) X-Git-Tag: releases/gcc-4.5.0~783 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=1acb8caa791e6bddc4ba4ab531aedad64803323a;p=thirdparty%2Fgcc.git re PR c++/41997 ([C++0x] constant initializer_list not optimised) PR c++/41997 * semantics.c (finish_compound_literal): Use cp_apply_type_quals_to_decl when creating a static variable. From-SVN: r156760 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 7e37b69545bb..0b96f4c8fbf8 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2010-02-14 Jason Merrill + + PR c++/41997 + * semantics.c (finish_compound_literal): Use + cp_apply_type_quals_to_decl when creating a static variable. + 2010-02-12 Jason Merrill PR c++/43024 diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c index 985e2c0f4648..90a76d9391ce 100644 --- a/gcc/cp/semantics.c +++ b/gcc/cp/semantics.c @@ -2257,6 +2257,7 @@ finish_compound_literal (tree type, tree compound_literal) tree decl = create_temporary_var (type); DECL_INITIAL (decl) = compound_literal; TREE_STATIC (decl) = 1; + cp_apply_type_quals_to_decl (cp_type_quals (type), decl); decl = pushdecl_top_level (decl); DECL_NAME (decl) = make_anon_name (); SET_DECL_ASSEMBLER_NAME (decl, DECL_NAME (decl)); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 157d79cb4c8a..891e33d5e5a7 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-02-14 Jason Merrill + + PR c++/41997 + * g++.dg/cpp0x/initlist-opt.C: New. + 2010-02-13 Paul Thomas PR fortran/41113 diff --git a/gcc/testsuite/g++.dg/cpp0x/initlist-opt.C b/gcc/testsuite/g++.dg/cpp0x/initlist-opt.C new file mode 100644 index 000000000000..f515ed89d986 --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/initlist-opt.C @@ -0,0 +1,19 @@ +// PR c++/41997 +// { dg-options "-std=c++0x -O2 -fdump-tree-optimized" } +// { dg-final { scan-tree-dump-not "_0" "optimized" } } +// { dg-final { cleanup-tree-dump "optimized" } } + +#include + +int max_val(std::initializer_list il) +{ + int i = *(il.begin()); + int j = *(il.begin() + 1); + return (i > j ? i : j); +} + +int main(void) +{ + return max_val({1,2}); +} +