Publication: Automated procedure clustering for reverse engineering PL/SQL programs
dc.contributor.author | Altınışık, M. | |
dc.contributor.author | Sözer, Hasan | |
dc.contributor.department | Computer Science | |
dc.contributor.ozuauthor | SÖZER, Hasan | |
dc.date.accessioned | 2016-07-29T05:25:58Z | |
dc.date.available | 2016-07-29T05:25:58Z | |
dc.date.issued | 2016 | |
dc.description | Due to copyright restrictions, the access to the full text of this article is only available via subscription. | |
dc.description.abstract | PL/SQL programs are mainly composed of procedures that interact with a database. These procedures are grouped into packages at the architecture design level for increasing modularity and maintainability. However, the intended modular structure is subject to architectural drift especially for large scale programs that are maintained for a long duration. Existing reverse engineering and refactoring techniques cannot be directly applied for these programs. Unlike other programs, PL/SQL programs involve procedures that are in most cases indirectly coupled due to their database operations. In this paper, we provide an approach and a tool that support reverse engineering and refactoring of PL/SQL programs. We analyze dependencies among PL/SQL procedures based on the accessed database elements. We represent these dependencies in the form of a design structure matrix. Then, we cluster the procedures and propose a packaging structure to the designer. We performed an industrial case study from the telecommunications domain. We observed promising results in which several unexisted packages were proposed by our tool and the accuracy of the results were approved by domain experts. | |
dc.description.sponsorship | Turkcell Technology | |
dc.identifier.doi | 10.1145/2851613.2851781 | |
dc.identifier.endpage | 1445 | |
dc.identifier.isbn | 978-1-4503-3739-7 | |
dc.identifier.scopus | 2-s2.0-84975889745 | |
dc.identifier.startpage | 1440 | |
dc.identifier.uri | http://hdl.handle.net/10679/4343 | |
dc.identifier.uri | https://doi.org/10.1145/2851613.2851781 | |
dc.language.iso | eng | en_US |
dc.peerreviewed | yes | |
dc.publicationstatus | published | en_US |
dc.publisher | ACM | |
dc.relation.ispartof | SAC '16 Proceedings of the 31st Annual ACM Symposium on Applied Computing | |
dc.relation.publicationcategory | International | |
dc.rights | restrictedAccess | |
dc.subject.keywords | Reverse engineering | |
dc.subject.keywords | Refactoring | |
dc.subject.keywords | Module clustering | |
dc.subject.keywords | PL/SQL programs | |
dc.subject.keywords | Industrial case study | |
dc.title | Automated procedure clustering for reverse engineering PL/SQL programs | en_US |
dc.type | conferenceObject | en_US |
dc.type.subtype | Conference paper | |
dspace.entity.type | Publication | |
relation.isOrgUnitOfPublication | 85662e71-2a61-492a-b407-df4d38ab90d7 | |
relation.isOrgUnitOfPublication.latestForDiscovery | 85662e71-2a61-492a-b407-df4d38ab90d7 |