Ambrosio Blanco
2021
Jointly Learning to Repair Code and Generate Commit Message
Jiaqi Bai
|
Long Zhou
|
Ambrosio Blanco
|
Shujie Liu
|
Furu Wei
|
Ming Zhou
|
Zhoujun Li
Proceedings of the 2021 Conference on Empirical Methods in Natural Language Processing
We propose a novel task of jointly repairing program codes and generating commit messages. Code repair and commit message generation are two essential and related tasks for software development. However, existing work usually performs the two tasks independently. We construct a multilingual triple dataset including buggy code, fixed code, and commit messages for this novel task. We first introduce a cascaded method with two models, one is to generate the fixed code first, and the other generates the commit message based on the fixed and original codes. We enhance the cascaded method with different training approaches, including the teacher-student method, the multi-task method, and the back-translation method. To deal with the error propagation problem of the cascaded method, we also propose a joint model that can both repair the program code and generate the commit message in a unified framework. Massive experiments on our constructed buggy-fixed-commit dataset reflect the challenge of this task and that the enhanced cascaded model and the proposed joint model significantly outperform baselines in both quality of code and commit messages.
Grammar-Based Patches Generation for Automated Program Repair
Yu Tang
|
Long Zhou
|
Ambrosio Blanco
|
Shujie Liu
|
Furu Wei
|
Ming Zhou
|
Muyun Yang
Findings of the Association for Computational Linguistics: ACL-IJCNLP 2021