Formalizing Reusable Software Components in the Programmer's Apprentice.

Abstract

There has been a long-standing desire in computer science for a way of collecting and using libraries of standard software components. Unfortunately, there has been only limited success in actually doing this. The lack of success stems not from any resistance to the idea, nor from any lack of trying, but rather from the difficulty of choosing an appropriate formalism for representing components. For a formalism to be maximally useful, it must satisfy five key desiderata: expressiveness, convenient combinability, semantic soundness, machine monipulability, and programming language independence. The Plan Calculus formalism developed as part of the Programmer's Apprentice project satisfies each of these desiderata quite well. It does this by combining the ideas from flowchart schemas, data abstracton, logical formalisms, and program transformations. The efficacy of the Plan Calculus has been demonstrated in part by a prototype program editor called the knowledge-based Editor in Emacs. This editor makes it possible for a programmer to construct a program rapidly and reliably by combining components represented as plans.

Document Details

Document Type
Technical Report
Publication Date
Feb 01, 1987
Accession Number
ADA185843

Entities

People

  • Charles Rich
  • Richard C. Waters

Organizations

  • Massachusetts Institute of Technology

Tags

DTIC Thesaurus Topics

  • Calculus
  • Computer Languages
  • Computer Programming
  • Computer Science
  • Computers
  • Language
  • Programming Languages
  • Prototypes
  • Resistance
  • Standards

Fields of Study

  • Computer science

Readers

  • Applied Combinatorial Optimization and Logic Circuit Design.
  • Artificial Intelligence
  • Database Systems and Applications