News:

Pretty crazy that we're closer to 2030, than we are 2005. Where did the time go!

Main Menu

[BNET/RB] Where to start...

Started by Ryan Marcus, August 29, 2005, 09:00:25 PM

Previous topic - Next topic

0 Members and 1 Guest are viewing this topic.

rabbit

This is the buffer I am currently using, hope it helps:Option Explicit
Private Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" _
    (pDst As Any, pSrc As Any, ByVal ByteLen As Long)

Private databuff As String
Private datalen As Integer
Private epos As Integer
Private isOutbuff As Boolean

Public Event buffError(Number As Integer, Description As String, Routine As String)

Private Sub Class_Initialize()
    Call Me.Clear
End Sub

Public Sub SetOutBuff()
    isOutbuff = True
End Sub

Public Sub Clear()
    databuff = ""
    datalen = 0
    epos = 1
End Sub

Public Sub LoadBuffer(ByVal s_Data As String)
    On Error GoTo Handler
   
    Call Me.Clear
    databuff = s_Data
    datalen = Len(s_Data)
   
    On Error GoTo 0
    Exit Sub
   
Handler:
    If isOutbuff Then
        RaiseEvent buffError(Err.Number, Err.Description, "LoadBuffer()")
    End If
End Sub

Public Sub Setepos(place As Integer)
    If place > 0 And place < Len(databuff) Then epos = place
End Sub

Public Function Getepos() As Integer
    Getepos = epos
End Function

Public Sub SendPacket(socket As CSocket, PID As Byte)
    socket.SendData Chr(&HCF) & Chr(PID)
    socket.SendData MakeDBYTE(datalen + 4)
    socket.SendData databuff
   
    Call Clear
End Sub

Public Sub SendPacket2(socket As CSocket, PID As Byte, cbuff As clsBuffer)
    socket.SendData Chr(&HCF) & Chr(PID)
    socket.SendData MakeDBYTE(Len(cbuff.getBuffer()) + 4)
    socket.SendData cbuff.getBuffer()
   
    Call Clear
End Sub

Public Sub InsertSTRING(ByVal s_Data As String)
    On Error GoTo Handler
   
    datalen = datalen + Len(s_Data) + 1
    databuff = Left(databuff, datalen) & s_Data & Chr(0)
   
    On Error GoTo 0
    Exit Sub
   
Handler:
    If isOutbuff Then
        RaiseEvent buffError(Err.Number, Err.Description, "InsertSTRING()")
    End If
End Sub

Public Sub InsertBYTE(ByVal b_Data As Byte)
    On Error GoTo Handler
   
    databuff = databuff & Chr(b_Data)
    datalen = datalen + 1
   
    On Error GoTo 0
    Exit Sub
   
Handler:
    If isOutbuff Then
        RaiseEvent buffError(Err.Number, Err.Description, "InsertBYTE()")
    End If
End Sub

Public Sub InsertDBYTE(ByVal db_Data As Integer)
    On Error GoTo Handler
   
    databuff = databuff & MakeDBYTE(db_Data)
    datalen = datalen + 2
   
    On Error GoTo 0
    Exit Sub
   
Handler:
    If isOutbuff Then
        RaiseEvent buffError(Err.Number, Err.Description, "InsertDBYTE()")
    End If
End Sub

Public Sub InsertWORD(ByVal w_Data As Long)
    On Error GoTo Handler
   
    databuff = databuff & MakeWORD(w_Data)
    datalen = datalen + 4
   
    On Error GoTo 0
    Exit Sub
   
Handler:
    If isOutbuff Then
        RaiseEvent buffError(Err.Number, Err.Description, "InsertWORD()")
    End If
End Sub

Public Function getBuffer() As String
    On Error GoTo Handler
   
    If datalen = 0 Then Exit Function
   
    getBuffer = Left(databuff, datalen)
   
    On Error GoTo 0
    Exit Function
   
Handler:
    If isOutbuff Then
        RaiseEvent buffError(Err.Number, Err.Description, "getBuffer()")
    End If
End Function

Public Function ExtractSTRING() As String
    Dim ret As String
    ret = Mid(databuff, epos, InStr(epos, databuff, Chr(&H0)))
   
    ret = Left(ret, InStr(1, ret, Chr(&H0)))
    epos = epos + Len(ret)
   
    ExtractSTRING = ret
End Function

Public Function ExtractBYTE() As String
    Dim ret As String
    ret = Mid(databuff, epos, 1)
    epos = epos + 1
   
    ExtractBYTE = ret
End Function

Public Function ExtractDBYTE() As String
    Dim ret As String
    ret = Mid(databuff, epos, 2)
    epos = epos + 2
   
    ExtractDBYTE = ret
End Function

Public Function ExtractWORD() As String
    Dim ret As String
    ret = Mid(databuff, epos, 4)
    epos = epos + 4
   
    ExtractWORD = ret
End Function

Public Function ExtractDATA(LENGTH As Long) As String
    Dim ret As String
    ret = Mid(databuff, epos, LENGTH)
    epos = epos + LENGTH
   
    ExtractDATA = ret
End Function

Private Function MakeWORD(Value As Long) As String
    On Error GoTo Handler
   
    Dim Result As String * 4
    CopyMemory ByVal Result, Value, 4
    MakeWORD = Result
   
    On Error GoTo 0
    Exit Function
   
Handler:
    If isOutbuff Then
        RaiseEvent buffError(Err.Number, Err.Description, "MakeWORD()")
    End If
End Function

Private Function MakeDBYTE(Value As Integer) As String
    On Error GoTo Handler
   
    Dim Result As String * 2
    CopyMemory ByVal Result, Value, 2
    MakeDBYTE = Result
   
    On Error GoTo 0
    Exit Function
   
Handler:
    If isOutbuff Then
        RaiseEvent buffError(Err.Number, Err.Description, "MakeDBYTE()")
    End If
End Function

Public Function GetByteAsString(var As String) As String
    Dim k As Long
    Dim ret As String
   
    k = Asc(Left(var, 1))
    If k < 0 Or k > 255 Then
        GetByteAsString = "[error]"
        Exit Function
    End If
   
    ret = Hex(k)
    ret = IIf(Len(ret) = 1, "0", "") & ret
    GetByteAsString = "0x" & ret
End Function

Joe

#16
Well, mine use copymemory or cpymem or whatever you want to call it, a Win32 API. You probably won't want to use that. Regaurdless, here they are.

These can easily be written without copymemory, but seeing as how it VB instead of C(++) or whatever they wrote the API in, its a *tad* slower. I've found not to mind it. I'll write these for you, but I'm off to school in a few minutes. I'll catch ya when I get home.

EDIT -
R.a.B.B.i.T, unless you go back into the buffer to dig something out again, I find it much quicker (not compiled, but to write) if you just kill the front of the buffer instead of moving along it with a position marker.
Quote from: Camel on June 09, 2009, 04:12:23 PMI'd personally do as Joe suggests

Quote from: AntiVirus on October 19, 2010, 02:36:52 PM
You might be right about that, Joe.


rabbit

Well I use that so I can have multiple things use the same data without duplicating the buffer several times.  Do what you will.

Eric

#18
Quote from: Joex86] link=topic=2517.msg24652#msg24652 date=1125661186]
Well, mine use copymemory or cpymem or whatever you want to call it, a Win32 API. You probably won't want to use that. Regaurdless, here they are.

These can easily be written without copymemory, but seeing as how it VB instead of C(++) or whatever they wrote the API in, its a *tad* slower. I've found not to mind it. I'll write these for you, but I'm off to school in a few minutes. I'll catch ya when I get home.

EDIT -
R.a.B.B.i.T, unless you go back into the buffer to dig something out again, I find it much quiker (not compiled, but to write) if you just kill the front of the buffer instead of moving along it with a position marker.

RtlMoveMemory, or CopyMemory as it's been called since Visual Basic supported the use of API calls, is much faster than any Visual Basic-made clone.

Joe

I know that. Statistics are great. However, look on the reality side. What end user is really going to sit there and count the miliseconds used by your MakeDWORD method? Unless you do it about 1000 times over, nobody will notice.

Disclaimer:
I didn't actually test it 1000 times. It was an estimate.
Quote from: Camel on June 09, 2009, 04:12:23 PMI'd personally do as Joe suggests

Quote from: AntiVirus on October 19, 2010, 02:36:52 PM
You might be right about that, Joe.


Eric

And that's exactly why you'll never become a good programmer.

rabbit

Quote from: Joex86] link=topic=2517.msg24830#msg24830 date=1125779297]
I know that. Statistics are great. However, look on the reality side. What end user is really going to sit there and count the miliseconds used by your MakeDWORD method? Unless you do it about 1000 times over, nobody will notice.

Disclaimer:
I didn't actually test it 1000 times. It was an estimate.
API calls were added to VB for a reason, Joe.