Build Predictor: More Accurate Missed Dependency Prediction in Build Configuration Files

COMPSAC(2014)

引用 17|浏览65
暂无评分
摘要
Software build system (e.g., Make) plays an important role in compiling human-readable source code into an executable program. One feature of build system such as make-based system is that it would use a build configuration file (e.g., Make file) to record the dependencies among different target and source code files. However, sometimes important dependencies would be missed in a build configuration file, which would cause additional debugging effort to fix it. In this paper, we propose a novel algorithm named Build Predictor to mine the missed dependncies. We first analyze dependencies in a build configuration file (e.g., Make file), and establish a dependency graph which captures various dependencies in the build configuration file. Next, considering that a build configuration file is constructed based on the source code dependency relationship, we establish a code dependency graph (code graph). Build Predictor is a composite model, which combines both dependency graph and code graph, to achieve a high prediction performance. We collected 7 build configuration files from various open source projects, which are Zlib, putty, vim, Apache Portable Runtime (APR), memcached, nginx, and Tengine, to evaluate the effectiveness of our algorithm. The experiment results show that compared with the state-of-the-art link prediction algorithms used by Xia et al., our Build Predictor achieves the best performance in predicting the missed dependencies.
更多
查看译文
关键词
link prediction,public domain software,missed dependency prediction,nginx,source code files,makefile,software build system,build system, link prediction, build graph, code graph, makefile,build configuration files,apache portable runtime,make-based system,source code (software),make file,executable program,link prediction algorithms,tengine,putty,memcached,code graph,open source projects,human-readable source code compiling,zlib,build graph,build system,source code dependency relationship,program compilers,vim,build predictor,prediction algorithms,accuracy
AI 理解论文
溯源树
样例
生成溯源树,研究论文发展脉络
Chat Paper
正在生成论文摘要