Abstract
Developers often face difficulties while using APIs. API usage patterns can aid them in using APIs efficiently, which are extracted from source code stored in software repositories. Previous approaches have mined repositories to extract API usage patterns by simply applying data mining techniques to the collection of method invocations of API objects. In these approaches, respective functional roles of invoked methods within API objects are ignored. The functional role represents what type of purpose each method actually achieves, and a method has a specific predefined order of invocation in accordance with its role. Therefore, the simple application of conventional mining techniques fails to produce API usage patterns that are helpful for code completion. This paper proposes an improved approach that extracts API usage patterns at a higher abstraction level rather than directly mining the actual method invocations. It embraces a multilevel sequential mining technique and uses categorization of method invocations based on their functional roles. We have implemented a mining tool and an extended Eclipse's code completion facility with extracted API usage patterns. Evaluation results of this tool show that our approach improves existing code completion.
Original language | English |
---|---|
Pages (from-to) | 1069-1083 |
Number of pages | 15 |
Journal | IEICE Transactions on Information and Systems |
Volume | E96-D |
Issue number | 5 |
DOIs | |
Publication status | Published - May 2014 |
Externally published | Yes |
Keywords
- Code completion
- Recommendation
- Sequential pattern mining
- Software repositories