SEDec 18, 2018

Impact of Tool Support in Patch Construction

arXiv:1812.07416v125 citations
Originality Synthesis-oriented
AI Analysis

This work provides insights into patching practices for software developers and researchers, but it is incremental as it analyzes existing methods without introducing new techniques.

The study investigated patch construction in the Linux kernel, comparing manual patches, tool-derived patches, and automatically generated patches, finding that tool-supported patches are increasingly adopted but manually-written patches are accepted more quickly, with patches often involving multiple change operations.

In this work, we investigate the practice of patch construction in the Linux kernel development, focusing on the differences between three patching processes: (1) patches crafted entirely manually to fix bugs, (2) those that are derived from warnings of bug detection tools, and (3) those that are automatically generated based on fix patterns. With this study, we provide to the research community concrete insights on the practice of patching as well as how the development community is currently embracing research and commercial patching tools to improve productivity in repair. The result of our study shows that tool-supported patches are increasingly adopted by the developer community while manually-written patches are accepted more quickly. Patch application tools enable developers to remain committed to contributing patches to the code base. Our findings also include that, in actual development processes, patches generally implement several change operations spread over the code, even for patches fixing warnings by bug detection tools. Finally, this study has shown that there is an opportunity to directly leverage the output of bug detection tools to readily generate patches that are appropriate for fixing the problem, and that are consistent with manually-written patches.

Foundations

The foundational work for this paper's niche, ranked by how specifically the neighbourhood builds on it — not by global fame.

Your Notes