PLANC
From Wikipedia, the free encyclopedia
| Paradigm | Procedural, imperative, structured |
|---|---|
| Family | Pascal |
| Developer | Norsk Data |
| Final release | Final
|
| Typing discipline | Static, strong |
| Scope | Lexical |
| Platform | Norsk Data Nord-10 minicomputers, ND-500 superminicomputer; Motorola 68000, 88000; Intel x86 |
| OS | Sintran III |
| License | Proprietary |
| Influenced by | |
| Nord Programming Language | |
PLANC (Programming LAnguage for Nd Computers, pronounced as plank) is a high-level programming language.
Compilers were developed by Norsk Data for several architectures, including the Motorola 68000, 88000, Intel x86, and the Norsk Data Nord-10 minicomputers and ND-500 superminicomputer.[1]
The language was designed to be cross-platform software. It was mainly used internally at Norsk Data for writing high level systems software such as the upper parts of operating systems and compilers.
PLANC programs are structured into modules and routines.
A very simple example of a PLANC program is as follows:
MODULE mod
INTEGER ARRAY : stack (0:100)
PROGRAM : mprog
INTEGER : i, j,k, m
INISTACK stack
1 =: i
2 =: j
i+j =: k =: m
ENDROUTINE
ENDMODULE
A difference from popular programming languages is that the assignment operator evaluates from left to right: First it computes the value, and then stores it. Compile-time initialization of variables, in contrast, evaluates from right to left.
The assignment operator returns the stored value, so it can be stored multiple times: 5 =: a =: b would store 5 into both the A and B variables. It shares this direction with Plankalkül, ALGOL 60, Mary (another little known language developed in Norway), and the popular language C.
A related distinct syntactic feature is that a function can be defined to take as input the computed value of the expression on its left side. Also, a single additional argument does not require surrounding parentheses. The resulting infix notation blurs the syntactic difference between functions and operators. Such expressions seem conceptually as having a computed value flowing from left to the right.
Data types
As with all high level languages, PLANC uses variables as can be seen in the prior sample, here are the allowed data types within PLANC:
- Simple types
- INTEGER, REAL, BOOLEAN, LABEL, VOID, ENUMERATION, POINTER
- Composite types
- ARRAY, RECORD, SET, ROUTINE
- User defined types: declared by TYPE T = .....;
An enumeration was declared thus:
ENUMERATION (Winter, Spring, Summer, Autumn) : Seasons := Summer
This defines an enumeration of the seasons and sets the default value to Summer.
LABEL is a little different from a normal data type. This is used to predefine a label within code and is used together with a GO statement; very much like GOTO in BASIC.
Access modifiers can be applied to make them READ or WRITE only.
For string data several predefined datatypes are used, they are:
BYTE– Contains one characterBYTES– Contains character stringsBITS– Contains BIT strings
Array pointers were 3-word constructs that included both the base address, the lower bound, and the higher bound of the array; this made it possible to do reliable run-time checking of array boundaries, and made the kind of pointer arithmetic that makes C a more challenging language in which to write.