Получение списка методов VB-объекта.

Здесь можно найти готовые «кирпичики» — части кода, пригодные для построения более крупных проектов, а также решения различных типовых и не очень задач на VB.

Модератор: Brickgroup

The trick
Постоялец
Постоялец
 
Сообщения: 775
Зарегистрирован: 26.06.2010 (Сб) 23:08

Получение списка методов VB-объекта.

Сообщение The trick » 04.02.2023 (Сб) 15:48

Метод возвращает список всех пользовательских публичных методов VB-объекта.

Код: Выделить всё
Option Explicit
Option Base 0

Public Enum PTR
    [_]
End Enum

Private Declare Function GetMem1 Lib "msvbvm60" ( _
                         ByRef Source As Any, _
                         ByRef Dest As Any) As Long
Private Declare Function GetMem4 Lib "msvbvm60" ( _
                         ByRef Source As Any, _
                         ByRef Dest As Any) As Long
Private Declare Function GetMemPtr Lib "msvbvm60" Alias "GetMem4" ( _
                         ByRef Source As Any, _
                         ByRef Dest As Any) As Long
Private Declare Function GetMem2 Lib "msvbvm60" ( _
                         ByRef Source As Any, _
                         ByRef Dest As Any) As Long
Private Declare Function lstrlenA Lib "kernel32" ( _
                         ByRef lpString As Any) As Long
Private Declare Function SysAllocStringByteLen Lib "oleaut32" ( _
                         ByRef psz As Any, _
                         ByVal lSize As Long) As String

' // Get list of VB6 object methods
Public Property Get ListOfMethods( _
                    ByVal cObj As Object) As String()
    Dim sRet()      As String
    Dim lIndex      As Long
    Dim lCount      As Long
    Dim pObjInfo    As PTR
    Dim pPubDesc    As PTR
    Dim pPrivDesc   As PTR
    Dim pMembers    As PTR
    Dim pMethDesc   As PTR
    Dim pVtbl       As PTR
    Dim lMethods    As Long
    Dim pNames      As PTR
    Dim pName       As PTR
    Dim lMethOffset As Long
    Dim lPropCount  As Long
    Dim lFlags      As Long
   
    GetMemPtr ByVal ObjPtr(cObj), pVtbl
    GetMemPtr ByVal pVtbl - 4, pObjInfo
    GetMemPtr ByVal pObjInfo + &H18, pPubDesc
    GetMemPtr ByVal pObjInfo + &HC, pPrivDesc
    GetMemPtr ByVal pPubDesc + &H20, pNames
   
    If pPrivDesc = 0 Then
        Exit Property
    End If
   
    GetMemPtr ByVal pPrivDesc + &H18, pMembers
    GetMem2 ByVal pPubDesc + &H1C, lMethods
   
    If lMethods = 0 Then
        Exit Property
    End If

    For lIndex = 0 To lMethods - 1
       
        GetMemPtr ByVal pMembers, pMethDesc

        If pMethDesc Then
           
            GetMem2 ByVal pMethDesc + 2, lMethOffset
           
            If lMethOffset And 1 Then
               
                lMethOffset = lMethOffset And -2
               
                GetMemPtr ByVal pNames + lIndex * Len(pName), pName
               
                If lCount Then
                    If lCount > UBound(sRet) Then
                        ReDim Preserve sRet(lCount + 10)
                    End If
                Else
                    ReDim sRet(9)
                End If
               
                sRet(lCount) = SysAllocStringByteLen(ByVal pName, lstrlenA(ByVal pName))
               
                lCount = lCount + 1
               
            End If

        End If
       
        pMembers = pMembers + 4
       
    Next
   
    GetMem2 ByVal pPrivDesc + &H10, lPropCount
    GetMemPtr ByVal pPrivDesc + &H20, pMembers
   
    For lIndex = 0 To lPropCount - 1
       
        GetMemPtr ByVal pMembers, pMethDesc
       
        If pMethDesc Then
           
            GetMem2 ByVal pMethDesc + &H10, lFlags
           
            If lFlags And 2 Then
               
                GetMemPtr ByVal pMethDesc, pName
                GetMem2 ByVal pMethDesc + &H12, lMethOffset
               
                If lCount Then
                    If lCount > UBound(sRet) Then
                        ReDim Preserve sRet(lCount + 10)
                    End If
                Else
                    ReDim sRet(9)
                End If
               
                sRet(lCount) = SysAllocStringByteLen(ByVal pName, lstrlenA(ByVal pName))
               
                lCount = lCount + 1
               
            End If
           
        End If
       
        pMembers = pMembers + 4
       
    Next
   
    If lCount Then
        ReDim Preserve sRet(lCount - 1)
    End If
   
    ListOfMethods = sRet
   
End Property
UA6527P

Вернуться в Кирпичный завод

Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 1

    TopList