From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 9147 invoked by alias); 9 Dec 2013 16:33:31 -0000 Mailing-List: contact gcc-bugs-help@gcc.gnu.org; run by ezmlm Precedence: bulk List-Id: List-Archive: List-Post: List-Help: Sender: gcc-bugs-owner@gcc.gnu.org Received: (qmail 8893 invoked by uid 48); 9 Dec 2013 16:33:27 -0000 From: "thomas.sanchz at gmail dot com" To: gcc-bugs@gcc.gnu.org Subject: [Bug c++/59435] New: sizeof...(T) as default value for an argument does not work Date: Mon, 09 Dec 2013 16:33:00 -0000 X-Bugzilla-Reason: CC X-Bugzilla-Type: new X-Bugzilla-Watch-Reason: None X-Bugzilla-Product: gcc X-Bugzilla-Component: c++ X-Bugzilla-Version: 4.8.1 X-Bugzilla-Keywords: X-Bugzilla-Severity: normal X-Bugzilla-Who: thomas.sanchz at gmail dot com X-Bugzilla-Status: UNCONFIRMED X-Bugzilla-Priority: P3 X-Bugzilla-Assigned-To: unassigned at gcc dot gnu.org X-Bugzilla-Target-Milestone: --- X-Bugzilla-Flags: X-Bugzilla-Changed-Fields: bug_id short_desc product version bug_status bug_severity priority component assigned_to reporter Message-ID: Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit X-Bugzilla-URL: http://gcc.gnu.org/bugzilla/ Auto-Submitted: auto-generated MIME-Version: 1.0 X-SW-Source: 2013-12/txt/msg00748.txt.bz2 http://gcc.gnu.org/bugzilla/show_bug.cgi?id=59435 Bug ID: 59435 Summary: sizeof...(T) as default value for an argument does not work Product: gcc Version: 4.8.1 Status: UNCONFIRMED Severity: normal Priority: P3 Component: c++ Assignee: unassigned at gcc dot gnu.org Reporter: thomas.sanchz at gmail dot com Hi everybody, I encountered something not supported in gcc from 4.7 to 4.9, but working in clang from 3.2 (tested on gcc goldbot). Here is the code: template struct T { T(unsigned int i = sizeof...(E)){} // does not compile static constexpr unsigned int U = sizeof...(E); T(unsigned int j, unsigned int i = U){} // compile }; template void test(int i = sizeof...(T)) // compile {} Invocation with "g++ -std=c++11 test.cpp" is enough to reproduce the bug. Please let me know if you need more information. Cheers,