Solved

Form giving "specified cast is not valid" in call expecting object

Posted on 2006-11-16
1
257 Views
Last Modified: 2010-04-23
I am adding a property to some of my forms and would like to be able to check for it's existence without using error trapping (just trying to be more elegant).
I found this nice code for checking the existence of a property of an object here at EE and so implemented it (with a little customization naturally).

However, as you can see with the example calls below, it works for controls but not forms.
Does anyone know of an elegant way of doing this with forms or should I just use do something basic like use error trapping or keep a hard coded list of the forms that I want to track as having certain characteristics.

Also, I am just starting with vb.net (got years of VB2-6 though) and my understanding was that forms in vb.net were regarded as true forms/objects (in the old VB they were fudged a bit in some respects) so I am little puzzled as to why this does not work with forms, any enlightenment would be appreciated.

ret = HasProp(Myform.MyControl, "MyProperty")  ' This works
ret = HasProp(Myform, "MyProperty")  ' This does not work

Public Function HasProp(ByRef obj As Object, ByVal sProp$) As Boolean
            Dim prop As TLI.MemberInfo
            Dim TL As TLI.TLIApplication
            Dim oInterface As TLI.InterfaceInfo

            TL = New TLI.TLIApplication
            oInterface = TL.InterfaceInfoFromObject(obj) ' This is the line that gives the error: "specified cast is not valid"

            For Each prop In oInterface.Members
                  If UCase(prop.Name) = UCase(sProp) Then
                        Select Case prop.InvokeKind
                              Case _
                               TLI.InvokeKinds.INVOKE_PROPERTYGET OrElse _
                               TLI.InvokeKinds.INVOKE_PROPERTYPUT OrElse _
                               TLI.InvokeKinds.INVOKE_PROPERTYPUTREF
                                    Return True

                        End Select
                  End If
            Next

            Return False
  end function

One other question. In all the examples of this code on EE I saw something like:
                              Case INVOKE_PROPERTYGET

That would not work for me and I had to fully qualify it as:
                              Case TLI.InvokeKinds.INVOKE_PROPERTYGET

If there is something I missing on being able to use shorter qualifying I would appreciate knowing how. I did try using "with TLI.InvokeKinds" but that was not allowed, as I suspected would be the case.


0
Comment
Question by:RegProctor
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
1 Comment
 
LVL 96

Accepted Solution

by:
Bob Learned earned 250 total points
ID: 17955397
Sounds like you could be using System.Reflection calls instead:

Imports System.Reflection

...

        Dim prop As PropertyInfo = Me.GetType().GetProperty("name")

Bob
0

Featured Post

Get HTML5 Certified

Want to be a web developer? You'll need to know HTML. Prepare for HTML5 certification by enrolling in July's Course of the Month! It's free for Premium Members, Team Accounts, and Qualified Experts.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Microsoft Reports are based on a report definition, which is an XML file that describes data and layout for the report, with a different extension. You can create a client-side report definition language (*.rdlc) file with Visual Studio, and build g…
If you need to start windows update installation remotely or as a scheduled task you will find this very helpful.
Michael from AdRem Software explains how to view the most utilized and worst performing nodes in your network, by accessing the Top Charts view in NetCrunch network monitor (https://www.adremsoft.com/). Top Charts is a view in which you can set seve…
Add bar graphs to Access queries using Unicode block characters. Graphs appear on every record in the color you want. Give life to numbers. Hopes this gives you ideas on visualizing your data in new ways ~ Create a calculated field in a query: …

617 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question