Home | Contact Us | FAQ | Search & Site Map | Link to Us
Sign In | Join | Other 45 Sites in Network
HomeAnnouncementsFree MagazinesWhite PapersSubmit Content
Discussion GroupsASP.NETWindows FormsLanguages.NET FrameworkVisual Studio.NET
Articles.NET FrameworkASP.NETToolsWindows Forms
.NET DirectoryOpen Source ProjectsUser GroupsWeb Resources
Related Topics
Visual Basic 6SQL ServerMS AccessOther DB ProductsMS Server ProductsMore Topics ...

.NET Forum / Languages / Managed C++ / May 2004

Tip: Looking for answers? Try searching our database.

[March 2005 Preview] overriding virtual function return type differs from 'System::Object ^System::Collections::IList::get_Item(int)'

Thread view: 
Enable EMail Alerts  Start New Thread
Thread rating: 
Bern McCarty - 07 May 2004 20:17 GMT
I'm trying to use the VS 2005 March Tech Preview and am trying to adjust
some MC++ to the new C++/CLI syntax.  I got a little hung up when I
encountered the below error.  Certainly my 'Bentley::Mstn::Element' type
derives ultimately from System::Object. It is a ref class. And upcasting is
always implicit right?  So I don't understand why I'm getting this error.
It's happening on my get method:

   property Bentley::Mstn::Element^ Item[]
       {
       Bentley::Mstn::Element^ get(int index);
       void set (int index, Bentley::Mstn::Element^ value);
       }

And here is the error

C:\mycode\elementWhidbey\ElementList.Mstn.Bentley.h(97) : error C2553:
'Bentley::Mstn::Element ^Bentley::Mstn::ElementList::Item::get(int)':
overriding virtual function return type differs from 'System::Object
^System::Collections::IList::get_Item(int)'
mscorlib.dll : see declaration of 'System::Collections::IList::get_Item'
Gary Chang - 08 May 2004 07:08 GMT
Hi Bern,

Currently we don't support the VS 2005 Preview, however I have consulted
your problem to the dev team, I will reply you if I got any result.

Thanks for your understanding!

Best regards,

Gary Chang
Microsoft Online Partner Support

Signature

Get Secure! - www.microsoft.com/security
This posting is provided "AS IS" with no warranties, and confers no rights.

--------------------
Gary Chang - 11 May 2004 02:44 GMT
Hi Bern,

One dev team member gave the following answer to your question:
"The compiler in the Tech Preview does not support covariant returns for
member functions (or properties) of managed classes.  It is a restriction
imposed by the CLI, so I don??t think C++/CLI or the Whidbey compiler will
allow them."

Thanks!

Best regards,

Gary Chang
Microsoft Online Partner Support

Signature

Get Secure! - www.microsoft.com/security
This posting is provided "AS IS" with no warranties, and confers no rights.

--------------------
Bern McCarty - 11 May 2004 14:09 GMT
That deserves further explanation.  The code snippet I gave is the textbook
way to create a type-safe collection pre-Whidbey is it not? You derive from
System.Collections.CollectionBase and then, among other things, you can
override get_Item(int index) and do a cast of List->item[index] from
System.Object * to the type that you're making a collection of.  This is
straight out of the documentation.

I realize that as of Whidbey there are superior ways to do type-safe
collections, but are you saying that code written to follow the past
recommended practice for creating type-safe collections will not even
compile in Whidbey?  Is CollectionBase being removed from the framework
then?  There doesn't seem to be much point in keeping it if the compilers
won't let you use it as intended.

Bern McCarty
Bentley Systems, Inc.

> Hi Bern,
>
[quoted text clipped - 14 lines]
> This posting is provided "AS IS" with no warranties, and confers no rights.
> --------------------
Gary Chang - 13 May 2004 03:22 GMT
Hi Bern,

Our dev team has provided an example in the new syntax of doing the
explicit interface implementation which is how you write a typesafe
collection in generic-less CLR:

ref class R : ICloneable {
   int X;
   virtual Object^ C() = ICloneable::Clone {
   return this->Clone();
 }

public:
   R() : X(0) {}
   R(int x) : X(x) {}

   virtual R^ Clone() new {
   R^ r = gcnew R;
   r->X = this->X;
   return r;
 }
};

Wish it helps!

Best regards,

Gary Chang
Microsoft Online Partner Support

Signature

Get Secure! - www.microsoft.com/security
This posting is provided "AS IS" with no warranties, and confers no rights.

--------------------
Bern McCarty - 13 May 2004 13:48 GMT
Thanks Gary.  I'll have to study the C++/CLI draft to try to understand that
code.  Meanwhile, could you provide an example of how to do the same thing
using /clr:oldsyntax ?

Bern McCarty
Bentley Systems, Inc.

> Hi Bern,
>
[quoted text clipped - 29 lines]
> This posting is provided "AS IS" with no warranties, and confers no rights.
> --------------------
Ronald Laeremans [MSFT] - 13 May 2004 19:11 GMT
Hi Bern,

That isn't possible in a direct way since the 7.0/7.1 syntax does not
support explicit interface implementation.

Ronald Laeremans
Visual C++ team

> Thanks Gary.  I'll have to study the C++/CLI draft to try to understand
> that
[quoted text clipped - 38 lines]
> rights.
>> --------------------

Rate this thread:







Free Magazines

Get these publications absolutely FREE for up to 12 months. There are no hidden fees and no obligation. Simply choose a title, complete the application form and submit it. Read more ...

Oracle MagazineNetwork ComputingComputer WorldBio-IT WorldeWeekInformation WeekInfosecurity
 
Sign In
Join
My Latest Posts
My Monitored Threads
My Blog
My Photo Gallery
My Profile
My Homepage

Start New Thread
Enable EMail Alerts
Rate this Thread



©2008 Advenet LLC   Privacy Policy - Terms of Use
This website includes both content owned or controlled by Advenet as well as content owned or controlled by third parties.