Title :
Identifying and Summarizing Systematic Code Changes via Rule Inference
Author :
Kim, Miryung ; Notkin, David ; Grossman, Dan ; Wilson, Gary, Jr.
Author_Institution :
Dept. of Electr. & Comput. Eng., Univ. of Texas at Austin, Austin, TX, USA
Abstract :
Programmers often need to reason about how a program evolved between two or more program versions. Reasoning about program changes is challenging as there is a significant gap between how programmers think about changes and how existing program differencing tools represent such changes. For example, even though modification of a locking protocol is conceptually simple and systematic at a code level, diff extracts scattered text additions and deletions per file. To enable programmers to reason about program differences at a high level, this paper proposes a rule-based program differencing approach that automatically discovers and represents systematic changes as logic rules. To demonstrate the viability of this approach, we instantiated this approach at two different abstraction levels in Java: first at the level of application programming interface (API) names and signatures, and second at the level of code elements (e.g., types, methods, and fields) and structural dependences (e.g., method-calls, field-accesses, and subtyping relationships). The benefit of this approach is demonstrated through its application to several open source projects as well as a focus group study with professional software engineers from a large e-commerce company.
Keywords :
Java; application program interfaces; electronic commerce; inference mechanisms; reasoning about programs; software engineering; API; Java; application programming interface; large e-commerce company; locking protocol; professional software engineers; reasoning about program; rule inference; rule-based program differencing approach; scattered text additions; structural dependences; systematic code; Cloning; Inference algorithms; Libraries; Semantics; Software; Syntactics; Systematics; Software evolution; logic-based program representation; program differencing; rule learning;
Journal_Title :
Software Engineering, IEEE Transactions on
DOI :
10.1109/TSE.2012.16