Spork: Structured Merge for Java With Formatting Preservation

Autor: Simon Larsen, Jean-Remy Falleri, Benoit Baudry, Martin Monperrus
Rok vydání: 2023
Předmět:
Zdroj: IEEE Transactions on Software Engineering. 49:64-83
ISSN: 2326-3881
0098-5589
DOI: 10.1109/tse.2022.3143766
Popis: The highly parallel workflows of modern software development have made merging of source code a common activity for developers. The state of the practice is based on line-based merge, which is ubiquitously used with "git merge". Line-based merge is however a generalized technique for any text that cannot leverage the structured nature of source code, making merge conflicts a common occurrence. As a remedy, research has proposed structured merge tools, which typically operate on abstract syntax trees instead of raw text. Structured merging greatly reduces the prevalence of merge conflicts but suffers from important limitations, the main ones being a tendency to alter the formatting of the merged code and being prone to excessive running times. In this paper, we present SPORK, a novel structured merge tool for JAVA. SPORK is unique as it preserves formatting to a significantly greater degree than comparable state-of-the-art tools. SPORK is also overall faster than the state of the art, in particular significantly reducing worst-case running times in practice. We demonstrate these properties by replaying 1740 real-world file merges collected from 119 open-source projects, and further demonstrate several key differences between SPORK and the state of the art with in-depth case studies.
Comment: 21 pages, 18 figures, 11 tables, accepted for publication in IEEE Transactions on Software Engineering
Databáze: OpenAIRE