Dealing with merge conflicts in version control systems is a challenging task for software developers. Resolving merge conflicts is a time-consuming and error-prone process, which distracts developers from important tasks. Recent work shows that refactorings are often involved in merge conflicts and that refactoring-related conflicts tend to be larger, making them harder to resolve. In the literature, there are two refactoring-aware merging techniques that claim to automatically resolve refactoring-related conflicts; however, these two techniques have never been empirically compared. In this paper, we present RefMerge, a rejuvenated Java-based design and implementation of the first technique, which is an operation-based refactoring-aware merging algorithm. We compare RefMerge to Git and the state-of-the-art graph-based refactoring-aware merging tool, IntelliMerge, on 2,001 merge scenarios with refactoring-related conflicts from 20 open-source projects. We find that RefMerge resolves or reduces conflicts in 497 (25%) merge scenarios while increasing conflicting LOC in only 214 (11%) scenarios. On the other hand, we find that IntelliMerge resolves or reduces conflicts in 478 (24%) merge scenarios but increases conflicting LOC in 597 (30%) merge scenarios. We additionally conduct a qualitative analysis of the differences between the three merging algorithms and provide insights of the strengths and weaknesses of each tool. We find that while IntelliMerge does well with ordering and formatting conflicts, it struggles with class-level refactorings and scenarios with several refactorings. On the other hand, RefMerge is resilient to the number of refactorings in a merge scenario, but we find that RefMerge introduces conflicts when inverting move-related refactorings.
翻译:处理版本控制系统中的合并冲突对于软件开发者来说是一项艰巨的任务。 解决合并冲突是一个耗时和容易出错的过程, 它会分散开发者对重要任务的注意力。 最近的工作显示, 重构因素往往涉及合并冲突, 重构因素相关的冲突往往更大, 使得它们更难解决。 在文献中, 有两种重构意识合并技术, 声称自动解决重构相关冲突; 但是, 这两种技术从未被经验性地比较过。 在本文中, 我们展示了RefMeorge, 一个基于爪哇的更新型设计和实施第一种技术, 这是基于操作的重构因素的合并算法。 我们比较了 RefMeorge 和基于最新图表的合并工具, IntelleeMe, 在20个开放源项目中, 与再定义相关冲突合并了2 001的假想。 我们发现RefterFerge在497中找到或减少冲突( 25 % ) 合并了假设, 而在214( 11 %) 中, 将Refmilleal 和Leal meal 变变换了其他的变换的变变变变变变。