gambas-source-code/app/examples/Networking/ClientSocket/.src/FrmMain.class
2019-05-17 10:04:14 +03:00

231 lines
6 KiB
Text

' Gambas class file
'********************************************
' THIS EXAMPLE SHOWS HOW TO USE THE 'Socket'
' CLASS FROM 'gb.net' COMPONENT
'
' (C) 2003-2004 Daniel Campos Fernández
' (danielcampos@netcourrier.com)
'********************************************
Private CurProtocol As Integer
Public Sub Form_Open()
CurProtocol = 0
End
Public Sub MySocket_Ready()
'***********************************
' When connection proccess has finished
' successfully, "Connected" event will raise
'***********************************
timTimeout.Enabled = False
If CurProtocol = 1 Then
lblMessage.Text = ("Connected to path ") & MySocket.Path
Else
lblMessage.Text = ("Connected to remote host ") & MySocket.Path
lblMessage.Text = lblMessage.Text & (" - Using local address : ") & MySocket.LocalHost & ":" & MySocket.LocalPort
End If
Me.Enabled = True
Set_Interface(True)
End
Public Sub MySocket_Closed()
'********************************************
' this event will raise when foreing host
' closes the socket by any reason
'********************************************
lblMessage.Caption = ("Connection Closed by foreign host.")
Me.Enabled = True
Set_Interface(False)
End
Public Sub MySocket_Found()
'********************************************
' this event will raise when foreing host
' name has been translated to IP
'********************************************
lblMessage.Caption = ("Host Found. Connecting...")
End
Public Sub MySocket_Read()
'****************************************
' When some data arrives from the remote
' part of the socket, "DataAvailable" event
' is raised
'****************************************
Dim S As String
If MySocket.Status = Net.Connected Then
Read #MySocket, S, Lof(MySocket)
txtReceive.Pos = txtReceive.Length
txtReceive.Insert(S)
End If
End
Public Sub MySocket_Error()
'**********************************
' this is the function to
' handle Errors when trying
' to read or write to the socket
'**********************************
Select Case MySocket.Status
Case Net.CannotCreateSocket
lblMessage.Text = ("The system does not allow to create a socket")
Case Net.HostNotFound
lblMessage.Text = ("Host not Found")
Case Net.ConnectionRefused
lblMessage.Text = ("Unable to Connect. Connection Refused")
Case Net.CannotRead
lblMessage.Text = ("Error Reading Data")
Case Net.CannotWrite
lblMessage.Text = ("Error Writing Data")
End Select
Set_Interface(False)
End
Private Sub Set_Interface(bState As Boolean)
'****************************************
' An auxiliar method to enable/disable
' controls in the formulary , when
' connection is stablished or closed
'****************************************
btnConnect.Enabled = Not bState
txtHost.Enabled = Not bState
txtPort.Enabled = Not bState
cmbProtocol.Enabled = Not bState
Label5.Enabled = Not bState
btnClose.Enabled = bState
timTimeout.Enabled = bState
'TextArea1.Enabled=bState
btnSend.Enabled = bState
txtSend.Enabled = bState
If bState Then
txtReceive.Text = ""
txtReceive.SetFocus
Endif
End
Public Sub btnConnect_Click()
'******************************************
' To connect to remote host we call to
' connectsocket method, passing Host Name
' and port as arguments
'******************************************
Dim RetVal As Integer
btnConnect.Enabled = False
Select Case CurProtocol
Case 0
' Stablishing a TCP connection.
' Here we use Host and
' Port properties, we could also
' do directly MySock.Connect(TextBox1.Text,VAL(TextBox2.Text))
MySocket.Host = txtHost.Text
MySocket.Port = Val(txtPort.Text)
MySocket.Connect()
Case 1
' Stablishing a Local connection.
' Here we use Path and
' Port properties, we could also
' do directly MySock.Connect(TextBox1.Text,0)
MySocket.Path = txtHost.Text
MySocket.Port = Net.Local
MySocket.Connect()
End Select
If MySocket.Status > Net.Inactive Then
If CurProtocol = 0 Then
'**************************
' TCP : connection in progress...
'**************************
btnClose.Enabled = True
'ME.Enabled=FALSE
lblMessage.Text = ("Looking up host name...")
timTimeout.Delay = 10000 ' we'll wait a maximun time of 10 seconds
timTimeout.Enabled = True
End If
End If
End
Public Sub timTimeout_Timer()
'***************************
' timeout trying to connect
'***************************
Me.Enabled = True
timTimeout.Enabled = False
If MySocket.Status <> Net.Connected Then
Close MySocket
Set_Interface(False)
lblMessage.Text = ("Timeout trying to stablish connection")
End If
End
Public Sub btnClose_Click()
'**********************************
' Here we close the connection
' to remote host
'**********************************
Close MySocket
Set_Interface(False)
lblMessage.Text = ("Connection closed by user")
End
Public Sub btnSend_Click()
'****************************************************
' Here we send data to the remote part of the socket.
' We have to be sure that connection is active
'****************************************************
If MySocket.Status = Net.Connected Then
Write #MySocket, txtSend.Text, Len(txtSend.Text)
txtSend.Text = ""
End If
End
Public Sub Form_Close()
'*********************
' Close possible Stablished connections
'*********************
If MySocket.Status > 0 Then Close #MySocket
End
Public Sub cmbProtocol_Click()
'**************************************************
' Here we select protocol to use : TCP,UDP or UNIX
'**************************************************
CurProtocol = cmbProtocol.Index
If CurProtocol = 0 Then
Label2.Visible = True
txtPort.Visible = True
Label1.Text = ("Host :")
Else
Label2.Visible = False
txtPort.Visible = False
Label1.Text = ("Path :")
End If
End