From 463025a4a1aa4f9405fb2cf43429b22514277545 Mon Sep 17 00:00:00 2001 From: paolo Date: Sat, 28 Oct 2017 16:10:10 +0000 Subject: 2017-10-28 Paolo Carlini PR c++/70971 * g++.dg/torture/pr70971.C: New. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@254199 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/testsuite/ChangeLog | 5 ++++ gcc/testsuite/g++.dg/torture/pr70971.C | 48 ++++++++++++++++++++++++++++++++++ 2 files changed, 53 insertions(+) create mode 100644 gcc/testsuite/g++.dg/torture/pr70971.C diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 1646f4cb033..49693bca887 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2017-10-28 Paolo Carlini + + PR c++/70971 + * g++.dg/torture/pr70971.C: New. + 2017-10-28 Paul Thomas PR fortran/81758 diff --git a/gcc/testsuite/g++.dg/torture/pr70971.C b/gcc/testsuite/g++.dg/torture/pr70971.C new file mode 100644 index 00000000000..23f33aafaba --- /dev/null +++ b/gcc/testsuite/g++.dg/torture/pr70971.C @@ -0,0 +1,48 @@ +// { dg-additional-options "-std=c++14" } + +template +class function; + +template +class invoker_base +{ + public: + virtual ~invoker_base() { } +}; + +template +class functor_invoker : public invoker_base +{ + public: + explicit functor_invoker(const F& f) : f(f) { } + private: + F f; +}; + +template +class function { + public: + template + function(const F& f) : invoker(0) { + invoker = new functor_invoker(f); + } + ~function() { + if (invoker) + delete invoker; + } + private: + invoker_base* invoker; +}; + +template +struct unique_ptr { }; + +struct A {}; +template struct typelist {}; +template unique_ptr chooseB(typelist); +template +unique_ptr chooseB(typelist choices, Idx, Rest... rest) { + auto f = [=](auto) { return [=] { return chooseB(choices, rest...); }; }; + function()> fs[]{f(Cs{})...}; +} +main() { chooseB(typelist{}, 0, 1, 2); } -- cgit v1.2.1