Key points are not available for this paper at this time.
Recent advances in program repair techniques have raised the possibility of patching bugs automatically. For an automatically generated patch to be accepted by developers, it should not only resolve the bug but also satisfy certain humanrelated factors including readability and comprehensibility. In this paper, we focus on the simplicity of patches (the size of changes). We present a novel semantics-based repair method that generates the simplest patch such that the program structure of the buggy program is maximally preserved. To take into account the simplicity of repairs in an efficient way (i.e., without explicitly enumerating each repair candidate for each fault location), our method fuses fault localization and repair generation into one step. We do so by leveraging partial MaxSAT constraint solving and component-based program synthesis. We compare our prototype implementation, DirectFix, with the state-of-theart semantics-based repair tool SemFix, that performs fault localization before repair generation. In our experiments with SIR programs and GNU Coreutils, DirectFix generates repairs that are simpler than those generated by SemFix. Since both DirectFix and SemFix are test-driven repair tools, they can introduce regressions for other tests which do not drive the repair. We found that DirectFix causes substantially less regression errors than SemFix.
Building similarity graph...
Analyzing shared references across papers
Loading...
Mechtaev et al. (Sat,) studied this question.
synapsesocial.com/papers/6a0ead71a14f152feaf9b1c1 — DOI: https://doi.org/10.5555/2818754.2818811
Sergey Mechtaev
National University of Singapore
Jooyong Yi
Ulsan National Institute of Science and Technology
Abhik Roychoudhury
National University of Singapore
National University of Singapore
Building similarity graph...
Analyzing shared references across papers
Loading...