CAL (programming language)
CAL, short for Conversational Algebraic Language, was a programming language and system designed and developed by Butler Lampson at Berkeley in 1967 for the SDS 940 mainframe computer. CAL is a version of the seminal JOSS language with a number of cleanups and new features to take advantage of the SDS platform.
The Berkeley SDS was used for the development of the Tymshare commercial time-sharing platform and an improved version of CAL was offered as a programming environment to its customers in 1969. Although CAL saw "almost no use", it had a lasting impact by influencing the design of Tymshare SUPER BASIC which copied a number of its features. Some of those features, in turn, appeared in BASIC-PLUS on the PDP-11, which is the direct ancestor of Microsoft BASIC.[1]
Description
Basic concepts
JOSS had been designed to be used by non-programmers in the US Air Force and within Rand Corporation, and to aid with that, Rand designed custom computer terminals that were easier to set up and use. These terminals, based on the IBM Selectric typewriter, also included a custom character set that implemented common mathematical symbols like ≥
and ≠
.
To a large degree, CAL was a version of JOSS that replaced these sorts of customizations with more common solutions like >=
and #
so they could run on common terminals.[2] The other noticeable differences were that CAL was all upper-case, as opposed to sentence casing in JOSS, and it did not require a period at the end of the line.[3] The commands were otherwise almost identical and the overall structure and syntax the same, porting from JOSS to CAL is simple.
As with JOSS, CAL had an interactive user interface that allowed the user to type in statements in "direct mode" or programs to be run in "indirect mode". In BASIC, the former is more commonly referred to as "immediate mode". Both used a two-part line number, known as the part and step, separated by a period, for instance, 1.100
for part 1 step 100. Parts were generally used to group related statements into subroutines. In CAL, the part number could be between 0 and 999999, and the step from 0 to 99999.[4]
There were two main versions of CAL, released in 1967 and 1969. The following description will be based primarily on the former version unless otherwise noted.
Statements
As in JOSS, CAL supported the TO
command to branch to a provided part or step, as in TO PART 3
or TO STEP 4.5
, and DO
for subroutine calls, as in DO PART 9
to perform the entire part, or DO STEP 5.1
to run that single step and then return. The later syntax was useful when there were many small subroutines as they could be implemented on a single line without an associated RETURN
or similar concept.[5]
One of the more notable syntactic features of JOSS was the concept of "statement modifiers" which controlled the operation of other statements. In most languages, one would write something to the effect of "if this expression is true, then do this...". In JOSS, this order was reversed, and such statements took the form "do this if this is true", for instance, Type "HELLO" if X=5.
. CAL added some syntactic sugar to this basic concept by adding the new modifier UNLESS
, which, depending on context, led to more obvious code, TYPE "IT IS NOT EQUAL TO FIVE" UNLESS X=5
.[6]
CAL further modified the basic if statement by adding THEN
and ELSE
. In JOSS, if one wanted to assign the value 5 to a variable A if the value of B was larger than 10, and 0 otherwise, the code would be:
Set A=5 if B>10. Set A=0 if B<=10.
This sort of either/or assignment is very common and takes up two lines. CAL improved on JOSS by implementing an Elvis operator:[7]
A=IF B>10 THEN 5 ELSE 0
A similar modification was the WHERE
statement, used to set variables as part of an if or for. It was similar in concept to the if/then/else structure, but could have any number of items. For instance,=A*B WHERE A=B UNTIL A>20, WHERE A=1 UNTIL A>100
.[8]
Looping in JOSS was also controlled by a modifier, the For
. This used somewhat obscure syntax; Type i for i=1(2)10.
runs a loop from 1 to 10 stepping by 2, so it would print 1,3,5,7,9. CAL cleaned this up with the BY
and TO
keywords, so the equivalent code in CAL would be TYPE I FOR I=1 BY 2 TO 10
. As in JOSS, the range of the for could be defined using BY and TO, an explicit list of numbers, FOR I=2,5,7
, or a mixture of both, FOR A=2,3,10 BY 1 TO 20,35
. CAL further modified the for loop by adding conditional exits, using WHILE
and UNTIL
. For instance, TYPE A FOR A=1 BY 1 WHILE A<=50
or TYPE B FOR B=1 UNTIL A=50
. In the later case, the BY is assumed to be 1,[9] which was not optional in JOSS because the step value's parenthesis also acted as the field separator. These types of calls were particularly useful when combined with the "single-line subroutine" DO
concept mentioned above; if a mathematical expression can be listed on a single line, it can easily be iterated over using DO STEP 5.1 FOR I=1 TO 10
.[7]
CAL included the mathematical functions of JOSS but added a number of new ones including ABS
, TAN
, ATAN
, and LOG10
.[10] It added a new operator as well, MOD
, which returned the remainder of a division of its two operands.[11]
Improvements in CAL 1969
One minor change in the 1969 version was the elimination of the SET
command for variable assignment. This had been optional in direct mode in JOSS but was required in program statements, and the 1967 version of CAL had followed this rule.[12] The 1969 version made it optional in both cases.
References
Citations
- ^ Lampson, "Systems", Research, Microsoft.
- ^ Manual 1969, p. 7.
- ^ Manual 1969, p. 23.
- ^ Manual 1969, p. 11.
- ^ Manual 1969, p. 15, 26.
- ^ Manual 1969, p. 12.
- ^ a b Manual 1969, p. 14.
- ^ Manual 1969, p. 21.
- ^ Manual 1969, p. 13.
- ^ Manual 1967, p. 9.
- ^ Manual 1967, p. 10.
- ^ Manual 1967, p. 8.
Bibliography
- Lampson, Butler (June 1969). CAL Reference Manual for SDS 940 Time-Sharing Computer System (PDF). Scientific Data Systems.
- Lampson, Butler (June 1967). CAL Reference Manual for SDS 940 Time-Sharing Computer Systems (PDF). Scientific Data Systems.