The motivation behind the work in very-high-level languages is to ease the programming task by providing the programmer with a language containing primitives or abstractions suitable to his problem area. The programmer is then able to spend his effort in the right place; he concentrates on solving his problem, and the resulting program will be more reliable as a result. Clearly, this is a worthwhile goal.
Unfortunately, it is very difficult for a designer to select in advance all the abstractions which the users of his language might need. If a language is to be used at all, it is likely to be used to solve problems which its designer did not envision, and for which the abstractions embedded in the language are not sufficient.
This paper presents an approach which allows the set of built-in abstractions to be augmented when the need for a new data abstraction is discovered. This approach to the handling of abstraction is an outgrowth of work on designing a language for structured programming. Relevant aspects of this language are described, and examples of the use and definitions of abstractions are given.
[1]
David Lorge Parnas,et al.
Information Distribution Aspects of Design Methodology
,
1971,
IFIP Congress.
[2]
George H. Mealy,et al.
Another look at data
,
1967,
AFIPS '67 (Fall).
[3]
Philippe Jorrand,et al.
Definition mechanisms in extensible programming languages
,
1899,
AFIPS '70 (Fall).
[4]
Barbara Liskov,et al.
A design methodology for reliable software systems
,
1972,
AFIPS '72 (Fall, part I).
[5]
Edsger W. Dijkstra,et al.
Notes on structured programming
,
1970
.
[6]
P. G. Neumann,et al.
A general-purpose file system for secondary storage
,
1965,
Published in AFIPS '65 (Fall, part I).
[7]
Robert Balzer.
Dataless programming
,
1967,
AFIPS '67 (Fall).
[8]
Stephen N. Zilles.
Procedural encapsulation: A linguistic protection technique
,
1973
.
[9]
Jay Earley,et al.
Toward an understanding of data structures
,
1971,
SIGFIDET '70.