home *** CD-ROM | disk | FTP | other *** search
/ Visual Basic 4 Unleashed / Visual_Basic_4_Unleashed_SAMS_Publishing_1995.iso / source / chap15 / tcpecho.frm < prev    next >
Text File  |  1995-10-11  |  14KB  |  484 lines

  1. VERSION 2.00
  2. Begin Form MainForm 
  3.    BackColor       =   &H00C0C0C0&
  4.    BorderStyle     =   3  'Fixed Double
  5.    Caption         =   "Echo"
  6.    ClientHeight    =   4050
  7.    ClientLeft      =   1905
  8.    ClientTop       =   1950
  9.    ClientWidth     =   7095
  10.    FontBold        =   0   'False
  11.    FontItalic      =   0   'False
  12.    FontName        =   "MS Sans Serif"
  13.    FontSize        =   8.25
  14.    FontStrikethru  =   0   'False
  15.    FontUnderline   =   0   'False
  16.    Height          =   4740
  17.    Left            =   1845
  18.    LinkTopic       =   "Form1"
  19.    ScaleHeight     =   4050
  20.    ScaleWidth      =   7095
  21.    Top             =   1320
  22.    Width           =   7215
  23.    Begin Socket Socket2 
  24.       Backlog         =   1
  25.       Binary          =   -1  'True
  26.       Blocking        =   -1  'True
  27.       Broadcast       =   0   'False
  28.       BufferSize      =   0
  29.       HostAddress     =   ""
  30.       HostFile        =   ""
  31.       HostName        =   ""
  32.       InLine          =   0   'False
  33.       Interval        =   0
  34.       KeepAlive       =   0   'False
  35.       Left            =   600
  36.       Linger          =   0
  37.       LocalPort       =   0
  38.       LocalService    =   ""
  39.       Peek            =   0   'False
  40.       Protocol        =   0
  41.       RecvLen         =   0
  42.       RemotePort      =   0
  43.       RemoteService   =   ""
  44.       ReuseAddress    =   0   'False
  45.       Route           =   -1  'True
  46.       SendLen         =   0
  47.       TabIndex        =   15
  48.       Timeout         =   0
  49.       Top             =   3480
  50.       Type            =   1
  51.       Urgent          =   0   'False
  52.    End
  53.    Begin Socket Socket1 
  54.       Backlog         =   1
  55.       Binary          =   -1  'True
  56.       Blocking        =   -1  'True
  57.       Broadcast       =   0   'False
  58.       BufferSize      =   0
  59.       HostAddress     =   ""
  60.       HostFile        =   ""
  61.       HostName        =   ""
  62.       InLine          =   0   'False
  63.       Interval        =   0
  64.       KeepAlive       =   0   'False
  65.       Left            =   120
  66.       Linger          =   0
  67.       LocalPort       =   0
  68.       LocalService    =   ""
  69.       Peek            =   0   'False
  70.       Protocol        =   0
  71.       RecvLen         =   0
  72.       RemotePort      =   0
  73.       RemoteService   =   ""
  74.       ReuseAddress    =   0   'False
  75.       Route           =   -1  'True
  76.       SendLen         =   0
  77.       TabIndex        =   14
  78.       Timeout         =   0
  79.       Top             =   3480
  80.       Type            =   1
  81.       Urgent          =   0   'False
  82.    End
  83.    Begin CommandButton CancelButton 
  84.       Caption         =   "Cancel"
  85.       Height          =   375
  86.       Left            =   4080
  87.       TabIndex        =   11
  88.       Top             =   3480
  89.       Width           =   1215
  90.    End
  91.    Begin CommandButton ActionButton 
  92.       Caption         =   "Connect"
  93.       Height          =   375
  94.       Left            =   1800
  95.       TabIndex        =   10
  96.       Top             =   3480
  97.       Width           =   1215
  98.    End
  99.    Begin TextBox SocketInput 
  100.       BackColor       =   &H00C0C0C0&
  101.       Height          =   285
  102.       Left            =   120
  103.       TabIndex        =   9
  104.       Top             =   3000
  105.       Width           =   6855
  106.    End
  107.    Begin ListBox SocketOutput 
  108.       BackColor       =   &H00C0C0C0&
  109.       FontBold        =   0   'False
  110.       FontItalic      =   0   'False
  111.       FontName        =   "Courier New"
  112.       FontSize        =   9.75
  113.       FontStrikethru  =   0   'False
  114.       FontUnderline   =   0   'False
  115.       Height          =   1230
  116.       Left            =   120
  117.       TabIndex        =   8
  118.       Top             =   1680
  119.       Width           =   6855
  120.    End
  121.    Begin Frame ServiceFrame 
  122.       BackColor       =   &H00C0C0C0&
  123.       Caption         =   "Service"
  124.       Height          =   1455
  125.       Left            =   3600
  126.       TabIndex        =   13
  127.       Top             =   120
  128.       Width           =   3375
  129.       Begin SpinButton Spin1 
  130.          Delay           =   150
  131.          Height          =   285
  132.          Left            =   1560
  133.          Top             =   840
  134.          Width           =   255
  135.       End
  136.       Begin TextBox ServicePort 
  137.          BackColor       =   &H00C0C0C0&
  138.          Height          =   285
  139.          Left            =   840
  140.          TabIndex        =   7
  141.          Top             =   840
  142.          Width           =   735
  143.       End
  144.       Begin TextBox ServiceName 
  145.          BackColor       =   &H00C0C0C0&
  146.          Height          =   285
  147.          Left            =   840
  148.          TabIndex        =   5
  149.          Top             =   480
  150.          Width           =   2175
  151.       End
  152.       Begin Label Label4 
  153.          BackStyle       =   0  'Transparent
  154.          Caption         =   "&Port:"
  155.          Height          =   255
  156.          Left            =   120
  157.          TabIndex        =   6
  158.          Top             =   840
  159.          Width           =   495
  160.       End
  161.       Begin Label Label3 
  162.          BackStyle       =   0  'Transparent
  163.          Caption         =   "&Name:"
  164.          Height          =   255
  165.          Left            =   120
  166.          TabIndex        =   4
  167.          Top             =   480
  168.          Width           =   615
  169.       End
  170.    End
  171.    Begin Frame RemoteFrame 
  172.       BackColor       =   &H00C0C0C0&
  173.       Caption         =   "System"
  174.       Height          =   1455
  175.       Left            =   120
  176.       TabIndex        =   12
  177.       Top             =   120
  178.       Width           =   3375
  179.       Begin ComboBox Hostname 
  180.          BackColor       =   &H00C0C0C0&
  181.          Height          =   300
  182.          Left            =   1200
  183.          Sorted          =   -1  'True
  184.          TabIndex        =   1
  185.          Top             =   480
  186.          Width           =   1935
  187.       End
  188.       Begin TextBox IPAddress 
  189.          BackColor       =   &H00C0C0C0&
  190.          Height          =   285
  191.          Left            =   1200
  192.          TabIndex        =   3
  193.          Top             =   840
  194.          Width           =   1575
  195.       End
  196.       Begin Label Label2 
  197.          BackStyle       =   0  'Transparent
  198.          Caption         =   "IP &Address:"
  199.          Height          =   255
  200.          Left            =   120
  201.          TabIndex        =   2
  202.          Top             =   840
  203.          Width           =   1095
  204.       End
  205.       Begin Label Label1 
  206.          BackStyle       =   0  'Transparent
  207.          Caption         =   "&Hostname:"
  208.          Height          =   255
  209.          Left            =   120
  210.          TabIndex        =   0
  211.          Top             =   480
  212.          Width           =   975
  213.       End
  214.    End
  215.    Begin Menu FileMenu 
  216.       Caption         =   "&File"
  217.       Begin Menu ExitApp 
  218.          Caption         =   "E&xit"
  219.       End
  220.    End
  221.    Begin Menu OptionsMenu 
  222.       Caption         =   "&Options"
  223.       Begin Menu ServerOption 
  224.          Caption         =   "Echo Server"
  225.       End
  226.    End
  227. End
  228.  
  229. Sub ActionButton_Click ()
  230.     If Not Socket1.Connected Then
  231.         On Error Resume Next
  232.         HostName.Text = Trim$(HostName.Text)
  233.         IPAddress.Text = Trim$(IPAddress.Text)
  234.         If Len(HostName.Text) > 0 Then
  235.             Socket1.HostName = HostName.Text
  236.             IPAddress.Text = Socket1.HostAddress
  237.         ElseIf Len(IPAddress.Text) > 0 Then
  238.             Socket1.HostAddress = Trim$(IPAddress.Text)
  239.             HostName.Text = Socket1.HostName
  240.         Else
  241.             MsgBox "No system name or address specified"
  242.             Exit Sub
  243.         End If
  244.         ServiceName.Text = Trim$(ServiceName.Text)
  245.         ServicePort.Text = Trim$(ServicePort.Text)
  246.         If Len(ServiceName.Text) > 0 Then
  247.             Socket1.RemoteService = ServiceName.Text
  248.             ServicePort.Text = Trim$(Str$(Socket1.RemotePort))
  249.         ElseIf Len(ServicePort) > 0 Then
  250.             Socket1.RemotePort = Val(Trim$(ServicePort.Text))
  251.             ServiceName.Text = Socket1.RemoteService
  252.         Else
  253.             MsgBox "No service name or port specified"
  254.             Exit Sub
  255.         End If
  256.         Socket1.LocalPort = IPPORT_ANY
  257.         Socket1.Action = SOCKET_CONNECT
  258.         If Err <> 0 Then Exit Sub
  259.         ActionButton.Enabled = False
  260.         ActionButton.Default = False
  261.     Else
  262.         Socket1.Action = SOCKET_CLOSE
  263.         ActionButton.Caption = "Connect"
  264.         ActionButton.Default = True
  265.         HostName.SetFocus
  266.     End If
  267.     Exit Sub
  268. End Sub
  269.  
  270. Sub CancelButton_Click ()
  271.     Unload MainForm
  272. End Sub
  273.  
  274. Sub ExitApp_Click ()
  275.     Unload MainForm
  276. End Sub
  277.  
  278. Sub Form_Load ()
  279.     '
  280.     ' Initialize the socket control
  281.     '
  282.     Socket1.AddressFamily = AF_INET
  283.     Socket1.Binary = False
  284.     Socket1.Blocking = False
  285.     Socket1.BufferSize = 1024
  286.     Socket1.Protocol = IPPROTO_IP
  287.     Socket1.Type = SOCK_STREAM
  288.     Socket1.RemoteService = "echo"
  289.  
  290.     Socket2.AddressFamily = AF_INET
  291.     Socket2.Binary = True
  292.     Socket2.Blocking = False
  293.     Socket2.HostAddress = INADDR_ANY
  294.     Socket2.Protocol = IPPROTO_IP
  295.     Socket2.Type = SOCK_STREAM
  296.     Socket2.LocalService = "echo"
  297.     
  298.     '
  299.     ' Initialize hostname combo box
  300.     '
  301.     On Error Resume Next
  302.     Socket1.HostFile = "HOSTS"
  303.     If Err = 0 Then
  304.         Host$ = Socket1.GetFirstHost
  305.         While Host$ <> ""
  306.             HostName.AddItem Host$
  307.             Host$ = Socket1.GetNextHost
  308.         Wend
  309.     End If
  310.     Socket1.HostFile = ""
  311.  
  312.     '
  313.     ' Initialize the other controls
  314.     '
  315.     ActionButton.Caption = "Connect"
  316.     ActionButton.Default = True
  317.     ActionButton.Enabled = False
  318.     ServiceName.Text = Socket1.RemoteService
  319.     ServicePort.Text = Trim$(Str$(Socket1.RemotePort))
  320. End Sub
  321.  
  322. Sub Form_Unload (Cancel As Integer)
  323.     If Socket1.Connected Then Socket1.Action = SOCKET_CLOSE
  324.     If Socket2.Listening Or Socket2.Connected Then Socket2.Action = SOCKET_CLOSE
  325.     End
  326. End Sub
  327.  
  328. Sub Hostname_Change ()
  329.     If Len(HostName.Text) > 0 Or Len(IPAddress.Text) > 0 Then
  330.         ActionButton.Enabled = True
  331.     Else
  332.         ActionButton.Enabled = False
  333.     End If
  334. End Sub
  335.  
  336. Sub Hostname_GotFocus ()
  337.     HostName.SelStart = 0
  338.     HostName.SelLength = Len(HostName.Text)
  339. End Sub
  340.  
  341. Sub Hostname_KeyPress (KeyAscii As Integer)
  342.     IPAddress.Text = ""
  343. End Sub
  344.  
  345. Sub IPAddress_Change ()
  346.     If Len(HostName.Text) > 0 Or Len(IPAddress.Text) > 0 Then
  347.         ActionButton.Enabled = True
  348.     Else
  349.         ActionButton.Enabled = False
  350.     End If
  351. End Sub
  352.  
  353. Sub IPAddress_GotFocus ()
  354.     IPAddress.SelStart = 0
  355.     IPAddress.SelLength = Len(IPAddress.Text)
  356. End Sub
  357.  
  358. Sub IPAddress_KeyPress (KeyAscii As Integer)
  359.     HostName.Text = ""
  360. End Sub
  361.  
  362. Sub ServerOption_Click ()
  363.     If Not Socket2.Connected Then
  364.         ServerOption.Checked = Not ServerOption.Checked
  365.         If ServerOption.Checked Then
  366.             Socket2.Action = SOCKET_LISTEN
  367.         Else
  368.             Socket2.Action = SOCKET_CLOSE
  369.         End If
  370.     End If
  371. End Sub
  372.  
  373. Sub ServiceName_GotFocus ()
  374.     ServiceName.SelStart = 0
  375.     ServiceName.SelLength = Len(ServiceName.Text)
  376. End Sub
  377.  
  378. Sub ServiceName_KeyPress (KeyAscii As Integer)
  379.     ServicePort.Text = ""
  380. End Sub
  381.  
  382. Sub ServicePort_GotFocus ()
  383.     ServicePort.SelStart = 0
  384.     ServicePort.SelLength = Len(ServicePort.Text)
  385. End Sub
  386.  
  387. Sub ServicePort_KeyPress (KeyAscii As Integer)
  388.     ServiceName.Text = ""
  389.     If KeyAscii > Asc("9") Then
  390.         KeyAscii = 0
  391.         Beep
  392.     ElseIf KeyAscii >= Asc("0") And Len(ServicePort.Text) > 5 Then
  393.         KeyAscii = 0
  394.         Beep
  395.     End If
  396. End Sub
  397.  
  398. Sub Socket1_Close ()
  399.     Socket1.Action = SOCKET_CLOSE
  400.     ActionButton.Caption = "Connect"
  401.     ActionButton.Default = True
  402.     HostName.SetFocus
  403. End Sub
  404.  
  405. Sub Socket1_Connect ()
  406.     MainForm.MousePointer = 0
  407.     ActionButton.Caption = "Close"
  408.     ActionButton.Enabled = True
  409.     SocketInput.SetFocus
  410. End Sub
  411.  
  412. Sub Socket1_Error (ErrCode As Integer, ErrMsg As String, Response As Integer)
  413.     If Socket1.Action = SOCKET_CONNECT Then
  414.         MsgBox ErrMsg, 0, "Connect"
  415.         Response = SOCKET_ERRIGNORE
  416.         Socket1.Action = SOCKET_CLOSE
  417.         ActionButton.Caption = "Connect"
  418.         ActionButton.Default = True
  419.         ActionButton.Enabled = True
  420.         Exit Sub
  421.     End If
  422. End Sub
  423.  
  424. Sub Socket1_Read (DataLength As Integer, IsUrgent As Integer)
  425.     Socket1.RecvLen = DataLength
  426.     SocketOutput.AddItem Socket1.RecvData
  427.     SocketOutput.ListIndex = SocketOutput.ListCount - 1
  428.     SocketOutput.Selected(SocketOutput.ListIndex) = False
  429. End Sub
  430.  
  431. Sub Socket2_Accept (SocketId As Integer)
  432.     Socket2.Action = SOCKET_ACCEPT
  433. End Sub
  434.  
  435. Sub Socket2_Close ()
  436.     Socket2.Action = SOCKET_CLOSE
  437.     If ServerOption.Checked Then
  438.         Socket2.ReuseAddress = True
  439.         Socket2.Action = SOCKET_LISTEN
  440.     End If
  441. End Sub
  442.  
  443. Sub Socket2_Read (DataLength As Integer, IsUrgent As Integer)
  444.     Socket2.RecvLen = DataLength
  445.     Socket2.SendLen = DataLength
  446.     Socket2.SendData = Socket2.RecvData
  447. End Sub
  448.  
  449. Sub SocketInput_KeyPress (KeyAscii As Integer)
  450.     If KeyAscii = 13 Then
  451.         KeyAscii = 0
  452.         Socket1.SendLen = Len(SocketInput.Text) + 2
  453.         Socket1.SendData = SocketInput.Text & Chr(13) & Chr(10)
  454.         SocketInput.Text = ""
  455.     End If
  456. End Sub
  457.  
  458. Sub Spin1_SpinDown ()
  459.     Dim Value As Integer
  460.  
  461.     Value = Val(ServicePort.Text) - 1
  462.     If Value >= 0 Then
  463.         Socket1.RemotePort = Value
  464.         ServiceName.Text = Socket1.RemoteService
  465.         ServicePort.Text = Trim(Str(Value))
  466.     Else
  467.         Beep
  468.     End If
  469. End Sub
  470.  
  471. Sub Spin1_SpinUp ()
  472.     Dim Value As Integer
  473.  
  474.     Value = Val(ServicePort.Text) + 1
  475.     If Value > 0 Then
  476.         Socket1.RemotePort = Value
  477.         ServiceName.Text = Socket1.RemoteService
  478.         ServicePort.Text = Trim(Str(Value))
  479.     Else
  480.         Beep
  481.     End If
  482. End Sub
  483.  
  484.