首页 | 本学科首页   官方微博 | 高级检索  
     


Identifying and understanding header file hotspots in C/C++ build processes
Authors:Shane McIntosh  Bram Adams  Meiyappan Nagappan  Ahmed E. Hassan
Affiliation:1.Department of Electrical and Computer Engineering, McGill University,Montreal,Canada;2.Lab on Maintenance, Construction, and Intelligence of Software (MCIS),Polytechnique Montréal,Montreal,Canada;3.Department of Software Engineering,Rochester Institute of Technology,Rochester,USA;4.Software Analysis and Intelligence Lab (SAIL),Queen’s University,Kingston,Canada
Abstract:
Software developers rely on a fast build system to incrementally compile their source code changes and produce modified deliverables for testing and deployment. Header files, which tend to trigger slow rebuild processes, are most problematic if they also change frequently during the development process, and hence, need to be rebuilt often. In this paper, we propose an approach that analyzes the build dependency graph (i.e., the data structure used to determine the minimal list of commands that must be executed when a source code file is modified), and the change history of a software system to pinpoint header file hotspots—header files that change frequently and trigger long rebuild processes. Through a case study on the GLib, PostgreSQL, Qt, and Ruby systems, we show that our approach identifies header file hotspots that, if improved, will provide greater improvement to the total future build cost of a system than just focusing on the files that trigger the slowest rebuild processes, change the most frequently, or are used the most throughout the codebase. Furthermore, regression models built using architectural and code properties of source files can explain 32–57 % of these hotspots, identifying subsystems that are particularly hotspot-prone and would benefit the most from architectural refinement.
Keywords:
本文献已被 SpringerLink 等数据库收录!
设为首页 | 免责声明 | 关于勤云 | 加入收藏

Copyright©北京勤云科技发展有限公司  京ICP备09084417号