public inbox for gcc-prs@sourceware.org
help / color / mirror / Atom feed
* c++/10542: warning: choosing `T::operator int&()' over `T::operator  const int&() const'
@ 2003-04-29 16:26 gianni
  0 siblings, 0 replies; 2+ messages in thread
From: gianni @ 2003-04-29 16:26 UTC (permalink / raw)
  To: gcc-gnats


>Number:         10542
>Category:       c++
>Synopsis:       warning: choosing `T::operator int&()' over `T::operator  const int&() const'
>Confidential:   no
>Severity:       serious
>Priority:       medium
>Responsible:    unassigned
>State:          open
>Class:          sw-bug
>Submitter-Id:   net
>Arrival-Date:   Tue Apr 29 16:26:00 UTC 2003
>Closed-Date:
>Last-Modified:
>Originator:     gianni@mariani.ws
>Release:        GCC 3.2.2
>Organization:
>Environment:
Linux RH 8.0

configure --enable-shared --enable-threads=posix --disable-checking --host=i386-redhat-linux --with-system-zlib --enable-__cxa_atexit
Thread model: posix
gcc version 3.2.2
>Description:

The warnings below ahould not be issued.  The code below should work without problems.

g++     tt5.cpp   -o tt5
tt5.cpp: In function `int main()':
tt5.cpp:53: warning: choosing `IType::operator int&()' over `IType::operator 
   const int&() const'
tt5.cpp:53: warning:   for conversion from `IType' to `int'
tt5.cpp:53: warning:   because conversion sequence for the argument is better

#include <cassert>
      
class IType
{
    public:
     
    int                                          m_value;
     
    inline IType()
      : m_value( 3322-21 )
    {
    }
     
    inline operator int & ()
    {
        return m_value;
    }

    inline operator const int & () const
    {
        return m_value;
    }

    inline int & operator = ( const int & i_value )
    {
        m_value = i_value;

        return m_value;
    }

};


class tester
{
    public:

  
    IType                                                            m_int;


};

int main()
{


    tester          z;

    const tester    * a = & z;

    assert( z.m_int == 3301 );

    assert( a->m_int == 3301 );

    return 0;
}
>How-To-Repeat:

>Fix:

>Release-Note:
>Audit-Trail:
>Unformatted:


^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: c++/10542: warning: choosing `T::operator int&()' over `T::operator  const int&() const'
@ 2003-04-30  1:13 bangerth
  0 siblings, 0 replies; 2+ messages in thread
From: bangerth @ 2003-04-30  1:13 UTC (permalink / raw)
  To: gcc-bugs, gcc-prs, gianni, nobody

Synopsis: warning: choosing `T::operator int&()' over `T::operator  const int&() const'

State-Changed-From-To: open->closed
State-Changed-By: bangerth
State-Changed-When: Wed Apr 30 01:13:27 2003
State-Changed-Why:
    Already fixed in 3.4

http://gcc.gnu.org/cgi-bin/gnatsweb.pl?cmd=view%20audit-trail&database=gcc&pr=10542


^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2003-04-30  1:13 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2003-04-29 16:26 c++/10542: warning: choosing `T::operator int&()' over `T::operator const int&() const' gianni
2003-04-30  1:13 bangerth

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).