bri189a Posted November 2, 2004 Posted November 2, 2004 So I need to have a custom type that supported all the standard binary and unary operators. So VB was immediately out of the picture...made my custom type in C# and did all the operator overloading and did some explicit and implicit conversion functions too. Everything works great in C# environment...an example of code use: [CS] ComplexType c = 4; c++; c-= 12; int i = c; c += i; System.Int64 i64 = (System.Int64) c; c = (ComplexType)--i64; [/code] All those lines above work fine in C#...notice the implict casting for Integer and the explicit for Int64. Now I compile that and open a VB project and import the reference to the DLL. Now in VB I do: Dim c as ComplexType = 15 c += 5 c = c + 5 c = CType(15, ComplexType) Here's the error on every line: Cannot convert from Integer to ComplexType... this shouldn't happen because of my implicit casting. Obviously since this is a value type I can't do DirectCast. I also went back and changed my implicit cast functions to explicit, not thinking it would make a differance...but had to try... and it didn't do anything for me of coarse. Someone told me to try turning Option Strict off; that didn't change anything; I even tried turn Option Explcit off... same error. Since I wrote the custom type in C# and compiled it, it shouldn't matter what language it was written in from there right? It's all .NET. Maybe there is a compile switch or something I don't know about or some sort of attribute, or assembly thing. Can someone point me in the right direction and tell me what I'm doing wrong...and again...everything works perfectly in C#. Quote
Mike_R Posted November 2, 2004 Posted November 2, 2004 This isn't my specialty at all... but I think you might want to try CType() here. (I know, bummer...) For Coercion between Enums and Integer Types I don't think there is any way around CType(). I have a feeling that Complex Types are likely in the same boat, but I'm not a C# guy, and don't have experience with Complex Types, and so I really can't say. So I would try CType() next, although, to be honest, I'm a bit surprised that 'Option Strict Off' did not do the trick... Quote Posting Guidelines Avatar by Lebb
Administrators PlausiblyDamp Posted November 2, 2004 Administrators Posted November 2, 2004 (edited) IIRC operator overloading is not entirely built into the .Net framework but is rather a feature of the language compiler, when C# code that uses the various operators is compiled then certain functions are emitted into the MSIL e.g. when the following is compiled public class Class1 { public static explicit operator Class1 (int i) { return new Class1(); } public static implicit operator Class1 (string s) { return new Class1(); } } the following 2 method signatures are generated .method public hidebysig specialname static class WindowsApplication2.Class1 op_Explicit(int32 i) cil managed .method public hidebysig specialname static class WindowsApplication2.Class1 op_Implicit(string s) cil managed similar methods are generated for other operators. C# will use these methods when your code calls the operator, as things stand at the moment the VB compiler doesn't support these methods and therefore cannot use the overloaded operators (the next version of VB will gain this functionality though). Also out of general curiosity is there a reason why you are requiring an explicit cast to an int64 but not an int32 - or was this just as a general example? Edited November 2, 2004 by PlausiblyDamp Quote Posting Guidelines FAQ Post Formatting Intellectuals solve problems; geniuses prevent them. -- Albert Einstein
bri189a Posted November 2, 2004 Author Posted November 2, 2004 It was a general example PD, thanks for the insight on this one, I can sleep tonight. :) Quote
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.