A Software Design System

<p>The goal of the research described in this thesis was to build a system that supports, without interfering with, the activity of systematic software design and takes upon itself mechanical activities the designer can be spared.</p> <p>Two of the main activities which constitu...

Full description

Bibliographic Details
Main Author: Hess, Gideon David
Format: Others
Language:en
Published: 1980
Online Access:https://thesis.library.caltech.edu/4163/1/Hess_gd_1980.pdf
Hess, Gideon David (1980) A Software Design System. Dissertation (Ph.D.), California Institute of Technology. doi:10.7907/Z9348HB7. https://resolver.caltech.edu/CaltechETD:etd-10182006-082833 <https://resolver.caltech.edu/CaltechETD:etd-10182006-082833>
Description
Summary:<p>The goal of the research described in this thesis was to build a system that supports, without interfering with, the activity of systematic software design and takes upon itself mechanical activities the designer can be spared.</p> <p>Two of the main activities which constitute the process of software creation are:<br /> 1.Designing a solution to the problem. <br /> 2. Implementing the design.</p> <p>The activity of design has to be performed by the programmer himself, it can only be aided by the computer. Producing a program from a complete design is a mechanical activity the computer can take upon itself.</p> <p>These observations lead to the following objectives that a software design system should meet:<br /> 1. Providing tools that support the design activity and enable maximum flexibility.<br /> 2. Recognizing the lowest level primitives of the design as the target language and producing the program in this language.</p> <p>A system along these guidelines was implemented. It permits the user to write definitions which refine high level design decisions into lower levels and, at the same time, serve as syntax descriptions and translation rules for the languages used in the design.</p> <p>The system operates in two user-controlled passes. In the first pass the user's definitions are read, either interactively or from external files, and the syntax rules are stored in a dictionary. In the second pass a syntax driven language processor uses the dictionary to compile the user's program into the target language which consists of the lowest level constructs of the design.</p> <p>Due to the freedom the programmer has in design, several kinds of syntactic ambiguities may be introduced with - or without - the user's attention. Unless caused by user errors, the translator tries to resolve these ambiguities to match the designers intentions.</p> <p>In order to reduce the amount of time and space required for parsing, long texts are divided into subtexts which are translated separately. Guidance as to which subtexts are separately translatable is provided by the user in a natural way by composing the design of statements.</p> <p>A command language enables the user to control the passes, to look at the contents of the dictionary and of external files, to monitor the translation process for debugging purposes, to store dictionaries for later use and retrieve them and to modify special symbols used in definitions.</p> <p>The system is implemented in Simula. A second system is presently being implemented as part of POL (Problem Oriented Language), a system for writing and using application languages. POL's metalanguage enables the user to build - or extend object languages by writing new syntax rules. The tools of the development system described above are incorporated into the metalanguage in order to aid the application programmer in the design and compilation of the semantic routines of these rules.</p>