Scalable and accurate detection of code clones


Citar

Texto integral

Acesso aberto Acesso aberto
Acesso é fechado Acesso está concedido
Acesso é fechado Somente assinantes

Resumo

A detailed description of a method for detection of code clones is described. This method is based on the semantic analysis of programs and on new algorithms that make it scalable without affecting its accuracy. The proposed method involves two phases. In the first phase, the program dependence graph (PDG) is constructed while the program is compiled. LLVM is used as the compilation infrastructure. In the second phase, similar subgraphs of maximum size that represent code clones are detected. Before starting the search for similar subgraphs, the PDG is divided into subgraphs that will be considered as potential clones of each other. To ensure scalability of the search for similar subgraphs, the composition of algorithms is used. The first algorithm checks that a pair of graphs cannot have similar subgraphs of the desired size; this is done in a linear amount of time. If this algorithm fails, another (approximate) algorithm is executed to find similar subgraphs of maximum size. After similar subgraphs have been found, the program code is additionally checked for the position of the code lines corresponding to the detected clone candidates. Tests showed that the developed tool is more accurate than similar tools, such as MOSS, CCFinder, and CloneDR. Results obtained for the projects Linux-2.6, Firefox Mozilla, LLVM/Clang, and OpenSSL are presented.

Sobre autores

S. Sargsyan

Institute for System Programming

Autor responsável pela correspondência
Email: sevaksargsyan@ispras.ru
Rússia, Moscow, 109004

Sh. Kurmangaleev

Institute for System Programming

Email: sevaksargsyan@ispras.ru
Rússia, Moscow, 109004

A. Belevantsev

Institute for System Programming; Moscow State University; Moscow Institute of Physics and Technology State University

Email: sevaksargsyan@ispras.ru
Rússia, Moscow, 109004; Moscow, 119991; Dolgoprudny, Moscow oblast, 141700

A. Avetisyan

Institute for System Programming; Moscow State University; Moscow Institute of Physics and Technology State University

Email: sevaksargsyan@ispras.ru
Rússia, Moscow, 109004; Moscow, 119991; Dolgoprudny, Moscow oblast, 141700


Declaração de direitos autorais © Pleiades Publishing, Ltd., 2016

Este site utiliza cookies

Ao continuar usando nosso site, você concorda com o procedimento de cookies que mantêm o site funcionando normalmente.

Informação sobre cookies