Use este identificador para citar ou linkar para este item:
http://repositorio.ufla.br/jspui/handle/1/43124
Registro completo de metadados
Campo DC | Valor | Idioma |
---|---|---|
dc.creator | Silva, Danilo | - |
dc.creator | Silva, João | - |
dc.creator | Santos, Gustavo Jansen De Souza | - |
dc.creator | Terra, Ricardo | - |
dc.creator | Valente, Marco Tulio O. | - |
dc.date.accessioned | 2020-09-17T20:05:46Z | - |
dc.date.available | 2020-09-17T20:05:46Z | - |
dc.date.issued | 2020-01 | - |
dc.identifier.citation | SILVA, D. et al. RefDiff 2.0: A Multi-language Refactoring Detection Tool. IEEE Transactions on Software Engineering, Piscataway, Jan. 2020. DOI: 10.1109/TSE.2020.2968072. | pt_BR |
dc.identifier.uri | https://ieeexplore.ieee.org/document/8966516 | pt_BR |
dc.identifier.uri | http://repositorio.ufla.br/jspui/handle/1/43124 | - |
dc.description.abstract | Identifying refactoring operations in source code changes is valuable to understand software evolution. Therefore, several tools have been proposed to automatically detect refactorings applied in a system by comparing source code between revisions. The availability of such infrastructure has enabled researchers to study refactoring practice in large scale, leading to important advances on refactoring knowledge. However, although a plethora of programming languages are used in practice, the vast majority of existing studies are restricted to the Java language due to limitations of the underlying tools. This fact poses an important threat to external validity. Thus, to overcome such limitation, in this paper we propose RefDiff 2.0, a multi-language refactoring detection tool. Our approach leverages techniques proposed in our previous work and introduces a novel refactoring detection algorithm that relies on the Code Structure Tree (CST), a simple yet powerful representation of the source code that abstracts away the specificities of particular programming languages. Despite its language-agnostic design, our evaluation shows that RefDiff's precision (96%) and recall (80%) are on par with state-of-the-art refactoring detection approaches specialized in the Java language. Our modular architecture also enables one to seamless extend RefDiff to support other languages via a plugin system. As a proof of this, we implemented plugins to support two other popular programming languages: JavaScript and C. Our evaluation in these languages reveals that precision and recall ranges from 88% to 91%. With these results, we envision RefDiff as a viable alternative for breaking the single-language barrier in refactoring research and in practical applications of refactoring detection. | pt_BR |
dc.language | en_US | pt_BR |
dc.publisher | Institute of Electrical and Electronic Engineers - IEEE | pt_BR |
dc.rights | restrictAccess | pt_BR |
dc.source | IEEE Transactions on Software Engineering | pt_BR |
dc.subject | Tools | pt_BR |
dc.subject | Java | pt_BR |
dc.subject | Crawlers | pt_BR |
dc.subject | Measurement | pt_BR |
dc.subject | Software - Refatoração | pt_BR |
dc.subject | Linguagens de programação | pt_BR |
dc.title | RefDiff 2.0: A Multi-language Refactoring Detection Tool | pt_BR |
dc.type | Artigo | pt_BR |
Aparece nas coleções: | DCC - Artigos publicados em periódicos |
Arquivos associados a este item:
Não existem arquivos associados a este item.
Os itens no repositório estão protegidos por copyright, com todos os direitos reservados, salvo quando é indicado o contrário.
Ferramentas do administrador