Issue No.07 - July (1998 vol.24)
DOI Bookmark: http://doi.ieeecomputersociety.org/10.1109/32.708568
<p><b>Abstract</b>—Restructuring software to improve its design can lower software maintenance costs. One problem encountered during restructuring is formulating the new design. A meaning-preserving program restructuring tool with a <it>star diagram</it> manipulable visualization can help a programmer redesign a program based on abstract data types. However, the transformational support required for meaning-preserving restructuring is costly to provide. Also, programmers encounter comprehension and recall difficulties in complex restructuring tasks. Consequently, transformations were replaced with visual and organizational aids that help a programmer to plan and carry out a complex restructuring. For example, a star diagram manipulation called <it>trimming</it> was added, which mimics the way that basic restructuring transformations affect the star diagram display, allowing a programmer to plan a restructuring without depending upon restructuring transformations. With the ability to annotate trimmed star diagram components, plans can be recorded and later recalled. Programmer-controlled elision was added to help remove clutter from star diagram views. We implemented a star diagram planning tool for C programs, measured its elision capabilities, and performed a programmer study. We found that elision is effective in controlling star diagram size, and the study revealed that each programming team successfully planned its restructuring in rather different, unanticipated ways. These experiments resulted in important improvements in the tool's software design and user interface.</p>
Program restructuring, re-engineering, software maintenance and enhancement, abstract data types, modularity and information hiding, graphical user interface design, programmer study.
Morison I. Chen, Robert W. Bowdidge, Jenny L. Cabaniss, Van B. Nguyen, J. David Morgenthaler, "Tool Support for Planning the Restructuring of Data Abstractions in Large Systems", IEEE Transactions on Software Engineering, vol.24, no. 7, pp. 534-558, July 1998, doi:10.1109/32.708568