Avoiding ambiguities

M

MiG

Hello,

I have the following operators declared in a class:

// Provides R/W direct access to the matrix.
__forceinline const T& operator[](USHORT ndx) const throw()
{ _ASSERT(ndx < 16); return(_mx[ndx]); }
__forceinline T& operator[](USHORT ndx) throw()
{ _ASSERT(ndx < 16); return(_mx[ndx]); }

// Returns pointer to matrix data.
__forceinline operator const T*() const throw()
{ return(_mx); }
__forceinline operator T*() throw()
{ return(_mx); }


When I compile it I get the following errors:

error C2666: 'Matrix4<T>::eek:perator []' : 4 overloads have similar
conversions
with
[
T=float
]
d:\~alibrary\prj\cpp\xgl\0.1a1\inc\primitives.hpp(1515): could
be 'float &Matrix4<T>::eek:perator [](USHORT) throw()'
with
[
T=float
]
d:\~alibrary\prj\cpp\xgl\0.1a1\inc\primitives.hpp(1513): or
'const float &Matrix4<T>::eek:perator [](USHORT) throw() const'
with
[
T=float
]
or 'built-in C++ operator[(const float *, int)'
or 'built-in C++ operator[(float *, int)'


Is there a way of avoiding these errors without having to create a
method for, say, replacing the functionality of the T* operators?
 
V

Victor Bazarov

MiG said:
I have the following operators declared in a class:

// Provides R/W direct access to the matrix.
__forceinline const T& operator[](USHORT ndx) const throw()
{ _ASSERT(ndx < 16); return(_mx[ndx]); }
__forceinline T& operator[](USHORT ndx) throw()
{ _ASSERT(ndx < 16); return(_mx[ndx]); }

// Returns pointer to matrix data.
__forceinline operator const T*() const throw()
{ return(_mx); }
__forceinline operator T*() throw()
{ return(_mx); }

Please, when posting here, try to remove all compiler-specific
junk, like that ___blah nonsense. Your code is not easy to read
with all that crud in it.
When I compile it I get the following errors:

error C2666: 'Matrix4<T>::eek:perator []' : 4 overloads have similar
conversions
with
[
T=float
]
d:\~alibrary\prj\cpp\xgl\0.1a1\inc\primitives.hpp(1515): could
be 'float &Matrix4<T>::eek:perator [](USHORT) throw()'
with
[
T=float
]
d:\~alibrary\prj\cpp\xgl\0.1a1\inc\primitives.hpp(1513): or
'const float &Matrix4<T>::eek:perator [](USHORT) throw() const'
with
[
T=float
]
or 'built-in C++ operator[(const float *, int)'
or 'built-in C++ operator[(float *, int)'


Is there a way of avoiding these errors without having to create a
method for, say, replacing the functionality of the T* operators?

Well, just don't provide the operator T*. Why do you think you need
it in the first place?

V
 
M

MiG

Victor said:
MiG said:
I have the following operators declared in a class:

// Provides R/W direct access to the matrix.
__forceinline const T& operator[](USHORT ndx) const throw()
{ _ASSERT(ndx < 16); return(_mx[ndx]); }
__forceinline T& operator[](USHORT ndx) throw()
{ _ASSERT(ndx < 16); return(_mx[ndx]); }

// Returns pointer to matrix data.
__forceinline operator const T*() const throw()
{ return(_mx); }
__forceinline operator T*() throw()
{ return(_mx); }

Please, when posting here, try to remove all compiler-specific
junk, like that ___blah nonsense. Your code is not easy to read
with all that crud in it.
When I compile it I get the following errors:

error C2666: 'Matrix4<T>::eek:perator []' : 4 overloads have similar
conversions
with
[
T=float
]
d:\~alibrary\prj\cpp\xgl\0.1a1\inc\primitives.hpp(1515): could
be 'float &Matrix4<T>::eek:perator [](USHORT) throw()'
with
[
T=float
]
d:\~alibrary\prj\cpp\xgl\0.1a1\inc\primitives.hpp(1513): or
'const float &Matrix4<T>::eek:perator [](USHORT) throw() const'
with
[
T=float
]
or 'built-in C++ operator[(const float *, int)'
or 'built-in C++ operator[(float *, int)'


Is there a way of avoiding these errors without having to create a
method for, say, replacing the functionality of the T* operators?

Well, just don't provide the operator T*. Why do you think you need
it in the first place?

V

Alright V, thanks for that. I was really hoping there was a way to keep
the two operators. Not a problem though; I'll just remove the T*s...

Again, thanks V.
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

Forum statistics

Threads
473,780
Messages
2,569,611
Members
45,278
Latest member
BuzzDefenderpro

Latest Threads

Top