DocumentCode :
650763
Title :
Large-Scale Automated Refactoring Using ClangMR
Author :
Wright, Hyrum K. ; Jasper, Daniel ; Klimek, Malgorzata ; Carruth, Chandler ; Zhanyong Wan
Author_Institution :
Google, Inc., Mountain View, CA, USA
fYear :
2013
fDate :
22-28 Sept. 2013
Firstpage :
548
Lastpage :
551
Abstract :
Maintaining large code bases can be a challenging endeavour. As new libraries, APIs and standards are introduced, old code is migrated to use them. To provide as clean and succinct an interface as possible for developers, old APIs are ideally removed as new ones are introduced. In practice, this becomes difficult as automatically finding and transforming code in a semantically correct way can be challenging, particularly as the size of a code base increases. In this paper, we present a real-world implementation of a system to refactor large C++ code bases efficiently. A combination of the Clang compiler framework and the MapReduce parallel processor, ClangMR enables code maintainers to easily and correctly transform large collections of code. We describe the motivation behind such a tool, its implementation and then present our experiences using it in a recent API update with Google´s C++ code base.
Keywords :
C++ language; application program interfaces; parallel programming; program compilers; software maintenance; API update; Clang compiler framework; ClangMR; Google; MapReduce parallel processor; large C++ codebases; large-scale automated refactoring; Conferences; Google; Indexes; Semantics; Software systems; Standards; Transforms;
fLanguage :
English
Publisher :
ieee
Conference_Titel :
Software Maintenance (ICSM), 2013 29th IEEE International Conference on
Conference_Location :
Eindhoven
ISSN :
1063-6773
Type :
conf
DOI :
10.1109/ICSM.2013.93
Filename :
6676954
Link To Document :
بازگشت