From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 15735 invoked by alias); 8 Jan 2003 22:56:04 -0000 Mailing-List: contact gcc-prs-help@gcc.gnu.org; run by ezmlm Precedence: bulk List-Archive: List-Post: List-Help: Sender: gcc-prs-owner@gcc.gnu.org Received: (qmail 15715 invoked by uid 71); 8 Jan 2003 22:56:03 -0000 Resent-Date: 8 Jan 2003 22:56:03 -0000 Resent-Message-ID: <20030108225603.15714.qmail@sources.redhat.com> Resent-From: gcc-gnats@gcc.gnu.org (GNATS Filer) Resent-Cc: gcc-prs@gcc.gnu.org, gcc-bugs@gcc.gnu.org, gdr@integrable-solutions.net Resent-Reply-To: gcc-gnats@gcc.gnu.org, reichelt@igpm.rwth-aachen.de Received: (qmail 5117 invoked by uid 61); 8 Jan 2003 22:47:22 -0000 Message-Id: <20030108224722.5116.qmail@sources.redhat.com> Date: Wed, 08 Jan 2003 22:56:00 -0000 From: reichelt@igpm.rwth-aachen.de Reply-To: reichelt@igpm.rwth-aachen.de To: gcc-gnats@gcc.gnu.org Cc: gdr@integrable-solutions.net X-Send-Pr-Version: gnatsweb-2.9.3 (1.1.1.1.2.31) X-GNATS-Notify: gdr@integrable-solutions.net Subject: libstdc++/9234: [3.3/3.4 regression] unary minus for valarrays broken X-SW-Source: 2003-01/txt/msg00571.txt.bz2 List-Id: >Number: 9234 >Category: libstdc++ >Synopsis: [3.3/3.4 regression] unary minus for valarrays broken >Confidential: no >Severity: serious >Priority: medium >Responsible: unassigned >State: open >Class: wrong-code >Submitter-Id: net >Arrival-Date: Wed Jan 08 14:56:02 PST 2003 >Closed-Date: >Last-Modified: >Originator: Volker Reichelt >Release: 3.3-20021230, 3.4-20021230 >Organization: >Environment: i686-pc-linux-gnu >Description: The following program should return -1, but returns 1 instead (just compile with "g++ -c"): -----------------------snip here------------------ #include int main () { std::valarray u(1); u[0]=1; return (-u)[0]; } -----------------------snip here------------------ I think that Gaby's patch http://gcc.gnu.org/ml/gcc-patches/2002-08/msg00197.html caused the regression, since the patch below fixes the problem for me. (I didn't do a bootstrap or regression tests, though.) >How-To-Repeat: g++ -c >Fix: =========================================================== --- gcc-old/libstdc++-v3/include/bits/valarray_meta.h Sat Jan 4 01:37:31 2003 +++ gcc-new/libstdc++-v3/include/bits/valarray_meta.h Wed Jan 8 23:26:44 2003 @@ -457,7 +457,7 @@ namespace std _UnBase(const _Arg& __e) : _M_expr(__e) {} value_type operator[](size_t __i) const - { return _M_expr[__i]; } + { return _Oper() (_M_expr[__i]); } size_t size() const { return _M_expr.size(); } ============================================================ >Release-Note: >Audit-Trail: >Unformatted: