BAS (I) 1/15/73 BAS (I)
NAME bas -- basic
SYNOPSIS bas [ file ]
DESCRIPTION bas is a dialect of basic [1]. If a file argu-
ment is provided, the file is used for input be-
fore the console is read.
bas accepts lines of the form:
statement
integer statement
Integer numbered statements (known as internal
statements) are stored for later execution. They
are stored in sorted ascending order. Non-
numbered statements are immediately executed.
The result of an immediate expression statement
(that does not have '=' as its highest operator)
is printed.
Statements have the following syntax:
expression
The expression is executed for its side ef-
fects (assignment or function call) or for
printing as described above.
done
Return to system level.
draw expression expression expression
A line is drawn on the Tektronix 611 dis-
play (/dev/vt0) from the current display
position to the XY co-ordinates specified
by the first two expressions. (The scale
is zero to one in both X and Y directions)
If the third expression is zero, the line
is invisible. The current display position
is set to the end point.
display list
The list of expressions and strings is con-
catenated and displayed (i.e. printed) on
the 611 starting at the current display po-
sition. The current display position is
not changed.
erase
The 611 screen is erased.
for name = expression expression statement
for name = expression expression
...
next
The for statement repetitively executes a
statement (first form) or a group of state-
ments (second form) under control of a
named variable. The variable takes on the
value of the first expression, then is in-
cremented by one on each loop, not to ex-
ceed the value of the second expression.
goto expression
The expression is evaluated, truncated to
an integer and execution goes to the corre-
sponding integer numbered statment. If ex-
ecuted from immediate mode, the internal
statements are compiled first.
if expression statement
The statement is executed if the expression
evaluates to non-zero.
list [expression [expression]]
list is used to print out the stored inter-
nal statements. If no arguments are given,
all internal statements are printed. If
one argument is given, only that internal
statement is listed. If two arguments are
given, all internal statements inclusively
between the arguments are printed.
print list
The list of expressions and strings are
concatenated and printed. (A string is de-
limited by " characters.)
return [expression]
The expression is evaluated and the result
is passed back as the value of a function
call. If no expression is given, zero is
returned.
run
The internal statements are compiled. The
symbol table is re-initialized. The random
number generator is re-set. Control is
passed to the lowest numbered internal
statement.
Expressions have the following syntax:
name
A name is used to specify a variable.
Names are composed of a letter ('a' - 'z')
followed by letters and digits. The first
four characters of a name are significant.
number
A number is used to represent a constant
value. A number is composed of digits, at
most one decimal point ('.') and possibly
a scale factor of the form e digits or e-
digits.
( expression )
Parentheses are used to alter normal order
of evaluation.
expression operator expression
Common functions of two arguments are ab-
breviated by the two arguments separated by
an operator denoting the function. A com-
plete list of operators is given below.
expression ( [expression [, expression ...]] )
Functions of an arbitrary number of argu-
ments can be called by an expression fol-
lowed by the arguments in parentheses sepa-
rated by commas. The expression evaluates
to the line number of the entry of the
function in the internally stored state-
ments. This causes the internal statements
to be compiled. If the expression evalu-
ates negative, a builtin function is
called. The list of builtin functions ap-
pears below.
name [ expression [, expression ...] ]
Each expression is truncated to an integer
and used as a specifier for the name. The
result is syntactically identical to a
name. a[1,2] is the same as a[1][2]. The
truncated expressions are restricted to
values between 0 and 32767.
The following is the list of operators:
=
= is the assignment operator. The left
operand must be a name or an array element.
The result is the right operand. Assign-
ment binds right to left, all other opera-
tors bind left to right.
& |
& (logical and) has result zero if either
of its arguments are zero. It has result
one if both its arguments are non-zero. |
(logical or) has result zero if both of its
arguments are zero. It has result one if
either of its arguments are non-zero.
< <= > >= == <>
The relational operators (< less than, <=
less than or equal, > greater than, >=
greater than or equal, == equal to, <> not
equal to) return one if their arguments are
in the specified relation. They return
zero otherwise. Relational operators at
the same level extend as follows: a>b>c is
the same as a>b&b>c.
+ -
Add and subtract.
* /
Multiply and divide.
^
Exponentiation.
The following is a list of builtin functions:
arg
Arg(i) is the value of the ith actual pa-
rameter on the current level of function
call.
exp
Exp(x) is the exponential function of x.
log
Log(x) is the logarithm base e of x.
sin
Sin(x) is the sine of x (radians).
cos
Cos(x) is the cosine of x (radians).
atn
Atn(x) is the arctangent of x.
rnd
Rnd() is a uniformly distributed random
number between zero and one.
expr
Expr() is the only form of program input.
A line is read from the input and evaluated
as an expression. The resultant value is
returned.
int
Int(x) returns x truncated to an integer.
FILES /tmp/btm? temporary
SEE ALSO [1] DEC-11-AJPB-D
DIAGNOSTICS Syntax errors cause the incorrect line to be
typed with an underscore where the parse failed.
All other diagnostics are self explanatory.
BUGS --