Resolving cyclic dependencies between packages with Enriched Dependency Structural Matrix - Archive ouverte HAL Access content directly
Journal Articles Software: Practice and Experience Year : 2012

Resolving cyclic dependencies between packages with Enriched Dependency Structural Matrix

(1) , (1)
1

Abstract

Dependency Structural Matrix (DSM) is an approach originally developed for process optimization. It has been successfully applied to identify software dependencies among packages and subsystems. A number of algorithms have been proposed to compute the matrix so that it highlights patterns and problematic dependencies between subsystems. However, existing DSM implementations often miss important information to fully support reengineering effort. For example, they do not clearly qualify and quantify problematic relationships, information that is crucial to support remediation tasks. We propose Enriched Dependency Structural Matrix (eDSM), which provides small multiple views and micro-macro readings by adding fine-grained information in each cell of the matrix. Each cell is enriched with contextual information about (i) the type of dependencies (inheritance, class reference, etc.), (ii) the proportion of referencing entities, (iii) the proportion of referenced entities. We distinguish independent cycles and stress potentially simple fixes for cycles using coloring information. This work is language independent and has been implemented on top of the Moose software analysis platform. In this paper, we expand our previous work. We improved the cell content information view based on user feedback and performed multiple validations: two different case studies on Moose and Seaside software; one user study for validating eDSM as a usable approach for developers. Solutions to problems identified with eDSM have been performed and retrofitted in analyzed software.
Fichier principal
Vignette du fichier
Lava12z-ResolvingCyclicDependencies.pdf (679.91 Ko) Télécharger le fichier
Origin : Files produced by the author(s)
Loading...

Dates and versions

hal-00748120 , version 1 (04-05-2013)

Identifiers

Cite

Jannik Laval, Stéphane Ducasse. Resolving cyclic dependencies between packages with Enriched Dependency Structural Matrix. Software: Practice and Experience, 2012, ⟨10.1002/spe.2164⟩. ⟨hal-00748120⟩
194 View
830 Download

Altmetric

Share

Gmail Facebook Twitter LinkedIn More