www.digitalmars.com Home | Search | C & C++ | D | DMDScript | News Groups | index | prev | next
Archives

D Programming
D
D.gnu
digitalmars.D
digitalmars.D.bugs
digitalmars.D.dtl
digitalmars.D.dwt
digitalmars.D.announce
digitalmars.D.learn
digitalmars.D.debugger

C/C++ Programming
c++
c++.announce
c++.atl
c++.beta
c++.chat
c++.command-line
c++.dos
c++.dos.16-bits
c++.dos.32-bits
c++.idde
c++.mfc
c++.rtl
c++.stl
c++.stl.hp
c++.stl.port
c++.stl.sgi
c++.stlsoft
c++.windows
c++.windows.16-bits
c++.windows.32-bits
c++.wxwindows

digitalmars.empire
digitalmars.DMDScript
electronics



c++.beta - possible dmc ambiguity bug ?

Here is a dmc bug reduced from wxBoxSizer code; in AMethod, removing the 
const before wxSize allows the code to compile
chris

C:\wx\wxwidgets\build\msw>dmc -mn -c -cpp -osize.obj -g -o+none size.cpp
size.cpp(25) : Error: ambiguous reference to symbol
Had: wxBoxSizer::SizeInMajorDir(const wxSize&)const
and: wxBoxSizer::SizeInMajorDir(wxSize&)
--- errorlevel 1

#define wxHORIZONTAL 1

class wxSize
{
public:
     int x, y ;
};

class wxBoxSizer
{
protected:
     int SizeInMajorDir(const wxSize& sz) const
     {
         return m_orient == wxHORIZONTAL ? sz.x : sz.y;
     }

     int& SizeInMajorDir(wxSize& sz)
     {
         return m_orient == wxHORIZONTAL ? sz.x : sz.y;
     }

     int AMethod ()
     {
	const wxSize sizeThis ;
	return SizeInMajorDir(sizeThis);
     }

     int m_orient ;
} ;
Oct 27 2007