From 7a79ff3be3d08ef53b5b6ca9a0adb7fc84ebdb19 Mon Sep 17 00:00:00 2001 From: Jason Merrill Date: Wed, 10 Feb 2010 16:48:25 -0500 Subject: [PATCH] re PR c++/43016 ([C++0x] Inappropriate multiple definition error for lambda function when inside inline functions) PR c++/43016 * semantics.c (maybe_add_lambda_conv_op): Set DECL_INTERFACE_KNOWN. From-SVN: r156671 --- gcc/cp/ChangeLog | 5 +++++ gcc/cp/semantics.c | 2 ++ gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/g++.dg/cpp0x/lambda/lambda-conv.C | 14 ++++++++++++-- 4 files changed, 24 insertions(+), 2 deletions(-) diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 6bd2eca6d568..fd637fbba104 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2010-02-10 Jason Merrill + + PR c++/43016 + * semantics.c (maybe_add_lambda_conv_op): Set DECL_INTERFACE_KNOWN. + 2010-02-10 Shujing Zhao * Make-lang.in (cp/cvt.o, cp/parser.o, cp/search.o): Depend on intl.h. diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c index 39085be19d41..f8ced6fd5493 100644 --- a/gcc/cp/semantics.c +++ b/gcc/cp/semantics.c @@ -5871,6 +5871,8 @@ maybe_add_lambda_conv_op (tree type) DECL_NOT_REALLY_EXTERN (fn) = 1; DECL_DECLARED_INLINE_P (fn) = 1; DECL_STATIC_FUNCTION_P (fn) = 1; + if (nested) + DECL_INTERFACE_KNOWN (fn) = 1; add_method (type, fn, NULL_TREE); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index d599f15a07cc..c63c1ff73807 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-02-10 Jason Merrill + + PR c++/43016 + * g++.dg/cpp0x/lambda/lambda-conv.C: Test for weakness. + 2010-02-10 Richard Guenther PR tree-optimization/43017 diff --git a/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-conv.C b/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-conv.C index e308248b657d..fd7e40193505 100644 --- a/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-conv.C +++ b/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-conv.C @@ -1,6 +1,16 @@ -// { dg-options -std=c++0x } +// Test for conversion from stateless lambda to function pointer, which is +// not yet part of the draft but hopefully will be after the March 2010 +// meeting. -int main() +// { dg-options -std=c++0x } +// { dg-final { scan-assembler "weak\[^\n\r\]*_?_ZZ1fvENUlvE_cvPFvvEEv" { target { ! { *-*-darwin* *-*-mingw* *-*-cygwin } } } } } + +inline void f() { void (*pfn)() = []{}; } + +int main() +{ + f(); +}