Affiliation:
1. Department of Computer Science, University of Durham, Durham, DH1 3LE, England
Abstract
There is a vast collection of operational software systems which are vitally important to their users, yet are becoming increasingly difficult to maintain, enhance, and keep up to date with rapidly changing requirements. For many of these so-called legacy systems, the option of throwing the system away and rewriting it from scratch is not economically viable. Methods are therefore urgently required which enable these systems to evolve in a controlled manner. The approach described in this paper uses formal proven program transformations, which preserve or refine the semantics of a program while changing its form. These transformations are applied to restructure and simplify the legacy systems and to extract higher-level representations. By using an appropriate sequence of transformations, the extracted representation is guaranteed to be equivalent to the code. The method is based on a formal wide spectrum language, called WSL, with an accompanying formal method. Over the last ten years we have developed a large catalog of proven transformations, together with mechanically verifiable applicability conditions. These have been applied to many software development, reverse engineering, and maintenance problems. In this paper, we focus on the results of using this approach in the reverse engineering of medium scale, industrial software, written mostly in languages such as assembler and JOVIAL. Results from both benchmark algorithms and heavily modified, geriatric software are summarized. We conclude that formal methods have an important practical role in software evolution.
Publisher
World Scientific Pub Co Pte Lt
Subject
Artificial Intelligence,Computer Graphics and Computer-Aided Design,Computer Networks and Communications,Software
Cited by
15 articles.
订阅此论文施引文献
订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献
1. A Framework for Flexible Program Evolution and Verification of Distributed Systems;Communications in Computer and Information Science;2020
2. A Flexible Framework for Program Evolution and Verification;Proceedings of the 7th International Conference on Model-Driven Engineering and Software Development;2019
3. A Formal Approach to Checking Consistency in Software Refactoring;Mobile Networks and Applications;2017-01-26
4. The formal semantics of program slicing for nonterminating computations;Journal of Software: Evolution and Process;2016-10-04
5. Formal methods;ACM Computing Surveys;2009-10