Hummingbird Basic
Hummingbird Basic
Programmer’s Guide
8157-6M
Hummingbird Basic Language Programmer’s Guide
0800 8157-6M
05/31/02
Hummingbird Ltd.
1 Sparks Avenue, Toronto, Ontario, Canada M2H 2W1
Tel: +1-416-496-2200 Toll Free Canada/USA: 1-877-FLY-HUMM (1-877-359-4866)
Fax: +1-416-496-2207
E-mail: support@hummingbird.com or getinfo@hummingbird.com
FTP: ftp.hummingbird.com
For more information, visit www.hummingbird.com
RESTRICTED RIGHTS LEGEND. Unpublished rights reserved under the copyright laws of the United States. The SOFTWARE is provided with
restricted rights. Use, duplications, or disclosure by the U.S. Government is subject to restrictions as set forth in subparagraph (c) (1)(ii) of The
Rights in Technical Data and Computer Software clause at DFARS 252.227-7013, subparagraph (c)(1) and (2) (a) (15) of the Commercial Computer
Software-Restricted Rights clause at 48 CFR 52.227-19, as applicable, similar clauses in the FAR and NASA FAR Supplement, any successor or
similar regulation.
Information in this document is subject to change without notice and does not represent a commitment on the part of Hummingbird Ltd. Not all
copyrights pertain to all products.
© 1990–2002 Hummingbird Ltd. All rights reserved.
Exceed, Exceed 3D, Exceed onDemand, Exceed PowerSuite, Exceed X Development Kit, Exceed Web, HostExplorer Print Services, HostExplorer,
HostExplorer Web, HostExplorer Deployment Wizard, Hummingbird Connectivity Security Pack, Hummingbird Basic Language,
Hummingbird Portal, Hummingbird Core Services, Hummingbird e-Toolkit, JuMP, Enterprise Toolkit for JuMP, Hummingbird e-Gateway,
Hummingbird FTP, Hummingbird G2G, Hummingbird Web Server, Hummingbird SOCKS Client, NFS Maestro Client, NFS Maestro Gateway,
NFS Maestro Server, NFS Maestro Solo, PrintExplorer, and XWeb are trademarks of Hummingbird Ltd. and/or its subsidiaries.
ACKNOWLEDGEMENTS Portions of the code have been contributed by MIT. Portions copyright © Blue Sky Software Corporation. All rights
reserved. All other copyrights, trademarks, and tradenames are the property of their respective owners.
DISCLAIMER Hummingbird Ltd. software and documentation has been tested and reviewed. Nevertheless, Hummingbird Ltd. makes no
warranty or representation, either express or implied, with respect to the software and documentation included. In no event will Hummingbird Ltd.
be liable for direct, indirect, special, incidental, or consequential damages resulting from any defect in the software or documentation included with
these products. In particular, Hummingbird Ltd. shall have no liability for any programs or data used with these products, including the cost of
recovering such programs or data.
ii
Related Documentation and Services
Manuals
All manuals are available in print and online. The online versions require Adobe Acrobat Reader 5.0 and are installed
only if you do a Complete installation.
Help
The online Help is a comprehensive, context-sensitive collection of information regarding your Hummingbird product.
It contains conceptual and reference information, and detailed, step-by-step procedures to assist you in completing your
tasks.
Release Notes
The release notes for each product contain descriptions of the new features and details on release-time issues. They are
available in both print and HTML. The HTML version can be installed with the software. Read the release notes before
installing your product.
iii
Hummingbird Exposé Online
Hummingbird Exposé Online is an electronic mailing list and online newsletter. It was created to facilitate the delivery
of Hummingbird product-related information. It also provides tips, help, and interaction with Hummingbird users. To
subscribe/unsubscribe, browse to the following web address:
http://www.hummingbird.com/expose/about.html
To unsubscribe:
Send an e-mail to listserv@hummingbird.com. Leave the Subject line blank. In the body of the e-mail message, type the
following:
unsubscribe exceedusers Your Name
unsubscribe hostexplorer-users Your Name
unsubscribe nfsmaestro-users Your Name
iv
Contents
v
Hummingbird Basic Language Programmer’s Guide
vi
Contents
vii
Hummingbird Basic Language Programmer’s Guide
Glossary 107
Index 111
viii
Chapter 1
Introducing Hummingbird Basic
Note: Xlib API commands are available only if you purchased the
Exceed product. Use only the applications that have OLE API
libraries with Hummingbird BASIC.
3
Hummingbird Basic Language Programmer’s Guide
Development Tools
Hummingbird Basic includes the following development tools:
Workbench A development environment to write, compile and debug
your scripts.
Dialog Editor Accessed from Workbench, this drag-and-drop dialog box
editor lets you design a dialog box without having to manually code one.
When you are finished designing, the code for the dialog box is
automatically generated and updated into your script.
Variable Scope
The placement of variable declarations determines their scope.
4
Chapter 1: Introducing Hummingbird Basic
Data Types
Modern BASIC is now a typed language. In addition to the standard data
types—numeric, string, array, and record—Hummingbird Basic also
includes variants and objects.
Variables that are defined as variants can store any type of data. For
example, the same variable can hold integers one time, and then, later in a
procedure, it can hold strings.
Objects give you the ability to manipulate complex data supplied by an
application, such as Windows, Forms, or OLE objects.
5
Hummingbird Basic Language Programmer’s Guide
6
Chapter 2
Hummingbird Basic Scripts
Sample Scripts 9
Programming Terminology 11
Structure of a Hummingbird Basic Script 12
Variable Scope 13
Functions and Control Statements 13
Control Statements 16
Variables, Constants, and Data Types 16
Variables and Constants 17
Data Types 18
Expressions and Operators 26
Numeric Operators 26
String Operators 26
Comparison Operators 27
Logical Operators 27
Programming Tips and Coding Suggestions 28
Naming Variables and Constants 28
Global Variables 28
Declaring Variables 28
Option Base 28
Dynamic Array 28
Runtime Error 29
Controls 29
Compatibility 29
Checking for the Existence of PC Files 29
Using Win32 API 30
Network Logon Name 30
Always Visible Message Box 31
Working with Windows Registry 32
OLE Functions 33
Error-Handling and Debugging 34
Error Types 34
Debugging Scripts for Syntax and Logic Errors 35
Handling Runtime Errors 36
Trapping Errors 36
Chapter 2: Hummingbird Basic Scripts
Sample Scripts
Before starting, you may find it useful to review the provided sample scripts.
Source files (.ebs) and their associated compiled files (.ebx) are located in
the user directory under
Applications
Data\Hummingbird\Connectivity\version\Accessories\Eb
The following sample scripts are provided:
dialog.ebs This sample script displays the various types of dialogs that
Hummingbird Basic can use. It also stores information as shown below that
you either select or press, and displays it when you press Exit.
• Input Boxes
• OK, Cancel Button
• Text Boxes
• Combo Boxes
• Drop Down Lists
• List Boxes
• Option Groups
• Push Buttons
testftp.ebs FTP automation using OLE. This sample script demonstrates
how you can use FTP OLE functions to log onto a host and download a file
automatically.
dde.ebs This sample script creates a Program Group called “XXX”.
filelist.ebs This OLE example is a Hummingbird Basic macro that
facilitates the downloading of files from a CMS or TSO account. It must be
run from the “Ready” prompt of a CMS or TSO HostExplorer session.
pastword.ebs This macro copies a screen from HostExplorer, starts
Microsoft Word and pastes the screen to Word. You need to have
HostExplorer running before you run the script.
9
Hummingbird Basic Language Programmer’s Guide
test1.ebs This sample script lists the index of the field attribute which
contains the field at the given position. You can also simply list each row of
the screen instead. The current OIA is displayed below the list box.
(Demonstrates usage of host.rows and host.columns methods).
test2.ebs This script demonstrates how to access information using the
Field object. In TCP3270, you can access the screen as an entire string, row
by row, or using field objects. The advantage of the field objects is that they
are not dependent upon their position.
test3.ebs This is a demonstration of configuring TN3270 using the
appropriate method. The Cfg3270 sub-object configures the emulator.
Anything that can be configured via the user dialogs can be configured
using the Cfg3270 object.
test4.ebs This sample script demonstrates how to perform file transfers to
a host system. The file transfer is implemented in an asynchronous manner
allowing the script to continue to run while the file transfer is taking place.
The method IsXfer tests if the file transfer is complete. You can also use the
WaitXfer method to wait until the file transfer completes.
10
Chapter 2: Hummingbird Basic Scripts
Programming Terminology
11
Hummingbird Basic Language Programmer’s Guide
A subprocedure is defined with the Sub...End Sub statement. You invoke it,
either with the Call statement, or by entering it on a line by itself. If you use
the Call statement, enclose any arguments you are passing to the
subprocedure in parentheses. For example, the following two statements are
equivalent:
GetFTP file1,file2,file3
Call GetFTP(file1,file2,file3)
12
Chapter 2: Hummingbird Basic Scripts
Variable Scope
The placement of variable declarations determines their scope.
Scope Definition
13
Hummingbird Basic Language Programmer’s Guide
If an argument is passed by value, it means that the variable used for that
argument retains its value when the function returns to the caller. If an
argument is passed by reference, it means that the variable's value might be
(and probably will be) changed for the calling procedure. For example,
suppose you set the value of a variable X to 5, and pass X as an argument to
a subprocedure, named mysub. If you pass X by value to mysub, the value of
X will always be 5 after mysub returns. If you pass X by reference to mysub,
however, X could be 5 or any other value depending on the outcome of
mysub.
or
y=myfunction((X))
Call myfunction((X))
or
y=myfunction(X)
Call myfunction(X)
Named Arguments
When you call a function that takes arguments, you usually supply values
for those arguments by listing them in the order shown in the syntax for the
statement or function.
For example, suppose you define a function this way:
myfunction(id$,action%,suppvalue&)
14
Chapter 2: Hummingbird Basic Scripts
Myfunction requires three arguments: id, action, and value. When you call
this function, you supply those arguments in the order shown. If the
function contains just a few arguments, it is fairly easy to remember the
order of each of the arguments. However, if a function has several
arguments, and you want to be sure the values you supply are assigned to
the correct arguments, use named arguments.
Named arguments are identified by name rather than by their position in
the syntax. To use a named argument, use the following syntax:
namedarg:=value
Note: Although you can shift the order of named arguments, you
cannot omit required arguments.
15
Hummingbird Basic Language Programmer’s Guide
Control Statements
Control statements provide the flow of logic in your script. These
statements direct the script as to when, if, and how a set of commands are
performed and executed. The following control statements can be included
in your script:
If...Then... Else
For...Next
Do...Loop
While...Wend
Select Case
On...Goto
Variables store values that are returned from statements and functions. A
variable is given a name, and then assigned a data type. Its data type
determines the kind of value that is stored by the variable.
Hummingbird Basic supports standard BASIC data types such as Numeric,
String, record, array, and Variant data types. With the exception of Variant
type variables, the variable you define can contain only data of the declared
type. In addition to this, Hummingbird Basic also supports Dialog Box
Records and Objects as data types.
16
Chapter 2: Hummingbird Basic Scripts
Dimensioned Variables
For more information on If a variable is declared at the beginning of your script with the Dim
variable scoping, see statement, it is available throughout the script. To reduce the scope of a
“Structure of a variable to a function or a subprocedure, either declare the variable in the
Hummingbird Basic
Script” on page 12.
function, or in the body of the subprocedure. For example:
Function interact(id$)
Dim myvariable as Integer
End Function
Defined Constants
Defined constants retain the value they are assigned throughout a script,
whenever they are referenced in a function or statement.
Constant variables are declared with the Const statement. For example:
Const conPI= 3.14159265358979
17
Hummingbird Basic Language Programmer’s Guide
Global Variables
Declare a global variable only if you want to keep the same variable type for
all of your related Hummingbird Basic modules. Global data is shared
across all loaded modules. If an attempt is made to load a module that has a
global variable of a different data type than the existing global variable of
the same name, the module load will fail.
Static Variables
For more information on A Static variable retains its value when it is called from one function to
static variables, see another. These variable types are generally used by advanced users.
Hummingbird Basic
Language Help.
Data Types
As you name and declare your variable, you assign it a data type. The data
type determines what kind of value is stored in the variable. The variable
can only contain data of the declared type, except when you implicitly or
explicitly declare a variable as a Variant data type.
If a variable is not explicitly defined with the Dim or Global statements, or is
not declared a data type (implicitly declared), then it defaults to the Variant
data type.
18
Chapter 2: Hummingbird Basic Scripts
Another way to explicitly declare a variable and its type, without having to
type out the entire syntax, is to use data type characters. Data type
characters are appended to the end of your variable name.
For example, these two statements are equivalent:
Dim bird As String
Dim bird$
% Integer 1 byte
? Portable integer
Variant
A Variant variable can hold any type of data. This variable changes its data
type depending on how it is assigned. To examine the type of data that a
Variant variable contains, use the VarType function.
Values returned by this function are explained in the table below.
Variant
Name Size of Data Range
Type
0 Empty 0 N/A
1 Null 0 N/A
19
Hummingbird Basic Language Programmer’s Guide
Variant
Name Size of Data Range
Type
Any newly defined Variant defaults to the Empty type to signify that it
contains no initialized data. An empty Variant converts to zero when used
in a numeric expression, or an empty string in a string expression.
Null Variants have no associated data, and serve only to represent invalid or
ambiguous results. Null is not the same as Empty, which indicates that a
Variant has not yet been initialized.
Numeric
If the variable you declare in your script is a number, you should define its
type. There are six Numeric types. These types are shown in the table below.
Type From To
20
Chapter 2: Hummingbird Basic Scripts
Type From To
String
String variables contain text. String length can be either fixed or dynamic.
Fixed strings have a length specified when they are defined, and the length
cannot be changed. Fixed strings cannot be of 0 length. Dynamic strings
have no specified length. A string can vary in length from 0 to 32,767
characters. There are no restrictions on the type of characters which can be
included in a string. For example, the character whose binary value is 0 can
also be embedded in strings.
21
Hummingbird Basic Language Programmer’s Guide
Object
An object is a special data type. Objects let you communicate with another
Windows application using OLE automation. You can use Hummingbird
Basic as an automation controller to manipulate another application. An
object is a complex data type in which the elements of the data type are the
methods and properties of the other application.
Properties This determines how an object behaves. For example, width
can be a property of a range of cells in a spreadsheet; colors are a property of
graphs; and margins are a property of word processor documents.
Methods This causes the application to do something. Examples are:
Calculate for a spread sheet, Snap to Grid for a graph, and Autosave for a
document.
Array
An Array is a predefined range or series of variables. You must specify the
data type of an array. Hummingbird Basic arrays can be any one of the
following:
• Numeric
• String
• Variant
• Record
22
Chapter 2: Hummingbird Basic Scripts
For example:
Dim lifespan(0 to 75) As Integer
Subscripts specify the beginning and ending index for each dimension. If
you specify only an ending index, then the beginning index depends on the
Option Base setting. The Option Base statement specifies the lower bound
to be used for array subscripts. The lower bound can be either 0 or 1. If no
Option Base is specified, then the default of 0 is used.
Dynamic Array
If you do not know what the size of your array is going to be, then use a
dynamic array. Dynamic arrays differ from fixed arrays in that you do not
specify a subscript range for the array elements when you declare the array.
Instead, the subscript range is set using the ReDim statement.
For example, you might want to use an array to store a set of values entered
by a user, but you do not know in advance how many values the user will
enter. In this case, dimension the array without specifying a subscript range,
and then execute a ReDim statement (which reallocates memory) each time
the user enters a new value.
If the dynamic array is dimensioned with the Dim statement, then 8 is the
maximum number of dimensions it can have. To create dynamic arrays with
more dimensions (up to 60), do not Dim the array; instead, use the ReDim
statement inside your procedure.
23
Hummingbird Basic Language Programmer’s Guide
The following procedure uses a dynamic array, varray, to hold cash flow
values entered by the user:
Sub Main
Dim aprate as Single
Dim varray() as Double
Dim cflowper as Integer
Dim msgtext
Dim x as Integer
Dim netpv as Double
cflowper = InputBox("Enter number of cash flow periods")
ReDim varray(cflowper)
For x = 1 to cflowper
varray(x) = InputBox("Enter cash flow amount for period
#" & x & ":")
Next x
aprate = InputBox("Enter discount rate: ")
If aprate > 1 then
aprate = aprate/100
End If
netpv = NPV(aprate,varray())
msgtext = "The net present value is: "
msgtext = msgtext & Format(netpv, "Currency")
MsgBox msgtext
End Sub
24
Chapter 2: Hummingbird Basic Scripts
Record
A record, or record variable, is a data structure containing one or more
elements, each of which has a value.
Where an array defines a range of values, all of the same data type (for
example, String or Integer), a record variable references a range of values
that can be of different data types.
Note: You cannot use data type character suffixes when using
record data types.
Before defining a record element as a variable, you must assign each element
a type, using the Type statement.
The following example defines phone_number as a data type:
Type phone_number
phone as String
area_code as String
End Type
Dialog box records are treated as record data types as well. Elements or
controls are referenced using the same dialogname.controlname syntax. The
difference is that each element is tied to a control of a dialog box.
25
Hummingbird Basic Language Programmer’s Guide
Numeric Operators
These operators are used in arithmetic expressions:
Operand Explanation
^ Exponentiation
String Operators
These operators are used to combine or concatenate two or more strings:
Operand Explanation
+ String Concatenation
26
Chapter 2: Hummingbird Basic Scripts
Comparison Operators
When using comparison operators with numbers, the operands are
widened to the type with the smallest size (Integer is preferred over Long,
which is preferred over Double). For String operators, the comparison is
case-sensitive, and is based on the collating sequence used by the language
specified in the Windows Control Panel.
Logical Operators
The logical operators perform logical evaluations on one or more
expressions. The result of logical operations is either True or False.
Operand Explanation
27
Hummingbird Basic Language Programmer’s Guide
The following tips and suggestions are intended to help reduce the errors
returned when creating scripts with Hummingbird Basic.
Global Variables
Limit the use of global variables to avoid a module load failure. Global data
is shared across all loaded modules, so when you attempt to load a module
which has a different data type variable than that of the existing global
variable with the same name, it results in the module failing to load.
Declaring Variables
Explicitly declare all variables, especially so that error tracking is possible in
long and complicated scripts. Use the Option Explicit command to force
the use of variable declarations.
Option Base
The Option Base statement specifies the lower bound to be used for array
subscripts. This statement is not allowed inside a procedure, and it must
precede any use of arrays in the module. Only one Option Base statement is
allowed per module.
Dynamic Array
Eight is the maximum number of dimensions for a dynamic array being
dimensioned using the Dim statement. However, to create dynamic arrays
with more dimensions (up to 60), use the ReDim statement instead of the Dim
statement inside your procedure.
28
Chapter 2: Hummingbird Basic Scripts
Runtime Error
Have a routine in your script that handles runtime errors, such as if the user
tries to log onto a non-existent host, or enters text into a field where only
numbers are accepted.
Controls
Before aligning the controls for a dialog box, click the Grid toolbar button to
turn the grid on.
Compatibility
You can use a single set of source code to create applications that run on
Windows NT/95/98/Me/2000. To create an application, load the source
code into Hummingbird Basic and make an.ebx file.
To find a file on a Unix computer, use the same technique, but instead of
DIR$, use the string returned by the UNIX ls file name command.
29
Hummingbird Basic Language Programmer’s Guide
30
Chapter 2: Hummingbird Basic Scripts
31
Hummingbird Basic Language Programmer’s Guide
32
Chapter 2: Hummingbird Basic Scripts
OLE Functions
Use OLE automation to work with FTP and Telnet using Hummingbird
Basic.
The following two examples show you how you could execute an FTP
session.
1 You have to declare an object as a data type before you can use the
object's methods.
dim FtpEngine As Object
dim FtpSession As Object
dim FtpSessions As Object
' Must first initialize Ftp Engine
Set FtpEngine = CreateObject ("HclFtp.Engine")
'Create collection of sessions
on error goto FtpSessionsError
Set FtpSessions = FtpEngine.Sessions
'Create FTP session
on error goto FtpSessionError
SetFtpSession = FtpSessions.NewSession
FtpSessions.LocalDefaultDirectory = "c:\temp"
'normally should be_ taken via dialog
33
Hummingbird Basic Language Programmer’s Guide
The following example shows how the start of a Telnet session can look:
' if current EMPTY telnet session exists, get it as a tn
object or step to the next line:
Set tn = GetObject (, "Hummingbird.Telnet")
'if failed to get existing object, create new telnet_ object
If tn is Nothing then
Set tn = CreateObject("Hummingbird.Telnet")
end if
loginEvent = tn.LookForString(loginPrompt)
'look for the login_ and password prompt
passwordEvent = tn.LookForString(passwordPrompt)
Error Types
After you compile or run your script, any or all of the following types of
errors may be detected:
• Syntax errors—These are errors which occur in the script as a result of
misspelling a statement or function or using either one incorrectly, for
example, errors in language syntax and programming logic. To help you
fix syntax errors, the Hummingbird Script Editor highlights language
syntax errors in red after a script is compiled.
34
Chapter 2: Hummingbird Basic Scripts
• Logic errors—These are errors that occur because of faulty logic, for
example, infinite loops and incorrect values returned by functions.
These types of errors generally cause unexpected results during the
execution of your script.
• Runtime errors—These errors occur because the user takes an
unforeseen action. For example, the user tries to log on to a host that
does not exist, or types text into a field that accepts only numbers. You
should have a routine for these scenarios included in your script that
handles runtime errors. Runtime errors are handled through a set of
error-handling functions and statements.
35
Hummingbird Basic Language Programmer’s Guide
When in debug mode, the Call Stack Control displays all Hummingbird
Basic subprocedures and function calls that got you to the current line.
Open the Variables window to examine the contents of variables in the
currently selected call frame.
Note: Lines that contain syntax errors appear in red text. The Error
Messages and a short description of the error, if available, are
displayed in the Output window.
Function/Statement Explanation
Trapping Errors
Hummingbird Basic provides two methods for handling errors:
On Error Resume Next Use this statement to bypass an error and
continue to execute the script. The On Error Resume Next statement must
appear before the line that produces the error.
36
Chapter 2: Hummingbird Basic Scripts
On Error Goto label Use this statement to direct the execution of the
script to the specified label. When this error trap is set, it remains in effect
until the procedure finishes running. You can redirect the error trap with
another On Error statement in the procedure. If you want to cancel the
existing error trap without setting up another one, use the On Error GoTo 0
statement.
All error handling subprocedures begin with the On Error statement and
end either with the Resume statement or the Goto statement. Unless an On
Error statement is used, any run-time error terminates the execution of the
script. Error-handling procedures are embedded within a subprocedure,
usually near the end of a subprocedure. If a Goto statement is used, the
Resume statement is expected at the end of the error-handling code.
Example 1
This example places error-handling code immediately following the
statement in which the error occurred. It uses the Resume Next statement to
direct the code to continue execution when an error has occurred.
Sub Main
Dim userdir
in1: userdrive = InputBox("Enter Drive:",,"C:")
On Error Resume Next
Err = 0
ChDrive userdrive
If Err = 68 then
MsgBox "Invalid Drive. Try Again."
Goto in1
End If
End Sub
37
Hummingbird Basic Language Programmer’s Guide
Example 2
This example places error-handling code immediately following a label.
Sub Main
Dim userdir, msgtext
on error goto Errhdlr1
in2: userdir = InputBox("Enter Directory.")
' error generated here
Chdir userdrive & "\" & userdir
MsgBox "New Default Directory is: " & userdrive & "\" &
userdir
Exit Sub
Errhdlr1:' handle error here
Select Case Err
Case 75
msgtext = "Path is invalid"
Case 76
msgtext = "Path not found"
Case else
msgtext = "Error" & err & "" & Error$ & "
occured"
End Select
MsgBox msgtext & "Try Again."
Resume in2' resume normal execution
End Sub
38
Chapter 2: Hummingbird Basic Scripts
Example 1
To trap the error, the following example places error-handling code directly
before the line of code that could cause an error.
Sub Main
Dim custname as String
On Error Resume Next
in1: Err = 0
custname = InputBox$("Enter customer name:")
if custname = "" then
Error 30000' generate error here
Select Case Err' handle error here
Case 30000
MsgBox "You must enter a customer name."
Goto in1
Case Else
MsgBox "Undetermined Error. Try Again."
Goto in1
End Select
End if
MsgBox "The name is: " & custname
End Sub
Example 2
The following example contains a labeled section of code that handles any
user-defined errors. You can also generate an error code in a subprocedure,
and then have the main procedure handle it (similar to example 1 on
page 39).
Sub Main
Dim custname as String
on Error Goto Errhandler
in1: Err = 0
custname = InputBox$("Enter customer name:")
39
Hummingbird Basic Language Programmer’s Guide
Trappable Errors
The following table lists the runtime errors that Hummingbird Basic
returns. These errors can be trapped by On Error. The Err function can be
used to query the error code, and the Error function can be used to query
the error text.
6 Overflow
7 Out of memory
10 Duplicate definition
11 Division by zero
13 Type mismatch
19 No resume
40
Chapter 2: Hummingbird Basic Scripts
61 Disk full
68 Device unavailable
70 Permission denied
93 Invalid pattern
41
Hummingbird Basic Language Programmer’s Guide
42
Chapter 3
Using Development Tools to
Edit Scripts
Toolbar
Code
Window
Variables
Window
Output Window
Status Bar
45
Hummingbird Basic Language Programmer’s Guide
Code Window
Statements and functions are typed into the Code window. To get help on a
specific function or statement, click the right mouse button while the cursor
is on the statement or function. Alternatively, highlight the statement or
function in the Code window and press F1.
For more information about A Hummingbird Basic script must contain one main subprocedure.
structuring your scripts, Functions referenced in your main subprocedure must be declared before
see "Structure of a the main subprocedure.
Hummingbird Basic
Script" on page 12.
Variables Window
Select Variables on the Window menu to display the Variables window. This
window displays the variables you declared in your script. A plus sign beside
a heading in magenta text indicates there is an expandable list. Place the
cursor next to a plus sign and double-click to see all the variables.
46
Chapter 3: Using Development Tools to Edit Scripts
Output Window
To open the Output window, either select Output window on the Window
menu or click the Output toolbar button.
The Output window provides information about your script after it has been
compiled. This window indicates whether the script has been successfully
compiled or not. If errors were detected, then they are displayed by an Error
Message. Clicking the Next or Previous toolbar button highlights each error
in the script.
Status Bar
The status bar indicates the mode in which you are currently working.
There are three modes: Edit, Debug and Run. In Edit mode, you can write
and compile your script. In Debug mode, you can check for syntax errors
and create breakpoints. To revert to Edit mode when you are in Debug
mode, click Stop on the toolbar. In Run mode the compiled script is
executing. To stop running the script and revert to Edit mode, click Pause.
The status bar also lists the number of errors in your script after it has
finished compiling.
47
Hummingbird Basic Language Programmer’s Guide
48
Chapter 3: Using Development Tools to Edit Scripts
Before you compile your script, open the Output window. Any error
messages that occur in the script appear after the script has finished
compiling. To compile your script, either click Check on the toolbar or click
Compile on the File menu.
Errors detected in the compiled script appear in red text. To view the errors
sequentially through the script, click Next Error and Previous Error on the Edit
menu.
To execute a successfully compiled script file, either click Run on the File
menu or click Execute on the toolbar.
49
Hummingbird Basic Language Programmer’s Guide
The following toolbar buttons are available to help you compile and run
your script file:
Output Window
Execute Script
Run Script in
Animated Mode
50
Chapter 4
Designing Dialog Boxes
Toolbar
Dialog Box
Dialog
Code
Window
Control
Palette
Status Bar
53
Hummingbird Basic Language Programmer’s Guide
Toolbar
The toolbar contains the most frequently used commands from the drop-
down menus. To get a short description of the toolbar button, place the
mouse pointer over top of a button and wait a few seconds for the ToolTip
to appear.
Dialog Box
This is the area where you create the dialog box. The dialog box you create
will appear in your running script exactly as it appears in the Dialog Box
window. By default, when the Editor is first opened there is an OK button
and a Cancel button.
54
Chapter 4: Designing Dialog Boxes
Control Palette
The Control Palette contains all of the controls that can be added to a dialog
box. The following table explains what each control is and how to use it.
Control Palette
Explanation
Button
ListBox Control
55
Hummingbird Basic Language Programmer’s Guide
Control Palette
Explanation
Button
56
Chapter 4: Designing Dialog Boxes
There are a number of commands from the Layout menu that can help you
align and lay out controls on the dialog box.
To align the controls, select one by clicking it with the mouse. To select
multiple controls, drag a rectangle across all of the controls you want
selected. Selected controls have a dotted black outline. When the controls
are selected, choose a command from the Layout menu.
57
Hummingbird Basic Language Programmer’s Guide
You may find it useful to turn the grid on before you begin aligning the
controls. The grid is enabled by clicking the Grid toolbar button. To change
the incremental units of the grid, select Options on the Edit menu. Enabling
the Snap To Grid check box in the Option dialog box aligns the controls to the
nearest grid unit.
Note: One of the controls in the dialog window will be the primary
control. It is identified by the darker black outline when selected.
The primary control is always the first in the tab order. All controls
will be set relative to the primary control.
Once the controls are placed and aligned on the dialog box, you can begin
setting specific properties for each of the controls added. Control properties
are settings that affect the attributes and the behavior of the control.
Examples of control properties include position and size, and whether or
not an expression is attached to the control. Also, most of the controls have
a Control ID. The Control ID is an identifier that you use to reference and
access the control from a function in your Hummingbird Basic script.
58
Chapter 4: Designing Dialog Boxes
59
Hummingbird Basic Language Programmer’s Guide
Size and Position A dialog box is positioned relative to the upper left
corner of the application. By default, dialog boxes are centered on the
application.
• X and Y Position—To specify the position of the dialog box, enable the
Edit dialog position box and type the desired values in the X and Y fields.
Type either numeric values or Hummingbird Basic expressions into the
X and Y fields. If you type a new numeric value in either of these fields,
Dialog Editor moves the dialog box accordingly. If you type an
expression (non-numeric value), the position of the control or dialog
box is interpreted when you execute the script file containing this dialog
box.
• Width and Height—These fields allow you to change the size of the
dialog box. Enter a value in pixels in the Width and Height fields. Dialog
Editor sizes the dialog box accordingly.
60
Chapter 4: Designing Dialog Boxes
61
Hummingbird Basic Language Programmer’s Guide
62
Chapter 4: Designing Dialog Boxes
63
Hummingbird Basic Language Programmer’s Guide
64
Chapter 4: Designing Dialog Boxes
ListBox Contents This field allows you to enter the strings that will form
the contents of the ListBox.
Use content as a macro input expression If you want to assign a
Hummingbird Basic expression to the contents of the ListBox, enable this
check box. The contents of the ListBox will be interpreted when you execute
the script containing this dialog box.
Size and Position Hummingbird Basic positions controls relative to the
upper left corner of the dialog box:
• X and Y Position—To specify the position of the control, type the
desired values in the X and Y fields. These values can be either numeric
values or Hummingbird Basic expressions. If you type a new numeric
value in either of these fields, Dialog Editor moves the control
accordingly. If you type an expression (non-numeric value), the
position of the control is interpreted when you execute the script file
containing this dialog box.
• Width and Height—These fields allow you to change the size of the
dialog box or control. Enter a value in pixels in the Width and Height
fields. Dialog Editor sizes the control accordingly.
65
Hummingbird Basic Language Programmer’s Guide
66
Chapter 4: Designing Dialog Boxes
67
Hummingbird Basic Language Programmer’s Guide
68
Chapter 4: Designing Dialog Boxes
69
Hummingbird Basic Language Programmer’s Guide
A dialog box must be defined and declared before you can refer to it in your
script. Dialog boxes are defined using the Begin Dialog...End Dialog
statements.
70
Chapter 4: Designing Dialog Boxes
After defining your dialog box, you must declare a variable of this data type.
In the following example, the variable named td refers to the dialog box
named testdlg.
Begin Dialog testdlg 286, 245, "Interactive Dialog", .interact
<statements that define the controls on your dialog box>
End Dialog
Dim td as testdlg
For more information, see If you are writing a function to accept user input and to define what occurs
“Writing a Dialog in the dialog box, then enter the function at the end of the Begin Dialog
Function” on page 74. statement. In the above example this is a function called interact.
If you use Dialog Editor, the Begin Dialog…. End Dialog statement is
inserted into your code. You must add the function parameter to the Begin
Dialog statement and the variable information after the End Dialog
statement.
The dialog function and the dialog statement differ slightly in their use:
• The Dialog Function—This function both displays a dialog box and
returns a number when the user presses any of the command buttons.
• The Dialog Statement—This statement displays a dialog box.
In most cases, use the Dialog Function. If you use a Dialog statement to
display the dialog box, then you have to write an error-handling routine at
the end of your main subprocedure using the On Error statement.
71
Hummingbird Basic Language Programmer’s Guide
Dynamic dialog box functions and statements can be used only while a
dialog box is displayed on the screen and is calling a dialog control function.
These functions and statements are used to get or set information about a
particular control in a dialog box.
The functions and statements in this category are:
Function Explanation
Most of these functions and statements take the Control ID as the first
argument. For example, consider the following check box definition:
CheckBox 20, 30, 50, 15 "My checkbox", .check1
72
Chapter 4: Designing Dialog Boxes
Dynamic dialog functions and statements can also work with numeric IDs,
which are automatically assigned in the order in which dialog controls are
defined. For example, if a check box is the first control defined in the dialog
record, DlgValue (0) is equivalent to DlgValue ("Check1"). Control
numbering begins at 0. Labels are not numbered.
The example below creates a dialog box with a drop-down combo box
within it, and the three buttons: OK, Cancel, and Help. The Dialog Function
used here enables the subprocedure to trap when the user clicks any of these
buttons.
Sub Main
Dim cchoices as String
cchoices = "All" + Chr$(9) + "Nothing"
Begin Dialog UserDialog 180, 95, "Hummingbird Dialog
Box"
Text 9, 3, 69, 13, "File name:", .Text1
ButtonGroup .ButtonGroup1
ComboBox 9, 17, 111, 41, cchoices, .ComboBox1
OKButton 131, 8, 42, 13
CancelButton 131, 27, 42, 13
PushButton 132, 48, 42, 13, "Help", .Push1
End Dialog
Dim mydialogbox As UserDialog
answer = Dialog(mydialogbox)
Select Case answer
Case -1
MsgBox "You pressed OK"
Case 0
MsgBox "You pressed Cancel"
Case 1
MsgBox "You pressed Help"
End Select
End Sub
73
Hummingbird Basic Language Programmer’s Guide
The function receives the following three parameters from the Begin
Dialog statement:
The Dialog Function does not return until the dialog box is closed. To leave
the dialog box open after the user clicks a command button (such as the OK
button), return a non-zero suppval.
74
Chapter 4: Designing Dialog Boxes
The following table explains the meaning of each value that action% can
contain:
Value Meaning
75
Hummingbird Basic Language Programmer’s Guide
Control Suppval
Option button Number of the option button in the option group, 0-based.
Combo box The number of the item selected (0-based) for action 2, the
number of characters in its text box for action 3.
OK Button 1
Cancel Button 2
Push button An internal button ID. This is not the same as the numeric ID of
the button control.
In most cases, the return value of the Dialog Function is ignored. The
exceptions are the return values from action% 5 (as discussed above), and
from action% 2. If action% 2 is called because the user clicked the OK button,
Cancel button, or a command button (as indicated by id$), and the Dialog
Function returns a non-zero value, the dialog box will not be closed. To close
the dialog box when a user clicks a button, return a 0 to the function.
You can use the information these parameters provide to change the
behavior of the dialog. For example:
Function interact%(Id as String, Action as Integer, Suppval as
Long Integer)
If Id = "bcancel" and action = 2 Then interact = 0
End If
End Function
This example shows that if the user presses the Cancel button, the dialog
box closes. Id = bcancel (the button ID for cancel), Action = 2 indicates
that the user has chosen a command button. If this occurs, interact = 0,
which causes the dialog box to close. If the function returned 1, for example
interact = 1, then the dialog box would stay open.
76
Chapter 4: Designing Dialog Boxes
77
Hummingbird Basic Language Programmer’s Guide
78
Chapter 4: Designing Dialog Boxes
79
Chapter 5
Hummingbird Basic Language
Reference
Arrays
Function Description
Compiler Directives
Function Description
83
Hummingbird Basic Language Programmer’s Guide
Control Flow
Function Description
84
Chapter 5: Hummingbird Basic Language Reference
Function Description
DateSerial Return the date value for year, month, and day specified.
TimeSerial Return the time value for the hour, minute, and second
specified.
Weekday Return the day of the week for the specified date-time
value.
85
Hummingbird Basic Language Programmer’s Guide
Declarations
Function Description
Option Base Declare the default lower bound for array dimensions.
86
Chapter 5: Hummingbird Basic Language Reference
Function Description
87
Hummingbird Basic Language Programmer’s Guide
Function Description
Dialog Function Display a dialog box, and return the button pressed.
DlgFocus Function Return the ID of the dialog control having input focus.
88
Chapter 5: Hummingbird Basic Language Reference
Function Description
Environment Control
Function Description
Command Return the command line specified when the MAIN sub
was run.
89
Hummingbird Basic Language Programmer’s Guide
Error-Handling Functions
Function Description
Function Description
90
Chapter 5: Hummingbird Basic Language Reference
File Control
Function Description
File Input/Output
Function Description
91
Hummingbird Basic Language Programmer’s Guide
Function Description
Financial Functions
Function Description
IRR Return the internal rate of return for a cash flow stream.
92
Chapter 5: Hummingbird Basic Language Reference
Numeric Functions
Function Description
Trigonometric Functions
Function Description
93
Hummingbird Basic Language Programmer’s Guide
Objects
Function Description
GetObject Retrieve an OLE object from a file, or get the active OLE
object for an OLE class.
Screen Input/Output
Function Description
PasswordBox Display a dialog box that prompts for input. Don't echo
input.
94
Chapter 5: Hummingbird Basic Language Reference
String Functions
Function Description
95
Hummingbird Basic Language Programmer’s Guide
String Conversions
Function Description
Variants
Function Description
96
Chapter 5: Hummingbird Basic Language Reference
For information about using TN3270 or TN5250 API function calls, refer to
HostExplorer Programming Help, located in the HostExplorer folder.
97
Hummingbird Basic Language Programmer’s Guide
The DDE application name is usually the name of the .exe file used to start
the application, without the .exe extension. For example, the DDE name
for Microsoft Word is Winword. The topic name is usually a file name to get
or send data to, although there are some reserved DDE topic names, such as
System. Refer to the documentation for the application to get a list of topic
names.
98
Chapter 5: Hummingbird Basic Language Reference
After opening a channel to the application, you can get text and numbers
(DDERequest), send text and numbers (DDEPoke), or send commands
(DDEExecute). When you have finished communicating with the
application, you should close the DDE channel with the DDETerminate
function.
99
Hummingbird Basic Language Programmer’s Guide
100
Appendix A
Technical Support
and Accessibility
Accessibility 103
Microsoft Accessibility Options 104
Technical Support 105
Appendix A: Technical Support and Accessibility
Accessibility
103
Hummingbird Basic Language Programmer’s Guide
104
Appendix A: Technical Support and Accessibility
Technical Support
Hummingbird Ltd.
1 Sparks Avenue, North York, Ontario, Canada M2H 2W1
Main: +1-416-496-2200
Fax: +1-416-496-2207
E-mail: support@hummingbird.com
FTP: ftp.hummingbird.com
105
Glossary
Emulation Function
The process of a computer, device, or A construct which, when executed,
program imitating the function of another calculates and returns a value as
computer, device, or program. Terminal determined by its arguments.
emulation drivers included in Hummingbird Basic contains a variety of
communications software enable a PC to built-in functions you can use in your
emulate a terminal type. This makes it scripts. You can also write your own
possible for a user to log on to a functions.
mainframe.
Interpreter
Error A program that translates, and then
A value or condition that is not consistent executes, each statement in a program
with the true, specified, or expected written in an interpreted language.
condition. In computers, an error results
when an event does not occur as expected, Logic Error
or when impossible or illegal maneuvers Occurs because of incorrect coding that
are attempted. In data communications, an causes unexpected results (such as infinite
error occurs when there is a discrepancy loops or incorrect values returned by
between the transmitted and received data. functions) during the execution of the
script. These types of errors generally cause
Error-Handling unexpected results during the execution of
A special set of instructions that enable your script.
your script to trap errors that may occur
while your script is running. Object Linking and Embedding (OLE)
A compound document standard that
Expression allows you to create objects with one
A collection of terms that perform a application and link or embed the objects
mathematical or a logical operation. The in a second application. Embedded objects
terms are either variables or functions that retain their original format and links.
are combined with an operator to evaluate
a result. There are several types of Windows and Macintosh operating
operators. systems support OLE.
Operator
A symbol or other character indicating an
operation that acts on one or more
elements.
108
Glossary
Procedure Statement
A procedure contains a set of variables and An instruction written in a high-level
statements that you defined for the script. programming language that defines how a
There are two different types of procedures task in the script is carried out. It provides
in Hummingbird Basic: functions and the conditional logic or looping for a
subprocedures. A Hummingbird Basic procedure. It also defines the state of a
script can contain one main subprocedure. dialog box, such as its display and
When the script is run, the main configuration.
subprocedure is executed first.
Syntax Error
Runtime Error Usually the result of spelling a statement or
Can be caused by an unforeseen action a function incorrectly. It can also be the
taken by the user, a coding error, or the result of using either a statement or
data your script is using (the script function incorrectly. To help you fix syntax
attempts to read a file containing no data). errors, the Hummingbird Script Editor
Runtime errors are handled through a set highlights language syntax errors in red
of error-handling functions and after a script is compiled.
statements.
Trappable error
See Error.
Variable
Placeholders for values that are declared,
named, and assigned a data type.
109
Index
A Button ID .......................................................60
accessibility features..................................... 103 Button Label................................................... 60
directional arrow keys .......................... 103 Button Type, Label, ID .................................. 60
Enter key............................................... 103 ButtonGroup ID ............................................ 59
Esc key .................................................. 103 byVal argument ............................................. 14
in Microsoft Windows ......................... 104
Keyboard shortcuts .............................. 103 C
Spacebar ............................................... 103 Call Stack control........................................... 47
Tab key sequence ................................. 103 calling external functions............................... 97
ToolTips ............................................... 103 Caption Type & Caption ............................... 59
action argument............................................. 74 Check Script button....................................... 50
action value table ........................................... 75 CheckBox .................................................72, 87
adding controls to a dialog ............................ 56 ID and Label ........................................... 64
Animated mode ............................................. 49 Code window ................................................. 46
API and OLE function calls............................. 3 command
API calls ......................................................... 97 DDEAppReturnCode............................. 99
arguments ...................................................... 13 Option Explicit ....................................... 18
byVal....................................................... 14 comparison operators.................................... 27
Control ID.............................................. 72 compiler directives......................................... 83
DDEInitiate ............................................ 98 constants ..................................................16, 17
named..................................................... 14 decimal ................................................... 21
pass by value, by reference ..................... 14 defined ....................................................17
arrays........................................................22, 83 integer.....................................................21
Dynamic ................................................. 23 terms in operators .................................. 26
control flow....................................................84
B Control ID ...............................................58, 73
BASIC control palette buttons................................... 55
early versions ............................................ 4
modern..................................................... 5
support of data types.............................. 16
Begin Dialog ............................... 59, 70, 73, 74
Hummingbird Basic Language Programmer’s Guide
112
Index
E objects .....................................................94
EB subdirectory ............................................... 9 running dialog boxes ..............................88
EBS and EBX file extension ........................... 45 screen input/output................................94
EBX ................................................................ 11 string .......................................................95
Edit mode ...................................................... 47 string conversions...................................96
End Dialog ..................................................... 70 trigonometric..........................................93
environment control .................................6, 89 variant .....................................................96
error handling
defined.................................................... 11 G
functions................................................. 90 Global variable ...............................................18
Execute Script button .................................... 50 GlossaryEntry...............................................107
expressions..................................................... 26 GroupBox.......................................................68
defined.................................................... 11 description ..............................................87
Label and ID ...........................................68
F
file control...................................................... 91 H
file input/output ............................................ 91 Hummingbird accessibility..........................103
FILELIST.ebs ................................................... 9 Hummingbird Basic
financial functions ......................................... 92 calling external functions .......................97
FTP API ........................................................... 3 DDE command ......................................99
FTP OLE dialog box handling ..................................5
sample script ............................................ 9 environment control ................................6
function financial functions ....................................5
environment control .............................. 89 object handling .........................................6
procedure ............................................... 12 script structure..................................12–16
functions ........................................................ 13 statements and functions reference........83
arguments............................................... 13 support of BASIC data types ..................16
compiler directives ................................. 83 utilities ......................................................4
control flow ............................................ 84 Workbench .......................................45–47
dates & times .......................................... 85 Hummingbird Information Resources
DDETerminate....................................... 99 Technical Support ................................105
declarations ............................................ 86 Hummingbird Telnet ....................................22
defined.................................................... 11
defining dialog boxes ............................. 87 I
disk and directory control...................... 90 IBM 3270 or 5250 ............................................3
dynamic dialog box ................................ 72 identifier
error handling ........................................ 90 Begin Dialog statement ..........................74
file control .............................................. 91 Control ID ..............................................58
file input/output..................................... 91 information resources, Hummingbird
financial .................................................. 92 Technical Support ................................105
Hummingbird Basic............................... 83 integer constants ............................................21
interact.................................................... 74
numeric .................................................. 93
113
Hummingbird Basic Language Programmer’s Guide
O S
object ..............................................................94 sample script
object data type ..............................................22 calling external functions ....................... 97
OLE ............................................................. 5, 6 DDE........................................................ 99
automation .............................................98 DLGTEST.EBS....................................... 77
automation server...................................22 overview ................................................... 9
object.......................................................22 screen input/output....................................... 94
operators script
comparison .............................................27 compiling and running .......................... 49
logical......................................................27 creating a file .......................................... 47
numeric...................................................26 elements ................................................. 11
overview ..................................................26 errors ...................................................... 49
string .......................................................26 toolbar buttons....................................... 50
Option Base statement ...................................23 translating tasks, actions ........................ 48
Option Explicit command .............................18 Scripting Tool
OptionButton See Workbench
label and ID ............................................61 Sendrecv.ebs .................................................. 10
OptionButton group......................................61
114
Index
115
Hummingbird Basic Language Programmer’s Guide
116
Notes
Notes
Notes
Notes